fix: limit resetting form on defaultValues change

This commit is contained in:
kasia.oczkowska
2024-10-04 10:30:50 +01:00
parent 13c0a8ceaa
commit ef4a4c8611

View File

@@ -1,6 +1,7 @@
import * as React from 'react';
import { FormProvider, useForm, useWatch } from 'react-hook-form';
import PropTypes from 'prop-types';
import isEqual from 'lodash/isEqual';
const noop = () => null;
@@ -23,6 +24,7 @@ function Form(props) {
});
const form = useWatch({ control: methods.control });
const prevDefaultValues = React.useRef(defaultValues);
/**
* For fields having `dependsOn` fields, we need to re-validate the form.
@@ -32,7 +34,10 @@ function Form(props) {
}, [methods.trigger, form]);
React.useEffect(() => {
methods.reset(defaultValues);
if (!isEqual(defaultValues, prevDefaultValues.current)) {
prevDefaultValues.current = defaultValues;
methods.reset(defaultValues);
}
}, [defaultValues]);
return (