Subform to create related record
Using Supabase as a data provider and following the exemple in the CRM app, I am trying to create a related record as it is done in this exemple CRM app, however the data variable return in https://github.com/refinedev/refine/blob/8066c0c1d8bba422e1b38ee325a6f4bca811e95d/examples/app-crm/src/routes/companies/create.tsx#L110 is empty, so I can’t set the companyId using createdCompany. Is there anything special to do when using a different data provider than the one used in the CRM exemple app to get the id of the newly created record in a onFinish callback ?
GitHub
refine/examples/app-crm/src/routes/companies/create.tsx at 8066c0c1...
A React Framework for building internal tools, admin panels, dashboards & B2B apps with unmatched flexibility. - refinedev/refine
5 Replies
Hi @jibize. I'm kapa.ai, your friendly support bot. I will try to answer your question by searching through the knowledge base. :wave:
----------------------
Hmm, I don't know enough to give you a confident answer yet. However, based on the information provided, it seems like you're trying to create a related record and retrieve the ID of the newly created record in the
onFinish
callback.
In the provided code snippets, the onFinish
function is used to handle form submission. When the form is submitted, onFinish
is called with the form values. In the edit
action, onFinish
calls the useUpdate
hook with the form values, and in the clone
action, it calls the useCreate
hook. The useUpdate
and useCreate
hooks then call the dataProvider
's update
and create
functions respectively and return the response. The onSuccess
or onError
function is then called with the response, depending on the response status.
If you're using a different data provider, you might need to adjust how you're handling the response in the onFinish
function. The response might be structured differently depending on the data provider, so you might need to access the ID of the newly created record differently.
For more information on how to use the useForm
, useUpdate
, and useCreate
hooks, you can refer to the Refine documentation (https://refine.dev/docs/data/hooks/use-form).
For more specific guidance, you might want to check the documentation or support resources for your specific data provider.
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@740787797765521508> kapa.ai is still learning and improving, please let us know how it did by reacting below
other-emerald•7mo ago
Thank you @kapa.ai, is the onMutationSuccess function callback a good place to create a related record in a subform ?
Let me check the knowledge base for you. One moment! :books:
----------------------
Yes, the
onMutationSuccess
function callback can be a good place to create a related record in a subform. This function is called after a successful mutation, such as creating or updating a record.
The onMutationSuccess
function receives several parameters, including data
, which is the returned value from useCreate
or useUpdate
depending on the action. This means you can access the ID of the newly created or updated record in this function.
Here's an example of how you might use it:
Remember that the exact structure of the data
parameter might depend on your data provider, so you might need to adjust how you're accessing the ID.
For more information on how to use the onMutationSuccess
function, you can refer to the Refine documentation (https://refine.dev/docs/data/hooks/use-form#onmutationsuccess).
----------------------
Note: you can ask me a follow up question by @ mentioning me again :speech_balloon:
----------------------<@740787797765521508> kapa.ai is still learning and improving, please let us know how it did by reacting below