Merged in feature/IO-3571-Create-Job-Done-Loading (pull request #3105)

IO-3571 Create Job Done Button Loading

Approved-by: Dave Richer
This commit is contained in:
Allan Carr
2026-03-09 16:59:22 +00:00
committed by Dave Richer
5 changed files with 16 additions and 13 deletions

View File

@@ -10,14 +10,12 @@ import JobsCreateOwnerInfoContainer from "../../components/jobs-create-owner-inf
import JobsCreateVehicleInfoContainer from "../../components/jobs-create-vehicle-info/jobs-create-vehicle-info.container"; import JobsCreateVehicleInfoContainer from "../../components/jobs-create-vehicle-info/jobs-create-vehicle-info.container";
import JobCreateContext from "../../pages/jobs-create/jobs-create.context"; import JobCreateContext from "../../pages/jobs-create/jobs-create.context";
export default function JobsCreateComponent({ form }) { export default function JobsCreateComponent({ form, isSubmitting }) {
const [pageIndex, setPageIndex] = useState(0); const [pageIndex, setPageIndex] = useState(0);
const [errorMessage, setErrorMessage] = useState(null); const [errorMessage, setErrorMessage] = useState(null);
const [state] = useContext(JobCreateContext); const [state] = useContext(JobCreateContext);
const { t } = useTranslation(); const { t } = useTranslation();
const steps = [ const steps = [
{ {
title: t("jobs.labels.create.vehicleinfo"), title: t("jobs.labels.create.vehicleinfo"),
@@ -42,11 +40,9 @@ export default function JobsCreateComponent({ form }) {
const next = () => { const next = () => {
setPageIndex(pageIndex + 1); setPageIndex(pageIndex + 1);
console.log("Next");
}; };
const prev = () => { const prev = () => {
setPageIndex(pageIndex - 1); setPageIndex(pageIndex - 1);
console.log("Previous");
}; };
const ProgressButtons = ({ top }) => { const ProgressButtons = ({ top }) => {
@@ -79,17 +75,19 @@ export default function JobsCreateComponent({ form }) {
{pageIndex === steps.length - 1 && ( {pageIndex === steps.length - 1 && (
<Button <Button
type="primary" type="primary"
loading={isSubmitting}
onClick={() => { onClick={() => {
form form
.validateFields() .validateFields()
.then(() => { .then(() => {
// NO OP form.submit();
}) })
.catch((error) => console.log("error", error)); .catch((error) => {
form.submit(); console.log("error", error);
});
}} }}
> >
Done {t("general.actions.done")}
</Button> </Button>
)} )}
</Space> </Space>
@@ -146,13 +144,11 @@ export default function JobsCreateComponent({ form }) {
) : ( ) : (
<div> <div>
<ProgressButtons top /> <ProgressButtons top />
{errorMessage ? ( {errorMessage ? (
<div> <div>
<AlertComponent title={errorMessage} type="error" /> <AlertComponent title={errorMessage} type="error" />
</div> </div>
) : null} ) : null}
{steps.map((item, idx) => ( {steps.map((item, idx) => (
<div <div
key={idx} key={idx}

View File

@@ -46,6 +46,7 @@ function JobsCreateContainer({ bodyshop, setBreadcrumbs, setSelectedHeader, curr
}); });
const [form] = Form.useForm(); const [form] = Form.useForm();
const [state, setState] = contextState; const [state, setState] = contextState;
const [isSubmitting, setIsSubmitting] = useState(false);
const [insertJob] = useMutation(INSERT_NEW_JOB); const [insertJob] = useMutation(INSERT_NEW_JOB);
const [loadOwner, remoteOwnerData] = useLazyQuery(QUERY_OWNER_FOR_JOB_CREATION); const [loadOwner, remoteOwnerData] = useLazyQuery(QUERY_OWNER_FOR_JOB_CREATION);
@@ -83,16 +84,19 @@ function JobsCreateContainer({ bodyshop, setBreadcrumbs, setSelectedHeader, curr
newJobId: resp.data.insert_jobs.returning[0].id newJobId: resp.data.insert_jobs.returning[0].id
}); });
logImEXEvent("manual_job_create_completed", {}); logImEXEvent("manual_job_create_completed", {});
setIsSubmitting(false);
}) })
.catch((error) => { .catch((error) => {
notification.error({ notification.error({
title: t("jobs.errors.creating", { error: error }) title: t("jobs.errors.creating", { error: error })
}); });
setState({ ...state, error: error }); setState({ ...state, error: error });
setIsSubmitting(false);
}); });
}; };
const handleFinish = (values) => { const handleFinish = (values) => {
setIsSubmitting(true);
let job = Object.assign( let job = Object.assign(
{}, {},
values, values,
@@ -297,7 +301,7 @@ function JobsCreateContainer({ bodyshop, setBreadcrumbs, setSelectedHeader, curr
}) })
}} }}
> >
<JobsCreateComponent form={form} /> <JobsCreateComponent form={form} isSubmitting={isSubmitting} />
</Form> </Form>
</RbacWrapper> </RbacWrapper>
</JobCreateContext.Provider> </JobCreateContext.Provider>

View File

@@ -1296,6 +1296,7 @@
"delete": "Delete", "delete": "Delete",
"deleteall": "Delete All", "deleteall": "Delete All",
"deselectall": "Deselect All", "deselectall": "Deselect All",
"done": "Done",
"download": "Download", "download": "Download",
"edit": "Edit", "edit": "Edit",
"gotoadmin": "Go to Admin Panel", "gotoadmin": "Go to Admin Panel",

View File

@@ -1296,6 +1296,7 @@
"delete": "Borrar", "delete": "Borrar",
"deleteall": "", "deleteall": "",
"deselectall": "", "deselectall": "",
"done": "",
"download": "", "download": "",
"edit": "Editar", "edit": "Editar",
"gotoadmin": "", "gotoadmin": "",

View File

@@ -1296,6 +1296,7 @@
"delete": "Effacer", "delete": "Effacer",
"deleteall": "", "deleteall": "",
"deselectall": "", "deselectall": "",
"done": "",
"download": "", "download": "",
"edit": "modifier", "edit": "modifier",
"gotoadmin": "", "gotoadmin": "",