UNPKG

@schema-render/core-react

Version:

Through a set of simple JSON Schema, efficiently build a set of forms.

238 lines (237 loc) 9.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); var _jsxruntime = require("react/jsx-runtime"); var _react = require("react"); var _ErrorBoundary = /*#__PURE__*/ _interop_require_default(require("./components/ErrorBoundary")); var _useCoreValue = /*#__PURE__*/ _interop_require_default(require("./hooks/useCoreValue")); var _useLayoutStyle = /*#__PURE__*/ _interop_require_wildcard(require("./hooks/useLayoutStyle")); var _useOpenApi = /*#__PURE__*/ _interop_require_default(require("./hooks/useOpenApi")); var _zh_CN = /*#__PURE__*/ _interop_require_default(require("./locale/zh_CN")); var _RootContext = /*#__PURE__*/ _interop_require_default(require("./RootContext")); var _RendererIterator = /*#__PURE__*/ _interop_require_default(require("./services/RendererIterator")); var _assert = /*#__PURE__*/ _interop_require_default(require("./utils/assert")); var _base = require("./utils/base"); var _classnames = /*#__PURE__*/ _interop_require_default(require("./utils/classnames")); var _tinyLodash = require("./utils/tinyLodash"); function _array_like_to_array(arr, len) { if (len == null || len > arr.length) len = arr.length; for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i]; return arr2; } function _array_without_holes(arr) { if (Array.isArray(arr)) return _array_like_to_array(arr); } function _define_property(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interop_require_wildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = { __proto__: null }; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for(var key in obj){ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _iterable_to_array(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } function _non_iterable_spread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _object_spread(target) { for(var i = 1; i < arguments.length; i++){ var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === "function") { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function(key) { _define_property(target, key, source[key]); }); } return target; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function(sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; } function _object_spread_props(target, source) { source = source != null ? source : {}; if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function(key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } function _to_consumable_array(arr) { return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread(); } function _unsupported_iterable_to_array(o, minLen) { if (!o) return; if (typeof o === "string") return _array_like_to_array(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen); } var DEFAULT_CONFIG = { prefixCls: 'schema-render', layout: 'normal', layoutColumnGap: 10, layoutRowGap: 15, layoutMinMax: _useLayoutStyle.LAYOUT_MIN_MAX, disabled: false, readonly: false, validators: {}, userCtx: {} }; var InnerCore = /*#__PURE__*/ (0, _react.forwardRef)(function(coreProps, ref) { _assert.default.falsy(coreProps.schema, 'missing schema.'); _assert.default.falsy(coreProps.itemLayout, 'missing itemLayout.'); var props = _object_spread({}, DEFAULT_CONFIG, coreProps); var rootElementRef = (0, _react.useRef)(null); var rootContextRef = (0, _react.useRef)({}); // 表单数据 value 控制 var _useCoreValue1 = (0, _useCoreValue.default)(props), value = _useCoreValue1.value, onChange = _useCoreValue1.onChange, getValue = _useCoreValue1.getValue, setValue = _useCoreValue1.setValue, resetValue = _useCoreValue1.resetValue; // 合并语言 var locale = (0, _react.useMemo)(function() { return _object_spread({}, _zh_CN.default, props.locale); }, [ props.locale ]); // 处理渲染器与其名称 var renderers = (0, _react.useMemo)(function() { return (0, _tinyLodash.mapKeys)(props.renderers, function(_, key) { return key.toLowerCase(); }); }, [ props.renderers ]); // 计算布局样式 var layoutStyle = (0, _useLayoutStyle.default)(props); // root context value var rootCtxVal = rootContextRef.current = _object_spread_props(_object_spread({}, (0, _tinyLodash.pick)(props, 'disabled', 'readonly', 'prefixCls', 'layout', 'itemLayout', 'userCtx', 'validators', 'catchErrorTips')), { objectStyle: layoutStyle, renderers: renderers, rootSchema: props.schema, rootValue: value, locale: locale, rendererStorage: {}, // 事件 onChange: onChange, // 方法 prefixClassNames: function() { for(var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++){ args[_key] = arguments[_key]; } return _base.classNamesWithPrefix.apply(void 0, [ props.prefixCls ].concat(_to_consumable_array(args))); } }); // 开放 API (0, _useOpenApi.default)({ ref: ref, rootElementRef: rootElementRef, rootContextRef: rootContextRef, getValue: getValue, setValue: setValue, resetValue: resetValue }); return /*#__PURE__*/ (0, _jsxruntime.jsx)(_RootContext.default.Provider, { value: rootCtxVal, children: /*#__PURE__*/ (0, _jsxruntime.jsx)("div", { className: (0, _classnames.default)(rootCtxVal.prefixCls, props.className, { 'is-disabled': rootCtxVal.disabled, 'is-readonly': rootCtxVal.readonly }), ref: rootElementRef, style: _object_spread({ position: 'relative' }, layoutStyle, props.style), children: /*#__PURE__*/ (0, _jsxruntime.jsx)(_RendererIterator.default, { schema: rootCtxVal.rootSchema, path: [] }) }) }); }); var Core = /*#__PURE__*/ (0, _react.forwardRef)(function(props, ref) { return /*#__PURE__*/ (0, _jsxruntime.jsx)(_ErrorBoundary.default, { catchErrorTips: props.catchErrorTips, children: /*#__PURE__*/ (0, _jsxruntime.jsx)(InnerCore, _object_spread_props(_object_spread({}, props), { ref: ref })) }); }); var _default = Core;