UNPKG

cw-form-render-mobile

Version:

通过 JSON Schema 生成标准 Form,常用于自定义搭建配置界面生成

121 lines (120 loc) 6.95 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _form = _interopRequireDefault(require("antd-mobile/es/components/form")); var _tslib = require("tslib"); var _react = _interopRequireWildcard(require("react")); var _lodashEs = require("lodash-es"); var _utils = require("../../utils"); var _context = require("../../models/context"); var _expression = require("cw-form-render/es/models/expression"); var _module = require("./module"); var _main = _interopRequireDefault(require("./main")); var _constants = require("../../constants"); function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); } function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } // 将嵌套的表单数据扁平化(移除布局容器层级) var flattenFormData = function flattenFormData(values, flattenSchema) { if (!flattenSchema || !values || !(0, _utils.isObject)(values)) { return values; } // 找出所有布局容器字段 var containerPaths = Object.keys(flattenSchema).filter(function (key) { var _a; var schema = (_a = flattenSchema[key]) === null || _a === void 0 ? void 0 : _a.schema; return (0, _constants.isLayoutContainer)(schema); }).sort(function (a, b) { var depthA = (a.match(/\./g) || []).length; var depthB = (b.match(/\./g) || []).length; return depthB - depthA; // 从深到浅 }); if (containerPaths.length === 0) { return values; } var result = (0, _lodashEs.cloneDeep)(values); containerPaths.forEach(function (containerPath) { var cleanPath = containerPath.replace(/\[\]/g, '').replace(/^#\.?/, ''); if (!cleanPath) return; var pathParts = cleanPath.split('.'); var containerKey = pathParts[pathParts.length - 1]; var parentPath = pathParts.slice(0, -1); var parent = result; var _iterator = _createForOfIteratorHelper(parentPath), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var part = _step.value; if (!parent[part]) return; parent = parent[part]; } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } if (parent[containerKey] && (0, _utils.isObject)(parent[containerKey])) { var container = parent[containerKey]; Object.keys(container).forEach(function (childKey) { parent[childKey] = container[childKey]; }); delete parent[containerKey]; } }); return result; }; var _default = exports.default = function _default(props) { var schema = props.schema, rootPath = props.rootPath, otherProps = (0, _tslib.__rest)(props, ["schema", "rootPath"]); var store = (0, _react.useContext)(_context.FRContext); var _store$getState = store.getState(), formSchema = _store$getState.schema; var dependencies = schema === null || schema === void 0 ? void 0 : schema.dependencies; // No function expressions exist if (!(0, _expression.isHasExpression)(schema) && !(schema === null || schema === void 0 ? void 0 : schema.dependencies)) { return /*#__PURE__*/_react.default.createElement(_main.default, Object.assign({}, props, { store: store })); } // Need to listen to form values for dynamic rendering return /*#__PURE__*/_react.default.createElement(_form.default.Item, { noStyle: true, //dependencies={schema.dependencies} shouldUpdate: function shouldUpdate(prevValues, curValues) { // Observe whether the value of a function expression dependency has changed // TODO 进行优化 return true; } }, function (form) { var formData = form.getFieldsValue(true); var _store$getState2 = store.getState(), flattenSchema = _store$getState2.flattenSchema, flattenData = _store$getState2.flattenData; // 如果启用了 flattenData,将嵌套数据扁平化供表达式使用 if (flattenData && flattenSchema) { formData = flattenFormData(formData, flattenSchema); } var formDependencies = []; var dependValues = (dependencies || []).map(function (depPath) { var item = []; formDependencies.push(item); return (0, _module.getDependValues)(form.getFieldsValue(true), depPath, props, item, flattenSchema); }); var newSchema = (0, _expression.parseAllExpression)(schema, formData, rootPath, formSchema); return /*#__PURE__*/_react.default.createElement(_main.default, Object.assign({ schema: Object.assign(Object.assign({}, newSchema), { dependencies: formDependencies }), rootPath: rootPath }, otherProps, { dependValues: dependValues, store: store })); }); };