UNPKG

react-hook-form-antd

Version:

Master your And Design form with React Hook Form!

91 lines (90 loc) 3.08 kB
var __defProp = Object.defineProperty; var __defProps = Object.defineProperties; var __getOwnPropDescs = Object.getOwnPropertyDescriptors; var __getOwnPropSymbols = Object.getOwnPropertySymbols; var __hasOwnProp = Object.prototype.hasOwnProperty; var __propIsEnum = Object.prototype.propertyIsEnumerable; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __spreadValues = (a, b) => { for (var prop in b || (b = {})) if (__hasOwnProp.call(b, prop)) __defNormalProp(a, prop, b[prop]); if (__getOwnPropSymbols) for (var prop of __getOwnPropSymbols(b)) { if (__propIsEnum.call(b, prop)) __defNormalProp(a, prop, b[prop]); } return a; }; var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); var __objRest = (source, exclude) => { var target = {}; for (var prop in source) if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0) target[prop] = source[prop]; if (source != null && __getOwnPropSymbols) for (var prop of __getOwnPropSymbols(source)) { if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop)) target[prop] = source[prop]; } return target; }; // src/FormItem.tsx import { Form as AntdForm } from "antd"; import { Children, cloneElement, isValidElement, useEffect } from "react"; import { useController } from "react-hook-form"; import { jsx } from "react/jsx-runtime"; var FormItem = (_a) => { var _b = _a, { children, control, name, disabled, help, valuePropName, overrideFieldOnChange } = _b, props = __objRest(_b, [ "children", "control", "name", "disabled", "help", "valuePropName", "overrideFieldOnChange" ]); var _a2, _b2; const { field, fieldState } = useController({ name, control, disabled }); const form = AntdForm.useFormInstance(); useEffect(() => { form.setFieldValue(name, field.value); }, [field.value, form, name]); return /* @__PURE__ */ jsx( AntdForm.Item, __spreadProps(__spreadValues({}, props), { name, initialValue: field.value, validateStatus: fieldState.invalid ? "error" : void 0, help: (_b2 = (_a2 = fieldState.error) == null ? void 0 : _a2.message) != null ? _b2 : help, children: Children.map( children, (child) => isValidElement(child) && cloneElement(child, __spreadValues(__spreadProps(__spreadValues({}, field), { //@ts-expect-error onChange type safe is not necessary here onChange: (...params) => { child.props.onChange && child.props.onChange(...params); overrideFieldOnChange ? overrideFieldOnChange(...params) : field.onChange(...params); }, onBlur: () => { child.props.onBlur && child.props.onBlur(); field.onBlur(); } }), valuePropName && { [valuePropName]: field.value })) ) }) ); }; export { FormItem }; //# sourceMappingURL=index.js.map