Files
Dorod-Sky/skyvern-frontend/src/components/ui/use-form-field.ts
2024-04-01 21:34:52 +03:00

47 lines
1.1 KiB
TypeScript

import React from "react";
import { FieldPath, FieldValues, useFormContext } from "react-hook-form";
type FormFieldContextValue<
TFieldValues extends FieldValues = FieldValues,
TName extends FieldPath<TFieldValues> = FieldPath<TFieldValues>,
> = {
name: TName;
};
export const FormFieldContext = React.createContext<FormFieldContextValue>(
{} as FormFieldContextValue,
);
type FormItemContextValue = {
id: string;
};
export const FormItemContext = React.createContext<FormItemContextValue>(
{} as FormItemContextValue,
);
const useFormField = () => {
const fieldContext = React.useContext(FormFieldContext);
const itemContext = React.useContext(FormItemContext);
const { getFieldState, formState } = useFormContext();
const fieldState = getFieldState(fieldContext.name, formState);
if (!fieldContext) {
throw new Error("useFormField should be used within <FormField>");
}
const { id } = itemContext;
return {
id,
name: fieldContext.name,
formItemId: `${id}-form-item`,
formDescriptionId: `${id}-form-item-description`,
formMessageId: `${id}-form-item-message`,
...fieldState,
};
};
export { useFormField };