import { FieldContextKey, useFieldError, useIsFieldDirty, useIsFieldTouched, useIsFieldValid } from "vee-validate" import { inject } from "vue" import { FORM_ITEM_INJECTION_KEY } from "./injectionKeys" export function useFormField() { const fieldContext = inject(FieldContextKey) const fieldItemContext = inject(FORM_ITEM_INJECTION_KEY) if (!fieldContext) throw new Error("useFormField should be used within ") const { name } = fieldContext const id = fieldItemContext const fieldState = { valid: useIsFieldValid(name), isDirty: useIsFieldDirty(name), isTouched: useIsFieldTouched(name), error: useFieldError(name), } return { id, name, formItemId: `${id}-form-item`, formDescriptionId: `${id}-form-item-description`, formMessageId: `${id}-form-item-message`, ...fieldState, } }