garage-erp/apps/dashboard/shared/hooks/use-form-mutation.ts
humam kerdiah 4f0a2f790f feat: add logo field to settings schema and update settings client to handle file uploads
feat: integrate dialog close context in vendor select field and CRUD dialog components

feat: enhance vendor general info to format status using utility function

feat: implement form dialog context for managing dialog close actions

feat: add async select field dialog close context for better form handling

fix: update form mutation hook to close dialog on successful submission

feat: extend document print types to include expense and credit note

feat: add settings update payload type to include logo and other fields

feat: create employee attendance and work history pages with resource management

feat: implement payment made and received detail pages with actions

feat: add quick shortcuts component for easy navigation in the dashboard

feat: create actions for payment made and received with print and delete options

feat: implement dialog close context for better dialog management

feat: add error parsing utility for improved error handling in API responses
2026-05-19 17:56:39 +04:00

34 lines
1.3 KiB
TypeScript

"use client"
import { useMutation, type UseMutationOptions } from "@tanstack/react-query"
import type { FieldValues, UseFormReturn } from "react-hook-form"
import { ApiError } from "@garage/api"
import { useDialogClose } from "./use-dialog-close"
export function useFormMutation<TValues extends FieldValues, TResponse = unknown>(
form: UseFormReturn<TValues>,
options: UseMutationOptions<TResponse, Error, TValues>,
) {
const closeDialog = useDialogClose()
return useMutation<TResponse, Error, TValues>({
...options,
onSuccess: async (data, vars, onMutateResult, ctx) => {
await options.onSuccess?.(data, vars, onMutateResult, ctx)
// If this form is rendered inside a dialog wrapper that registers
// a close handler (e.g. FormDialog), dismiss the dialog after a
// successful submit. Plain pages render the form without the
// provider, so this is a no-op there.
closeDialog?.()
},
onError: (err, vars, values, ctx) => {
if (err instanceof ApiError && err.validationErrors) {
Object.entries(err.validationErrors).forEach(([field, msgs]) => {
form.setError(field as any, { message: msgs[0] })
})
}
options.onError?.(err, vars, values, ctx,)
},
})
}