This commit is contained in:
David Arranz 2025-10-21 16:39:03 +02:00
parent 81e59777cb
commit c99cab0e51

View File

@ -1,5 +1,5 @@
import { zodResolver } from "@hookform/resolvers/zod"; import { zodResolver } from "@hookform/resolvers/zod";
import { useEffect } from "react"; import { useEffect, useRef } from "react";
import { FieldValues, UseFormProps, UseFormReturn, useForm } from "react-hook-form"; import { FieldValues, UseFormProps, UseFormReturn, useForm } from "react-hook-form";
import * as z4 from "zod/v4/core"; import * as z4 from "zod/v4/core";
@ -28,20 +28,40 @@ export function useHookForm<TFields extends FieldValues = FieldValues, TContext
const { const {
formState: { isDirty }, formState: { isDirty },
reset,
} = form; } = form;
// Evita bucles de reset: guarda última instantánea aplicada
const lastAppliedRef = useRef<unknown>(undefined);
useEffect(() => { useEffect(() => {
onDirtyChange?.(isDirty); onDirtyChange?.(isDirty);
}, [isDirty, onDirtyChange]); }, [isDirty, onDirtyChange]);
useEffect(() => { /*useEffect(() => {
const applyReset = async () => { const applyReset = async () => {
const values = typeof initialValues === "function" ? await initialValues() : initialValues; const values = typeof initialValues === "function" ? await initialValues() : initialValues;
form.reset(values); form.reset(values);
}; };
applyReset(); applyReset();
}, [initialValues, form]); }, [initialValues, form]);*/
useEffect(() => {
let mounted = true;
const apply = async () => {
const next = typeof initialValues === "function" ? await initialValues() : initialValues;
// Evita reset redundante
if (mounted && JSON.stringify(next) !== JSON.stringify(lastAppliedRef.current)) {
reset(next as TFields);
lastAppliedRef.current = next;
}
};
void apply();
return () => {
mounted = false;
};
}, [initialValues, reset]);
return form; return form;
} }