From f5ed9c4b3c65b90e8f346deb70bc5b8f1a07205d Mon Sep 17 00:00:00 2001 From: dmolinari Date: Sat, 18 Apr 2026 21:05:51 -0300 Subject: [PATCH] fix(frontend): MoveRubroDialog type cast para zodResolver output (CAT-001) --- .../rubros/components/MoveRubroDialog.tsx | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/web/src/features/rubros/components/MoveRubroDialog.tsx b/src/web/src/features/rubros/components/MoveRubroDialog.tsx index bd05c93..2e3652b 100644 --- a/src/web/src/features/rubros/components/MoveRubroDialog.tsx +++ b/src/web/src/features/rubros/components/MoveRubroDialog.tsx @@ -77,13 +77,14 @@ const moveRubroSchema = z.object({ .pipe(z.number().int().min(0, 'El orden debe ser 0 o mayor')), }) -// Raw form field types (what useForm sees before zod transforms) +// Raw form field types (what useForm sees — strings before zod transforms). type MoveRubroFormRaw = { nuevoParentId: string nuevoOrden: string } -// Output type after zod transforms +// Output type after zod transforms run (what handleSubmit receives at runtime +// thanks to zodResolver). We type-cast to reconcile with SubmitHandler. type MoveRubroFormOutput = { nuevoParentId: number | null nuevoOrden: number @@ -152,8 +153,7 @@ export function MoveRubroDialog({ if (!rubro) return setBackendError(null) - const nuevoParentId = data.nuevoParentId - const nuevoOrden = data.nuevoOrden + const { nuevoParentId, nuevoOrden } = data try { await mutateAsync({ id: rubro.id, data: { nuevoParentId, nuevoOrden } }) @@ -183,7 +183,13 @@ export function MoveRubroDialog({
- + [0], + )} + className="space-y-4" + noValidate + > {backendError && (