react-hook-form-antd
Version:
Master your And Design form with React Hook Form!
91 lines (90 loc) • 3.08 kB
JavaScript
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