tdesign-react
Version:
TDesign Component for React
71 lines (65 loc) • 2.96 kB
JavaScript
/**
* tdesign v1.16.2
* (c) 2025 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var slicedToArray = require('../../_chunks/dep-5cb0d66d.js');
var React = require('react');
var form_hooks_useForm = require('./useForm.js');
var _util_noop = require('../../_util/noop.js');
var get = require('../../_chunks/dep-b7bd245a.js');
var isUndefined = require('../../_chunks/dep-6ea1b49c.js');
require('../../_chunks/dep-737b8bd8.js');
require('../../_chunks/dep-a7fe58de.js');
require('../../_chunks/dep-831bdf33.js');
require('../../_chunks/dep-0fe55884.js');
require('../../_chunks/dep-b325182b.js');
require('../../_chunks/dep-05f87b98.js');
require('../../_chunks/dep-5dd1b13c.js');
require('../../_chunks/dep-bdafd287.js');
require('../../_chunks/dep-eb2203ae.js');
require('../../_chunks/dep-4ce0670e.js');
require('../../_chunks/dep-3448f35f.js');
require('../../_chunks/dep-3332ad6f.js');
require('../../_chunks/dep-98783318.js');
require('../../_chunks/dep-967e785f.js');
require('../../_chunks/dep-5c8525ea.js');
require('../../_chunks/dep-fc884a8e.js');
require('../../_chunks/dep-7659797a.js');
function useWatch(name, form) {
var _useState = React.useState(),
_useState2 = slicedToArray._slicedToArray(_useState, 2),
value = _useState2[0],
setValue = _useState2[1];
var valueStr = React.useMemo(function () {
return JSON.stringify(value);
}, [value]);
var valueStrRef = React.useRef(valueStr);
var isValidForm = form && form._init;
React.useEffect(function () {
var _form$getInternalHook3, _form$getFieldsValue2;
if (!isValidForm) return;
var _form$getInternalHook = (_form$getInternalHook3 = form.getInternalHooks) === null || _form$getInternalHook3 === void 0 ? void 0 : _form$getInternalHook3.call(form, form_hooks_useForm.HOOK_MARK),
_form$getInternalHook2 = _form$getInternalHook.registerWatch,
registerWatch = _form$getInternalHook2 === void 0 ? _util_noop["default"] : _form$getInternalHook2;
var cancelRegister = registerWatch(function () {
var _form$getFieldsValue;
var allFieldsValue2 = (_form$getFieldsValue = form.getFieldsValue) === null || _form$getFieldsValue === void 0 ? void 0 : _form$getFieldsValue.call(form, true);
var newValue = get.get(allFieldsValue2, name);
var nextValueStr = JSON.stringify(newValue);
if (valueStrRef.current !== nextValueStr) {
valueStrRef.current = nextValueStr;
setValue(nextValueStr);
}
});
var allFieldsValue = (_form$getFieldsValue2 = form.getFieldsValue) === null || _form$getFieldsValue2 === void 0 ? void 0 : _form$getFieldsValue2.call(form, true);
var initialValue = get.get(allFieldsValue, name);
setValue(JSON.stringify(initialValue));
return cancelRegister;
}, []);
return isUndefined.isUndefined(value) ? value : JSON.parse(value);
}
exports["default"] = useWatch;
//# sourceMappingURL=useWatch.js.map