When the form is saved, wait for some events that have not yet been loaded. For example: upload files etc.
Usually when you submit a form to save data, and you find a file in the form that is being uploaded, you do this by reminding the user that the file is being uploaded, and that the user needs to click submit again.
So there are two problems:
-
How do you know that a file is being uploaded in the form? What if it is a multi-form?
-
How do you know when all files have been uploaded?
This gadget solves both of these problems.
After using this gadget, you don't have to care when the file is uploaded or set the loading status of Submit when the file is uploaded.
- Get ready: Install the gadget.
yarn add loading-before-saving-form
- Record the ID of the form, as well as the ID of the file.
const formId = 'formId';
- Call
setLoadingStatus
before and after file upload
import { setLoadingStatus } from 'loading-before-saving-form';
import request from './service'; // upload file server.
const uploadFile = async (key: string) => {
const option = {
formId,
key, // file id
status: true
}
setLoadingStatus(option);
await request('....'); // upload file
option.status = false;
setLoadingStatus(option);
}
- Add
saveBeforeLoading
to the submit button before the event
const submit = async (formId, formData) => {
await saveBeforeLoading(formId);
saveData(formData); // submit data function
}