From 5b469969c884a3a5b305a577d6d63bb15c330174 Mon Sep 17 00:00:00 2001 From: Samir Kamal <1954121+skamril@users.noreply.github.com> Date: Wed, 10 Jul 2024 15:50:33 +0200 Subject: [PATCH] fix(ui-commons): prompt form Form displayed on dialog validation --- webapp/src/components/common/Form/index.tsx | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/webapp/src/components/common/Form/index.tsx b/webapp/src/components/common/Form/index.tsx index 7c4958bb7f..c14bc783be 100644 --- a/webapp/src/components/common/Form/index.tsx +++ b/webapp/src/components/common/Form/index.tsx @@ -1,5 +1,5 @@ /* eslint-disable @typescript-eslint/no-explicit-any */ -import { FormEvent, useEffect, useMemo, useRef } from "react"; +import { FormEvent, useEffect, useMemo, useRef, useState } from "react"; import { DeepPartial, FieldPath, @@ -116,6 +116,7 @@ function Form( const { t } = useTranslation(); const autoSubmitConfig = toAutoSubmitConfig(autoSubmit); + const [isInProgress, setIsInProgress] = useState(false); const [showAutoSubmitLoader, setShowAutoSubmitLoader] = useDebouncedState( false, 750, @@ -130,7 +131,6 @@ function Form( const lastSubmittedData = useRef(); // eslint-disable-next-line @typescript-eslint/no-empty-function const submitSuccessfulCb = useRef(() => {}); - const preventClose = useRef(false); const contextValue = useMemo( () => ({ isAutoSubmitEnabled: autoSubmitConfig.enable }), @@ -224,7 +224,7 @@ function Form( // Prevent browser close if a submit is pending useEffect(() => { const listener = (event: BeforeUnloadEvent) => { - if (preventClose.current) { + if (isInProgress) { // eslint-disable-next-line no-param-reassign event.returnValue = t("form.submit.inProgress"); } else if (isDirty) { @@ -238,14 +238,14 @@ function Form( return () => { window.removeEventListener("beforeunload", listener); }; - }, [t, isDirty]); + }, [t, isInProgress, isDirty]); useUpdateEffect(() => onStateChange?.(formState), [formState]); useEffect(() => setRef(apiRef, formApiPlus)); - usePrompt(t("form.submit.inProgress"), preventClose.current); - usePrompt(t("form.changeNotSaved"), isDirty); + usePrompt(t("form.submit.inProgress"), isInProgress); + usePrompt(t("form.changeNotSaved"), isDirty && !isInProgress); //////////////////////////////////////////////////////////////// // Submit @@ -299,7 +299,7 @@ function Form( }); }) .finally(() => { - preventClose.current = false; + setIsInProgress(false); }); }, onInvalid); @@ -309,7 +309,8 @@ function Form( const submitDebounced = useDebounce(submit, autoSubmitConfig.wait); const requestSubmit = () => { - preventClose.current = true; + setIsInProgress(true); + if (autoSubmitConfig.enable) { submitDebounced(); } else {