Named routes
Hi, does Refine.dev support named routes?
e.g. if I create a custom route, not related to any resource (so I cannot use "show", "edit" ... etc), can I assign a name to it and use something like push([myname], [myparameter]) instead of ([full path])
e.g.
route is
<Route path="/admin/stuff/:id/custom" element={<Custom />} />
Instead of doing
push("/admin/stuff/5/custom" )
I would like to do
push("custom", 5)
of course adding the name to the route or something similar
e.g. <Route path="/admin/stuff/:id/custom" name="custom" element={<Custom />} />
it would be really helpful in case or site URLs structure change
Thanks
6 Replies
Hi @.simoneb. I'm kapa.ai, your friendly support bot. I will try to answer your question by searching through the knowledge base. :wave:
----------------------
Refine.dev does support the use of parameters in routes, but it doesn't seem to support named routes in the way you're describing.
In Refine, you can define your routes using the
resources
prop in the <Refine>
component. Each resource can have actions (list
, create
, edit
, show
, clone
) defined as paths. You can use :param
syntax to define parameters in your routes. For example:
In this example, :tenantId
and :id
are parameters. When these actions are used in the navigation helpers, the existing parameters from the URL and the meta
property of these functions will be used to determine the additional parameters when composing the path.
However, Refine doesn't seem to support assigning a name to a route and then using that name to navigate. You would need to use the full path when navigating. For example:
If you want to create a custom route not related to any resource, you can do so by defining a <Route>
with the desired path and element. But again, you would need to use the full path when navigating.
For more information, you can refer to the Refine documentation on routing (https://refine.dev/docs/packages/documentation/routers/nextjs/).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@539513465103056900> kapa.ai is still learning and improving, please let us know how it did by reacting below
Let me check the knowledge base for you. One moment! :books:
Sorry @.simoneb, I seem to be having a bit of trouble. Don't worry though, I've pinged my supprt and they will try to fix me up! :technologist:
Perhaps try again in 15mins?
ratty-blush•12mo ago
is it possible to create custom hooks per resources?
e.g.
resources={[
{
name: "products",
list: "/:tenantId/products",
show: "/:tenantId/products/:id",
edit: "/:tenantId/products/:id/edit",
create: "/:tenantId/products/create",
custom: "/:tenantId/products/:id/custom",
}
]}
@kapa.ai
Let me check the knowledge base for you. One moment! :books:
----------------------
Refine.dev allows you to define custom routes for your resources, but it doesn't directly support defining custom hooks per resource in the
resources
prop.
In the resources
prop, you can define the list
, create
, edit
, show
, and clone
actions for each resource. These actions correspond to the CRUD operations and each has a corresponding hook (useList
, useCreate
, useEdit
, useShow
, useClone
).
However, there's no direct way to define a custom hook in the resources
prop. If you want to create a custom hook for a resource, you would need to do this separately in your component code.
For example, you could create a custom hook that uses the useQuery
or useMutation
hooks from React Query (which Refine is built on top of) to fetch or update data for a specific resource.
Here's an example of what a custom hook might look like:
This custom hook useCustomProductData
fetches data for a specific product. You can use it in your components like this:
For more information, you can refer to the Refine documentation on hooks (https://refine.dev/docs/api-reference/core/hooks/data/useList/) and the React Query documentation on custom hooks (https://react-query.tanstack.com/guides/custom-hooks).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@539513465103056900> kapa.ai is still learning and improving, please let us know how it did by reacting below