From a4e23ec0c4b47230932e526c17938fd6d5c433d6 Mon Sep 17 00:00:00 2001 From: Petr Knetl Date: Mon, 30 Sep 2024 15:34:07 +0200 Subject: [PATCH] fix(suite-native): validate send form if there is already existing draft --- .../src/screens/SendOutputsScreen.tsx | 30 ++++++++++++++----- 1 file changed, 23 insertions(+), 7 deletions(-) diff --git a/suite-native/module-send/src/screens/SendOutputsScreen.tsx b/suite-native/module-send/src/screens/SendOutputsScreen.tsx index fe6b327a5a5..ac052956f1c 100644 --- a/suite-native/module-send/src/screens/SendOutputsScreen.tsx +++ b/suite-native/module-send/src/screens/SendOutputsScreen.tsx @@ -109,7 +109,7 @@ export const SendOutputsScreen = ({ decimals: network?.decimals, }, defaultValues: { - outputs: sendFormDraft?.outputs ?? DEFAULT_VALUES, + outputs: DEFAULT_VALUES, }, }); @@ -117,6 +117,8 @@ export const SendOutputsScreen = ({ handleSubmit, control, getValues, + setValue, + trigger, formState: { isValid, isSubmitting }, } = form; const watchedFormValues = useWatch({ control }); @@ -131,11 +133,6 @@ export const SendOutputsScreen = ({ ); }, [accountKey, dispatch, getValues]); - // Triggered for every change of watchedFormValues. - useEffect(() => { - if (isValid) debounce(storeFormDraftIfValid); - }, [storeFormDraftIfValid, watchedFormValues, debounce, isValid]); - const calculateNormalFeeMaxAmount = useCallback(async () => { const response = await dispatch( calculateMaxAmountWithNormalFeeThunk({ @@ -149,6 +146,25 @@ export const SendOutputsScreen = ({ } }, [getValues, accountKey, dispatch]); + useEffect(() => { + const prefillValuesFromStoredDraft = async () => { + if (sendFormDraft?.outputs) { + setValue('outputs', sendFormDraft.outputs); + await calculateNormalFeeMaxAmount(); + trigger(); + } + }; + + prefillValuesFromStoredDraft(); + // this effect should be triggered only for the first render to fill the form with the stored draft on entry. + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + // Triggered for every change of watchedFormValues. + useEffect(() => { + if (isValid) debounce(storeFormDraftIfValid); + }, [storeFormDraftIfValid, watchedFormValues, debounce, isValid]); + useEffect(() => { calculateNormalFeeMaxAmount(); }, [watchedAddress, calculateNormalFeeMaxAmount, networkFeeInfo]); @@ -210,7 +226,7 @@ export const SendOutputsScreen = ({ ) } > - +