refactor(FE): Prevent duplicate initial value loading in form modals

This commit is contained in:
rstubryan
2026-03-06 13:37:35 +07:00
parent aeceef4361
commit 7da63dc542
2 changed files with 16 additions and 2 deletions
@@ -536,9 +536,13 @@ const DeliveryOrderFormModal = ({}: { initialValues?: Marketing }) => {
formModal.closeModal();
};
const hasLoadedInitialValues = useRef(false);
useEffect(() => {
const getFilledInitialValues = async () => {
if (marketingId && isResponseSuccess(marketing)) {
if (hasLoadedInitialValues.current) return;
hasLoadedInitialValues.current = true;
const filledInitialValues = await getFilledMarketingFormInitialValues(
marketing.data
);
@@ -582,9 +586,15 @@ const DeliveryOrderFormModal = ({}: { initialValues?: Marketing }) => {
setFormErrorMessage('');
}, [step]);
// sync delivery order values to formik
const prevDeliveryOrderValuesRef = useRef(deliveryOrderValues);
useEffect(() => {
if (
JSON.stringify(prevDeliveryOrderValuesRef.current) !==
JSON.stringify(deliveryOrderValues)
) {
prevDeliveryOrderValuesRef.current = deliveryOrderValues;
formik.setFieldValue('delivery_order', deliveryOrderValues);
}
}, [deliveryOrderValues]);
const grandTotal = useMemo(() => {
@@ -458,9 +458,13 @@ const SalesOrderFormModal = ({
);
}, [memoSalesOrder]);
const hasLoadedInitialValues = useRef(false);
useEffect(() => {
const getFilledInitialValues = async () => {
if (marketingId && isResponseSuccess(marketing)) {
if (hasLoadedInitialValues.current) return;
hasLoadedInitialValues.current = true;
const filledInitialValues = await getFilledMarketingFormInitialValues(
marketing.data
);