22 Replies
Hi @yohan. I'm kapa.ai, your friendly support bot. I will try to answer your question by searching through the knowledge base. :wave:
----------------------
Sure, here is a basic usage example of the
useCustom
hook from the Refine documentation:
In this example, useApiUrl
is used to get the base URL of the API endpoint. The useCustom
hook is then used to send a request to the endpoint. The useCustom
hook expects a url
, method
, and config
properties. The url
property accepts the endpoint URL. The method
property accepts the type of method of the endpoint (a "get
" endpoint in this case). The config
property accepts values like the headers
for the endpoint, query
parameters, and more.
When properties are changed, the useCustom
hook will trigger a new request. The response from the request can be accessed through the data
property, and the loading state can be checked with the isLoading
property.
For more detailed information, you can refer to the useCustom documentation (https://refine.dev/docs/data/hooks/use-custom/).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@706071614717952071> kapa.ai is still learning and improving, please let us know how it did by reacting below
frozen-sapphire•8mo ago
can you give me sample how to trigger api call using useCustom when the button is clicked
@kapa.ai can you give me sample how to trigger api call using useCustom when the button is clicked
Let me check the knowledge base for you. One moment! :books:
----------------------
Sure, to trigger an API call using
useCustom
when a button is clicked, you can use the enabled
option in queryOptions
to control when the query runs. Here's an example:
In this example, useCustom
is initially set with enabled: false
to prevent the query from running immediately. When the button is clicked, the refetch
function is called to trigger the query.
Please note that this is a basic example and you might need to adjust it according to your needs. For more detailed information, you can refer to the useCustom documentation (https://refine.dev/docs/data/hooks/use-custom/).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@706071614717952071> kapa.ai is still learning and improving, please let us know how it did by reacting below
frozen-sapphire•8mo ago
@kapa.ai can you give example how to submit custom form using useCustom hook?
Let me check the knowledge base for you. One moment! :books:
----------------------
Sure, here's an example of how you might use the
useCustom
hook to submit a form:
In this example, useCustom
is initially set with enabled: false
to prevent the query from running immediately. When the form is submitted, the refetch
function is called with the new configuration to trigger the query.
Please note that this is a basic example and you might need to adjust it according to your needs. For more detailed information, you can refer to the useCustom documentation (https://refine.dev/docs/data/hooks/use-custom/).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------frozen-sapphire•8mo ago
@kapa.ai I think for submitting form it's better to use useMutation instead of useCustom. Do you have sample how to use useMutation for submitting form when a button is clicked?
Let me check the knowledge base for you. One moment! :books:
----------------------
Sure, here's an example of how you might use the
useMutation
hook to submit a form:
In this example, useMutation
is used to create a mutation function (mutate
). When the form is submitted, the handleSubmit
function is called, which in turn calls the mutate
function with the necessary parameters to create a new post.
Please note that this is a basic example and you might need to adjust it according to your needs. For more detailed information, you can refer to the useMutation documentation (https://refine.dev/docs/data/hooks/use-mutation/).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@706071614717952071> kapa.ai is still learning and improving, please let us know how it did by reacting below
frozen-sapphire•8mo ago
@kapa.ai do you mean useCustomMutation instead of useMutation?
Let me check the knowledge base for you. One moment! :books:
----------------------
Yes, you're correct. I apologize for the confusion. In the context of Refine, you should use
useCustomMutation
for custom mutation requests. Here's an example of how you might use the useCustomMutation
hook to submit a form:
In this example, useCustomMutation
is used to create a mutation function (mutate
). When the form is submitted, the handleSubmit
function is called, which in turn calls the mutate
function with the necessary parameters to create a new category.
Please note that this is a basic example and you might need to adjust it according to your needs. For more detailed information, you can refer to the useCustomMutation documentation (https://refine.dev/docs/data/hooks/use-custom-mutation).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@706071614717952071> kapa.ai is still learning and improving, please let us know how it did by reacting below
frozen-sapphire•8mo ago
@kapa.ai how to handle axios connection error?
Let me check the knowledge base for you. One moment! :books:
----------------------
To handle connection errors with Axios, you can use Axios interceptors. An interceptor allows you to run your code or modify the request or response before the request is sent or before Promise settles.
Here's an example of how you might set up an interceptor to handle errors:
In this example,
axios.create
is used to create a new Axios instance. An interceptor is then added to the instance using axiosInstance.interceptors.response.use
. The second function passed to use
will be called when a request is rejected. In this function, the error is transformed into an HttpError
and then rejected again.
Please note that this is a basic example and you might need to adjust it according to your needs. For more detailed information, you can refer to the Refine documentation (https://refine.dev/docs/tutorial/understanding-dataprovider/create-dataprovider#error-handling) and Axios documentation (https://axios-http.com/docs/interceptors).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------