dynamic query and mutation
Hello. I have an
edit form
component like this:
this code is going to be repeated for different models (Product, User, Color, Category, etc.). so, I am looking for a way to make it DRY and reusable.
the only difference between them is the model name in trpc trpc.admin.THE_MODEL_NAME
and the validation schema. the rest are just same and repeated
how can I make it reusable? I thought maybe I can create a Component for it and pass fetchData
, updateData
props to handle the query and mutations. but they are harder to manage as I can't track the status and abort on unmount2 Replies
The only difference between those models is the name? They can all use the same zod schema?
You could probably make an object type that represents all your models using a const string or something to differentiate the types, but I can’t imagine that making the code easier in any way on either the client or the server. There’s very little to no boilerplate code for tRPC or tanstack/query so I don’t see the benefit of trying to combine all the models
well, their schema is different but extending a common schema.
I handled it using the
useMutation
and useQuary
hooks imported directly from react-query
and used the trpc getQueryKey
method and useContext()
methods.
not sure if it is a good practice, but does the job