linkmore-design
Version:
π πlmη»δ»ΆεΊγπ
50 lines (49 loc) β’ 1.67 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = useForm;
var _rcFieldForm = require("rc-field-form");
var React = _interopRequireWildcard(require("react"));
var _scrollIntoViewIfNeeded = _interopRequireDefault(require("scroll-into-view-if-needed"));
var _util = require("../util");
function toNamePathStr(name) {
const namePath = (0, _util.toArray)(name);
return namePath.join('_');
}
function useForm(form) {
const [rcForm] = (0, _rcFieldForm.useForm)();
const itemsRef = React.useRef({});
const wrapForm = React.useMemo(() => form ?? {
...rcForm,
__INTERNAL__: {
itemRef: name => node => {
const namePathStr = toNamePathStr(name);
if (node) {
itemsRef.current[namePathStr] = node;
} else {
delete itemsRef.current[namePathStr];
}
}
},
scrollToField: (name, options = {}) => {
const namePath = (0, _util.toArray)(name);
const fieldId = (0, _util.getFieldId)(namePath, wrapForm.__INTERNAL__.name);
const node = fieldId ? document.getElementById(fieldId) : null;
if (node) {
(0, _scrollIntoViewIfNeeded.default)(node, {
scrollMode: 'if-needed',
block: 'nearest',
...options
});
}
},
getFieldInstance: name => {
const namePathStr = toNamePathStr(name);
return itemsRef.current[namePathStr];
}
}, [form, rcForm]);
return [wrapForm];
}