react-hook-form-antd
Version:
Master your And Design form with React Hook Form!
111 lines (109 loc) • 4.02 kB
JavaScript
;
var __defProp = Object.defineProperty;
var __defProps = Object.defineProperties;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
var __getOwnPropNames = Object.getOwnPropertyNames;
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;
};
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
// src/index.ts
var src_exports = {};
__export(src_exports, {
FormItem: () => FormItem
});
module.exports = __toCommonJS(src_exports);
// src/FormItem.tsx
var import_antd = require("antd");
var import_react = require("react");
var import_react_hook_form = require("react-hook-form");
var import_jsx_runtime = require("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 } = (0, import_react_hook_form.useController)({ name, control, disabled });
const form = import_antd.Form.useFormInstance();
(0, import_react.useEffect)(() => {
form.setFieldValue(name, field.value);
}, [field.value, form, name]);
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
import_antd.Form.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: import_react.Children.map(
children,
(child) => (0, import_react.isValidElement)(child) && (0, import_react.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
}))
)
})
);
};
//# sourceMappingURL=index.cjs.map