Showing
36 changed files
with
3477 additions
and
431 deletions
Too many changes to show.
To preserve performance only 36 of 112 files are displayed.
es/core/RenderChildren/RenderList/icon.js
0 → 100644
| 1 | +import { createFromIconfontCN } from '@ant-design/icons/lib'; | |
| 2 | +/** | |
| 3 | + * 使用: | |
| 4 | + * import QxIcon from '@/packages/qx-icon'; | |
| 5 | + * <QxIcon type="xxx"/> | |
| 6 | + * 说明: | |
| 7 | + * `xxx`为图标唯一标识,`iconfont.cn`对应图标下的“复制代码”所得,建议命名为“icon-xxx_yyy”, | |
| 8 | + * “icon-”为固定前缀,xxx为模块类型,yyy为图标名。公共类的xxx命名为“comm” | |
| 9 | + * eg: <QxIcon type="icon-flow_eye"/> | |
| 10 | + * | |
| 11 | + * @type {React.FC<IconFontProps<string>>} | |
| 12 | + */ | |
| 13 | + | |
| 14 | +var QxIcon = createFromIconfontCN({ | |
| 15 | + scriptUrl: 'https://lf1-cdn-tos.bytegoofy.com/obj/iconpark/icons_13749_95.b05de9dc2fbe8efffb150f83b64da806.es5.js' | |
| 16 | +}); | |
| 17 | +export default QxIcon; | |
| \ No newline at end of file | ... | ... |
es/core/RenderField/Title.js
deleted
100644 → 0
| 1 | -import React from 'react'; | |
| 2 | -import { useStore2 } from '../../hooks'; | |
| 3 | -import { isCheckBoxType } from '../../utils'; | |
| 4 | - | |
| 5 | -var Description = function Description(_ref) { | |
| 6 | - var displayType = _ref.displayType, | |
| 7 | - schema = _ref.schema; | |
| 8 | - var description = schema.description, | |
| 9 | - descType = schema.descType; | |
| 10 | - if (!description) return null; | |
| 11 | - | |
| 12 | - switch (displayType) { | |
| 13 | - case 'row': | |
| 14 | - return /*#__PURE__*/React.createElement("span", { | |
| 15 | - className: "fr-tooltip-toggle", | |
| 16 | - "aria-label": description | |
| 17 | - }, /*#__PURE__*/React.createElement("i", { | |
| 18 | - className: "fr-tooltip-icon" | |
| 19 | - }), /*#__PURE__*/React.createElement("div", { | |
| 20 | - className: "fr-tooltip-container" | |
| 21 | - }, /*#__PURE__*/React.createElement("i", { | |
| 22 | - className: "fr-tooltip-triangle" | |
| 23 | - }), description)); | |
| 24 | - | |
| 25 | - case 'inline': | |
| 26 | - return null; | |
| 27 | - | |
| 28 | - default: | |
| 29 | - if (descType === 'icon') { | |
| 30 | - return /*#__PURE__*/React.createElement("span", { | |
| 31 | - className: "fr-tooltip-toggle", | |
| 32 | - "aria-label": description | |
| 33 | - }, /*#__PURE__*/React.createElement("i", { | |
| 34 | - className: "fr-tooltip-icon" | |
| 35 | - }), /*#__PURE__*/React.createElement("div", { | |
| 36 | - className: "fr-tooltip-container" | |
| 37 | - }, /*#__PURE__*/React.createElement("i", { | |
| 38 | - className: "fr-tooltip-triangle" | |
| 39 | - }), description)); | |
| 40 | - } | |
| 41 | - | |
| 42 | - return /*#__PURE__*/React.createElement("span", { | |
| 43 | - className: "fr-desc ml2" | |
| 44 | - }, "( ".concat(description, " )")); | |
| 45 | - } | |
| 46 | -}; | |
| 47 | - | |
| 48 | -var Title = function Title(_ref2) { | |
| 49 | - var labelClass = _ref2.labelClass, | |
| 50 | - labelStyle = _ref2.labelStyle, | |
| 51 | - schema = _ref2.schema, | |
| 52 | - displayType = _ref2.displayType; | |
| 53 | - | |
| 54 | - var _useStore = useStore2(), | |
| 55 | - globalDisplayType = _useStore.displayType, | |
| 56 | - readOnly = _useStore.readOnly; | |
| 57 | - | |
| 58 | - var title = schema.title, | |
| 59 | - required = schema.required, | |
| 60 | - type = schema.type; | |
| 61 | - var isObjType = type === 'object'; | |
| 62 | - | |
| 63 | - var _displayType = schema.displayType || displayType || globalDisplayType || 'column'; | |
| 64 | - | |
| 65 | - return /*#__PURE__*/React.createElement("div", { | |
| 66 | - className: labelClass, | |
| 67 | - style: labelStyle | |
| 68 | - }, title ? /*#__PURE__*/React.createElement("label", { | |
| 69 | - className: "fr-label-title ".concat(isCheckBoxType(schema, readOnly) || _displayType === 'column' ? 'no-colon' : '') // checkbox不带冒号 | |
| 70 | - , | |
| 71 | - title: title | |
| 72 | - }, required === true && /*#__PURE__*/React.createElement("span", { | |
| 73 | - className: "fr-label-required" | |
| 74 | - }, " *"), /*#__PURE__*/React.createElement("span", { | |
| 75 | - className: "".concat(isObjType ? 'b' : '', " ").concat(_displayType === 'column' ? 'flex-none' : '') | |
| 76 | - }, /*#__PURE__*/React.createElement("span", { | |
| 77 | - dangerouslySetInnerHTML: { | |
| 78 | - __html: title | |
| 79 | - } | |
| 80 | - })), /*#__PURE__*/React.createElement(Description, { | |
| 81 | - schema: schema, | |
| 82 | - displayType: _displayType | |
| 83 | - })) : null); | |
| 84 | -}; | |
| 85 | - | |
| 86 | -export default Title; | |
| \ No newline at end of file |
es/form-render-core/src/Watcher.js
0 → 100644
| 1 | +/* eslint-disable react-hooks/exhaustive-deps */ | |
| 2 | +import { useEffect } from 'react'; | |
| 3 | +import { getValueByPath } from './utils'; | |
| 4 | + | |
| 5 | +var Watcher = function Watcher(_ref) { | |
| 6 | + var watchKey = _ref.watchKey, | |
| 7 | + watch = _ref.watch, | |
| 8 | + formData = _ref.formData, | |
| 9 | + firstMount = _ref.firstMount; | |
| 10 | + var value = getValueByPath(formData, watchKey); | |
| 11 | + var watchObj = watch[watchKey]; | |
| 12 | + useEffect(function () { | |
| 13 | + var runWatcher = function runWatcher() { | |
| 14 | + if (typeof watchObj === 'function') { | |
| 15 | + try { | |
| 16 | + watchObj(value); | |
| 17 | + } catch (error) { | |
| 18 | + console.log("".concat(watchKey, "\u5BF9\u5E94\u7684watch\u51FD\u6570\u6267\u884C\u62A5\u9519\uFF1A"), error); | |
| 19 | + } | |
| 20 | + } else if (watchObj && typeof watchObj.handler === 'function') { | |
| 21 | + try { | |
| 22 | + watchObj.handler(value); | |
| 23 | + } catch (error) { | |
| 24 | + console.log("".concat(watchKey, "\u5BF9\u5E94\u7684watch\u51FD\u6570\u6267\u884C\u62A5\u9519\uFF1A"), error); | |
| 25 | + } | |
| 26 | + } | |
| 27 | + }; | |
| 28 | + | |
| 29 | + if (firstMount) { | |
| 30 | + var immediate = watchObj && watchObj.immediate; | |
| 31 | + | |
| 32 | + if (immediate) { | |
| 33 | + runWatcher(); | |
| 34 | + } | |
| 35 | + } else { | |
| 36 | + runWatcher(); | |
| 37 | + } | |
| 38 | + }, [JSON.stringify(value), firstMount]); | |
| 39 | + return null; | |
| 40 | +}; | |
| 41 | + | |
| 42 | +export default Watcher; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/atom.css
renamed from
es/atom.css
| ... | ... | @@ -1066,7 +1066,7 @@ |
| 1066 | 1066 | outline: 1px solid black; |
| 1067 | 1067 | } |
| 1068 | 1068 | .fr-container .debug-grid { |
| 1069 | - background: transparent url( ) repeat top left; | |
| 1069 | + background: transparent url() repeat top left; | |
| 1070 | 1070 | } |
| 1071 | 1071 | .fr-container .truncate { |
| 1072 | 1072 | white-space: nowrap; | ... | ... |
es/form-render-core/src/connectForm.js
renamed from
es/connectForm.js
es/form-render-core/src/core/RenderChildren/RenderList/CardList.js
renamed from
es/core/RenderChildren/RenderList/CardList.js
| 1 | 1 | import "antd/es/button/style"; |
| 2 | 2 | import _Button from "antd/es/button"; |
| 3 | -import "antd/es/space/style"; | |
| 4 | -import _Space from "antd/es/space"; | |
| 5 | -import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined"; | |
| 6 | -import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined"; | |
| 7 | -import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined"; | |
| 8 | 3 | import "antd/es/popconfirm/style"; |
| 9 | 4 | import _Popconfirm from "antd/es/popconfirm"; |
| 10 | -import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined"; | |
| 5 | +import _CloseOutlined from "@ant-design/icons/es/icons/CloseOutlined"; | |
| 6 | +import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined"; | |
| 7 | +import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined"; | |
| 8 | +import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined"; | |
| 11 | 9 | |
| 12 | 10 | function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } |
| 13 | 11 | |
| ... | ... | @@ -19,8 +17,8 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope |
| 19 | 17 | |
| 20 | 18 | function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } |
| 21 | 19 | |
| 22 | -/* eslint-disable jsx-a11y/anchor-is-valid */ | |
| 23 | 20 | import React from 'react'; |
| 21 | +import { useTools } from '../../../hooks'; | |
| 24 | 22 | import Core from '../../index'; |
| 25 | 23 | |
| 26 | 24 | var CardList = function CardList(_ref) { |
| ... | ... | @@ -38,16 +36,33 @@ var CardList = function CardList(_ref) { |
| 38 | 36 | getFieldsProps = _ref.getFieldsProps; |
| 39 | 37 | var _schema$props = schema.props, |
| 40 | 38 | props = _schema$props === void 0 ? {} : _schema$props, |
| 41 | - itemProps = schema.itemProps; | |
| 39 | + itemProps = schema.itemProps, | |
| 40 | + _schema$min = schema.min, | |
| 41 | + min = _schema$min === void 0 ? 0 : _schema$min, | |
| 42 | + _schema$max = schema.max, | |
| 43 | + max = _schema$max === void 0 ? 9999 : _schema$max; | |
| 44 | + | |
| 45 | + var _useTools = useTools(), | |
| 46 | + methods = _useTools.methods; | |
| 47 | + | |
| 42 | 48 | var addBtnProps = { |
| 43 | 49 | type: 'dashed', |
| 44 | 50 | children: '新增一条' |
| 45 | 51 | }; |
| 52 | + var delConfirmProps = { | |
| 53 | + title: '确定删除?', | |
| 54 | + okText: '确定', | |
| 55 | + cancelText: '取消' | |
| 56 | + }; | |
| 46 | 57 | |
| 47 | 58 | if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') { |
| 48 | 59 | addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps); |
| 49 | 60 | } |
| 50 | 61 | |
| 62 | + if (props.delConfirmProps && _typeof(props.delConfirmProps) === 'object') { | |
| 63 | + delConfirmProps = _objectSpread(_objectSpread({}, delConfirmProps), props.delConfirmProps); | |
| 64 | + } | |
| 65 | + | |
| 51 | 66 | return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { |
| 52 | 67 | className: "fr-card-list" |
| 53 | 68 | }, displayList.map(function (item, idx) { |
| ... | ... | @@ -58,51 +73,60 @@ var CardList = function CardList(_ref) { |
| 58 | 73 | key: idx |
| 59 | 74 | }, /*#__PURE__*/React.createElement("div", { |
| 60 | 75 | className: "fr-card-index" |
| 61 | - }, idx + 1), /*#__PURE__*/React.createElement(Core, fieldsProps), /*#__PURE__*/React.createElement(_Space, { | |
| 76 | + }, idx + 1), /*#__PURE__*/React.createElement(Core, fieldsProps), /*#__PURE__*/React.createElement("div", { | |
| 62 | 77 | direction: "horizontal", |
| 63 | 78 | className: "fr-card-toolbar" |
| 64 | - }, !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, { | |
| 65 | - title: "\u786E\u5B9A\u5220\u9664?", | |
| 66 | - onConfirm: function onConfirm() { | |
| 67 | - return deleteItem(idx); | |
| 68 | - }, | |
| 69 | - okText: "\u786E\u5B9A", | |
| 70 | - cancelText: "\u53D6\u6D88" | |
| 71 | - }, /*#__PURE__*/React.createElement(_DeleteOutlined, { | |
| 72 | - style: { | |
| 73 | - fontSize: 17, | |
| 74 | - marginLeft: 8 | |
| 75 | - } | |
| 76 | - })), !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement(_CopyOutlined, { | |
| 79 | + }, !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 77 | 80 | style: { |
| 78 | 81 | fontSize: 16, |
| 79 | - marginLeft: 8 | |
| 82 | + marginLeft: 4 | |
| 80 | 83 | }, |
| 81 | 84 | onClick: function onClick() { |
| 82 | - return copyItem(idx); | |
| 85 | + return moveItemUp(idx); | |
| 83 | 86 | } |
| 84 | - }), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 87 | + }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, { | |
| 85 | 88 | style: { |
| 86 | 89 | fontSize: 16, |
| 87 | 90 | marginLeft: 4 |
| 88 | 91 | }, |
| 89 | 92 | onClick: function onClick() { |
| 90 | - return moveItemUp(idx); | |
| 93 | + return moveItemDown(idx); | |
| 91 | 94 | } |
| 92 | - }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, { | |
| 95 | + })), !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement(_CopyOutlined, { | |
| 93 | 96 | style: { |
| 94 | 97 | fontSize: 16, |
| 95 | - marginLeft: 4 | |
| 98 | + marginLeft: 8 | |
| 96 | 99 | }, |
| 97 | 100 | onClick: function onClick() { |
| 98 | - return moveItemDown(idx); | |
| 101 | + return copyItem(idx); | |
| 102 | + } | |
| 103 | + }), !props.hideDelete && displayList.length > min && /*#__PURE__*/React.createElement(_Popconfirm, _extends({ | |
| 104 | + onConfirm: function onConfirm() { | |
| 105 | + if (props.onConfirm && typeof props.onConfirm === 'string') { | |
| 106 | + var cb = methods[props.onConfirm]; | |
| 107 | + | |
| 108 | + if (typeof cb === 'function') { | |
| 109 | + var result = cb(item, idx); | |
| 110 | + | |
| 111 | + if (!result) { | |
| 112 | + return; | |
| 113 | + } | |
| 114 | + } | |
| 115 | + } | |
| 116 | + | |
| 117 | + deleteItem(idx); | |
| 118 | + } | |
| 119 | + }, delConfirmProps), /*#__PURE__*/React.createElement(_CloseOutlined, { | |
| 120 | + style: { | |
| 121 | + fontSize: 16, | |
| 122 | + marginLeft: 8 | |
| 99 | 123 | } |
| 100 | 124 | })))); |
| 101 | 125 | })), /*#__PURE__*/React.createElement("div", { |
| 102 | 126 | style: { |
| 103 | 127 | marginTop: displayList.length > 0 ? 0 : 8 |
| 104 | 128 | } |
| 105 | - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({ | |
| 129 | + }, !props.hideAdd && displayList.length < max && /*#__PURE__*/React.createElement(_Button, _extends({ | |
| 106 | 130 | onClick: addItem |
| 107 | 131 | }, addBtnProps)), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { |
| 108 | 132 | var callback = item.callback, | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/DrawerList.js
renamed from
es/core/RenderChildren/RenderList/DrawerList.js
| ... | ... | @@ -4,8 +4,6 @@ import "antd/es/drawer/style"; |
| 4 | 4 | import _Drawer from "antd/es/drawer"; |
| 5 | 5 | import "antd/es/button/style"; |
| 6 | 6 | import _Button from "antd/es/button"; |
| 7 | -import "antd/es/space/style"; | |
| 8 | -import _Space from "antd/es/space"; | |
| 9 | 7 | import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined"; |
| 10 | 8 | import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined"; |
| 11 | 9 | import "antd/es/popconfirm/style"; |
| ... | ... | @@ -33,15 +31,16 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va |
| 33 | 31 | |
| 34 | 32 | function _defineProperty(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; } |
| 35 | 33 | |
| 34 | +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } | |
| 35 | + | |
| 36 | 36 | function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } |
| 37 | 37 | |
| 38 | 38 | function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } |
| 39 | 39 | |
| 40 | -/* eslint-disable jsx-a11y/anchor-is-valid */ | |
| 41 | 40 | import React, { useRef } from 'react'; |
| 41 | +import { useSet, useTools } from '../../../hooks'; | |
| 42 | +import { getDataPath, getDisplayValue, getKeyFromPath } from '../../../utils'; | |
| 42 | 43 | import Core from '../../index'; |
| 43 | -import { useSet } from '../../../hooks'; | |
| 44 | -import { getDataPath, getKeyFromPath, getDisplayValue } from '../../../utils'; | |
| 45 | 44 | import ErrorMessage from '../../RenderField/ErrorMessage'; |
| 46 | 45 | var FIELD_LENGTH = 170; |
| 47 | 46 | |
| ... | ... | @@ -62,6 +61,10 @@ var DrawerList = function DrawerList(_ref) { |
| 62 | 61 | schema = _ref.schema, |
| 63 | 62 | changeList = _ref.changeList, |
| 64 | 63 | listData = _ref.listData; |
| 64 | + | |
| 65 | + var _useTools = useTools(), | |
| 66 | + widgets = _useTools.widgets; | |
| 67 | + | |
| 65 | 68 | var _schema$props = schema.props, |
| 66 | 69 | props = _schema$props === void 0 ? {} : _schema$props, |
| 67 | 70 | _schema$itemProps = schema.itemProps, |
| ... | ... | @@ -74,6 +77,34 @@ var DrawerList = function DrawerList(_ref) { |
| 74 | 77 | pagination = _props$pagination === void 0 ? {} : _props$pagination, |
| 75 | 78 | rest = _objectWithoutProperties(props, _excluded2); |
| 76 | 79 | |
| 80 | + var actionColumnProps = { | |
| 81 | + colHeaderText: '操作', | |
| 82 | + editText: '编辑', | |
| 83 | + delText: '删除' | |
| 84 | + }; | |
| 85 | + var delConfirmProps = { | |
| 86 | + title: '确定删除?', | |
| 87 | + okText: '确定', | |
| 88 | + cancelText: '取消' | |
| 89 | + }; | |
| 90 | + var addBtnProps = { | |
| 91 | + type: 'primary', | |
| 92 | + children: '新增一条', | |
| 93 | + size: 'small' | |
| 94 | + }; | |
| 95 | + | |
| 96 | + if (props.actionColumnProps && _typeof(props.actionColumnProps) === 'object') { | |
| 97 | + actionColumnProps = _objectSpread(_objectSpread({}, actionColumnProps), props.actionColumnProps); | |
| 98 | + } | |
| 99 | + | |
| 100 | + if (props.delConfirmProps && _typeof(props.delConfirmProps) === 'object') { | |
| 101 | + delConfirmProps = _objectSpread(_objectSpread({}, delConfirmProps), props.delConfirmProps); | |
| 102 | + } | |
| 103 | + | |
| 104 | + if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') { | |
| 105 | + addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps); | |
| 106 | + } | |
| 107 | + | |
| 77 | 108 | var paginationConfig = pagination && _objectSpread({ |
| 78 | 109 | size: 'small', |
| 79 | 110 | hideOnSinglePage: true |
| ... | ... | @@ -112,7 +143,11 @@ var DrawerList = function DrawerList(_ref) { |
| 112 | 143 | return item.name == childPath; |
| 113 | 144 | }) || {}; //TODO: 万一error在更深的层,这个办法是find不到的,会展示那一行没有提示。可以整一行加一个红线的方式处理 |
| 114 | 145 | |
| 115 | - return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", null, getDisplayValue(value, schema)), errorObj.error && /*#__PURE__*/React.createElement(ErrorMessage, { | |
| 146 | + var Widget = widgets[schema.readOnlyWidget]; | |
| 147 | + return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", null, Widget ? /*#__PURE__*/React.createElement(Widget, { | |
| 148 | + value: value, | |
| 149 | + schema: schema | |
| 150 | + }) : getDisplayValue(value, schema)), errorObj.error && /*#__PURE__*/React.createElement(ErrorMessage, { | |
| 116 | 151 | message: errorObj.error, |
| 117 | 152 | schema: schema |
| 118 | 153 | })); |
| ... | ... | @@ -120,40 +155,41 @@ var DrawerList = function DrawerList(_ref) { |
| 120 | 155 | }, columnProps); |
| 121 | 156 | }); |
| 122 | 157 | columns.push({ |
| 123 | - title: '操作', | |
| 158 | + title: actionColumnProps.colHeaderText, | |
| 124 | 159 | key: '$action', |
| 125 | 160 | fixed: 'right', |
| 126 | 161 | width: 120, |
| 127 | 162 | render: function render(value, record, idx) { |
| 128 | 163 | var index = value && value.$idx || 0; |
| 129 | - return /*#__PURE__*/React.createElement(_Space, null, /*#__PURE__*/React.createElement("a", { | |
| 164 | + return /*#__PURE__*/React.createElement("div", null, !props.hideEdit && /*#__PURE__*/React.createElement("a", { | |
| 130 | 165 | onClick: function onClick() { |
| 131 | 166 | return openDrawer(index); |
| 132 | 167 | } |
| 133 | - }, "\u7F16\u8F91"), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, { | |
| 134 | - title: "\u786E\u5B9A\u5220\u9664?", | |
| 168 | + }, actionColumnProps.editText), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, _extends({ | |
| 135 | 169 | onConfirm: function onConfirm() { |
| 136 | 170 | return deleteItem(index); |
| 137 | - }, | |
| 138 | - okText: "\u786E\u5B9A", | |
| 139 | - cancelText: "\u53D6\u6D88" | |
| 140 | - }, /*#__PURE__*/React.createElement("a", null, "\u5220\u9664")), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 171 | + } | |
| 172 | + }, delConfirmProps), /*#__PURE__*/React.createElement("a", { | |
| 173 | + style: { | |
| 174 | + marginLeft: 8 | |
| 175 | + } | |
| 176 | + }, actionColumnProps.delText)), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 141 | 177 | style: { |
| 142 | 178 | color: '#1890ff', |
| 143 | 179 | fontSize: 16, |
| 144 | - marginLeft: 4 | |
| 180 | + marginLeft: 8 | |
| 145 | 181 | }, |
| 146 | 182 | onClick: function onClick() { |
| 147 | - return moveItemUp(idx); | |
| 183 | + return moveItemUp(index); | |
| 148 | 184 | } |
| 149 | 185 | }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, { |
| 150 | 186 | style: { |
| 151 | 187 | color: '#1890ff', |
| 152 | 188 | fontSize: 16, |
| 153 | - marginLeft: 4 | |
| 189 | + marginLeft: 8 | |
| 154 | 190 | }, |
| 155 | 191 | onClick: function onClick() { |
| 156 | - return moveItemDown(idx); | |
| 192 | + return moveItemDown(index); | |
| 157 | 193 | } |
| 158 | 194 | }))); |
| 159 | 195 | } |
| ... | ... | @@ -181,11 +217,9 @@ var DrawerList = function DrawerList(_ref) { |
| 181 | 217 | |
| 182 | 218 | return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { |
| 183 | 219 | className: "w-100 mb2 tr" |
| 184 | - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, { | |
| 185 | - type: "primary", | |
| 186 | - size: "small", | |
| 220 | + }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({}, addBtnProps, { | |
| 187 | 221 | onClick: handleAdd |
| 188 | - }, "\u65B0\u589E"), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { | |
| 222 | + })), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { | |
| 189 | 223 | var callback = item.callback, |
| 190 | 224 | text = item.text, |
| 191 | 225 | html = item.html; |
| ... | ... | @@ -222,7 +256,7 @@ var DrawerList = function DrawerList(_ref) { |
| 222 | 256 | })); |
| 223 | 257 | }) : null), /*#__PURE__*/React.createElement(_Drawer, { |
| 224 | 258 | width: "600", |
| 225 | - title: "\u7F16\u8F91", | |
| 259 | + title: actionColumnProps.colHeaderText, | |
| 226 | 260 | placement: "right", |
| 227 | 261 | onClose: closeDrawer, |
| 228 | 262 | visible: showDrawer, | ... | ... |
| 1 | +import _PlusCircleFilled from "@ant-design/icons/es/icons/PlusCircleFilled"; | |
| 2 | +import _DownOutlined from "@ant-design/icons/es/icons/DownOutlined"; | |
| 3 | +import _UpOutlined from "@ant-design/icons/es/icons/UpOutlined"; | |
| 4 | +import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined"; | |
| 5 | + | |
| 6 | +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } | |
| 7 | + | |
| 8 | +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 9 | + | |
| 10 | +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } | |
| 11 | + | |
| 12 | +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } | |
| 13 | + | |
| 14 | +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } | |
| 15 | + | |
| 16 | +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 17 | + | |
| 18 | +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(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(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | |
| 19 | + | |
| 20 | +function _arrayLikeToArray(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; } | |
| 21 | + | |
| 22 | +function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } | |
| 23 | + | |
| 24 | +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } | |
| 25 | + | |
| 26 | +/* eslint-disable jsx-a11y/anchor-is-valid */ | |
| 27 | +import React, { useEffect, useMemo, useState } from 'react'; | |
| 28 | +import Core from '../../index'; // import { Button, Space, Popconfirm } from 'antd'; | |
| 29 | +// import ArrowDown from '../../../components/ArrowDown'; | |
| 30 | +// import { Collapse } from 'antd-mobile' | |
| 31 | + | |
| 32 | +// 数字转汉字 | |
| 33 | +function convertToChinaNum(num) { | |
| 34 | + var arr1 = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九']; | |
| 35 | + var arr2 = ['', '十', '百', '千', '万', '十', '百', '千', '亿', '十', '百', '千', '万', '十', '百', '千', '亿']; //可继续追加更高位转换值 | |
| 36 | + | |
| 37 | + if (!num || isNaN(num)) { | |
| 38 | + return "零"; | |
| 39 | + } | |
| 40 | + | |
| 41 | + var english = num.toString().split(""); | |
| 42 | + var result = ""; | |
| 43 | + | |
| 44 | + for (var i = 0; i < english.length; i++) { | |
| 45 | + var des_i = english.length - 1 - i; //倒序排列设值 | |
| 46 | + | |
| 47 | + result = arr2[i] + result; | |
| 48 | + var arr1_index = english[des_i]; | |
| 49 | + result = arr1[arr1_index] + result; | |
| 50 | + } | |
| 51 | + | |
| 52 | + result = result.replace(/零(千|百|十)/g, '零').replace(/十零/g, '十'); | |
| 53 | + result = result.replace(/零+/g, '零'); | |
| 54 | + result = result.replace(/零亿/g, '亿').replace(/零万/g, '万'); | |
| 55 | + result = result.replace(/亿万/g, '亿'); | |
| 56 | + result = result.replace(/零+$/, ''); | |
| 57 | + result = result.replace(/^一十/g, '十'); | |
| 58 | + return result; | |
| 59 | +} | |
| 60 | + | |
| 61 | +var ListForMobile = function ListForMobile(_ref) { | |
| 62 | + var _ref$displayList = _ref.displayList, | |
| 63 | + displayList = _ref$displayList === void 0 ? [] : _ref$displayList, | |
| 64 | + listData = _ref.listData, | |
| 65 | + changeList = _ref.changeList, | |
| 66 | + schema = _ref.schema, | |
| 67 | + deleteItem = _ref.deleteItem, | |
| 68 | + copyItem = _ref.copyItem, | |
| 69 | + addItem = _ref.addItem, | |
| 70 | + moveItemUp = _ref.moveItemUp, | |
| 71 | + moveItemDown = _ref.moveItemDown, | |
| 72 | + displayType = _ref.displayType, | |
| 73 | + getFieldsProps = _ref.getFieldsProps; | |
| 74 | + var _schema$props = schema.props, | |
| 75 | + props = _schema$props === void 0 ? {} : _schema$props, | |
| 76 | + itemProps = schema.itemProps; | |
| 77 | + | |
| 78 | + var _useState = useState([]), | |
| 79 | + _useState2 = _slicedToArray(_useState, 2), | |
| 80 | + allKeys = _useState2[0], | |
| 81 | + setKeys = _useState2[1]; // let addBtnProps = { | |
| 82 | + // type: 'dashed', | |
| 83 | + // children: '新增一条list', | |
| 84 | + // }; | |
| 85 | + // if (props.addBtnProps && typeof props.addBtnProps === 'object') { | |
| 86 | + // addBtnProps = { ...addBtnProps, ...props.addBtnProps }; | |
| 87 | + // } | |
| 88 | + | |
| 89 | + | |
| 90 | + useEffect(function () { | |
| 91 | + var _allKeys = []; | |
| 92 | + displayList.forEach(function (item, idx) { | |
| 93 | + if (item._active) { | |
| 94 | + _allKeys.push(String(idx)); | |
| 95 | + } | |
| 96 | + }); | |
| 97 | + setKeys(_allKeys); | |
| 98 | + }, [displayList]); | |
| 99 | + | |
| 100 | + var getTitle = function getTitle(id) { | |
| 101 | + return /*#__PURE__*/React.createElement("div", { | |
| 102 | + style: { | |
| 103 | + display: 'flex', | |
| 104 | + justifyContent: "space-between", | |
| 105 | + alignItems: 'center' | |
| 106 | + } | |
| 107 | + }, /*#__PURE__*/React.createElement("span", null, "\u6570\u636E", id + 1), /*#__PURE__*/React.createElement("a", { | |
| 108 | + onClick: function onClick(e) { | |
| 109 | + e.stopPropagation(); | |
| 110 | + deleteItem(id); | |
| 111 | + }, | |
| 112 | + style: { | |
| 113 | + display: 'inline-block', | |
| 114 | + padding: '0 10px' | |
| 115 | + } | |
| 116 | + }, /*#__PURE__*/React.createElement(_DeleteOutlined, { | |
| 117 | + style: { | |
| 118 | + fontSize: 16, | |
| 119 | + width: 16, | |
| 120 | + height: 16 | |
| 121 | + } | |
| 122 | + }))); | |
| 123 | + }; | |
| 124 | + | |
| 125 | + var handleArrow = function handleArrow(active) { | |
| 126 | + if (active) { | |
| 127 | + return /*#__PURE__*/React.createElement(_UpOutlined, { | |
| 128 | + onClick: function onClick() {} | |
| 129 | + }); | |
| 130 | + } else { | |
| 131 | + return /*#__PURE__*/React.createElement(_DownOutlined, null); | |
| 132 | + } | |
| 133 | + }; | |
| 134 | + | |
| 135 | + return null; | |
| 136 | + return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { | |
| 137 | + className: "fr-card-list qx-card-mobile" | |
| 138 | + }, /*#__PURE__*/React.createElement(Collapse, { | |
| 139 | + activeKey: allKeys | |
| 140 | + }, displayList.map(function (item, idx) { | |
| 141 | + var fieldsProps = getFieldsProps(idx); | |
| 142 | + fieldsProps.displayType = displayType; | |
| 143 | + return /*#__PURE__*/React.createElement(Collapse.Panel, { | |
| 144 | + key: String(idx), | |
| 145 | + title: getTitle(idx), | |
| 146 | + arrow: handleArrow, | |
| 147 | + onClick: function onClick() { | |
| 148 | + var _active = item._active || false; | |
| 149 | + | |
| 150 | + displayList[idx]._active = !_active; | |
| 151 | + changeList(_toConsumableArray(displayList)); | |
| 152 | + } | |
| 153 | + }, /*#__PURE__*/React.createElement("div", { | |
| 154 | + className: "fr-card-item qx-card-mobile-item ".concat(displayType === 'row' ? 'fr-card-item-row' : ''), | |
| 155 | + key: idx | |
| 156 | + }, /*#__PURE__*/React.createElement(Core, fieldsProps))); | |
| 157 | + }))), /*#__PURE__*/React.createElement("a", { | |
| 158 | + className: 'add-button', | |
| 159 | + onClick: function onClick() { | |
| 160 | + addItem(); | |
| 161 | + } | |
| 162 | + }, /*#__PURE__*/React.createElement(_PlusCircleFilled, { | |
| 163 | + style: { | |
| 164 | + marginRight: 2, | |
| 165 | + width: 14, | |
| 166 | + height: 14 | |
| 167 | + } | |
| 168 | + }), "\u70B9\u51FB\u65B0\u589E\u6570\u636E")); | |
| 169 | +}; | |
| 170 | + | |
| 171 | +export default ListForMobile; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/SimpleList.js
renamed from
es/core/RenderChildren/RenderList/SimpleList.js
| ... | ... | @@ -34,16 +34,29 @@ var SimpleList = function SimpleList(_ref) { |
| 34 | 34 | getFieldsProps = _ref.getFieldsProps; |
| 35 | 35 | var _schema$props = schema.props, |
| 36 | 36 | props = _schema$props === void 0 ? {} : _schema$props, |
| 37 | - itemProps = schema.itemProps; | |
| 37 | + itemProps = schema.itemProps, | |
| 38 | + _schema$min = schema.min, | |
| 39 | + min = _schema$min === void 0 ? 0 : _schema$min, | |
| 40 | + _schema$max = schema.max, | |
| 41 | + max = _schema$max === void 0 ? 99999 : _schema$max; | |
| 38 | 42 | var addBtnProps = { |
| 39 | 43 | type: 'dashed', |
| 40 | 44 | children: '新增一条' |
| 41 | 45 | }; |
| 46 | + var delConfirmProps = { | |
| 47 | + title: '确定删除?', | |
| 48 | + okText: '确定', | |
| 49 | + cancelText: '取消' | |
| 50 | + }; | |
| 42 | 51 | |
| 43 | 52 | if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') { |
| 44 | 53 | addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps); |
| 45 | 54 | } |
| 46 | 55 | |
| 56 | + if (props.delConfirmProps && _typeof(props.delConfirmProps) === 'object') { | |
| 57 | + delConfirmProps = _objectSpread(_objectSpread({}, delConfirmProps), props.delConfirmProps); | |
| 58 | + } | |
| 59 | + | |
| 47 | 60 | return /*#__PURE__*/React.createElement("div", { |
| 48 | 61 | className: "fr-list-1" |
| 49 | 62 | }, displayList.map(function (item, idx) { |
| ... | ... | @@ -63,14 +76,11 @@ var SimpleList = function SimpleList(_ref) { |
| 63 | 76 | style: { |
| 64 | 77 | marginTop: 6 |
| 65 | 78 | } |
| 66 | - }, !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, { | |
| 67 | - title: "\u786E\u5B9A\u5220\u9664?", | |
| 79 | + }, !props.hideDelete && displayList.length > min && /*#__PURE__*/React.createElement(_Popconfirm, _extends({ | |
| 68 | 80 | onConfirm: function onConfirm() { |
| 69 | 81 | return deleteItem(idx); |
| 70 | - }, | |
| 71 | - okText: "\u786E\u5B9A", | |
| 72 | - cancelText: "\u53D6\u6D88" | |
| 73 | - }, /*#__PURE__*/React.createElement(_DeleteOutlined, { | |
| 82 | + } | |
| 83 | + }, delConfirmProps), /*#__PURE__*/React.createElement(_DeleteOutlined, { | |
| 74 | 84 | style: { |
| 75 | 85 | fontSize: 17, |
| 76 | 86 | marginLeft: 8 |
| ... | ... | @@ -104,7 +114,7 @@ var SimpleList = function SimpleList(_ref) { |
| 104 | 114 | style: { |
| 105 | 115 | marginTop: displayList.length > 0 ? 0 : 8 |
| 106 | 116 | } |
| 107 | - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({ | |
| 117 | + }, !props.hideAdd && displayList.length < max && /*#__PURE__*/React.createElement(_Button, _extends({ | |
| 108 | 118 | onClick: addItem |
| 109 | 119 | }, addBtnProps)), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { |
| 110 | 120 | var callback = item.callback, | ... | ... |
| 1 | +import "antd/es/tabs/style"; | |
| 2 | +import _Tabs from "antd/es/tabs"; | |
| 3 | +var _excluded = ["tabName", "type", "draggable"]; | |
| 4 | + | |
| 5 | +function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } | |
| 6 | + | |
| 7 | +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } | |
| 8 | + | |
| 9 | +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } | |
| 10 | + | |
| 11 | +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } | |
| 12 | + | |
| 13 | +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 14 | + | |
| 15 | +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(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(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | |
| 16 | + | |
| 17 | +function _arrayLikeToArray(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; } | |
| 18 | + | |
| 19 | +function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } | |
| 20 | + | |
| 21 | +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } | |
| 22 | + | |
| 23 | +/* eslint-disable jsx-a11y/anchor-is-valid */ | |
| 24 | +import React, { useState, useRef } from 'react'; | |
| 25 | +import Core from '../../index'; | |
| 26 | +var TabPane = _Tabs.TabPane; | |
| 27 | +var dragType = 'DraggableTabNode'; | |
| 28 | + | |
| 29 | +var DraggableTabNode = function DraggableTabNode(_ref) { | |
| 30 | + var index = _ref.index, | |
| 31 | + children = _ref.children, | |
| 32 | + moveNode = _ref.moveNode; | |
| 33 | + var ref = useRef(null); | |
| 34 | + | |
| 35 | + var _useDrop = useDrop({ | |
| 36 | + accept: dragType, | |
| 37 | + collect: function collect(monitor) { | |
| 38 | + var _ref2 = monitor.getItem() || {}, | |
| 39 | + dragIndex = _ref2.index; | |
| 40 | + | |
| 41 | + if (dragIndex === index) { | |
| 42 | + return {}; | |
| 43 | + } | |
| 44 | + | |
| 45 | + return { | |
| 46 | + isOver: monitor.isOver(), | |
| 47 | + dropClassName: 'dropping' | |
| 48 | + }; | |
| 49 | + }, | |
| 50 | + drop: function drop(item) { | |
| 51 | + moveNode(item.index, index); | |
| 52 | + } | |
| 53 | + }), | |
| 54 | + _useDrop2 = _slicedToArray(_useDrop, 2), | |
| 55 | + _useDrop2$ = _useDrop2[0], | |
| 56 | + isOver = _useDrop2$.isOver, | |
| 57 | + dropClassName = _useDrop2$.dropClassName, | |
| 58 | + drop = _useDrop2[1]; | |
| 59 | + | |
| 60 | + var _useDrag = useDrag({ | |
| 61 | + type: dragType, | |
| 62 | + item: { | |
| 63 | + index: index | |
| 64 | + }, | |
| 65 | + collect: function collect(monitor) { | |
| 66 | + return { | |
| 67 | + isDragging: monitor.isDragging() | |
| 68 | + }; | |
| 69 | + } | |
| 70 | + }), | |
| 71 | + _useDrag2 = _slicedToArray(_useDrag, 2), | |
| 72 | + drag = _useDrag2[1]; | |
| 73 | + | |
| 74 | + drop(drag(ref)); | |
| 75 | + return /*#__PURE__*/React.createElement("div", { | |
| 76 | + ref: ref, | |
| 77 | + style: { | |
| 78 | + marginRight: 2 | |
| 79 | + }, | |
| 80 | + className: isOver ? dropClassName : '' | |
| 81 | + }, children); | |
| 82 | +}; | |
| 83 | + | |
| 84 | +var TabList = function TabList(_ref3) { | |
| 85 | + var _ref3$displayList = _ref3.displayList, | |
| 86 | + displayList = _ref3$displayList === void 0 ? [] : _ref3$displayList, | |
| 87 | + listData = _ref3.listData, | |
| 88 | + changeList = _ref3.changeList, | |
| 89 | + schema = _ref3.schema, | |
| 90 | + deleteItem = _ref3.deleteItem, | |
| 91 | + copyItem = _ref3.copyItem, | |
| 92 | + addItem = _ref3.addItem, | |
| 93 | + moveItemUp = _ref3.moveItemUp, | |
| 94 | + moveItemDown = _ref3.moveItemDown, | |
| 95 | + displayType = _ref3.displayType, | |
| 96 | + getFieldsProps = _ref3.getFieldsProps; | |
| 97 | + | |
| 98 | + var _useState = useState('0'), | |
| 99 | + _useState2 = _slicedToArray(_useState, 2), | |
| 100 | + activeKey = _useState2[0], | |
| 101 | + setActiveKey = _useState2[1]; | |
| 102 | + | |
| 103 | + var _schema$props = schema.props, | |
| 104 | + props = _schema$props === void 0 ? {} : _schema$props, | |
| 105 | + itemProps = schema.itemProps; | |
| 106 | + | |
| 107 | + var tabName = props.tabName, | |
| 108 | + type = props.type, | |
| 109 | + _props$draggable = props.draggable, | |
| 110 | + draggable = _props$draggable === void 0 ? false : _props$draggable, | |
| 111 | + restProps = _objectWithoutProperties(props, _excluded); | |
| 112 | + | |
| 113 | + var onEdit = function onEdit(targetKey, action) { | |
| 114 | + if (action === 'add') { | |
| 115 | + var currentKey = addItem(); | |
| 116 | + setActiveKey("".concat(currentKey)); | |
| 117 | + } else if (action === 'remove') { | |
| 118 | + deleteItem(Number(targetKey)); | |
| 119 | + setActiveKey("".concat(targetKey > 1 ? targetKey - 1 : 0)); | |
| 120 | + } else { | |
| 121 | + return null; | |
| 122 | + } | |
| 123 | + }; // 如果tabName传数组是可以「自定义」tab页的名字的。表单联动可以使用formrender的watch 配合 setSchemaByPath | |
| 124 | + | |
| 125 | + | |
| 126 | + var getCurrentTabPaneName = function getCurrentTabPaneName(idx) { | |
| 127 | + return tabName instanceof Array ? tabName[idx] || idx + 1 : "".concat(tabName || '项目', " ").concat(idx + 1); | |
| 128 | + }; | |
| 129 | + | |
| 130 | + return /*#__PURE__*/React.createElement(_Tabs, _extends({ | |
| 131 | + type: type || 'line', | |
| 132 | + onChange: setActiveKey, | |
| 133 | + activeKey: activeKey, | |
| 134 | + onEdit: onEdit | |
| 135 | + }, restProps), displayList.map(function (item, idx) { | |
| 136 | + var fieldsProps = getFieldsProps(idx); | |
| 137 | + fieldsProps.displayType = displayType; | |
| 138 | + return /*#__PURE__*/React.createElement(TabPane, { | |
| 139 | + tab: getCurrentTabPaneName(idx), | |
| 140 | + key: "".concat(idx) | |
| 141 | + }, /*#__PURE__*/React.createElement(Core, fieldsProps)); | |
| 142 | + })); | |
| 143 | +}; | |
| 144 | + | |
| 145 | +export default TabList; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/TableList.js
renamed from
es/core/RenderChildren/RenderList/TableList.js
| ... | ... | @@ -2,8 +2,6 @@ import "antd/es/table/style"; |
| 2 | 2 | import _Table from "antd/es/table"; |
| 3 | 3 | import "antd/es/button/style"; |
| 4 | 4 | import _Button from "antd/es/button"; |
| 5 | -import "antd/es/space/style"; | |
| 6 | -import _Space from "antd/es/space"; | |
| 7 | 5 | import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined"; |
| 8 | 6 | import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined"; |
| 9 | 7 | import "antd/es/popconfirm/style"; |
| ... | ... | @@ -31,14 +29,14 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va |
| 31 | 29 | |
| 32 | 30 | function _defineProperty(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; } |
| 33 | 31 | |
| 32 | +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } | |
| 33 | + | |
| 34 | 34 | function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } |
| 35 | 35 | |
| 36 | 36 | function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } |
| 37 | 37 | |
| 38 | -/* eslint-disable jsx-a11y/anchor-is-valid */ | |
| 39 | 38 | import React from 'react'; |
| 40 | 39 | import Core from '../../index'; |
| 41 | -// import ArrowDown from '../../../components/ArrowDown'; | |
| 42 | 40 | var FIELD_LENGTH = 170; |
| 43 | 41 | |
| 44 | 42 | var TableList = function TableList(_ref) { |
| ... | ... | @@ -67,6 +65,34 @@ var TableList = function TableList(_ref) { |
| 67 | 65 | pagination = _props$pagination === void 0 ? {} : _props$pagination, |
| 68 | 66 | rest = _objectWithoutProperties(props, _excluded2); |
| 69 | 67 | |
| 68 | + var actionColumnProps = { | |
| 69 | + colHeaderText: '操作', | |
| 70 | + copyText: '复制', | |
| 71 | + delText: '删除' | |
| 72 | + }; | |
| 73 | + var delConfirmProps = { | |
| 74 | + title: '确定删除?', | |
| 75 | + okText: '确定', | |
| 76 | + cancelText: '取消' | |
| 77 | + }; | |
| 78 | + var addBtnProps = { | |
| 79 | + type: 'primary', | |
| 80 | + children: '新增一条', | |
| 81 | + size: 'small' | |
| 82 | + }; | |
| 83 | + | |
| 84 | + if (props.actionColumnProps && _typeof(props.actionColumnProps) === 'object') { | |
| 85 | + actionColumnProps = _objectSpread(_objectSpread({}, actionColumnProps), props.actionColumnProps); | |
| 86 | + } | |
| 87 | + | |
| 88 | + if (props.delConfirmProps && _typeof(props.delConfirmProps) === 'object') { | |
| 89 | + delConfirmProps = _objectSpread(_objectSpread({}, delConfirmProps), props.delConfirmProps); | |
| 90 | + } | |
| 91 | + | |
| 92 | + if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') { | |
| 93 | + addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps); | |
| 94 | + } | |
| 95 | + | |
| 70 | 96 | var paginationConfig = pagination && _objectSpread({ |
| 71 | 97 | size: 'small', |
| 72 | 98 | hideOnSinglePage: true |
| ... | ... | @@ -102,27 +128,29 @@ var TableList = function TableList(_ref) { |
| 102 | 128 | |
| 103 | 129 | if (!props.hideDelete || !props.hideAdd || !props.hideCopy || !props.hideMove) { |
| 104 | 130 | columns.push({ |
| 105 | - title: '操作', | |
| 131 | + title: actionColumnProps.colHeaderText, | |
| 106 | 132 | key: '$action', |
| 107 | 133 | fixed: 'right', |
| 108 | 134 | width: 120, |
| 109 | - render: function render(value, record, idx) { | |
| 110 | - return /*#__PURE__*/React.createElement(_Space, null, !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement("a", { | |
| 135 | + render: function render(value, record) { | |
| 136 | + var idx = record.index; | |
| 137 | + return /*#__PURE__*/React.createElement("div", null, !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement("a", { | |
| 111 | 138 | onClick: function onClick() { |
| 112 | 139 | return copyItem(idx); |
| 113 | 140 | } |
| 114 | - }, "\u590D\u5236"), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, { | |
| 115 | - title: "\u786E\u5B9A\u5220\u9664?", | |
| 141 | + }, actionColumnProps.copyText), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, _extends({ | |
| 116 | 142 | onConfirm: function onConfirm() { |
| 117 | 143 | return deleteItem(idx); |
| 118 | - }, | |
| 119 | - okText: "\u786E\u5B9A", | |
| 120 | - cancelText: "\u53D6\u6D88" | |
| 121 | - }, /*#__PURE__*/React.createElement("a", null, "\u5220\u9664")), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 144 | + } | |
| 145 | + }, delConfirmProps), /*#__PURE__*/React.createElement("a", { | |
| 146 | + style: { | |
| 147 | + marginLeft: 8 | |
| 148 | + } | |
| 149 | + }, actionColumnProps.delText)), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, { | |
| 122 | 150 | style: { |
| 123 | 151 | color: '#1890ff', |
| 124 | 152 | fontSize: 16, |
| 125 | - marginLeft: 4 | |
| 153 | + marginLeft: 8 | |
| 126 | 154 | }, |
| 127 | 155 | onClick: function onClick() { |
| 128 | 156 | return moveItemUp(idx); |
| ... | ... | @@ -131,7 +159,7 @@ var TableList = function TableList(_ref) { |
| 131 | 159 | style: { |
| 132 | 160 | color: '#1890ff', |
| 133 | 161 | fontSize: 16, |
| 134 | - marginLeft: 4 | |
| 162 | + marginLeft: 8 | |
| 135 | 163 | }, |
| 136 | 164 | onClick: function onClick() { |
| 137 | 165 | return moveItemDown(idx); |
| ... | ... | @@ -143,11 +171,9 @@ var TableList = function TableList(_ref) { |
| 143 | 171 | |
| 144 | 172 | return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", { |
| 145 | 173 | className: "w-100 mb2 tr" |
| 146 | - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, { | |
| 147 | - type: "primary", | |
| 148 | - size: "small", | |
| 174 | + }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({}, addBtnProps, { | |
| 149 | 175 | onClick: addItem |
| 150 | - }, "\u65B0\u589E"), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { | |
| 176 | + })), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) { | |
| 151 | 177 | var callback = item.callback, |
| 152 | 178 | text = item.text, |
| 153 | 179 | html = item.html; | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/VirtualList.js
renamed from
es/core/RenderChildren/RenderList/VirtualList.js
| ... | ... | @@ -10,8 +10,6 @@ import _DownOutlined from "@ant-design/icons/es/icons/DownOutlined"; |
| 10 | 10 | import "antd/es/input/style"; |
| 11 | 11 | import _Input from "antd/es/input"; |
| 12 | 12 | import _SearchOutlined from "@ant-design/icons/es/icons/SearchOutlined"; |
| 13 | -import _CloseOutlined from "@ant-design/icons/es/icons/CloseOutlined"; | |
| 14 | -import _CheckOutlined from "@ant-design/icons/es/icons/CheckOutlined"; | |
| 15 | 13 | import "antd/es/message/style"; |
| 16 | 14 | import _message from "antd/es/message"; |
| 17 | 15 | import "antd/es/tooltip/style"; |
| ... | ... | @@ -21,16 +19,28 @@ import "antd/es/menu/style"; |
| 21 | 19 | import _Menu from "antd/es/menu"; |
| 22 | 20 | import "antd/es/button/style"; |
| 23 | 21 | import _Button from "antd/es/button"; |
| 24 | -import _MinusOutlined from "@ant-design/icons/es/icons/MinusOutlined"; | |
| 25 | -import _SelectOutlined from "@ant-design/icons/es/icons/SelectOutlined"; | |
| 26 | -import _ExpandAltOutlined from "@ant-design/icons/es/icons/ExpandAltOutlined"; | |
| 22 | +import _AlertOutlined from "@ant-design/icons/es/icons/AlertOutlined"; | |
| 23 | +import _BarsOutlined from "@ant-design/icons/es/icons/BarsOutlined"; | |
| 24 | +import _AppstoreOutlined from "@ant-design/icons/es/icons/AppstoreOutlined"; | |
| 25 | +import _PauseCircleOutlined from "@ant-design/icons/es/icons/PauseCircleOutlined"; | |
| 26 | +import _PlayCircleOutlined from "@ant-design/icons/es/icons/PlayCircleOutlined"; | |
| 27 | +import _ExportOutlined from "@ant-design/icons/es/icons/ExportOutlined"; | |
| 28 | +import _ImportOutlined from "@ant-design/icons/es/icons/ImportOutlined"; | |
| 29 | +import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined"; | |
| 30 | +import _ToolOutlined from "@ant-design/icons/es/icons/ToolOutlined"; | |
| 31 | +import _SettingOutlined from "@ant-design/icons/es/icons/SettingOutlined"; | |
| 32 | +import _EllipsisOutlined from "@ant-design/icons/es/icons/EllipsisOutlined"; | |
| 33 | +import _FileTextOutlined from "@ant-design/icons/es/icons/FileTextOutlined"; | |
| 27 | 34 | import _EditOutlined from "@ant-design/icons/es/icons/EditOutlined"; |
| 28 | 35 | import _EyeOutlined from "@ant-design/icons/es/icons/EyeOutlined"; |
| 29 | -import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined"; | |
| 30 | -import _PlusOutlined from "@ant-design/icons/es/icons/PlusOutlined"; | |
| 31 | 36 | import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined"; |
| 32 | -import _ImportOutlined from "@ant-design/icons/es/icons/ImportOutlined"; | |
| 33 | -import _ExportOutlined from "@ant-design/icons/es/icons/ExportOutlined"; | |
| 37 | +import _CheckOutlined from "@ant-design/icons/es/icons/CheckOutlined"; | |
| 38 | +import _CloseOutlined from "@ant-design/icons/es/icons/CloseOutlined"; | |
| 39 | +import _CloseCircleOutlined from "@ant-design/icons/es/icons/CloseCircleOutlined"; | |
| 40 | +import _MinusCircleOutlined from "@ant-design/icons/es/icons/MinusCircleOutlined"; | |
| 41 | +import _PlusCircleOutlined from "@ant-design/icons/es/icons/PlusCircleOutlined"; | |
| 42 | +import _MinusOutlined from "@ant-design/icons/es/icons/MinusOutlined"; | |
| 43 | +import _PlusOutlined from "@ant-design/icons/es/icons/PlusOutlined"; | |
| 34 | 44 | import "antd/es/modal/style"; |
| 35 | 45 | import _Modal from "antd/es/modal"; |
| 36 | 46 | var _excluded = ["scrollY", "summary", "batchKey", "type", "bar", "line", "searchKey", "rowSelection", "size"]; |
| ... | ... | @@ -78,17 +88,30 @@ import React, { useEffect, useMemo, useRef, useState } from 'react'; |
| 78 | 88 | import Core from '../../index'; |
| 79 | 89 | var confirm = _Modal.confirm; // import {useVT} from 'virtualizedtableforantd4'; |
| 80 | 90 | |
| 91 | +import QxIcon from './icon'; | |
| 81 | 92 | var BUTTON_ICONS_MAP = { |
| 82 | - ExportOutlined: /*#__PURE__*/React.createElement(_ExportOutlined, null), | |
| 83 | - ImportOutlined: /*#__PURE__*/React.createElement(_ImportOutlined, null), | |
| 84 | - DeleteOutlined: /*#__PURE__*/React.createElement(_DeleteOutlined, null), | |
| 85 | 93 | PlusOutlined: /*#__PURE__*/React.createElement(_PlusOutlined, null), |
| 86 | - CopyOutlined: /*#__PURE__*/React.createElement(_CopyOutlined, null), | |
| 94 | + MinusOutlined: /*#__PURE__*/React.createElement(_MinusOutlined, null), | |
| 95 | + PlusCircleOutlined: /*#__PURE__*/React.createElement(_PlusCircleOutlined, null), | |
| 96 | + MinusCircleOutlined: /*#__PURE__*/React.createElement(_MinusCircleOutlined, null), | |
| 97 | + CloseCircleOutlined: /*#__PURE__*/React.createElement(_CloseCircleOutlined, null), | |
| 98 | + CloseOutlined: /*#__PURE__*/React.createElement(_CloseOutlined, null), | |
| 99 | + CheckOutlined: /*#__PURE__*/React.createElement(_CheckOutlined, null), | |
| 100 | + DeleteOutlined: /*#__PURE__*/React.createElement(_DeleteOutlined, null), | |
| 87 | 101 | EyeOutlined: /*#__PURE__*/React.createElement(_EyeOutlined, null), |
| 88 | 102 | EditOutlined: /*#__PURE__*/React.createElement(_EditOutlined, null), |
| 89 | - remove: /*#__PURE__*/React.createElement(_ExpandAltOutlined, null), | |
| 90 | - SelectOutlined: /*#__PURE__*/React.createElement(_SelectOutlined, null), | |
| 91 | - MinusOutlined: /*#__PURE__*/React.createElement(_MinusOutlined, null) | |
| 103 | + FileTextOutlined: /*#__PURE__*/React.createElement(_FileTextOutlined, null), | |
| 104 | + EllipsisOutlined: /*#__PURE__*/React.createElement(_EllipsisOutlined, null), | |
| 105 | + SettingOutlined: /*#__PURE__*/React.createElement(_SettingOutlined, null), | |
| 106 | + ToolOutlined: /*#__PURE__*/React.createElement(_ToolOutlined, null), | |
| 107 | + CopyOutlined: /*#__PURE__*/React.createElement(_CopyOutlined, null), | |
| 108 | + ImportOutlined: /*#__PURE__*/React.createElement(_ImportOutlined, null), | |
| 109 | + ExportOutlined: /*#__PURE__*/React.createElement(_ExportOutlined, null), | |
| 110 | + PlayCircleOutlined: /*#__PURE__*/React.createElement(_PlayCircleOutlined, null), | |
| 111 | + PauseCircleOutlined: /*#__PURE__*/React.createElement(_PauseCircleOutlined, null), | |
| 112 | + AppstoreOutlined: /*#__PURE__*/React.createElement(_AppstoreOutlined, null), | |
| 113 | + BarsOutlined: /*#__PURE__*/React.createElement(_BarsOutlined, null), | |
| 114 | + AlertOutlined: /*#__PURE__*/React.createElement(_AlertOutlined, null) | |
| 92 | 115 | }; |
| 93 | 116 | var FIELD_LENGTH = 170; |
| 94 | 117 | var EXPORT_STATUS = { |
| ... | ... | @@ -124,7 +147,9 @@ var VirtualList = function VirtualList(_ref) { |
| 124 | 147 | fieldName = schema.fieldName, |
| 125 | 148 | _schema$qxProps = schema.qxProps, |
| 126 | 149 | qxProps = _schema$qxProps === void 0 ? {} : _schema$qxProps, |
| 127 | - subformMode = schema.subformMode; | |
| 150 | + subformMode = schema.subformMode, | |
| 151 | + subReadOnly = schema.subReadOnly, | |
| 152 | + isLoading = schema.isLoading; | |
| 128 | 153 | |
| 129 | 154 | var _props$scrollY = props.scrollY, |
| 130 | 155 | scrollY = _props$scrollY === void 0 ? 300 : _props$scrollY, |
| ... | ... | @@ -171,9 +196,19 @@ var VirtualList = function VirtualList(_ref) { |
| 171 | 196 | var _useState11 = useState(''), |
| 172 | 197 | _useState12 = _slicedToArray(_useState11, 2), |
| 173 | 198 | searchName = _useState12[0], |
| 174 | - setSearchName = _useState12[1]; | |
| 199 | + setSearchName = _useState12[1]; // const [dataSource, setDataSource] = useState([]); | |
| 200 | + // const [refresh, setRefresh] = useState('1'); | |
| 201 | + // const [authDisplayList, setAuthDisplayList] = useState([]) // 有权限展示的数据 | |
| 202 | + | |
| 203 | + | |
| 204 | + var _useState13 = useState(false), | |
| 205 | + _useState14 = _slicedToArray(_useState13, 2), | |
| 206 | + loading = _useState14[0], | |
| 207 | + setLoading = _useState14[1]; | |
| 175 | 208 | |
| 176 | - var btnMap = useRef({}); | |
| 209 | + useEffect(function () { | |
| 210 | + setLoading(!!isLoading); | |
| 211 | + }, [isLoading]); | |
| 177 | 212 | var padding = useMemo(function () { |
| 178 | 213 | return size === 'default' ? 32 : 16; |
| 179 | 214 | }, [size]); |
| ... | ... | @@ -220,7 +255,28 @@ var VirtualList = function VirtualList(_ref) { |
| 220 | 255 | }); |
| 221 | 256 | } else { |
| 222 | 257 | _displayList = _toConsumableArray(displayList); |
| 223 | - } // const _displayList = useMemo(() => { | |
| 258 | + } // useEffect(() => { | |
| 259 | + // 筛选展示的数据 | |
| 260 | + // if (props.originWidget === 'relSelector') { | |
| 261 | + // displayList.forEach((item, index) => { | |
| 262 | + // if (typeof item === 'object') { | |
| 263 | + // item.orginIdx = index; | |
| 264 | + // } | |
| 265 | + // if ((!item.hasOwnProperty('$auth') || item.$auth) && item.id) { | |
| 266 | + // _displayList.push(item) | |
| 267 | + // } | |
| 268 | + // }) | |
| 269 | + // } else { | |
| 270 | + // _displayList = [...displayList]; | |
| 271 | + // _displayList.forEach((item, index) => { | |
| 272 | + // if (typeof item === 'object') { | |
| 273 | + // item.orginIdx = index; | |
| 274 | + // } | |
| 275 | + // }) | |
| 276 | + // } | |
| 277 | + // setAuthDisplayList(_displayList) | |
| 278 | + // }, [displayList, props.originWidget]) | |
| 279 | + // const _displayList = useMemo(() => { | |
| 224 | 280 | // let arr = [] |
| 225 | 281 | // const cloneList = _.cloneDeep(displayList) |
| 226 | 282 | // cloneList.forEach((item, index) => { |
| ... | ... | @@ -242,21 +298,32 @@ var VirtualList = function VirtualList(_ref) { |
| 242 | 298 | var selectedIds = useMemo(function () { |
| 243 | 299 | var _selectedIds = []; |
| 244 | 300 | displayList.forEach(function (item) { |
| 245 | - if (selectedRowKeys.includes(item.orginIdx)) { | |
| 301 | + if (item && selectedRowKeys.includes(item.orginIdx)) { | |
| 246 | 302 | _selectedIds.push(item.id); |
| 247 | 303 | } |
| 248 | 304 | }); |
| 249 | 305 | return _selectedIds; |
| 250 | - }, [selectedRowKeys, displayList]); | |
| 306 | + }, [selectedRowKeys, displayList]); // useEffect(() => { | |
| 307 | + | |
| 251 | 308 | var dataSource = (keyWord.length ? _displayList.filter(function (item) { |
| 252 | 309 | var _String; |
| 253 | 310 | |
| 254 | 311 | return ((_String = String(item[searchKey])) === null || _String === void 0 ? void 0 : _String.indexOf(keyWord)) > -1; |
| 255 | 312 | }) : _displayList).map(function (item, idx) { |
| 256 | - return _objectSpread({ | |
| 313 | + return _objectSpread(_objectSpread({}, item), {}, { | |
| 257 | 314 | index: item.hasOwnProperty('orginIdx') ? item.orginIdx : idx |
| 258 | - }, item); | |
| 259 | - }); | |
| 315 | + }); | |
| 316 | + }); // useEffect(() => { | |
| 317 | + // setRefresh(refresh + '1') | |
| 318 | + // }, [JSON.stringify(dataSource)]) | |
| 319 | + // setDataSource(_dataSource) | |
| 320 | + // }, [keyWord, JSON.stringify(_displayList)]) | |
| 321 | + // useEffect(() => { | |
| 322 | + // const dataSource = (keyWord.length ? _displayList.filter(item => String(item[searchKey])?.indexOf(keyWord) > -1) : _displayList).map((item, idx) => { | |
| 323 | + // return {...item, index: item.hasOwnProperty('orginIdx') ? item.orginIdx : idx}; | |
| 324 | + // }) | |
| 325 | + // setDataSource(_dataSource) | |
| 326 | + // }, [keyWord, authDisplayList]) | |
| 260 | 327 | |
| 261 | 328 | var handleTotal = function handleTotal(total) { |
| 262 | 329 | if (!total) { |
| ... | ... | @@ -284,7 +351,8 @@ var VirtualList = function VirtualList(_ref) { |
| 284 | 351 | return handleTotal(total); |
| 285 | 352 | }, |
| 286 | 353 | defaultCurrent: 1, |
| 287 | - size: 'default' | |
| 354 | + size: size || 'small' // hideOnSinglePage: true | |
| 355 | + | |
| 288 | 356 | }; |
| 289 | 357 | }, [dataSource, props.limit]); |
| 290 | 358 | var barButtons = useMemo(function () { |
| ... | ... | @@ -383,7 +451,19 @@ var VirtualList = function VirtualList(_ref) { |
| 383 | 451 | border: 'none' |
| 384 | 452 | } |
| 385 | 453 | }, item, { |
| 386 | - icon: icon && bar.style !== 'TEXT' ? BUTTON_ICONS_MAP[icon] : null, | |
| 454 | + icon: icon && bar.style !== 'TEXT' ? String(icon).indexOf('http') > -1 ? /*#__PURE__*/React.createElement("img", { | |
| 455 | + src: String(icon), | |
| 456 | + style: { | |
| 457 | + width: '16px', | |
| 458 | + height: '16px', | |
| 459 | + marginRight: '4px', | |
| 460 | + verticalAlign: 'text-bottom', | |
| 461 | + borderRadius: '50%' | |
| 462 | + }, | |
| 463 | + alt: "" | |
| 464 | + }) : String(icon).indexOf('-') > -1 ? /*#__PURE__*/React.createElement(QxIcon, { | |
| 465 | + type: String(icon) | |
| 466 | + }) : BUTTON_ICONS_MAP[icon + ''] : null, | |
| 387 | 467 | onClick: function onClick() { |
| 388 | 468 | barBtnClick(code, needConfirm, confirmContent, action, item); |
| 389 | 469 | } |
| ... | ... | @@ -429,7 +509,8 @@ var VirtualList = function VirtualList(_ref) { |
| 429 | 509 | displayType: "inline", |
| 430 | 510 | key: index.toString(), |
| 431 | 511 | id: child, |
| 432 | - dataIndex: childIndex | |
| 512 | + dataIndex: childIndex // subReadOnly={subReadOnly} | |
| 513 | + | |
| 433 | 514 | }); |
| 434 | 515 | } |
| 435 | 516 | }; |
| ... | ... | @@ -506,7 +587,7 @@ var VirtualList = function VirtualList(_ref) { |
| 506 | 587 | |
| 507 | 588 | |
| 508 | 589 | var len = (line.buttons || []).length; |
| 509 | - var action = schema.isReadOnly ? {} : { | |
| 590 | + var action = schema.isReadOnly || subReadOnly ? {} : { | |
| 510 | 591 | title: '操作', |
| 511 | 592 | key: '$action', |
| 512 | 593 | fixed: fixed ? top ? 'left' : 'right' : props.originWidget === 'subform' ? 'right' : false, |
| ... | ... | @@ -535,7 +616,6 @@ var VirtualList = function VirtualList(_ref) { |
| 535 | 616 | style: { |
| 536 | 617 | marginLeft: 8 |
| 537 | 618 | }, |
| 538 | - size: "small", | |
| 539 | 619 | onClick: onClick |
| 540 | 620 | }, /*#__PURE__*/React.createElement("span", { |
| 541 | 621 | dangerouslySetInnerHTML: { |
| ... | ... | @@ -548,8 +628,10 @@ var VirtualList = function VirtualList(_ref) { |
| 548 | 628 | needConfirm = item.needConfirm, |
| 549 | 629 | confirmContent = item.confirmContent, |
| 550 | 630 | icon = item.icon; |
| 551 | - var display = handleState(record, code, props.originWidget); | |
| 552 | - btnMap.current[code] = display; | |
| 631 | + var display = handleState(record, code, props.originWidget); // if (display === '') { | |
| 632 | + // btnMap[code] = '' | |
| 633 | + // } | |
| 634 | + | |
| 553 | 635 | return /*#__PURE__*/React.createElement(_Tooltip, { |
| 554 | 636 | title: name |
| 555 | 637 | }, /*#__PURE__*/React.createElement(_Button, _extends({ |
| ... | ... | @@ -559,7 +641,19 @@ var VirtualList = function VirtualList(_ref) { |
| 559 | 641 | display: display |
| 560 | 642 | } |
| 561 | 643 | }, item, { |
| 562 | - icon: icon && style !== 'TEXT' ? BUTTON_ICONS_MAP[icon] : null, | |
| 644 | + icon: icon && style !== 'TEXT' ? String(icon).indexOf('http') > -1 ? /*#__PURE__*/React.createElement("img", { | |
| 645 | + src: String(icon), | |
| 646 | + style: { | |
| 647 | + width: '16px', | |
| 648 | + height: '16px', | |
| 649 | + marginRight: '4px', | |
| 650 | + verticalAlign: 'text-bottom', | |
| 651 | + borderRadius: '50%' | |
| 652 | + }, | |
| 653 | + alt: "" | |
| 654 | + }) : String(icon).indexOf('-') > -1 ? /*#__PURE__*/React.createElement(QxIcon, { | |
| 655 | + type: String(icon) | |
| 656 | + }) : BUTTON_ICONS_MAP[icon + ''] : null, | |
| 563 | 657 | type: 'link', |
| 564 | 658 | size: 'small' // disabled={props.originWidget === 'subform' ? false : handleAuth(record, code)} |
| 565 | 659 | , |
| ... | ... | @@ -603,34 +697,39 @@ var VirtualList = function VirtualList(_ref) { |
| 603 | 697 | } |
| 604 | 698 | } |
| 605 | 699 | } |
| 606 | - }), style !== 'ICON' || !item.icon ? name : null)); // } | |
| 700 | + }), style !== 'ICON' ? name : null)); // } | |
| 607 | 701 | }) : null); |
| 608 | 702 | } |
| 609 | 703 | }; |
| 610 | 704 | |
| 611 | 705 | if (style === "ICON" || props.originWidget === 'subform') { |
| 612 | - var effectiveLength = 0; | |
| 613 | - Object.keys(btnMap.current || {}).forEach(function (code) { | |
| 614 | - if (btnMap.current[code] !== 'none') { | |
| 615 | - effectiveLength += 1; | |
| 616 | - } | |
| 617 | - }); | |
| 618 | - action.width = effectiveLength * 32 + padding - 8; | |
| 706 | + // let effectiveLength = 0 | |
| 707 | + // console.log(line.buttons) | |
| 708 | + // line.buttons.forEach((btn) => { | |
| 709 | + // // console.log(btnMap) | |
| 710 | + // if (btnMap[btn.code] === '') { | |
| 711 | + // effectiveLength += 1 | |
| 712 | + // console.log(effectiveLength); | |
| 713 | + // } | |
| 714 | + // }) | |
| 715 | + // console.log(effectiveLength, padding); | |
| 716 | + action.width = len * 32 - 16 >= 30 ? len * 32 + padding - 8 : 30 + padding; | |
| 619 | 717 | } else { |
| 620 | - var div = document.createElement('div'); | |
| 621 | - div.style.position = 'absolute'; | |
| 622 | - div.style.visibility = 'hidden'; | |
| 623 | - div.style.fontSize = '14px'; | |
| 624 | - window.document.body.appendChild(div); | |
| 625 | 718 | var leng = 0; |
| 626 | 719 | line.buttons.map(function (item) { |
| 627 | - var _btnMap$current; | |
| 720 | + var div = document.createElement('div'); | |
| 721 | + div.style.position = 'absolute'; | |
| 722 | + div.style.visibility = 'hidden'; | |
| 723 | + div.style.fontSize = '14px'; | |
| 724 | + window.document.body.appendChild(div); | |
| 725 | + div.innerHTML = item.name; // leng += btnMap?.[item.code] === '' ? (div.clientWidth + (style !== 'TEXT' && item.icon ? 22 : 0)) : 0; | |
| 628 | 726 | |
| 629 | - div.innerHTML = item.name; | |
| 630 | - leng += ((_btnMap$current = btnMap.current) === null || _btnMap$current === void 0 ? void 0 : _btnMap$current[item.code]) === 'none' ? 0 : div.clientWidth + padding + (style !== 'TEXT' && item.icon ? 22 : 0); | |
| 631 | - }); | |
| 632 | - action.width = leng + padding - 8; | |
| 633 | - div.remove(); | |
| 727 | + leng += div.clientWidth + (style !== 'TEXT' && item.icon ? 22 : 0); // console.log(leng); | |
| 728 | + | |
| 729 | + div.remove(); | |
| 730 | + }); // console.log(leng + padding * 2 - 8, 'leng'); | |
| 731 | + | |
| 732 | + action.width = leng + padding * 2 - 8; | |
| 634 | 733 | } |
| 635 | 734 | |
| 636 | 735 | if (columns.findIndex(function (item) { |
| ... | ... | @@ -646,7 +745,7 @@ var VirtualList = function VirtualList(_ref) { |
| 646 | 745 | |
| 647 | 746 | var handleExport = /*#__PURE__*/function () { |
| 648 | 747 | var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { |
| 649 | - var queryParams, appCode, funCode, fieldName, result; | |
| 748 | + var queryParams, currentAppCode, currentFunCode, fieldName, result; | |
| 650 | 749 | return regeneratorRuntime.wrap(function _callee$(_context) { |
| 651 | 750 | while (1) { |
| 652 | 751 | switch (_context.prev = _context.next) { |
| ... | ... | @@ -658,9 +757,9 @@ var VirtualList = function VirtualList(_ref) { |
| 658 | 757 | queryParams = _defineProperty({ |
| 659 | 758 | dataId: props.dataId |
| 660 | 759 | }, searchKey, keyWord); |
| 661 | - appCode = qxProps.appCode, funCode = qxProps.funCode, fieldName = qxProps.fieldName; | |
| 760 | + currentAppCode = qxProps.currentAppCode, currentFunCode = qxProps.currentFunCode, fieldName = qxProps.fieldName; | |
| 662 | 761 | _context.next = 5; |
| 663 | - return props.exportChild(appCode, funCode, fieldName, queryParams); | |
| 762 | + return props.exportChild(currentAppCode, currentFunCode, fieldName, queryParams); | |
| 664 | 763 | |
| 665 | 764 | case 5: |
| 666 | 765 | result = _context.sent; |
| ... | ... | @@ -895,7 +994,19 @@ var VirtualList = function VirtualList(_ref) { |
| 895 | 994 | marginLeft: 8 |
| 896 | 995 | } |
| 897 | 996 | }, item, { |
| 898 | - icon: icon && bar.style !== 'TEXT' ? BUTTON_ICONS_MAP[icon] : null, | |
| 997 | + icon: icon && bar.style !== 'TEXT' ? String(icon).indexOf('http') > -1 ? /*#__PURE__*/React.createElement("img", { | |
| 998 | + src: String(icon), | |
| 999 | + style: { | |
| 1000 | + width: '16px', | |
| 1001 | + height: '16px', | |
| 1002 | + marginRight: '4px', | |
| 1003 | + verticalAlign: 'text-bottom', | |
| 1004 | + borderRadius: '50%' | |
| 1005 | + }, | |
| 1006 | + alt: "" | |
| 1007 | + }) : String(icon).indexOf('-') > -1 ? /*#__PURE__*/React.createElement(QxIcon, { | |
| 1008 | + type: String(icon) | |
| 1009 | + }) : BUTTON_ICONS_MAP[icon + ''] : null, | |
| 899 | 1010 | onClick: function onClick() { |
| 900 | 1011 | barBtnClick(code, needConfirm, confirmContent, action, item); |
| 901 | 1012 | } |
| ... | ... | @@ -954,15 +1065,19 @@ var VirtualList = function VirtualList(_ref) { |
| 954 | 1065 | handleCloseExport(exportProgressData.taskId); |
| 955 | 1066 | } |
| 956 | 1067 | }) : null, /*#__PURE__*/React.createElement(_Table, _extends({ |
| 1068 | + // key={props.originWidget === 'relSelector' ? refresh : ''} | |
| 957 | 1069 | id: 'qxVirtualList', |
| 958 | 1070 | className: 'qx-virtualList', |
| 959 | - rowKey: "index", | |
| 1071 | + rowKey: props.originWidget === 'relSelector' ? 'id' : 'orginIdx', | |
| 960 | 1072 | scroll: { |
| 961 | 1073 | y: scrollY, |
| 962 | 1074 | x: '100%' |
| 963 | 1075 | } // components={vt} |
| 964 | 1076 | , |
| 965 | - size: size || 'small', | |
| 1077 | + size: size || 'small' | |
| 1078 | + }, props.originWidget === 'relSelector' ? { | |
| 1079 | + loading: loading | |
| 1080 | + } : {}, { | |
| 966 | 1081 | columns: columns, |
| 967 | 1082 | dataSource: dataSource, |
| 968 | 1083 | pagination: pagination // style={{marginBottom: 25}} |
| ... | ... | @@ -975,7 +1090,7 @@ var VirtualList = function VirtualList(_ref) { |
| 975 | 1090 | |
| 976 | 1091 | return _summary(listData); |
| 977 | 1092 | } |
| 978 | - }, rest)), !props.hideAdd && props.originWidget === 'subform' && /*#__PURE__*/React.createElement(_Button, { | |
| 1093 | + }, rest)), !props.hideAdd && props.originWidget === 'subform' && !subReadOnly && /*#__PURE__*/React.createElement(_Button, { | |
| 979 | 1094 | type: "link", |
| 980 | 1095 | icon: /*#__PURE__*/React.createElement(_PlusOutlined, null), |
| 981 | 1096 | onClick: addItem | ... | ... |
| 1 | +import { createFromIconfontCN } from '@ant-design/icons/lib'; | |
| 2 | +/** | |
| 3 | + * 使用: | |
| 4 | + * import QxIcon from '@/packages/qx-icon'; | |
| 5 | + * <QxIcon type="xxx"/> | |
| 6 | + * 说明: | |
| 7 | + * `xxx`为图标唯一标识,`iconfont.cn`对应图标下的“复制代码”所得,建议命名为“icon-xxx_yyy”, | |
| 8 | + * “icon-”为固定前缀,xxx为模块类型,yyy为图标名。公共类的xxx命名为“comm” | |
| 9 | + * eg: <QxIcon type="icon-flow_eye"/> | |
| 10 | + * | |
| 11 | + * @type {React.FC<IconFontProps<string>>} | |
| 12 | + */ | |
| 13 | + | |
| 14 | +var QxIcon = createFromIconfontCN({ | |
| 15 | + scriptUrl: 'https://lf1-cdn-tos.bytegoofy.com/obj/iconpark/icons_13749_95.b05de9dc2fbe8efffb150f83b64da806.es5.js' | |
| 16 | +}); | |
| 17 | +export default QxIcon; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/index.js
renamed from
es/core/RenderChildren/RenderList/index.js
| ... | ... | @@ -20,13 +20,13 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len |
| 20 | 20 | import React from 'react'; |
| 21 | 21 | import { get } from 'lodash-es'; |
| 22 | 22 | import { useStore, useTools } from '../../../hooks'; |
| 23 | -import { getDataPath, getKeyFromPath, getDisplayValue } from '../../../utils'; // import ArrowDown from '../../../components/ArrowDown'; | |
| 24 | - | |
| 23 | +import { generateDataSkeleton, getDataPath, getSchemaFromFlatten } from '../../../utils'; | |
| 24 | +import CardList from './CardList'; | |
| 25 | +import DrawerList from './DrawerList'; | |
| 25 | 26 | import "./list.css"; |
| 26 | 27 | import SimpleList from './SimpleList'; |
| 27 | -import CardList from './CardList'; | |
| 28 | 28 | import TableList from './TableList'; |
| 29 | -import DrawerList from './DrawerList'; | |
| 29 | +import TabList from './TabList'; | |
| 30 | 30 | import VirtualList from './VirtualList'; |
| 31 | 31 | import ListForMobile from "./ListForMobile"; |
| 32 | 32 | |
| ... | ... | @@ -47,8 +47,12 @@ var RenderList = function RenderList(_ref) { |
| 47 | 47 | |
| 48 | 48 | var _useTools = useTools(), |
| 49 | 49 | onItemChange = _useTools.onItemChange, |
| 50 | - removeTouched = _useTools.removeTouched; | |
| 50 | + removeTouched = _useTools.removeTouched, | |
| 51 | + methods = _useTools.methods, | |
| 52 | + layoutWidgets = _useTools.layoutWidgets; | |
| 51 | 53 | |
| 54 | + var _schema$props = schema.props, | |
| 55 | + props = _schema$props === void 0 ? {} : _schema$props; | |
| 52 | 56 | var renderWidget = 'list'; |
| 53 | 57 | |
| 54 | 58 | try { |
| ... | ... | @@ -71,9 +75,13 @@ var RenderList = function RenderList(_ref) { |
| 71 | 75 | }; |
| 72 | 76 | |
| 73 | 77 | var addItem = function addItem() { |
| 74 | - var newList = [].concat(_toConsumableArray(displayList), [{ | |
| 78 | + // const newList = [...displayList, {_active: true}]; | |
| 79 | + var _schema = getSchemaFromFlatten(flatten, parentId); | |
| 80 | + | |
| 81 | + var newItem = generateDataSkeleton(_schema.items) || {}; | |
| 82 | + var newList = [].concat(_toConsumableArray(displayList), [_objectSpread(_objectSpread({}, newItem), {}, { | |
| 75 | 83 | _active: true |
| 76 | - }]); | |
| 84 | + })]); | |
| 77 | 85 | var newIndex = newList.length - 1; |
| 78 | 86 | onItemChange(dataPath, newList); |
| 79 | 87 | return newIndex; |
| ... | ... | @@ -98,10 +106,23 @@ var RenderList = function RenderList(_ref) { |
| 98 | 106 | }); |
| 99 | 107 | onItemChange(dataPath, newList); |
| 100 | 108 | removeTouched("".concat(dataPath, "[").concat(idx, "]")); |
| 109 | + }; | |
| 110 | + | |
| 111 | + var handleMoving = function handleMoving() { | |
| 112 | + if (props.onMove && typeof props.onMove === 'string') { | |
| 113 | + var cb = methods[props.onMove]; | |
| 114 | + | |
| 115 | + if (typeof cb === 'function') { | |
| 116 | + cb(); | |
| 117 | + } | |
| 118 | + } | |
| 101 | 119 | }; // 批量删除的方法 |
| 102 | 120 | |
| 103 | 121 | |
| 104 | 122 | var batchDelete = function batchDelete(ids) { |
| 123 | + displayList.forEach(function (item) { | |
| 124 | + return delete item.orginIdx; | |
| 125 | + }); | |
| 105 | 126 | var newList = displayList.filter(function (item, kdx) { |
| 106 | 127 | return !ids.includes(kdx); |
| 107 | 128 | }); |
| ... | ... | @@ -113,6 +134,7 @@ var RenderList = function RenderList(_ref) { |
| 113 | 134 | |
| 114 | 135 | |
| 115 | 136 | var moveItemUp = function moveItemUp(idx) { |
| 137 | + handleMoving(); | |
| 116 | 138 | if (idx === 0) return; |
| 117 | 139 | var currentItem = displayList[idx]; |
| 118 | 140 | var itemAbove = displayList[idx - 1]; |
| ... | ... | @@ -125,6 +147,7 @@ var RenderList = function RenderList(_ref) { |
| 125 | 147 | }; |
| 126 | 148 | |
| 127 | 149 | var moveItemDown = function moveItemDown(idx) { |
| 150 | + handleMoving(); | |
| 128 | 151 | if (idx >= displayList.length - 1) return; |
| 129 | 152 | var currentItem = displayList[idx]; |
| 130 | 153 | var itemBelow = displayList[idx + 1]; |
| ... | ... | @@ -138,7 +161,6 @@ var RenderList = function RenderList(_ref) { |
| 138 | 161 | |
| 139 | 162 | var itemSchema = { |
| 140 | 163 | type: 'object', |
| 141 | - // properties: (schema.items && schema.items.properties) || {}, | |
| 142 | 164 | properties: {}, |
| 143 | 165 | props: schema.props || {}, |
| 144 | 166 | $id: schema.$id |
| ... | ... | @@ -179,11 +201,12 @@ var RenderList = function RenderList(_ref) { |
| 179 | 201 | return /*#__PURE__*/React.createElement(ListForMobile, displayProps); |
| 180 | 202 | } |
| 181 | 203 | |
| 182 | - switch (renderWidget) { | |
| 183 | - case 'list0': | |
| 184 | - case 'cardList': | |
| 185 | - return /*#__PURE__*/React.createElement(CardList, displayProps); | |
| 204 | + if (layoutWidgets && layoutWidgets[renderWidget]) { | |
| 205 | + var Component = layoutWidgets[renderWidget]; | |
| 206 | + return /*#__PURE__*/React.createElement(Component, displayProps); | |
| 207 | + } | |
| 186 | 208 | |
| 209 | + switch (renderWidget) { | |
| 187 | 210 | case 'list1': |
| 188 | 211 | case 'simpleList': |
| 189 | 212 | return /*#__PURE__*/React.createElement(SimpleList, displayProps); |
| ... | ... | @@ -199,9 +222,12 @@ var RenderList = function RenderList(_ref) { |
| 199 | 222 | case 'list4': |
| 200 | 223 | case 'virtualList': |
| 201 | 224 | return /*#__PURE__*/React.createElement(VirtualList, displayProps); |
| 202 | - // case 'listForMobile': | |
| 203 | - // return <ListForMobile {...displayProps} /> | |
| 204 | 225 | |
| 226 | + case 'tabList': | |
| 227 | + return /*#__PURE__*/React.createElement(TabList, displayProps); | |
| 228 | + | |
| 229 | + case 'list0': | |
| 230 | + case 'cardList': | |
| 205 | 231 | default: |
| 206 | 232 | return /*#__PURE__*/React.createElement(CardList, displayProps); |
| 207 | 233 | } | ... | ... |
es/form-render-core/src/core/RenderChildren/RenderList/list.css
renamed from
es/core/RenderChildren/RenderList/list.css
es/form-render-core/src/core/RenderChildren/RenderObject.js
renamed from
es/core/RenderChildren/RenderObject.js
| ... | ... | @@ -9,10 +9,12 @@ var RenderObject = function RenderObject(_ref) { |
| 9 | 9 | _ref$dataIndex = _ref.dataIndex, |
| 10 | 10 | dataIndex = _ref$dataIndex === void 0 ? [] : _ref$dataIndex, |
| 11 | 11 | displayType = _ref.displayType, |
| 12 | + labelAlign = _ref.labelAlign, | |
| 12 | 13 | hideTitle = _ref.hideTitle; |
| 13 | 14 | return /*#__PURE__*/React.createElement(React.Fragment, null, children.map(function (child, i) { |
| 14 | 15 | var FRProps = { |
| 15 | 16 | displayType: displayType, |
| 17 | + labelAlign: labelAlign, | |
| 16 | 18 | id: child, |
| 17 | 19 | dataIndex: dataIndex, |
| 18 | 20 | hideTitle: hideTitle | ... | ... |
es/form-render-core/src/core/RenderField/ErrorMessage.css
renamed from
es/core/RenderField/ErrorMessage.css
es/form-render-core/src/core/RenderField/ErrorMessage.js
renamed from
es/core/RenderField/ErrorMessage.js
| ... | ... | @@ -14,7 +14,9 @@ var ErrorMessage = function ErrorMessage(_ref) { |
| 14 | 14 | msg = message[0] || ''; |
| 15 | 15 | } |
| 16 | 16 | |
| 17 | - msg = translateMessage(msg, schema); | |
| 17 | + msg = translateMessage(msg, schema); // 无错误信息不渲染 msg 元素占位,表单之间的间隔通过 field-block 元素分隔 | |
| 18 | + | |
| 19 | + if (!msg) return null; | |
| 18 | 20 | if (hardHidden) return /*#__PURE__*/React.createElement("div", { |
| 19 | 21 | className: "error-message" |
| 20 | 22 | }); | ... | ... |
es/form-render-core/src/core/RenderField/ExtendedWidget.js
renamed from
es/core/RenderField/ExtendedWidget.js
| ... | ... | @@ -5,10 +5,10 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va |
| 5 | 5 | function _defineProperty(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; } |
| 6 | 6 | |
| 7 | 7 | import React, { Suspense } from 'react'; |
| 8 | -import { getWidgetName, extraSchemaList } from '../../mapping'; | |
| 9 | -import { useTools, useStore } from '../../hooks'; | |
| 10 | 8 | import { transformProps } from '../../createWidget'; |
| 11 | -import { isObjType, isListType, isObject } from '../../utils'; | |
| 9 | +import { useStore, useTools } from '../../hooks'; | |
| 10 | +import { extraSchemaList, getWidgetName } from '../../mapping'; | |
| 11 | +import { isListType, isObject, isObjType } from '../../utils'; | |
| 12 | 12 | |
| 13 | 13 | var ErrorSchema = function ErrorSchema(schema) { |
| 14 | 14 | return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", { |
| ... | ... | @@ -30,7 +30,9 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 30 | 30 | readOnly = _ref.readOnly, |
| 31 | 31 | dataPath = _ref.dataPath, |
| 32 | 32 | disabled = _ref.disabled, |
| 33 | - dataIndex = _ref.dataIndex; | |
| 33 | + dataIndex = _ref.dataIndex, | |
| 34 | + watch = _ref.watch, | |
| 35 | + hasError = _ref.hasError; | |
| 34 | 36 | |
| 35 | 37 | var _useTools = useTools(), |
| 36 | 38 | widgets = _useTools.widgets, |
| ... | ... | @@ -43,7 +45,15 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 43 | 45 | getValues = _useTools.getValues, |
| 44 | 46 | resetFields = _useTools.resetFields, |
| 45 | 47 | setErrorFields = _useTools.setErrorFields, |
| 46 | - removeErrorField = _useTools.removeErrorField; | |
| 48 | + removeErrorField = _useTools.removeErrorField, | |
| 49 | + validateFields = _useTools.validateFields, | |
| 50 | + isFieldTouched = _useTools.isFieldTouched, | |
| 51 | + isFieldsTouched = _useTools.isFieldsTouched, | |
| 52 | + isFieldValidating = _useTools.isFieldValidating, | |
| 53 | + scrollToPath = _useTools.scrollToPath, | |
| 54 | + getFieldError = _useTools.getFieldError, | |
| 55 | + getFieldsError = _useTools.getFieldsError, | |
| 56 | + setFields = _useTools.setFields; | |
| 47 | 57 | |
| 48 | 58 | var _useStore = useStore(), |
| 49 | 59 | globalProps = _useStore.globalProps; // if (isObjType(schema)) { |
| ... | ... | @@ -79,7 +89,7 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 79 | 89 | }); |
| 80 | 90 | } |
| 81 | 91 | |
| 82 | - var Widget = widgets[widgetName]; | |
| 92 | + var Widget = widgets[widgetName] || widgets['html']; | |
| 83 | 93 | var extraSchema = extraSchemaList[widgetName]; |
| 84 | 94 | |
| 85 | 95 | var widgetProps = _objectSpread(_objectSpread({ |
| ... | ... | @@ -88,7 +98,10 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 88 | 98 | value: value, |
| 89 | 99 | children: children, |
| 90 | 100 | disabled: disabled, |
| 91 | - readOnly: readOnly | |
| 101 | + readOnly: readOnly, | |
| 102 | + // dataPath, | |
| 103 | + // dataIndex, | |
| 104 | + className: hasError ? 'fr-item-status-error' : '' | |
| 92 | 105 | }, schema.props), globalProps); |
| 93 | 106 | |
| 94 | 107 | if (schema.type === 'string' && typeof schema.max === 'number') { |
| ... | ... | @@ -141,7 +154,16 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 141 | 154 | resetFields: resetFields, |
| 142 | 155 | setErrorFields: setErrorFields, |
| 143 | 156 | removeErrorField: removeErrorField, |
| 144 | - hideSelf: hideSelf | |
| 157 | + validateFields: validateFields, | |
| 158 | + isFieldTouched: isFieldTouched, | |
| 159 | + isFieldsTouched: isFieldsTouched, | |
| 160 | + isFieldValidating: isFieldValidating, | |
| 161 | + scrollToPath: scrollToPath, | |
| 162 | + getFieldError: getFieldError, | |
| 163 | + getFieldsError: getFieldsError, | |
| 164 | + setFields: setFields, | |
| 165 | + hideSelf: hideSelf, | |
| 166 | + watch: watch | |
| 145 | 167 | }; |
| 146 | 168 | var finalProps = transformProps(widgetProps); |
| 147 | 169 | return /*#__PURE__*/React.createElement(Suspense, { |
| ... | ... | @@ -149,34 +171,37 @@ var ExtendedWidget = function ExtendedWidget(_ref) { |
| 149 | 171 | }, /*#__PURE__*/React.createElement("div", { |
| 150 | 172 | className: "fr-item-wrapper" |
| 151 | 173 | }, /*#__PURE__*/React.createElement(Widget, finalProps))); |
| 152 | -}; | |
| 153 | - | |
| 154 | -var areEqual = function areEqual(prev, current) { | |
| 155 | - if (prev.schema && prev.schema.$id === '#') { | |
| 156 | - return false; | |
| 157 | - } | |
| 158 | - | |
| 159 | - if (prev.readOnly !== current.readOnly) { | |
| 160 | - return false; | |
| 161 | - } | |
| 162 | - | |
| 163 | - if (prev.disabled !== current.disabled) { | |
| 164 | - return false; | |
| 165 | - } | |
| 166 | - | |
| 167 | - if (JSON.stringify(prev.dependValues) !== JSON.stringify(current.dependValues)) { | |
| 168 | - return false; | |
| 169 | - } | |
| 170 | - | |
| 171 | - if (isObjType(prev.schema) && isObjType(current.schema)) { | |
| 172 | - return false; | |
| 173 | - } | |
| 174 | - | |
| 175 | - if (JSON.stringify(prev.value) === JSON.stringify(current.value) && JSON.stringify(prev.schema) === JSON.stringify(current.schema)) { | |
| 176 | - return true; | |
| 177 | - } | |
| 178 | - | |
| 179 | - return false; | |
| 180 | -}; | |
| 181 | - | |
| 182 | -export default /*#__PURE__*/React.memo(ExtendedWidget, areEqual); | |
| \ No newline at end of file | ||
| 174 | +}; // const areEqual = (prev, current) => { | |
| 175 | +// if (prev.schema && current.schema) { | |
| 176 | +// if (prev.schema.$id === '#') { | |
| 177 | +// return false; | |
| 178 | +// } | |
| 179 | +// if (prev.schema.hidden && current.schema.hidden) { | |
| 180 | +// return true; | |
| 181 | +// } | |
| 182 | +// } | |
| 183 | +// if (prev.readOnly !== current.readOnly) { | |
| 184 | +// return false; | |
| 185 | +// } | |
| 186 | +// if (prev.disabled !== current.disabled) { | |
| 187 | +// return false; | |
| 188 | +// } | |
| 189 | +// if ( | |
| 190 | +// JSON.stringify(prev.dependValues) !== JSON.stringify(current.dependValues) | |
| 191 | +// ) { | |
| 192 | +// return false; | |
| 193 | +// } | |
| 194 | +// if (isObjType(prev.schema) && isObjType(current.schema)) { | |
| 195 | +// return false; | |
| 196 | +// } | |
| 197 | +// if ( | |
| 198 | +// JSON.stringify(prev.value) === JSON.stringify(current.value) && | |
| 199 | +// JSON.stringify(prev.schema) === JSON.stringify(current.schema) | |
| 200 | +// ) { | |
| 201 | +// return true; | |
| 202 | +// } | |
| 203 | +// return false; | |
| 204 | +// }; | |
| 205 | + | |
| 206 | + | |
| 207 | +export default ExtendedWidget; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/RenderField/Extra.css
renamed from
es/core/RenderField/Extra.css
es/form-render-core/src/core/RenderField/Extra.js
renamed from
es/core/RenderField/Extra.js
| 1 | +import "antd/es/tooltip/style"; | |
| 2 | +import _Tooltip from "antd/es/tooltip"; | |
| 3 | +import React from 'react'; | |
| 4 | +import { useStore2, useTools } from '../../hooks'; | |
| 5 | +import { isCheckBoxType } from '../../utils'; | |
| 6 | + | |
| 7 | +var Description = function Description(_ref) { | |
| 8 | + var displayType = _ref.displayType, | |
| 9 | + schema = _ref.schema; | |
| 10 | + var description = schema.description, | |
| 11 | + descType = schema.descType, | |
| 12 | + descWidget = schema.descWidget; | |
| 13 | + if (!description && !descWidget) return null; | |
| 14 | + | |
| 15 | + var _useTools = useTools(), | |
| 16 | + widgets = _useTools.widgets; | |
| 17 | + | |
| 18 | + var _description = typeof description === 'string' && /(^<|\/>)/.test(description) ? /*#__PURE__*/React.createElement("div", { | |
| 19 | + dangerouslySetInnerHTML: { | |
| 20 | + __html: description | |
| 21 | + } | |
| 22 | + }) : description; | |
| 23 | + | |
| 24 | + var RenderDesc = function RenderDesc() { | |
| 25 | + var Widget = widgets[schema.descWidget]; | |
| 26 | + | |
| 27 | + if (Widget) { | |
| 28 | + return /*#__PURE__*/React.createElement(Widget, { | |
| 29 | + schema: schema | |
| 30 | + }); | |
| 31 | + } | |
| 32 | + | |
| 33 | + return null; | |
| 34 | + }; | |
| 35 | + | |
| 36 | + switch (displayType) { | |
| 37 | + case 'row': | |
| 38 | + if (descType === 'widget') { | |
| 39 | + return /*#__PURE__*/React.createElement(RenderDesc, null); | |
| 40 | + } | |
| 41 | + | |
| 42 | + return /*#__PURE__*/React.createElement(_Tooltip, { | |
| 43 | + title: _description | |
| 44 | + }, /*#__PURE__*/React.createElement("i", { | |
| 45 | + className: "fr-tooltip-icon" | |
| 46 | + })); | |
| 47 | + | |
| 48 | + case 'inline': | |
| 49 | + return null; | |
| 50 | + | |
| 51 | + default: | |
| 52 | + if (descType === 'widget') { | |
| 53 | + return /*#__PURE__*/React.createElement(RenderDesc, null); | |
| 54 | + } | |
| 55 | + | |
| 56 | + if (descType === 'icon') { | |
| 57 | + return /*#__PURE__*/React.createElement(_Tooltip, { | |
| 58 | + title: _description | |
| 59 | + }, /*#__PURE__*/React.createElement("i", { | |
| 60 | + className: "fr-tooltip-icon" | |
| 61 | + })); | |
| 62 | + } | |
| 63 | + | |
| 64 | + return /*#__PURE__*/React.createElement("span", { | |
| 65 | + className: "fr-desc ml2" | |
| 66 | + }, "( ".concat(description, " )")); | |
| 67 | + } | |
| 68 | +}; | |
| 69 | + | |
| 70 | +var Title = function Title(_ref2) { | |
| 71 | + var labelClass = _ref2.labelClass, | |
| 72 | + labelStyle = _ref2.labelStyle, | |
| 73 | + schema = _ref2.schema, | |
| 74 | + displayType = _ref2.displayType, | |
| 75 | + renderTitle = _ref2.renderTitle, | |
| 76 | + globalRequiredMark = _ref2.requiredMark; | |
| 77 | + | |
| 78 | + var _useStore = useStore2(), | |
| 79 | + globalDisplayType = _useStore.displayType, | |
| 80 | + readOnly = _useStore.readOnly, | |
| 81 | + colon = _useStore.colon; | |
| 82 | + | |
| 83 | + var title = schema.title, | |
| 84 | + required = schema.required, | |
| 85 | + type = schema.type, | |
| 86 | + schemaRequiredMark = schema.requiredMark; | |
| 87 | + var isObjType = type === 'object'; | |
| 88 | + | |
| 89 | + var _displayType = schema.displayType || displayType || globalDisplayType || 'column'; | |
| 90 | + | |
| 91 | + if (renderTitle) { | |
| 92 | + return renderTitle({ | |
| 93 | + labelClass: labelClass, | |
| 94 | + labelStyle: labelStyle, | |
| 95 | + schema: schema, | |
| 96 | + displayType: _displayType, | |
| 97 | + readOnly: readOnly, | |
| 98 | + colon: colon | |
| 99 | + }); | |
| 100 | + } | |
| 101 | + | |
| 102 | + var requiredMark = typeof schemaRequiredMark === 'undefined' ? globalRequiredMark : schemaRequiredMark; // 左侧的的 * 号提示 | |
| 103 | + | |
| 104 | + var TitleRequiredMark = null; // 左侧的 option 提示 | |
| 105 | + | |
| 106 | + var TitleTextMark = null; | |
| 107 | + | |
| 108 | + if (required) { | |
| 109 | + /** | |
| 110 | + * ant-design requiredMark 实现 | |
| 111 | + * https://ant.design/components/form-cn/ | |
| 112 | + */ | |
| 113 | + if (requiredMark !== false && requiredMark !== 'optional') { | |
| 114 | + TitleRequiredMark = /*#__PURE__*/React.createElement("span", { | |
| 115 | + className: "fr-label-required" | |
| 116 | + }, " *"); | |
| 117 | + TitleTextMark = null; | |
| 118 | + } | |
| 119 | + } else { | |
| 120 | + if (requiredMark === 'optional') { | |
| 121 | + TitleRequiredMark = null; | |
| 122 | + TitleTextMark = /*#__PURE__*/React.createElement("span", { | |
| 123 | + className: "fr-label-required-text" | |
| 124 | + }, "\uFF08\u53EF\u9009\uFF09"); | |
| 125 | + } | |
| 126 | + } // requiredMark 为 false 不展示必填符号 | |
| 127 | + | |
| 128 | + | |
| 129 | + if (requiredMark === false) { | |
| 130 | + TitleRequiredMark = null; | |
| 131 | + TitleTextMark = null; | |
| 132 | + } | |
| 133 | + | |
| 134 | + return /*#__PURE__*/React.createElement("div", { | |
| 135 | + className: labelClass, | |
| 136 | + style: labelStyle | |
| 137 | + }, title ? /*#__PURE__*/React.createElement("label", { | |
| 138 | + className: "fr-label-title ".concat(isCheckBoxType(schema, readOnly) || _displayType === 'column' || !colon ? 'no-colon' : '') // checkbox不带冒号 | |
| 139 | + , | |
| 140 | + title: title | |
| 141 | + }, TitleRequiredMark, /*#__PURE__*/React.createElement("span", { | |
| 142 | + className: "".concat(isObjType ? 'b' : '', " ").concat(_displayType === 'column' ? 'flex-none' : '') | |
| 143 | + }, /*#__PURE__*/React.createElement("span", { | |
| 144 | + dangerouslySetInnerHTML: { | |
| 145 | + __html: title | |
| 146 | + } | |
| 147 | + })), TitleTextMark, /*#__PURE__*/React.createElement(Description, { | |
| 148 | + schema: schema, | |
| 149 | + displayType: _displayType | |
| 150 | + })) : null); | |
| 151 | +}; | |
| 152 | + | |
| 153 | +export default Title; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/RenderField/index.js
renamed from
es/core/RenderField/index.js
| 1 | 1 | function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } |
| 2 | 2 | |
| 3 | +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } | |
| 4 | + | |
| 5 | +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 6 | + | |
| 7 | +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(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(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | |
| 8 | + | |
| 9 | +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } | |
| 10 | + | |
| 11 | +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } | |
| 12 | + | |
| 13 | +function _arrayLikeToArray(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; } | |
| 14 | + | |
| 3 | 15 | function _defineProperty(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; } |
| 4 | 16 | |
| 5 | -import React, { useEffect, useRef } from 'react'; | |
| 17 | +import React, { useRef } from 'react'; | |
| 6 | 18 | import { useStore, useStore2, useTools } from '../../hooks'; |
| 7 | 19 | import useDebouncedCallback from '../../useDebounce'; |
| 8 | -import { getValueByPath, isCheckBoxType, isObjType } from '../../utils'; | |
| 20 | +import { getValueByPath, isCheckBoxType, isObjType, isBlockType } from '../../utils'; | |
| 21 | +import { validateField } from '../../validator'; | |
| 9 | 22 | import ErrorMessage from './ErrorMessage'; |
| 23 | +import ExtendedWidget from './ExtendedWidget'; | |
| 10 | 24 | import Extra from './Extra'; |
| 11 | -import FieldTitle from './Title'; | |
| 12 | -import ExtendedWidget from './ExtendedWidget'; // TODO: 之后不要直接用get,收口到一个内部方法getValue,便于全局 ctrl + f 查找 | |
| 25 | +import FieldTitle from './Title'; // TODO: 之后不要直接用get,收口到一个内部方法getValue,便于全局 ctrl + f 查找 | |
| 13 | 26 | |
| 14 | 27 | var RenderField = function RenderField(props) { |
| 15 | 28 | var $id = props.$id, |
| ... | ... | @@ -28,19 +41,28 @@ var RenderField = function RenderField(props) { |
| 28 | 41 | displayType = props.displayType; |
| 29 | 42 | |
| 30 | 43 | var _useStore = useStore(), |
| 31 | - formData = _useStore.formData; | |
| 44 | + formData = _useStore.formData, | |
| 45 | + flatten = _useStore.flatten; | |
| 32 | 46 | |
| 33 | 47 | var _useStore2 = useStore2(), |
| 34 | 48 | debounceInput = _useStore2.debounceInput, |
| 35 | 49 | readOnly = _useStore2.readOnly, |
| 36 | 50 | disabled = _useStore2.disabled, |
| 37 | - showValidate = _useStore2.showValidate; | |
| 51 | + showValidate = _useStore2.showValidate, | |
| 52 | + validateMessages = _useStore2.validateMessages, | |
| 53 | + locale = _useStore2.locale, | |
| 54 | + watch = _useStore2.watch; | |
| 38 | 55 | |
| 39 | 56 | var _useTools = useTools(), |
| 40 | 57 | onValuesChange = _useTools.onValuesChange, |
| 41 | 58 | onItemChange = _useTools.onItemChange, |
| 42 | 59 | setEditing = _useTools.setEditing, |
| 43 | - touchKey = _useTools.touchKey; | |
| 60 | + touchKey = _useTools.touchKey, | |
| 61 | + _setErrors = _useTools._setErrors, | |
| 62 | + renderTitle = _useTools.renderTitle, | |
| 63 | + requiredMark = _useTools.requiredMark, | |
| 64 | + setFieldValidating = _useTools.setFieldValidating, | |
| 65 | + removeFieldValidating = _useTools.removeFieldValidating; | |
| 44 | 66 | |
| 45 | 67 | var formDataRef = useRef(); |
| 46 | 68 | formDataRef.current = formData; // console.log('<renderField>', $id); |
| ... | ... | @@ -58,7 +80,38 @@ var RenderField = function RenderField(props) { |
| 58 | 80 | |
| 59 | 81 | var _readOnly = readOnly !== undefined ? readOnly : _schema.readOnly; |
| 60 | 82 | |
| 61 | - var _disabled = disabled !== undefined ? disabled : _schema.disabled; // TODO: 优化一下,只有touch还是false的时候,setTouched | |
| 83 | + var _disabled = disabled !== undefined ? disabled : _schema.disabled; | |
| 84 | + | |
| 85 | + var removeDupErrors = function removeDupErrors(arr) { | |
| 86 | + if (!Array.isArray(arr)) { | |
| 87 | + console.log('in removeDups: param is not an array'); | |
| 88 | + return; | |
| 89 | + } | |
| 90 | + | |
| 91 | + var array = []; | |
| 92 | + | |
| 93 | + for (var i = 0; i < arr.length; i++) { | |
| 94 | + var sameNameIndex = array.findIndex(function (item) { | |
| 95 | + return item.name === arr[i].name; | |
| 96 | + }); | |
| 97 | + | |
| 98 | + if (sameNameIndex > -1) { | |
| 99 | + var sameNameItem = array[sameNameIndex]; | |
| 100 | + var error1 = sameNameItem.error; | |
| 101 | + var error2 = arr[i].error; | |
| 102 | + array[sameNameIndex] = { | |
| 103 | + name: sameNameItem.name, | |
| 104 | + error: error1.length > 0 && error2.length > 0 ? error2 : [] | |
| 105 | + }; | |
| 106 | + } else { | |
| 107 | + array.push(arr[i]); | |
| 108 | + } | |
| 109 | + } | |
| 110 | + | |
| 111 | + return array.filter(function (item) { | |
| 112 | + return Array.isArray(item.error) && item.error.length > 0; | |
| 113 | + }); | |
| 114 | + }; // TODO: 优化一下,只有touch还是false的时候,setTouched | |
| 62 | 115 | |
| 63 | 116 | |
| 64 | 117 | var onChange = function onChange(value) { |
| ... | ... | @@ -78,13 +131,33 @@ var RenderField = function RenderField(props) { |
| 78 | 131 | if (typeof onValuesChange === 'function') { |
| 79 | 132 | onValuesChange(_defineProperty({}, dataPath, value), formDataRef.current); |
| 80 | 133 | } |
| 134 | + | |
| 135 | + validateField({ | |
| 136 | + path: dataPath, | |
| 137 | + formData: formDataRef.current, | |
| 138 | + flatten: flatten, | |
| 139 | + options: { | |
| 140 | + locale: locale, | |
| 141 | + validateMessages: validateMessages | |
| 142 | + }, | |
| 143 | + formInstance: { | |
| 144 | + setFieldValidating: setFieldValidating, | |
| 145 | + removeFieldValidating: removeFieldValidating | |
| 146 | + } | |
| 147 | + }).then(function (res) { | |
| 148 | + _setErrors(function (errors) { | |
| 149 | + return removeDupErrors([].concat(_toConsumableArray(errors), _toConsumableArray(res))); | |
| 150 | + }); | |
| 151 | + }); | |
| 81 | 152 | }; |
| 82 | 153 | |
| 83 | 154 | var titleProps = { |
| 84 | 155 | labelClass: labelClass, |
| 85 | 156 | labelStyle: labelStyle, |
| 86 | 157 | schema: _schema, |
| 87 | - displayType: displayType | |
| 158 | + displayType: displayType, | |
| 159 | + renderTitle: renderTitle, | |
| 160 | + requiredMark: requiredMark | |
| 88 | 161 | }; |
| 89 | 162 | var messageProps = { |
| 90 | 163 | message: errorMessage, |
| ... | ... | @@ -124,17 +197,31 @@ var RenderField = function RenderField(props) { |
| 124 | 197 | onItemChange: onItemChange, |
| 125 | 198 | dataIndex: dataIndex, |
| 126 | 199 | dataPath: dataPath, |
| 127 | - children: children | |
| 200 | + children: children, | |
| 201 | + watch: watch, | |
| 202 | + hasError: hasError | |
| 203 | + }; | |
| 204 | + | |
| 205 | + var displayBlock = function displayBlock() { | |
| 206 | + if (hasError && !_schema.extra) { | |
| 207 | + return false; | |
| 208 | + } | |
| 209 | + | |
| 210 | + return true; | |
| 128 | 211 | }; // if (_schema && _schema.default !== undefined) { |
| 129 | 212 | // widgetProps.value = _schema.default; |
| 130 | 213 | // } |
| 131 | 214 | // checkbox必须单独处理,布局太不同了 |
| 132 | 215 | |
| 216 | + | |
| 133 | 217 | if (isCheckBoxType(_schema, _readOnly)) { |
| 134 | 218 | return /*#__PURE__*/React.createElement(React.Fragment, null, _showTitle && /*#__PURE__*/React.createElement("div", placeholderTitleProps), /*#__PURE__*/React.createElement("div", { |
| 135 | 219 | className: contentClass, |
| 136 | - style: contentStyle | |
| 137 | - }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(Extra, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps))); | |
| 220 | + style: contentStyle, | |
| 221 | + datapath: dataPath | |
| 222 | + }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps), /*#__PURE__*/React.createElement(Extra, widgetProps), displayBlock() && /*#__PURE__*/React.createElement("div", { | |
| 223 | + className: "field-block" | |
| 224 | + }))); | |
| 138 | 225 | } |
| 139 | 226 | |
| 140 | 227 | var titleElement = /*#__PURE__*/React.createElement(FieldTitle, titleProps); |
| ... | ... | @@ -144,20 +231,30 @@ var RenderField = function RenderField(props) { |
| 144 | 231 | style: { |
| 145 | 232 | display: 'flex' |
| 146 | 233 | } |
| 147 | - }, titleElement, /*#__PURE__*/React.createElement(ErrorMessage, messageProps)); | |
| 234 | + }, titleElement, /*#__PURE__*/React.createElement(ErrorMessage, messageProps), displayBlock() && /*#__PURE__*/React.createElement("div", { | |
| 235 | + className: "field-block" | |
| 236 | + })); | |
| 148 | 237 | return /*#__PURE__*/React.createElement("div", { |
| 149 | 238 | className: contentClass, |
| 150 | - style: contentStyle | |
| 239 | + style: contentStyle, | |
| 240 | + datapath: dataPath | |
| 151 | 241 | }, /*#__PURE__*/React.createElement(ExtendedWidget, _extends({}, widgetProps, { |
| 152 | 242 | message: errorMessage, |
| 153 | 243 | title: _showTitle ? titleElement : undefined |
| 154 | 244 | })), /*#__PURE__*/React.createElement(Extra, widgetProps)); |
| 245 | + } else if (isBlockType(_schema)) { | |
| 246 | + return /*#__PURE__*/React.createElement("div", { | |
| 247 | + datapath: dataPath | |
| 248 | + }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps)); | |
| 155 | 249 | } |
| 156 | 250 | |
| 157 | 251 | return /*#__PURE__*/React.createElement(React.Fragment, null, _showTitle && titleElement, /*#__PURE__*/React.createElement("div", { |
| 158 | 252 | className: "".concat(contentClass, " ").concat(hideTitle ? 'fr-content-no-title' : ''), |
| 159 | - style: contentStyle | |
| 160 | - }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(Extra, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps))); | |
| 253 | + style: contentStyle, | |
| 254 | + datapath: dataPath | |
| 255 | + }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps), /*#__PURE__*/React.createElement(Extra, widgetProps), displayBlock() && /*#__PURE__*/React.createElement("div", { | |
| 256 | + className: "field-block" | |
| 257 | + }))); | |
| 161 | 258 | }; |
| 162 | 259 | |
| 163 | 260 | export default RenderField; |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/core/index.js
renamed from
es/core/index.js
| 1 | 1 | var _excluded = ["id", "_item", "dataIndex", "hideTitle", "hideValidation", "debugCss"], |
| 2 | - _excluded2 = ["id", "item", "dataIndex", "dataPath", "hideTitle", "hideValidation", "debugCss", "schema", "_value", "dependValues", "displayType", "column", "labelWidth", "readOnly", "errorFields", "effectiveLabelWidth"]; | |
| 2 | + _excluded2 = ["id", "item", "dataIndex", "dataPath", "hideTitle", "hideValidation", "debugCss", "schema", "_value", "dependValues", "displayType", "labelAlign", "column", "labelWidth", "readOnly", "errorFields", "effectiveLabelWidth"]; | |
| 3 | 3 | |
| 4 | 4 | function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } |
| 5 | 5 | |
| ... | ... | @@ -12,11 +12,11 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return |
| 12 | 12 | function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } |
| 13 | 13 | |
| 14 | 14 | import React, { useRef } from 'react'; |
| 15 | +import { useStore, useStore2 } from '../hooks'; | |
| 16 | +import { clone, getDataPath, getParentPath, getParentProps, getValueByPath, isCheckBoxType, isCssLength, isListType, isLooselyNumber, isObjType, parseRootValueInSchema } from '../utils'; | |
| 15 | 17 | import RenderList from './RenderChildren/RenderList'; |
| 16 | 18 | import RenderObject from './RenderChildren/RenderObject'; |
| 17 | 19 | import RenderField from './RenderField'; |
| 18 | -import { useStore, useStore2 } from '../hooks'; | |
| 19 | -import { isLooselyNumber, isCssLength, getParentProps, getParentPath, isListType, isCheckBoxType, isObjType, getValueByPath, getDataPath, parseRootValueInSchema, clone } from '../utils'; | |
| 20 | 20 | |
| 21 | 21 | var Core = function Core(_ref) { |
| 22 | 22 | var _ref$id = _ref.id, |
| ... | ... | @@ -31,7 +31,6 @@ var Core = function Core(_ref) { |
| 31 | 31 | debugCss = _ref.debugCss, |
| 32 | 32 | rest = _objectWithoutProperties(_ref, _excluded); |
| 33 | 33 | |
| 34 | - // console.log('<Core>', id); | |
| 35 | 34 | var snapShot = useRef(); |
| 36 | 35 | |
| 37 | 36 | var _useStore = useStore(), |
| ... | ... | @@ -45,7 +44,8 @@ var Core = function Core(_ref) { |
| 45 | 44 | displayType = _useStore2.displayType, |
| 46 | 45 | column = _useStore2.column, |
| 47 | 46 | labelWidth = _useStore2.labelWidth, |
| 48 | - readOnly = _useStore2.readOnly; | |
| 47 | + readOnly = _useStore2.readOnly, | |
| 48 | + labelAlign = _useStore2.labelAlign; | |
| 49 | 49 | |
| 50 | 50 | var item = _item ? _item : flatten[id]; |
| 51 | 51 | if (!item) return null; |
| ... | ... | @@ -54,7 +54,8 @@ var Core = function Core(_ref) { |
| 54 | 54 | |
| 55 | 55 | var _value = getValueByPath(formData, dataPath); |
| 56 | 56 | |
| 57 | - var schema = clone(item.schema); | |
| 57 | + var schema = clone(item.schema); // schema.disabled = !!subReadOnly; | |
| 58 | + | |
| 58 | 59 | var dependencies = schema.dependencies; |
| 59 | 60 | var dependValues = []; |
| 60 | 61 | var rootValue; |
| ... | ... | @@ -73,6 +74,10 @@ var Core = function Core(_ref) { |
| 73 | 74 | |
| 74 | 75 | try { |
| 75 | 76 | rootValue = getValueByPath(formData, parentPath); |
| 77 | + | |
| 78 | + if (dataIndex.length) { | |
| 79 | + rootValue.index = dataIndex[dataIndex.length - 1]; | |
| 80 | + } | |
| 76 | 81 | } catch (error) {} // 节流部分逻辑,编辑时不执行 |
| 77 | 82 | |
| 78 | 83 | |
| ... | ... | @@ -108,7 +113,8 @@ var Core = function Core(_ref) { |
| 108 | 113 | readOnly: readOnly, |
| 109 | 114 | errorFields: errorFields, |
| 110 | 115 | effectiveLabelWidth: effectiveLabelWidth, |
| 111 | - allTouched: allTouched | |
| 116 | + allTouched: allTouched, | |
| 117 | + labelAlign: labelAlign | |
| 112 | 118 | }, rest); |
| 113 | 119 | |
| 114 | 120 | return /*#__PURE__*/React.createElement(CoreRender, dataProps); |
| ... | ... | @@ -126,6 +132,7 @@ var CoreRender = function CoreRender(_ref2) { |
| 126 | 132 | _value = _ref2._value, |
| 127 | 133 | dependValues = _ref2.dependValues, |
| 128 | 134 | displayType = _ref2.displayType, |
| 135 | + labelAlign = _ref2.labelAlign, | |
| 129 | 136 | column = _ref2.column, |
| 130 | 137 | labelWidth = _ref2.labelWidth, |
| 131 | 138 | readOnly = _ref2.readOnly, |
| ... | ... | @@ -133,13 +140,16 @@ var CoreRender = function CoreRender(_ref2) { |
| 133 | 140 | effectiveLabelWidth = _ref2.effectiveLabelWidth, |
| 134 | 141 | rest = _objectWithoutProperties(_ref2, _excluded2); |
| 135 | 142 | |
| 136 | - // if (schema.hidden) { | |
| 137 | - // return null; | |
| 138 | - // } | |
| 139 | - // 样式的逻辑全放在这层 | |
| 143 | + if (schema.hidden) { | |
| 144 | + return null; | |
| 145 | + } // 样式的逻辑全放在这层 | |
| 140 | 146 | // displayType 一层层网上找值 |
| 147 | + | |
| 148 | + | |
| 141 | 149 | var _displayType = schema.displayType || rest.displayType || displayType || 'column'; |
| 142 | 150 | |
| 151 | + var _labelAlign = schema.labelAlign || rest.labelAlign || labelAlign || 'right'; | |
| 152 | + | |
| 143 | 153 | var isList = isListType(schema); |
| 144 | 154 | var isObj = isObjType(schema); |
| 145 | 155 | var isComplex = isObj || isList; |
| ... | ... | @@ -215,7 +225,7 @@ var CoreRender = function CoreRender(_ref2) { |
| 215 | 225 | } else if (_displayType === 'row') { |
| 216 | 226 | // row specific className |
| 217 | 227 | containerClass += ''; |
| 218 | - labelClass += ' fr-label-row'; | |
| 228 | + labelClass += " fr-label-row ".concat(_labelAlign === 'right' ? 'fr-label-align-right' : 'fr-label-align-left'); | |
| 219 | 229 | contentClass += ' fr-content-row'; |
| 220 | 230 | |
| 221 | 231 | if (!isObj && !isCheckBox) { |
| ... | ... | @@ -293,6 +303,7 @@ var CoreRender = function CoreRender(_ref2) { |
| 293 | 303 | dataIndex: dataIndex, |
| 294 | 304 | errorFields: errorFields, |
| 295 | 305 | displayType: _displayType, |
| 306 | + labelAlign: _labelAlign, | |
| 296 | 307 | hideTitle: hideTitle |
| 297 | 308 | }, item.children)); |
| 298 | 309 | var listChildren = /*#__PURE__*/React.createElement(RenderList, { |
| ... | ... | @@ -320,7 +331,8 @@ var CoreRender = function CoreRender(_ref2) { |
| 320 | 331 | style: columnStyle, |
| 321 | 332 | className: "".concat(containerClass, " ").concat(debugCss ? 'debug' : '') |
| 322 | 333 | }, /*#__PURE__*/React.createElement(RenderField, fieldProps, _children)); |
| 323 | -}; | |
| 334 | +}; // haven't used | |
| 335 | + | |
| 324 | 336 | |
| 325 | 337 | var areEqual = function areEqual(prev, current) { |
| 326 | 338 | if (prev.allTouched !== current.allTouched) { |
| ... | ... | @@ -339,6 +351,24 @@ var areEqual = function areEqual(prev, current) { |
| 339 | 351 | return false; |
| 340 | 352 | } |
| 341 | 353 | |
| 354 | + if (prev.readOnly !== current.readOnly) { | |
| 355 | + return false; | |
| 356 | + } | |
| 357 | + | |
| 358 | + if (prev.disabled !== current.disabled) { | |
| 359 | + return false; | |
| 360 | + } | |
| 361 | + | |
| 362 | + if (prev.schema && current.schema) { | |
| 363 | + if (prev.schema.$id === '#') { | |
| 364 | + return false; | |
| 365 | + } | |
| 366 | + } | |
| 367 | + | |
| 368 | + if (isObjType(prev.schema) && isObjType(current.schema)) { | |
| 369 | + return false; | |
| 370 | + } | |
| 371 | + | |
| 342 | 372 | if (JSON.stringify(prev.dependValues) !== JSON.stringify(current.dependValues)) { |
| 343 | 373 | return false; |
| 344 | 374 | } |
| ... | ... | @@ -350,5 +380,4 @@ var areEqual = function areEqual(prev, current) { |
| 350 | 380 | return false; |
| 351 | 381 | }; |
| 352 | 382 | |
| 353 | -var MCore = /*#__PURE__*/React.memo(CoreRender, areEqual); | |
| 354 | 383 | export default Core; |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/createWidget.js
renamed from
es/createWidget.js
es/form-render-core/src/hooks.js
renamed from
es/hooks.js
| ... | ... | @@ -16,7 +16,7 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy |
| 16 | 16 | |
| 17 | 17 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } |
| 18 | 18 | |
| 19 | -import { useReducer, useContext, useRef, useEffect, useState, createContext } from 'react'; | |
| 19 | +import { createContext, useContext, useEffect, useReducer, useRef, useState } from 'react'; | |
| 20 | 20 | export var Ctx = /*#__PURE__*/createContext(function () {}); |
| 21 | 21 | export var StoreCtx = /*#__PURE__*/createContext({}); |
| 22 | 22 | export var Store2Ctx = /*#__PURE__*/createContext({}); | ... | ... |
es/form-render-core/src/index.css
renamed from
es/index.css
| ... | ... | @@ -29,13 +29,56 @@ |
| 29 | 29 | align-items: center; |
| 30 | 30 | min-height: 32px; |
| 31 | 31 | } |
| 32 | +.fr-container .fr-item-has-error { | |
| 33 | + border-color: #ff4d4f; | |
| 34 | +} | |
| 35 | +.fr-container .fr-item-has-error:focus { | |
| 36 | + border-color: #ff7875 !important; | |
| 37 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 38 | +} | |
| 39 | +.fr-container .fr-item-has-error:hover { | |
| 40 | + border-color: #ff7875 !important; | |
| 41 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 42 | +} | |
| 43 | +.fr-container .fr-item-status-error { | |
| 44 | + border-color: #ff4d4f; | |
| 45 | +} | |
| 46 | +.fr-container .fr-item-status-error:focus { | |
| 47 | + border-color: #ff7875 !important; | |
| 48 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 49 | +} | |
| 50 | +.fr-container .fr-item-status-error:hover { | |
| 51 | + border-color: #ff7875 !important; | |
| 52 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 53 | +} | |
| 54 | +.fr-container .fr-item-status-error input[class~='ant-input'] { | |
| 55 | + border-color: #ff4d4f; | |
| 56 | +} | |
| 57 | +.fr-container .fr-item-status-error input[class~='ant-input']:focus { | |
| 58 | + border-color: #ff7875 !important; | |
| 59 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 60 | +} | |
| 61 | +.fr-container .fr-item-status-error input[class~='ant-input']:hover { | |
| 62 | + border-color: #ff7875 !important; | |
| 63 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 64 | +} | |
| 65 | +.fr-container .fr-item-status-error div[class~='ant-select-selector'] { | |
| 66 | + border-color: #ff4d4f; | |
| 67 | +} | |
| 68 | +.fr-container .fr-item-status-error div[class~='ant-select-selector']:focus { | |
| 69 | + border-color: #ff7875 !important; | |
| 70 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 71 | +} | |
| 72 | +.fr-container .fr-item-status-error div[class~='ant-select-selector']:hover { | |
| 73 | + border-color: #ff7875 !important; | |
| 74 | + box-shadow: 0 0 0 2px rgba(255, 77, 79, 0.2) !important; | |
| 75 | +} | |
| 32 | 76 | .fr-container .ant-table-cell .fr-field { |
| 33 | 77 | margin-bottom: 0; |
| 34 | 78 | } |
| 35 | 79 | .fr-container .fr-collapse-object { |
| 36 | 80 | margin-bottom: 8px; |
| 37 | 81 | overflow: hidden; |
| 38 | - background: #f7f7f7; | |
| 39 | 82 | border-radius: 2px; |
| 40 | 83 | } |
| 41 | 84 | .fr-container .fr-collapse-object .ant-collapse-header { |
| ... | ... | @@ -48,14 +91,25 @@ |
| 48 | 91 | .fr-container .fr-collapse-object .ant-collapse-arrow { |
| 49 | 92 | padding-top: 5px !important; |
| 50 | 93 | } |
| 94 | +.fr-container .fr-collapse-object .fr-collapse-object-child-column { | |
| 95 | + padding: 0 20px; | |
| 96 | +} | |
| 97 | +.fr-container .fr-collapse-object .fr-collapse-object-child-row { | |
| 98 | + padding: 0 32px; | |
| 99 | +} | |
| 51 | 100 | .fr-container .fr-label { |
| 52 | 101 | display: block; |
| 53 | 102 | } |
| 54 | 103 | .fr-container .fr-label-row { |
| 55 | - text-align: right; | |
| 56 | 104 | flex-shrink: 0; |
| 57 | 105 | margin-top: 5px; |
| 58 | 106 | } |
| 107 | +.fr-container .fr-label-align-right { | |
| 108 | + text-align: right; | |
| 109 | +} | |
| 110 | +.fr-container .fr-label-align-left { | |
| 111 | + text-align: left; | |
| 112 | +} | |
| 59 | 113 | .fr-container .fr-label-column { |
| 60 | 114 | margin-bottom: 4px; |
| 61 | 115 | } |
| ... | ... | @@ -73,6 +127,12 @@ |
| 73 | 127 | font-size: 14px; |
| 74 | 128 | font-family: SimSun, sans-serif; |
| 75 | 129 | } |
| 130 | +.fr-container .fr-label-required-text { | |
| 131 | + margin: 0 4px 0 0; | |
| 132 | + color: rgba(0, 0, 0, 0.45); | |
| 133 | + font-size: 14px; | |
| 134 | + font-family: SimSun, sans-serif; | |
| 135 | +} | |
| 76 | 136 | .fr-container .fr-label-title::after { |
| 77 | 137 | content: ':'; |
| 78 | 138 | position: relative; |
| ... | ... | @@ -80,8 +140,8 @@ |
| 80 | 140 | margin: 0 10px 0 2px; |
| 81 | 141 | } |
| 82 | 142 | .fr-container .fr-label-title.no-colon::after { |
| 83 | - content: ''; | |
| 84 | - margin: 0; | |
| 143 | + content: ' '; | |
| 144 | + margin: 0 10px 0 2px; | |
| 85 | 145 | } |
| 86 | 146 | .fr-container .fr-label-object .fr-label-title { |
| 87 | 147 | font-size: 16px; |
| ... | ... | @@ -235,10 +295,6 @@ |
| 235 | 295 | cursor: pointer; |
| 236 | 296 | position: relative; |
| 237 | 297 | } |
| 238 | -.fr-container .fr-tooltip-toggle:hover .fr-tooltip-container { | |
| 239 | - opacity: 1; | |
| 240 | - visibility: visible; | |
| 241 | -} | |
| 242 | 298 | .fr-container .fr-tooltip-icon { |
| 243 | 299 | height: 14px; |
| 244 | 300 | width: 14px; |
| ... | ... | @@ -247,57 +303,6 @@ |
| 247 | 303 | display: block; |
| 248 | 304 | margin: 4px 0 0 4px; |
| 249 | 305 | } |
| 250 | -.fr-container .fr-tooltip-container { | |
| 251 | - position: absolute; | |
| 252 | - width: 160px; | |
| 253 | - white-space: initial !important; | |
| 254 | - top: -4px; | |
| 255 | - left: 0; | |
| 256 | - bottom: unset; | |
| 257 | - transform: translateY(-100%); | |
| 258 | - text-align: left; | |
| 259 | - background: #2b222a; | |
| 260 | - padding: 4px; | |
| 261 | - margin-left: -69px; | |
| 262 | - border-radius: 4px; | |
| 263 | - color: #efefef; | |
| 264 | - font-size: 13px; | |
| 265 | - cursor: auto; | |
| 266 | - z-index: 99999; | |
| 267 | - transition: all 0.5s ease; | |
| 268 | - opacity: 0; | |
| 269 | - visibility: hidden; | |
| 270 | - word-wrap: break-word; | |
| 271 | -} | |
| 272 | -.fr-container .fr-tooltip-triangle { | |
| 273 | - position: absolute; | |
| 274 | - left: 50%; | |
| 275 | - border-left: 5px solid transparent; | |
| 276 | - border-right: 5px solid transparent; | |
| 277 | - border-top: 5px solid #2b222a; | |
| 278 | - transition: all 0.5s ease; | |
| 279 | - content: ' '; | |
| 280 | - font-size: 0; | |
| 281 | - line-height: 0; | |
| 282 | - margin-left: -5px; | |
| 283 | - width: 0; | |
| 284 | - bottom: -5px; | |
| 285 | -} | |
| 286 | -.fr-container .fr-tooltip-toggle::before, | |
| 287 | -.fr-container .fr-tooltip-toggle::after { | |
| 288 | - color: #efefef; | |
| 289 | - font-size: 13px; | |
| 290 | - opacity: 0; | |
| 291 | - pointer-events: none; | |
| 292 | - text-align: center; | |
| 293 | -} | |
| 294 | -.fr-container .fr-tooltip-toggle:focus::before, | |
| 295 | -.fr-container .fr-tooltip-toggle:focus::after, | |
| 296 | -.fr-container .fr-tooltip-toggle:hover::before, | |
| 297 | -.fr-container .fr-tooltip-toggle:hover::after { | |
| 298 | - opacity: 1; | |
| 299 | - transition: all 0.75s ease; | |
| 300 | -} | |
| 301 | 306 | .fr-container .fr-slider { |
| 302 | 307 | display: flex; |
| 303 | 308 | width: 100%; |
| ... | ... | @@ -314,14 +319,6 @@ |
| 314 | 319 | background-color: rgba(255, 77, 79, 0.2); |
| 315 | 320 | } |
| 316 | 321 | .fr-container .fr-theme-card-wrap { |
| 317 | - background-color: #fff; | |
| 318 | - padding: 36px 40px; | |
| 319 | - margin-bottom: 24px; | |
| 320 | - border-radius: 4px; | |
| 321 | - display: flex; | |
| 322 | - justify-content: space-between; | |
| 323 | -} | |
| 324 | -.fr-container .fr-theme-card-wrap .fr-theme-card-title { | |
| 325 | - font-size: 16px; | |
| 326 | 322 | margin-bottom: 16px; |
| 323 | + width: 100%; | |
| 327 | 324 | } | ... | ... |
es/form-render-core/src/index.d.ts
0 → 100644
| 1 | +import * as React from 'react'; | |
| 2 | +export interface Error { | |
| 3 | + /** 错误的数据路径 */ | |
| 4 | + name: string; | |
| 5 | + /** 错误的内容 */ | |
| 6 | + error: string[]; | |
| 7 | +} | |
| 8 | +export interface FormParams { | |
| 9 | + formData?: any; | |
| 10 | + onChange?: (data: any) => void; | |
| 11 | + onValidate?: (valid: any) => void; | |
| 12 | + showValidate?: boolean; | |
| 13 | + /** 数据分析接口,表单展示完成渲染时触发 */ | |
| 14 | + logOnMount?: (stats: any) => void; | |
| 15 | + /** 数据分析接口,表单提交成功时触发,获得本次表单填写的总时长 */ | |
| 16 | + logOnSubmit?: (stats: any) => void; | |
| 17 | +} | |
| 18 | + | |
| 19 | +export interface ValidateParams { | |
| 20 | + formData: any; | |
| 21 | + schema: any; | |
| 22 | + error: Error[]; | |
| 23 | + [k: string]: any; | |
| 24 | +} | |
| 25 | + | |
| 26 | +export interface ResetParams { | |
| 27 | + formData?: any; | |
| 28 | + submitData?: any; | |
| 29 | + errorFields?: Error[]; | |
| 30 | + touchedKeys?: any[]; | |
| 31 | + allTouched?: boolean; | |
| 32 | + [k: string]: any; | |
| 33 | +} | |
| 34 | + | |
| 35 | +export interface FormInstance { | |
| 36 | + formData: any; | |
| 37 | + schema: any; | |
| 38 | + flatten: any; | |
| 39 | + touchedKeys: string[]; | |
| 40 | + touchKey: (key: string) => void; | |
| 41 | + onItemChange: (path: string, value: any) => void; | |
| 42 | + setValueByPath: (path: string, value: any) => void; | |
| 43 | + getSchemaByPath: (path: string) => object; | |
| 44 | + setSchemaByPath: (path: string, value: any) => void; | |
| 45 | + setSchema: (settings: any) => void; | |
| 46 | + setValues: (formData: any) => void; | |
| 47 | + getValues: () => any; | |
| 48 | + resetFields: (options?: ResetParams) => void; | |
| 49 | + submit: () => Promise<void> | Promise<any[]>; | |
| 50 | + submitData: any; | |
| 51 | + errorFields: Error[]; | |
| 52 | + isValidating: boolean; | |
| 53 | + outsideValidating: boolean; | |
| 54 | + isSubmitting: boolean; | |
| 55 | + endValidating: () => void; | |
| 56 | + endSubmitting: () => void; | |
| 57 | + setErrorFields: (error: Error[]) => void; | |
| 58 | + removeErrorField: (path: string) => void; | |
| 59 | + removeTouched: (path: string) => void; | |
| 60 | + changeTouchedKeys: (pathArray: string[]) => void; | |
| 61 | + isEditing: boolean; | |
| 62 | + setEditing: (status: boolean) => void; | |
| 63 | + syncStuff: (args: any) => void; | |
| 64 | + /** 折中升级方案中使用到,正常用不到 */ | |
| 65 | + init: () => void; | |
| 66 | + /** 数据分析接口,表单展示完成渲染时触发 */ | |
| 67 | + logOnMount: (args: any) => void; | |
| 68 | + /** 数据分析接口,表单提交成功时触发,获得本次表单填写的总时长 */ | |
| 69 | + logOnSubmit: (args: any) => void; | |
| 70 | + _setErrors: (args: any) => void; | |
| 71 | + validateFields: (nameList?: string[]) => Promise<any>; | |
| 72 | + isFieldTouched: (name: string) => boolean; | |
| 73 | + isFieldsTouched: (nameList?: string[], allTouched?: boolean) => boolean; | |
| 74 | + isFieldValidating: (name: string) => boolean; | |
| 75 | + scrollToPath: (name: string) => void; | |
| 76 | + getFieldError: (name: string) => string[]; | |
| 77 | + getFieldsError: (nameList?: string[]) => Error[]; | |
| 78 | + setFields: (nameList: string[]) => void; | |
| 79 | +} | |
| 80 | + | |
| 81 | +export type WatchProperties = { | |
| 82 | + [path: string]: | |
| 83 | + | { | |
| 84 | + handler: (value: any) => void; | |
| 85 | + immediate?: boolean; | |
| 86 | + } | |
| 87 | + | ((value: any) => void); | |
| 88 | +}; | |
| 89 | + | |
| 90 | +export interface FRProps { | |
| 91 | + /** 表单 id */ | |
| 92 | + id?: string | number; | |
| 93 | + /** 表单顶层的className */ | |
| 94 | + className?: string; | |
| 95 | + /** 表单顶层的样式 */ | |
| 96 | + style?: any; | |
| 97 | + /** 表单 schema */ | |
| 98 | + schema: any; | |
| 99 | + /** form单例 */ | |
| 100 | + form: FormInstance; | |
| 101 | + /** 组件和schema的映射规则 */ | |
| 102 | + mapping?: any; | |
| 103 | + /** 自定义组件 */ | |
| 104 | + widgets?: any; | |
| 105 | + /** 表单提交前钩子 */ | |
| 106 | + displayType?: string; | |
| 107 | + /** 只读模式 */ | |
| 108 | + readOnly?: boolean; | |
| 109 | + /** 禁用模式 */ | |
| 110 | + disabled?: boolean; | |
| 111 | + /** 标签宽度 */ | |
| 112 | + labelWidth?: string | number; | |
| 113 | + /** antd的全局config */ | |
| 114 | + configProvider?: any; | |
| 115 | + theme?: string | number; | |
| 116 | + /** 覆盖默认的校验信息 */ | |
| 117 | + validateMessages?: any; | |
| 118 | + /** 显示当前表单内部状态 */ | |
| 119 | + debug?: boolean; | |
| 120 | + /** 显示css布局提示线 */ | |
| 121 | + debugCss?: boolean; | |
| 122 | + locale?: string; | |
| 123 | + column?: number; | |
| 124 | + debounceInput?: boolean; | |
| 125 | + size?: string; | |
| 126 | + // 数据会作为 beforeFinish 的第四个参数传入 | |
| 127 | + config?: any; | |
| 128 | + // 类似于 vuejs 的 watch 的用法,监控值的变化,触发 callback | |
| 129 | + watch?: WatchProperties; | |
| 130 | + /** 对象组件是否折叠(全局的控制) */ | |
| 131 | + allCollapsed?: boolean; | |
| 132 | + /** 表单的全局共享属性 */ | |
| 133 | + globalProps?: any; | |
| 134 | + /** 表单首次加载钩子 */ | |
| 135 | + onMount?: () => void; | |
| 136 | + /** 表单提交前钩子 */ | |
| 137 | + beforeFinish?: (params: ValidateParams) => Error[] | Promise<Error[]>; | |
| 138 | + /** 表单提交后钩子 */ | |
| 139 | + onFinish?: (formData: any, error: Error[]) => void; | |
| 140 | + /** 时时与外部更新同步的钩子 */ | |
| 141 | + onValuesChange?: (changedValues: any, formData: any) => void; | |
| 142 | + /** 隐藏的数据是否去掉,默认不去掉(false) */ | |
| 143 | + removeHiddenData?: boolean; | |
| 144 | +} | |
| 145 | + | |
| 146 | +declare const FR: React.FC<FRProps>; | |
| 147 | + | |
| 148 | +export declare function useForm(params?: FormParams): FormInstance; | |
| 149 | + | |
| 150 | +export type ConnectedForm<T> = T & { | |
| 151 | + form: FormInstance; | |
| 152 | +}; | |
| 153 | + | |
| 154 | +export declare function connectForm<T extends {} = any>( | |
| 155 | + component: React.ComponentType<ConnectedForm<T>> | |
| 156 | +): React.ComponentType<T>; | |
| 157 | + | |
| 158 | +export default FR; | ... | ... |
es/form-render-core/src/index.js
0 → 100644
| 1 | +var _excluded = ["id", "widgets", "layoutWidgets", "mapping", "form", "className", "style", "beforeFinish", "onFinish", "displayType", "labelAlign", "colon", "schema", "debug", "debugCss", "locale", "debounceInput", "size", "configProvider", "theme", "validateMessages", "watch", "config", "onMount", "labelWidth", "readOnly", "disabled", "allCollapsed", "onValuesChange", "column", "removeHiddenData", "globalProps", "methods", "renderTitle", "requiredMark"], | |
| 2 | + _excluded2 = ["onItemChange", "setEditing", "touchKey", "setValueByPath", "getSchemaByPath", "setSchemaByPath", "setSchema", "setValues", "getValues", "resetFields", "submit", "endValidating", "endSubmitting", "setErrorFields", "removeErrorField", "removeTouched", "changeTouchedKeys", "syncStuff", "logOnMount", "logOnSubmit", "setFirstMount", "_setErrors"], | |
| 3 | + _excluded3 = ["isOldVersion", "schema"]; | |
| 4 | + | |
| 5 | +function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } | |
| 6 | + | |
| 7 | +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } | |
| 8 | + | |
| 9 | +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } | |
| 10 | + | |
| 11 | +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | |
| 12 | + | |
| 13 | +function _defineProperty(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; } | |
| 14 | + | |
| 15 | +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } | |
| 16 | + | |
| 17 | +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } | |
| 18 | + | |
| 19 | +/* eslint-disable react-hooks/exhaustive-deps */ | |
| 20 | +import React, { useEffect, useMemo, useRef } from 'react'; | |
| 21 | +import "./atom.css"; | |
| 22 | +import Core from './core'; | |
| 23 | +import { Ctx, Store2Ctx, StoreCtx } from './hooks'; | |
| 24 | +import "./index.css"; | |
| 25 | +import { mapping as defaultMapping } from './mapping'; | |
| 26 | +import { getParamByName, msToTime, updateSchemaToNewVersion, yymmdd } from './utils'; | |
| 27 | +import Watcher from './Watcher'; | |
| 28 | + | |
| 29 | +var defaultFinish = function defaultFinish(data, errors) { | |
| 30 | + console.log('onFinish:', { | |
| 31 | + data: data, | |
| 32 | + errors: errors | |
| 33 | + }); | |
| 34 | +}; | |
| 35 | + | |
| 36 | +export { default as connectForm } from './connectForm'; | |
| 37 | +export { createWidget } from './createWidget'; | |
| 38 | +export { default as useForm } from './useForm'; | |
| 39 | +export { defaultMapping as mapping }; | |
| 40 | + | |
| 41 | +function App(_ref) { | |
| 42 | + var id = _ref.id, | |
| 43 | + widgets = _ref.widgets, | |
| 44 | + layoutWidgets = _ref.layoutWidgets, | |
| 45 | + mapping = _ref.mapping, | |
| 46 | + form = _ref.form, | |
| 47 | + className = _ref.className, | |
| 48 | + style = _ref.style, | |
| 49 | + beforeFinish = _ref.beforeFinish, | |
| 50 | + _ref$onFinish = _ref.onFinish, | |
| 51 | + onFinish = _ref$onFinish === void 0 ? defaultFinish : _ref$onFinish, | |
| 52 | + _ref$displayType = _ref.displayType, | |
| 53 | + displayType = _ref$displayType === void 0 ? 'column' : _ref$displayType, | |
| 54 | + _ref$labelAlign = _ref.labelAlign, | |
| 55 | + labelAlign = _ref$labelAlign === void 0 ? 'right' : _ref$labelAlign, | |
| 56 | + _ref$colon = _ref.colon, | |
| 57 | + colon = _ref$colon === void 0 ? true : _ref$colon, | |
| 58 | + schema = _ref.schema, | |
| 59 | + debug = _ref.debug, | |
| 60 | + debugCss = _ref.debugCss, | |
| 61 | + _ref$locale = _ref.locale, | |
| 62 | + locale = _ref$locale === void 0 ? 'cn' : _ref$locale, | |
| 63 | + _ref$debounceInput = _ref.debounceInput, | |
| 64 | + debounceInput = _ref$debounceInput === void 0 ? false : _ref$debounceInput, | |
| 65 | + size = _ref.size, | |
| 66 | + configProvider = _ref.configProvider, | |
| 67 | + theme = _ref.theme, | |
| 68 | + validateMessages = _ref.validateMessages, | |
| 69 | + _ref$watch = _ref.watch, | |
| 70 | + watch = _ref$watch === void 0 ? {} : _ref$watch, | |
| 71 | + config = _ref.config, | |
| 72 | + onMount = _ref.onMount, | |
| 73 | + labelWidth = _ref.labelWidth, | |
| 74 | + readOnly = _ref.readOnly, | |
| 75 | + disabled = _ref.disabled, | |
| 76 | + _ref$allCollapsed = _ref.allCollapsed, | |
| 77 | + allCollapsed = _ref$allCollapsed === void 0 ? false : _ref$allCollapsed, | |
| 78 | + onValuesChange = _ref.onValuesChange, | |
| 79 | + column = _ref.column, | |
| 80 | + _ref$removeHiddenData = _ref.removeHiddenData, | |
| 81 | + removeHiddenData = _ref$removeHiddenData === void 0 ? false : _ref$removeHiddenData, | |
| 82 | + _ref$globalProps = _ref.globalProps, | |
| 83 | + globalProps = _ref$globalProps === void 0 ? {} : _ref$globalProps, | |
| 84 | + _ref$methods = _ref.methods, | |
| 85 | + methods = _ref$methods === void 0 ? {} : _ref$methods, | |
| 86 | + renderTitle = _ref.renderTitle, | |
| 87 | + requiredMark = _ref.requiredMark, | |
| 88 | + rest = _objectWithoutProperties(_ref, _excluded); | |
| 89 | + | |
| 90 | + try { | |
| 91 | + var _ = form.submit; | |
| 92 | + } catch (error) { | |
| 93 | + console.error('form 为必填 props,<FormRender /> 没有接收到 form 属性!'); | |
| 94 | + } | |
| 95 | + | |
| 96 | + var _column = schema && schema.column || column; | |
| 97 | + | |
| 98 | + var onItemChange = form.onItemChange, | |
| 99 | + setEditing = form.setEditing, | |
| 100 | + touchKey = form.touchKey, | |
| 101 | + setValueByPath = form.setValueByPath, | |
| 102 | + getSchemaByPath = form.getSchemaByPath, | |
| 103 | + setSchemaByPath = form.setSchemaByPath, | |
| 104 | + setSchema = form.setSchema, | |
| 105 | + setValues = form.setValues, | |
| 106 | + getValues = form.getValues, | |
| 107 | + resetFields = form.resetFields, | |
| 108 | + submit = form.submit, | |
| 109 | + endValidating = form.endValidating, | |
| 110 | + endSubmitting = form.endSubmitting, | |
| 111 | + setErrorFields = form.setErrorFields, | |
| 112 | + removeErrorField = form.removeErrorField, | |
| 113 | + removeTouched = form.removeTouched, | |
| 114 | + changeTouchedKeys = form.changeTouchedKeys, | |
| 115 | + syncStuff = form.syncStuff, | |
| 116 | + logOnMount = form.logOnMount, | |
| 117 | + logOnSubmit = form.logOnSubmit, | |
| 118 | + setFirstMount = form.setFirstMount, | |
| 119 | + _setErrors = form._setErrors, | |
| 120 | + valuesThatWillChange = _objectWithoutProperties(form, _excluded2); | |
| 121 | + | |
| 122 | + var submitData = valuesThatWillChange.submitData, | |
| 123 | + errorFields = valuesThatWillChange.errorFields, | |
| 124 | + isValidating = valuesThatWillChange.isValidating, | |
| 125 | + outsideValidating = valuesThatWillChange.outsideValidating, | |
| 126 | + isSubmitting = valuesThatWillChange.isSubmitting, | |
| 127 | + formData = valuesThatWillChange.formData, | |
| 128 | + flatten = valuesThatWillChange.flatten, | |
| 129 | + showValidate = valuesThatWillChange.showValidate, | |
| 130 | + firstMount = valuesThatWillChange.firstMount; | |
| 131 | + useEffect(function () { | |
| 132 | + // Schema最外层的type是object来判断,没有的话,认为schema没有传 | |
| 133 | + if (schema && schema.type) { | |
| 134 | + setFirstMount(true); | |
| 135 | + syncStuff({ | |
| 136 | + schema: schema, | |
| 137 | + locale: locale, | |
| 138 | + validateMessages: validateMessages, | |
| 139 | + beforeFinish: beforeFinish, | |
| 140 | + onMount: onMount, | |
| 141 | + removeHiddenData: removeHiddenData | |
| 142 | + }); | |
| 143 | + } else {} | |
| 144 | + }, [JSON.stringify(schema)]); | |
| 145 | + useEffect(function () { | |
| 146 | + if (!firstMount && schema && schema.type) { | |
| 147 | + if (typeof onMount === 'function') { | |
| 148 | + // 等一下 useForm 里接到第一份schema时,计算第一份data的骨架 | |
| 149 | + setTimeout(function () { | |
| 150 | + onMount(); | |
| 151 | + }, 0); | |
| 152 | + } | |
| 153 | + | |
| 154 | + setTimeout(onMountLogger, 0); | |
| 155 | + } | |
| 156 | + }, [JSON.stringify(schema), firstMount]); | |
| 157 | + | |
| 158 | + var onMountLogger = function onMountLogger() { | |
| 159 | + var start = new Date().getTime(); | |
| 160 | + | |
| 161 | + if (typeof logOnMount === 'function' || typeof logOnSubmit === 'function') { | |
| 162 | + sessionStorage.setItem('FORM_MOUNT_TIME', start); | |
| 163 | + sessionStorage.setItem('FORM_START', start); | |
| 164 | + } | |
| 165 | + | |
| 166 | + if (typeof logOnMount === 'function') { | |
| 167 | + var logParams = { | |
| 168 | + schema: schema, | |
| 169 | + url: location.href, | |
| 170 | + formData: JSON.stringify(form.getValues()), | |
| 171 | + formMount: yymmdd(start) | |
| 172 | + }; | |
| 173 | + | |
| 174 | + if (id) { | |
| 175 | + logParams.id = id; | |
| 176 | + } | |
| 177 | + | |
| 178 | + logOnMount(logParams); | |
| 179 | + } // 如果是要计算时间,在 onMount 时存一个时间戳 | |
| 180 | + | |
| 181 | + | |
| 182 | + if (typeof logOnSubmit === 'function') { | |
| 183 | + sessionStorage.setItem('NUMBER_OF_SUBMITS', 0); | |
| 184 | + sessionStorage.setItem('FAILED_ATTEMPTS', 0); | |
| 185 | + } | |
| 186 | + }; // 组件 destroy 的时候,destroy form,因为useForm可能在上层,所以不一定会跟着destroy | |
| 187 | + | |
| 188 | + | |
| 189 | + useEffect(function () { | |
| 190 | + return function () { | |
| 191 | + form.resetFields(); | |
| 192 | + }; | |
| 193 | + }, []); | |
| 194 | + var store = useMemo(function () { | |
| 195 | + return _objectSpread(_objectSpread({}, valuesThatWillChange), {}, { | |
| 196 | + globalProps: globalProps | |
| 197 | + }, rest); | |
| 198 | + }, [JSON.stringify(flatten), JSON.stringify(formData), JSON.stringify(errorFields), JSON.stringify(globalProps)]); // 不常用的context单独放一个地方 | |
| 199 | + | |
| 200 | + var store2 = useMemo(function () { | |
| 201 | + return { | |
| 202 | + displayType: displayType, | |
| 203 | + labelAlign: labelAlign, | |
| 204 | + colon: colon, | |
| 205 | + theme: theme, | |
| 206 | + column: _column, | |
| 207 | + debounceInput: debounceInput, | |
| 208 | + debug: debug, | |
| 209 | + labelWidth: labelWidth, | |
| 210 | + locale: locale, | |
| 211 | + validateMessages: validateMessages, | |
| 212 | + readOnly: readOnly, | |
| 213 | + disabled: disabled, | |
| 214 | + allCollapsed: allCollapsed, | |
| 215 | + showValidate: showValidate, | |
| 216 | + watch: watch | |
| 217 | + }; | |
| 218 | + }, [displayType, labelAlign, colon, theme, _column, debounceInput, debug, labelWidth, locale, validateMessages, readOnly, disabled, allCollapsed, showValidate, watch]); | |
| 219 | + var tools = useMemo(function () { | |
| 220 | + return _objectSpread({ | |
| 221 | + widgets: widgets, | |
| 222 | + layoutWidgets: layoutWidgets, | |
| 223 | + mapping: _objectSpread(_objectSpread({}, defaultMapping), mapping), | |
| 224 | + onValuesChange: onValuesChange, | |
| 225 | + renderTitle: renderTitle, | |
| 226 | + requiredMark: requiredMark, | |
| 227 | + methods: methods | |
| 228 | + }, form); | |
| 229 | + }, [widgets]); | |
| 230 | + useEffect(function () { | |
| 231 | + // 需要外部校验的情况,此时 submitting 还是 false | |
| 232 | + if (outsideValidating === true) { | |
| 233 | + Promise.resolve(beforeFinish(_objectSpread({ | |
| 234 | + data: submitData, | |
| 235 | + schema: schema, | |
| 236 | + errors: errorFields | |
| 237 | + }, config))).then(function (error) { | |
| 238 | + if (error) { | |
| 239 | + setErrorFields(error); | |
| 240 | + } | |
| 241 | + | |
| 242 | + endValidating(); | |
| 243 | + }); | |
| 244 | + return; | |
| 245 | + } // 如果validation结束,submitting开始 | |
| 246 | + | |
| 247 | + | |
| 248 | + if (isValidating === false && isSubmitting === true) { | |
| 249 | + endSubmitting(); | |
| 250 | + onFinish(submitData, errorFields); | |
| 251 | + | |
| 252 | + if (typeof logOnSubmit === 'function') { | |
| 253 | + var start = sessionStorage.getItem('FORM_START'); | |
| 254 | + var mount = sessionStorage.getItem('FORM_MOUNT_TIME'); | |
| 255 | + var numberOfSubmits = Number(sessionStorage.getItem('NUMBER_OF_SUBMITS')) + 1; | |
| 256 | + var end = new Date().getTime(); | |
| 257 | + var failedAttempts = Number(sessionStorage.getItem('FAILED_ATTEMPTS')); | |
| 258 | + | |
| 259 | + if (errorFields.length > 0) { | |
| 260 | + failedAttempts = failedAttempts + 1; | |
| 261 | + } | |
| 262 | + | |
| 263 | + var logParams = { | |
| 264 | + formMount: yymmdd(mount), | |
| 265 | + ms: end - start, | |
| 266 | + duration: msToTime(end - start), | |
| 267 | + numberOfSubmits: numberOfSubmits, | |
| 268 | + failedAttempts: failedAttempts, | |
| 269 | + url: location.href, | |
| 270 | + formData: JSON.stringify(submitData), | |
| 271 | + errors: JSON.stringify(errorFields), | |
| 272 | + schema: JSON.stringify(schema) | |
| 273 | + }; | |
| 274 | + | |
| 275 | + if (id) { | |
| 276 | + logParams.id = id; | |
| 277 | + } | |
| 278 | + | |
| 279 | + logOnSubmit(logParams); | |
| 280 | + sessionStorage.setItem('FORM_START', end); | |
| 281 | + sessionStorage.setItem('NUMBER_OF_SUBMITS', numberOfSubmits); | |
| 282 | + sessionStorage.setItem('FAILED_ATTEMPTS', failedAttempts); | |
| 283 | + } | |
| 284 | + } | |
| 285 | + }, [isValidating, isSubmitting, outsideValidating]); // TODO: fk doesn't work | |
| 286 | + | |
| 287 | + var sizeCls = ''; | |
| 288 | + | |
| 289 | + if (size === 'small') { | |
| 290 | + sizeCls = 'fr-form-small'; | |
| 291 | + } else if (size === 'large') { | |
| 292 | + sizeCls = 'fr-form-large'; | |
| 293 | + } | |
| 294 | + | |
| 295 | + var rootProps = { | |
| 296 | + className: "fr-container ".concat(sizeCls, " ").concat(className || '') | |
| 297 | + }; | |
| 298 | + | |
| 299 | + if (style && _typeof(style) === 'object') { | |
| 300 | + rootProps.style = style; | |
| 301 | + } | |
| 302 | + | |
| 303 | + if (id && ['number', 'string'].indexOf(_typeof(id)) > -1) { | |
| 304 | + rootProps.id = id; | |
| 305 | + } | |
| 306 | + | |
| 307 | + var debugForm = getParamByName('_debug_form'); | |
| 308 | + var debugFormCss = getParamByName('_debug_form_css'); | |
| 309 | + var isPre = location.href.indexOf('pre') > -1; | |
| 310 | + var watchList = Object.keys(watch); | |
| 311 | + return /*#__PURE__*/React.createElement(StoreCtx.Provider, { | |
| 312 | + value: store | |
| 313 | + }, /*#__PURE__*/React.createElement(Store2Ctx.Provider, { | |
| 314 | + value: store2 | |
| 315 | + }, /*#__PURE__*/React.createElement(Ctx.Provider, { | |
| 316 | + value: tools | |
| 317 | + }, /*#__PURE__*/React.createElement("div", rootProps, isPre && debugForm || debug ? /*#__PURE__*/React.createElement("div", { | |
| 318 | + className: "mv2 bg-black-05 pa2 br2" | |
| 319 | + }, /*#__PURE__*/React.createElement("div", { | |
| 320 | + style: { | |
| 321 | + display: 'flex' | |
| 322 | + } | |
| 323 | + }, /*#__PURE__*/React.createElement("span", null, "formData:"), /*#__PURE__*/React.createElement("span", { | |
| 324 | + style: { | |
| 325 | + display: 'inline-block', | |
| 326 | + wordBreak: 'break-all', | |
| 327 | + whiteSpace: 'pre-wrap', | |
| 328 | + maxWidth: 600 | |
| 329 | + } | |
| 330 | + }, JSON.stringify(form.formData, null, 4))), /*#__PURE__*/React.createElement("div", null, 'errorFields:' + JSON.stringify(form.errorFields)), /*#__PURE__*/React.createElement("div", null, 'touchedKeys:' + JSON.stringify(form.touchedKeys)), /*#__PURE__*/React.createElement("div", null, 'allTouched:' + JSON.stringify(form.allTouched)), /*#__PURE__*/React.createElement("div", null, 'descriptor:' + JSON.stringify(window.descriptor))) : null, watchList.length > 0 ? watchList.map(function (item, idx) { | |
| 331 | + return /*#__PURE__*/React.createElement(Watcher, { | |
| 332 | + key: idx.toString(), | |
| 333 | + watchKey: item, | |
| 334 | + watch: watch, | |
| 335 | + formData: formData, | |
| 336 | + firstMount: firstMount | |
| 337 | + }); | |
| 338 | + }) : null, /*#__PURE__*/React.createElement(Core, { | |
| 339 | + debugCss: isPre && debugFormCss || debugCss | |
| 340 | + }))))); | |
| 341 | +} | |
| 342 | + | |
| 343 | +var Wrapper = function Wrapper(props) { | |
| 344 | + var _ref2 = props || {}, | |
| 345 | + _ref2$isOldVersion = _ref2.isOldVersion, | |
| 346 | + isOldVersion = _ref2$isOldVersion === void 0 ? true : _ref2$isOldVersion, | |
| 347 | + schema = _ref2.schema, | |
| 348 | + rest = _objectWithoutProperties(_ref2, _excluded3); | |
| 349 | + | |
| 350 | + var _schema = useRef(schema); | |
| 351 | + | |
| 352 | + if (isOldVersion) { | |
| 353 | + _schema.current = updateSchemaToNewVersion(schema); | |
| 354 | + } | |
| 355 | + | |
| 356 | + return /*#__PURE__*/React.createElement(App, _extends({ | |
| 357 | + schema: _schema.current | |
| 358 | + }, rest)); | |
| 359 | +}; | |
| 360 | + | |
| 361 | +export default Wrapper; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/mapping.js
0 → 100644
| 1 | +export var mapping = { | |
| 2 | + default: 'input', | |
| 3 | + string: 'input', | |
| 4 | + array: 'list', | |
| 5 | + boolean: 'checkbox', | |
| 6 | + integer: 'number', | |
| 7 | + number: 'number', | |
| 8 | + object: 'map', | |
| 9 | + html: 'html', | |
| 10 | + 'string:upload': 'upload', | |
| 11 | + 'string:url': 'url', | |
| 12 | + 'string:dateTime': 'date', | |
| 13 | + 'string:date': 'date', | |
| 14 | + 'string:year': 'date', | |
| 15 | + 'string:month': 'date', | |
| 16 | + 'string:week': 'date', | |
| 17 | + 'string:quarter': 'date', | |
| 18 | + 'string:time': 'time', | |
| 19 | + 'string:textarea': 'textarea', | |
| 20 | + 'string:color': 'color', | |
| 21 | + 'string:image': 'imageInput', | |
| 22 | + 'range:time': 'timeRange', | |
| 23 | + 'range:dateTime': 'dateRange', | |
| 24 | + 'range:date': 'dateRange', | |
| 25 | + 'range:year': 'dateRange', | |
| 26 | + 'range:month': 'dateRange', | |
| 27 | + 'range:week': 'dateRange', | |
| 28 | + 'range:quarter': 'dateRange', | |
| 29 | + '*?enum': 'radio', | |
| 30 | + '*?enum_long': 'select', | |
| 31 | + 'array?enum': 'checkboxes', | |
| 32 | + 'array?enum_long': 'multiSelect', | |
| 33 | + '*?readOnly': 'html' // TODO: html widgets for list / object | |
| 34 | + | |
| 35 | +}; | |
| 36 | +export function getWidgetName(schema) { | |
| 37 | + var _mapping = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : mapping; | |
| 38 | + | |
| 39 | + var type = schema.type, | |
| 40 | + format = schema.format, | |
| 41 | + enums = schema.enum, | |
| 42 | + readOnly = schema.readOnly, | |
| 43 | + widget = schema.widget; // 如果已经注明了渲染widget,那最好 | |
| 44 | + // if (schema['ui:widget']) { | |
| 45 | + // return schema['ui:widget']; | |
| 46 | + // } | |
| 47 | + | |
| 48 | + var list = []; | |
| 49 | + | |
| 50 | + if (readOnly) { | |
| 51 | + list.push("".concat(type, "?readOnly")); | |
| 52 | + list.push('*?readOnly'); | |
| 53 | + } | |
| 54 | + | |
| 55 | + if (enums) { | |
| 56 | + // 根据enum长度来智能选择控件 | |
| 57 | + if (Array.isArray(enums) && (type === 'array' && enums.length > 6 || type !== 'array' && enums.length > 2)) { | |
| 58 | + list.push("".concat(type, "?enum_long")); | |
| 59 | + list.push('*?enum_long'); | |
| 60 | + } else { | |
| 61 | + list.push("".concat(type, "?enum")); // array 默认使用list,array?enum 默认使用checkboxes,*?enum 默认使用select | |
| 62 | + | |
| 63 | + list.push('*?enum'); | |
| 64 | + } | |
| 65 | + } | |
| 66 | + | |
| 67 | + var _widget = widget || format; | |
| 68 | + | |
| 69 | + if (_widget) { | |
| 70 | + list.push("".concat(type, ":").concat(_widget)); | |
| 71 | + } | |
| 72 | + | |
| 73 | + list.push(type); // 放在最后兜底,其他都不match时使用type默认的组件 | |
| 74 | + | |
| 75 | + var found = ''; | |
| 76 | + list.some(function (item) { | |
| 77 | + found = _mapping[item]; | |
| 78 | + return !!found; | |
| 79 | + }); | |
| 80 | + return found; | |
| 81 | +} | |
| 82 | +export var extraSchemaList = { | |
| 83 | + checkbox: { | |
| 84 | + valuePropName: 'checked' | |
| 85 | + }, | |
| 86 | + switch: { | |
| 87 | + valuePropName: 'checked' | |
| 88 | + } | |
| 89 | +}; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/processData.js
renamed from
es/processData.js
| ... | ... | @@ -4,13 +4,12 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va |
| 4 | 4 | |
| 5 | 5 | function _defineProperty(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; } |
| 6 | 6 | |
| 7 | -import { removeEmptyItemFromList, cleanEmpty, removeHiddenFromResult } from './utils'; | |
| 8 | -import { unset, get, set } from 'lodash-es'; | |
| 9 | -import { isObject, clone } from './utils'; // 提交前需要先处理formData的逻辑 | |
| 7 | +import { get, set, unset } from 'lodash-es'; | |
| 8 | +import { cleanEmpty, clone, isObject, removeEmptyItemFromList, removeHiddenFromResult } from './utils'; // 提交前需要先处理formData的逻辑 | |
| 10 | 9 | |
| 11 | 10 | export var processData = function processData(data, flatten, removeHiddenData) { |
| 12 | - // 1. 去掉 hidden = true 的元素 | |
| 13 | - var _data = clone(data); | |
| 11 | + var _data = clone(data); // 1. 去掉 hidden = true 的元素 | |
| 12 | + | |
| 14 | 13 | |
| 15 | 14 | if (removeHiddenData) { |
| 16 | 15 | _data = removeHiddenFromResult(data, flatten); | ... | ... |
es/form-render-core/src/useDebounce.js
renamed from
es/useDebounce.js
es/form-render-core/src/useForm.js
renamed from
es/useForm.js
| ... | ... | @@ -25,12 +25,13 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy |
| 25 | 25 | function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } |
| 26 | 26 | |
| 27 | 27 | /* eslint-disable react-hooks/exhaustive-deps */ |
| 28 | -import { useEffect, useRef, useMemo, useState } from 'react'; | |
| 29 | -import { validateAll } from './validator'; | |
| 28 | +import { set, sortedUniqBy, get, isEmpty, isFunction } from 'lodash-es'; | |
| 29 | +import { useEffect, useMemo, useRef, useState } from 'react'; | |
| 30 | 30 | import { useSet } from './hooks'; |
| 31 | -import { set, sortedUniqBy } from 'lodash-es'; | |
| 32 | 31 | import { processData, transformDataWithBind2 } from './processData'; |
| 33 | -import { generateDataSkeleton, flattenSchema, clone, schemaContainsExpression, parseAllExpression } from './utils'; | |
| 32 | +import SmoothScroll from 'smooth-scroll'; | |
| 33 | +import { clone, flattenSchema, generateDataSkeleton, parseAllExpression, schemaContainsExpression, getHiddenData } from './utils'; | |
| 34 | +import { validateAll } from './validator'; | |
| 34 | 35 | |
| 35 | 36 | var useForm = function useForm(props) { |
| 36 | 37 | var _ref = props || {}, |
| ... | ... | @@ -69,7 +70,9 @@ var useForm = function useForm(props) { |
| 69 | 70 | // schema 的转换结构,便于处理 |
| 70 | 71 | finalFlatten: {}, |
| 71 | 72 | // 表达式等被处理过的flatten,用于渲染 |
| 72 | - firstMount: true | |
| 73 | + firstMount: true, | |
| 74 | + validatingFields: [] // 在校验状态的表单fields | |
| 75 | + | |
| 73 | 76 | }), |
| 74 | 77 | _useSet2 = _slicedToArray(_useSet, 2), |
| 75 | 78 | state = _useSet2[0], |
| ... | ... | @@ -100,6 +103,8 @@ var useForm = function useForm(props) { |
| 100 | 103 | var _allErrors = useRef([]); // 内部和外部的错误的合并 |
| 101 | 104 | |
| 102 | 105 | |
| 106 | + var _validatingFields = useRef([]); | |
| 107 | + | |
| 103 | 108 | var innerData = state.formData, |
| 104 | 109 | submitData = state.submitData, |
| 105 | 110 | _state$errorFields = state.errorFields, |
| ... | ... | @@ -176,20 +181,7 @@ var useForm = function useForm(props) { |
| 176 | 181 | setState({ |
| 177 | 182 | finalFlatten: newFlatten |
| 178 | 183 | }); |
| 179 | - }, [JSON.stringify(_flatten.current), JSON.stringify(_data.current), firstMount]); | |
| 180 | - useEffect(function () { | |
| 181 | - if (firstMount) return; | |
| 182 | - validateAll({ | |
| 183 | - formData: _data.current, | |
| 184 | - flatten: _finalFlatten.current, | |
| 185 | - isRequired: allTouched, | |
| 186 | - touchedKeys: _touchedKeys.current, | |
| 187 | - locale: localeRef.current, | |
| 188 | - validateMessages: validateMessagesRef.current | |
| 189 | - }).then(function (res) { | |
| 190 | - _setErrors(res); | |
| 191 | - }); | |
| 192 | - }, [JSON.stringify(_data.current)]); // All form methods are down here ---------------------------------------------------------------- | |
| 184 | + }, [JSON.stringify(_flatten.current), JSON.stringify(_data.current), firstMount]); // All form methods are down here ---------------------------------------------------------------- | |
| 193 | 185 | // 两个兼容 0.x 的函数 |
| 194 | 186 | |
| 195 | 187 | var _setData = function _setData(data) { |
| ... | ... | @@ -200,7 +192,8 @@ var useForm = function useForm(props) { |
| 200 | 192 | formData: data |
| 201 | 193 | }); |
| 202 | 194 | } |
| 203 | - }; | |
| 195 | + }; // Allow function to get the old value | |
| 196 | + | |
| 204 | 197 | |
| 205 | 198 | var _setErrors = function _setErrors(errors) { |
| 206 | 199 | if (typeof _onValidate === 'function') { |
| ... | ... | @@ -211,9 +204,18 @@ var useForm = function useForm(props) { |
| 211 | 204 | _onValidate(oldFormatErrors); |
| 212 | 205 | } |
| 213 | 206 | |
| 214 | - setState({ | |
| 215 | - errorFields: errors | |
| 216 | - }); | |
| 207 | + if (typeof errors === 'function') { | |
| 208 | + setState(function (_ref4) { | |
| 209 | + var errorFields = _ref4.errorFields; | |
| 210 | + return { | |
| 211 | + errorFields: errors(errorFields) | |
| 212 | + }; | |
| 213 | + }); | |
| 214 | + } else { | |
| 215 | + setState({ | |
| 216 | + errorFields: errors | |
| 217 | + }); | |
| 218 | + } | |
| 217 | 219 | }; |
| 218 | 220 | |
| 219 | 221 | var setFirstMount = function setFirstMount(value) { |
| ... | ... | @@ -228,6 +230,7 @@ var useForm = function useForm(props) { |
| 228 | 230 | } |
| 229 | 231 | |
| 230 | 232 | var newKeyList = [].concat(_toConsumableArray(_touchedKeys.current), [key]); |
| 233 | + _touchedKeys.current = newKeyList; | |
| 231 | 234 | setState({ |
| 232 | 235 | touchedKeys: newKeyList |
| 233 | 236 | }); |
| ... | ... | @@ -238,6 +241,7 @@ var useForm = function useForm(props) { |
| 238 | 241 | return item.indexOf(key) === -1; |
| 239 | 242 | }); |
| 240 | 243 | |
| 244 | + _touchedKeys.current = newTouch; | |
| 241 | 245 | setState({ |
| 242 | 246 | touchedKeys: newTouch |
| 243 | 247 | }); |
| ... | ... | @@ -272,12 +276,12 @@ var useForm = function useForm(props) { |
| 272 | 276 | // ] |
| 273 | 277 | |
| 274 | 278 | |
| 275 | - var syncStuff = function syncStuff(_ref4) { | |
| 276 | - var schema = _ref4.schema, | |
| 277 | - locale = _ref4.locale, | |
| 278 | - validateMessages = _ref4.validateMessages, | |
| 279 | - beforeFinish = _ref4.beforeFinish, | |
| 280 | - removeHiddenData = _ref4.removeHiddenData; | |
| 279 | + var syncStuff = function syncStuff(_ref5) { | |
| 280 | + var schema = _ref5.schema, | |
| 281 | + locale = _ref5.locale, | |
| 282 | + validateMessages = _ref5.validateMessages, | |
| 283 | + beforeFinish = _ref5.beforeFinish, | |
| 284 | + removeHiddenData = _ref5.removeHiddenData; | |
| 281 | 285 | schemaRef.current = schema; |
| 282 | 286 | localeRef.current = locale; |
| 283 | 287 | validateMessagesRef.current = validateMessages; |
| ... | ... | @@ -357,6 +361,7 @@ var useForm = function useForm(props) { |
| 357 | 361 | newErrorFields = sortedUniqBy(newErrorFields, function (item) { |
| 358 | 362 | return item.name; |
| 359 | 363 | }); |
| 364 | + _outErrorFields.current = newErrorFields; | |
| 360 | 365 | setState({ |
| 361 | 366 | outErrorFields: newErrorFields |
| 362 | 367 | }); |
| ... | ... | @@ -367,13 +372,69 @@ var useForm = function useForm(props) { |
| 367 | 372 | return item.name.indexOf(path) === -1; |
| 368 | 373 | }); |
| 369 | 374 | |
| 375 | + var newOutError = _outErrorFields.current.filter(function (item) { | |
| 376 | + return item.name.indexOf(path) === -1; | |
| 377 | + }); | |
| 378 | + | |
| 370 | 379 | setState({ |
| 371 | - outErrorFields: newError | |
| 380 | + errorFields: newError, | |
| 381 | + outErrorFields: newOutError | |
| 372 | 382 | }); |
| 373 | 383 | }; |
| 384 | + /** | |
| 385 | + * (nameList?: NamePath[], filterFunc?: (meta: { touched: boolean, validating: boolean }) => boolean) => any | |
| 386 | + * 参考rc-field-form中的getFieldsValue | |
| 387 | + * 如果第一个参数为数组类型,则获取nameList数据并且做filterFunc过滤 | |
| 388 | + * 如果第一个参数非数组类型,则获取所有数据并做filterFunc过滤 | |
| 389 | + * | |
| 390 | + * @returns | |
| 391 | + */ | |
| 392 | + | |
| 393 | + | |
| 394 | + var getValues = function getValues(nameList, filterFunc) { | |
| 395 | + var flatten = _finalFlatten.current; | |
| 396 | + var data = _data.current; | |
| 397 | + var currentData = {}; | |
| 398 | + var filterMetaKeys = []; // 当前符合filter条件的key | |
| 399 | + | |
| 400 | + if (Array.isArray(nameList)) { | |
| 401 | + nameList.forEach(function (path) { | |
| 402 | + set(currentData, path, get(data, path)); | |
| 403 | + }); | |
| 404 | + } else { | |
| 405 | + currentData = data; | |
| 406 | + } // 过滤出满足条件的path | |
| 407 | + | |
| 374 | 408 | |
| 375 | - var getValues = function getValues() { | |
| 376 | - return processData(_data.current, _finalFlatten.current, removeHiddenDataRef.current); | |
| 409 | + if (filterFunc && isFunction(filterFunc)) { | |
| 410 | + if (Array.isArray) { | |
| 411 | + flatten = {}; | |
| 412 | + nameList.forEach(function (path) { | |
| 413 | + flatten[path] = get(_finalFlatten.current, path); | |
| 414 | + }); | |
| 415 | + } | |
| 416 | + | |
| 417 | + var metas = {}; | |
| 418 | + Object.keys(flatten).forEach(function (key) { | |
| 419 | + metas[key] = { | |
| 420 | + touched: isFieldTouched(key), | |
| 421 | + validating: isFieldValidating(key) | |
| 422 | + }; | |
| 423 | + }); | |
| 424 | + filterMetaKeys = Object.keys(metas).filter(function (k) { | |
| 425 | + return filterFunc(metas[k]); | |
| 426 | + }); // 没有filter满足条件的就返回{} | |
| 427 | + | |
| 428 | + currentData = {}; | |
| 429 | + | |
| 430 | + if (!isEmpty(filterMetaKeys)) { | |
| 431 | + filterMetaKeys.forEach(function (key) { | |
| 432 | + set(currentData, key, get(data, key)); | |
| 433 | + }); | |
| 434 | + } | |
| 435 | + } | |
| 436 | + | |
| 437 | + return processData(currentData, _finalFlatten.current, removeHiddenDataRef.current); | |
| 377 | 438 | }; |
| 378 | 439 | |
| 379 | 440 | var setValues = function setValues(newFormData) { |
| ... | ... | @@ -392,10 +453,14 @@ var useForm = function useForm(props) { |
| 392 | 453 | return validateAll({ |
| 393 | 454 | formData: _data.current, |
| 394 | 455 | flatten: _finalFlatten.current, |
| 395 | - touchedKeys: [], | |
| 396 | - isRequired: true, | |
| 397 | - locale: localeRef.current, | |
| 398 | - validateMessages: validateMessagesRef.current | |
| 456 | + options: { | |
| 457 | + locale: localeRef.current, | |
| 458 | + validateMessages: validateMessagesRef.current | |
| 459 | + }, | |
| 460 | + formInstance: { | |
| 461 | + setFieldValidating: setFieldValidating, | |
| 462 | + removeFieldValidating: removeFieldValidating | |
| 463 | + } | |
| 399 | 464 | }).then(function (errors) { |
| 400 | 465 | setState({ |
| 401 | 466 | errorFields: errors |
| ... | ... | @@ -438,13 +503,13 @@ var useForm = function useForm(props) { |
| 438 | 503 | }); |
| 439 | 504 | }; |
| 440 | 505 | |
| 441 | - var resetFields = function resetFields() { | |
| 506 | + var resetFields = function resetFields(options) { | |
| 442 | 507 | setState({ |
| 443 | - formData: {}, | |
| 444 | - submitData: {}, | |
| 445 | - errorFields: [], | |
| 446 | - touchedKeys: [], | |
| 447 | - allTouched: false | |
| 508 | + formData: (options === null || options === void 0 ? void 0 : options.formData) || {}, | |
| 509 | + submitData: (options === null || options === void 0 ? void 0 : options.submitData) || {}, | |
| 510 | + errorFields: (options === null || options === void 0 ? void 0 : options.errorFields) || [], | |
| 511 | + touchedKeys: (options === null || options === void 0 ? void 0 : options.touchedKeys) || [], | |
| 512 | + allTouched: (options === null || options === void 0 ? void 0 : options.allTouched) || false | |
| 448 | 513 | }); |
| 449 | 514 | }; |
| 450 | 515 | |
| ... | ... | @@ -464,6 +529,187 @@ var useForm = function useForm(props) { |
| 464 | 529 | }); |
| 465 | 530 | }; |
| 466 | 531 | |
| 532 | + var setFieldValidating = function setFieldValidating(namePath) { | |
| 533 | + if (_validatingFields.current.indexOf(namePath) > -1) { | |
| 534 | + return; | |
| 535 | + } | |
| 536 | + | |
| 537 | + _validatingFields.current = [].concat(_toConsumableArray(_validatingFields.current), [namePath]); | |
| 538 | + }; | |
| 539 | + | |
| 540 | + var removeFieldValidating = function removeFieldValidating(namePath) { | |
| 541 | + _validatingFields.current = _validatingFields.current.filter(function (item) { | |
| 542 | + return item !== namePath; | |
| 543 | + }); | |
| 544 | + }; | |
| 545 | + | |
| 546 | + var isFieldValidating = function isFieldValidating(namePath) { | |
| 547 | + return _validatingFields.current.indexOf(namePath) > -1; | |
| 548 | + }; | |
| 549 | + /** | |
| 550 | + * 参考rc-field-form 校验不包含外部设置的error | |
| 551 | + * @param {*} nameList | |
| 552 | + * @returns | |
| 553 | + */ | |
| 554 | + | |
| 555 | + | |
| 556 | + var validateFields = function validateFields(nameList) { | |
| 557 | + var data = _data.current; | |
| 558 | + | |
| 559 | + if (Array.isArray(nameList)) { | |
| 560 | + set(data, {}); | |
| 561 | + nameList.forEach(function (path) { | |
| 562 | + set(data, path, get(_data.current, path)); | |
| 563 | + }); | |
| 564 | + } | |
| 565 | + | |
| 566 | + setState({ | |
| 567 | + isValidating: true | |
| 568 | + }); | |
| 569 | + return validateAll({ | |
| 570 | + formData: data, | |
| 571 | + flatten: _finalFlatten.current, | |
| 572 | + options: { | |
| 573 | + locale: localeRef.current, | |
| 574 | + validateMessages: validateMessagesRef.current | |
| 575 | + }, | |
| 576 | + formInstance: { | |
| 577 | + setFieldValidating: setFieldValidating, | |
| 578 | + removeFieldValidating: removeFieldValidating | |
| 579 | + } | |
| 580 | + }).then(function (errors) { | |
| 581 | + setState({ | |
| 582 | + isValidating: false, | |
| 583 | + errorFields: errors | |
| 584 | + }); | |
| 585 | + | |
| 586 | + if (!isEmpty(errors)) { | |
| 587 | + return Promise.reject({ | |
| 588 | + errors: errors, | |
| 589 | + data: processData(data, _finalFlatten.current, removeHiddenDataRef.current) | |
| 590 | + }); | |
| 591 | + } else { | |
| 592 | + return Promise.resolve(processData(data, _finalFlatten.current, removeHiddenDataRef.current)); | |
| 593 | + } | |
| 594 | + }); | |
| 595 | + }; | |
| 596 | + /** | |
| 597 | + * (nameList?: NamePath[], allTouched?: boolean) => boolean | |
| 598 | + * 参照antd rc-field-form的处理逻辑 | |
| 599 | + * 如果入参为空,则返回 是否有表单被触碰过 | |
| 600 | + * 如果参数为一个 | |
| 601 | + * 当args0 === Array,则返回当前表单list是否 >= 1个表单被触碰过 | |
| 602 | + * 否则,args0 ? 返回 是否‘所有’表单被触碰过 :是否有表单被触碰过 | |
| 603 | + * 如果参数为两个 | |
| 604 | + * args1 ? args0中的’所有‘表单都被触碰过: args0中的表单 >= 1个被触碰过 | |
| 605 | + * @returns | |
| 606 | + */ | |
| 607 | + | |
| 608 | + | |
| 609 | + function isFieldsTouched() { | |
| 610 | + var argsLen = arguments.length; | |
| 611 | + var namePathList = []; | |
| 612 | + var isAllFieldsTouched = false; | |
| 613 | + var allTouchedKeys = _touchedKeys.current; | |
| 614 | + | |
| 615 | + if (argsLen === 0) { | |
| 616 | + return _touchedKeys.current.length > 0; | |
| 617 | + } else if (argsLen === 1) { | |
| 618 | + if (Array.isArray(arguments[0])) { | |
| 619 | + namePathList = arguments[0]; | |
| 620 | + } else { | |
| 621 | + return arguments[0] ? allTouched : _touchedKeys.current.length > 0; | |
| 622 | + } | |
| 623 | + } else { | |
| 624 | + namePathList = Array.isArray(arguments[0]) ? arguments[0] : []; | |
| 625 | + isAllFieldsTouched = arguments[1]; | |
| 626 | + } | |
| 627 | + | |
| 628 | + try { | |
| 629 | + var touchedFunc = function touchedFunc(key) { | |
| 630 | + return allTouchedKeys.indexOf(key) !== -1; | |
| 631 | + }; | |
| 632 | + | |
| 633 | + return isAllFieldsTouched ? namePathList.every(touchedFunc) : namePathList.some(touchedFunc); | |
| 634 | + } catch (e) { | |
| 635 | + console.error('>>>> isFieldsTouched error, check your input arguments', e); | |
| 636 | + } | |
| 637 | + } | |
| 638 | + | |
| 639 | + var isFieldTouched = function isFieldTouched(namePath) { | |
| 640 | + return _touchedKeys.current.indexOf(namePath) > -1; | |
| 641 | + }; | |
| 642 | + | |
| 643 | + var scrollToPath = function scrollToPath(namePath) { | |
| 644 | + var scroll = new SmoothScroll(); | |
| 645 | + var node = document.querySelector("[datapath=\"".concat(namePath, "\"]")); | |
| 646 | + | |
| 647 | + if (node) { | |
| 648 | + scroll.animateScroll(node); | |
| 649 | + } | |
| 650 | + }; | |
| 651 | + | |
| 652 | + var getFieldError = function getFieldError(namePath) { | |
| 653 | + var _allErrors$current$fi; | |
| 654 | + | |
| 655 | + return ((_allErrors$current$fi = _allErrors.current.find(function (error) { | |
| 656 | + return error.name === namePath; | |
| 657 | + })) === null || _allErrors$current$fi === void 0 ? void 0 : _allErrors$current$fi.error) || []; | |
| 658 | + }; | |
| 659 | + | |
| 660 | + var getFieldsError = function getFieldsError(nameList) { | |
| 661 | + if (!nameList || !Array.isArray(nameList)) { | |
| 662 | + return _allErrors.current; | |
| 663 | + } | |
| 664 | + | |
| 665 | + return _allErrors.current.filter(function (error) { | |
| 666 | + return nameList.indexOf(error.name) > -1; | |
| 667 | + }); | |
| 668 | + }; | |
| 669 | + /** | |
| 670 | + * fields: {error?, name, touched?, validating?, value?} | |
| 671 | + * 参照rc-field-form的实现逻辑 | |
| 672 | + * @param {*} fields | |
| 673 | + * 设置一组字段状态 | |
| 674 | + */ | |
| 675 | + | |
| 676 | + | |
| 677 | + var setFields = function setFields(fields) { | |
| 678 | + // 设置error调用统一的函数,直接设置数组,省去forEach频繁操作 | |
| 679 | + var errors = fields.filter(function (field) { | |
| 680 | + return field.error; | |
| 681 | + }).map(function (field) { | |
| 682 | + return { | |
| 683 | + name: field.name, | |
| 684 | + error: field.error | |
| 685 | + }; | |
| 686 | + }); | |
| 687 | + !isEmpty(errors) && setErrorFields(errors); // 对 value, touched, validating进行设置 | |
| 688 | + | |
| 689 | + fields.forEach(function (field) { | |
| 690 | + var name = field.name, | |
| 691 | + value = field.value, | |
| 692 | + touched = field.touched, | |
| 693 | + validating = field.validating; | |
| 694 | + | |
| 695 | + if ('value' in field) { | |
| 696 | + onItemChange(name, value); | |
| 697 | + } | |
| 698 | + | |
| 699 | + if (typeof touched === 'boolean') { | |
| 700 | + touched ? touchKey(name) : removeTouched(name); | |
| 701 | + } | |
| 702 | + | |
| 703 | + if (typeof validating === 'boolean') { | |
| 704 | + validating ? setFieldValidating(name) : removeFieldValidating(name); | |
| 705 | + } | |
| 706 | + }); | |
| 707 | + }; | |
| 708 | + | |
| 709 | + var getHiddenValues = function getHiddenValues() { | |
| 710 | + return getHiddenData(_data.current, _finalFlatten.current); | |
| 711 | + }; | |
| 712 | + | |
| 467 | 713 | var form = { |
| 468 | 714 | // state |
| 469 | 715 | formData: _data.current, |
| ... | ... | @@ -483,6 +729,7 @@ var useForm = function useForm(props) { |
| 483 | 729 | setSchema: setSchema, |
| 484 | 730 | setValues: setValues, |
| 485 | 731 | getValues: getValues, |
| 732 | + getHiddenValues: getHiddenValues, | |
| 486 | 733 | resetFields: resetFields, |
| 487 | 734 | submit: submit, |
| 488 | 735 | init: submit, |
| ... | ... | @@ -500,11 +747,23 @@ var useForm = function useForm(props) { |
| 500 | 747 | setEditing: setEditing, |
| 501 | 748 | syncStuff: syncStuff, |
| 502 | 749 | showValidate: _showValidate, |
| 750 | + validateFields: validateFields, | |
| 751 | + isFieldTouched: isFieldTouched, | |
| 752 | + isFieldsTouched: isFieldsTouched, | |
| 753 | + setFieldValidating: setFieldValidating, | |
| 754 | + removeFieldValidating: removeFieldValidating, | |
| 755 | + isFieldValidating: isFieldValidating, | |
| 756 | + scrollToPath: scrollToPath, | |
| 757 | + getFieldError: getFieldError, | |
| 758 | + getFieldsError: getFieldsError, | |
| 759 | + setFields: setFields, | |
| 503 | 760 | // firstMount, |
| 504 | 761 | setFirstMount: setFirstMount, |
| 505 | 762 | // logs |
| 506 | 763 | logOnMount: logOnMount, |
| 507 | - logOnSubmit: logOnSubmit | |
| 764 | + logOnSubmit: logOnSubmit, | |
| 765 | + // inner api, DON'T USE | |
| 766 | + _setErrors: _setErrors | |
| 508 | 767 | }; |
| 509 | 768 | return form; |
| 510 | 769 | }; | ... | ... |
es/form-render-core/src/utils.js
0 → 100644
| 1 | +var _excluded = ["propsSchema"], | |
| 2 | + _excluded2 = ["schema"]; | |
| 3 | + | |
| 4 | +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } | |
| 5 | + | |
| 6 | +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 7 | + | |
| 8 | +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } | |
| 9 | + | |
| 10 | +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } | |
| 11 | + | |
| 12 | +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } | |
| 13 | + | |
| 14 | +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } | |
| 15 | + | |
| 16 | +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } | |
| 17 | + | |
| 18 | +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } | |
| 19 | + | |
| 20 | +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } | |
| 21 | + | |
| 22 | +function _defineProperty(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; } | |
| 23 | + | |
| 24 | +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } | |
| 25 | + | |
| 26 | +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } | |
| 27 | + | |
| 28 | +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(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(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } | |
| 29 | + | |
| 30 | +function _arrayLikeToArray(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; } | |
| 31 | + | |
| 32 | +function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } | |
| 33 | + | |
| 34 | +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } | |
| 35 | + | |
| 36 | +import { cloneDeep, get, isEmpty, set } from 'lodash-es'; | |
| 37 | +export function getParamByName(name) { | |
| 38 | + var url = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : window.location.href; | |
| 39 | + name = name.replace(/[\[\]]/g, '\\$&'); | |
| 40 | + var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)'), | |
| 41 | + results = regex.exec(url); | |
| 42 | + if (!results) return null; | |
| 43 | + if (!results[2]) return ''; | |
| 44 | + return decodeURIComponent(results[2].replace(/\+/g, ' ')); | |
| 45 | +} // export function isUrl(string) { | |
| 46 | +// const protocolRE = /^(?:\w+:)?\/\/(\S+)$/; | |
| 47 | +// // const domainRE = /^[^\s\.]+\.\S{2,}$/; | |
| 48 | +// if (typeof string !== 'string') return false; | |
| 49 | +// return protocolRE.test(string); | |
| 50 | +// } | |
| 51 | + | |
| 52 | +export function isCheckBoxType(schema, readOnly) { | |
| 53 | + if (readOnly) return false; | |
| 54 | + if (schema.widget === 'checkbox') return true; | |
| 55 | + | |
| 56 | + if (schema && schema.type === 'boolean') { | |
| 57 | + if (schema.enum) return false; | |
| 58 | + if (schema.widget === undefined) return true; | |
| 59 | + return false; | |
| 60 | + } | |
| 61 | +} // a[].b.c => a.b.c | |
| 62 | + | |
| 63 | +function removeBrackets(string) { | |
| 64 | + if (typeof string === 'string') { | |
| 65 | + return string.replace(/\[\]/g, ''); | |
| 66 | + } else { | |
| 67 | + return string; | |
| 68 | + } | |
| 69 | +} | |
| 70 | + | |
| 71 | +export function getParentPath(path) { | |
| 72 | + if (typeof path === 'string') { | |
| 73 | + var pathArr = path.split('.'); | |
| 74 | + | |
| 75 | + if (pathArr.length === 1) { | |
| 76 | + return '#'; | |
| 77 | + } | |
| 78 | + | |
| 79 | + pathArr.pop(); | |
| 80 | + return pathArr.join('.'); | |
| 81 | + } | |
| 82 | + | |
| 83 | + return '#'; | |
| 84 | +} | |
| 85 | +export function getValueByPath(formData, path) { | |
| 86 | + if (path === '#' || !path) { | |
| 87 | + return formData || {}; | |
| 88 | + } else if (typeof path === 'string') { | |
| 89 | + return get(formData, path); | |
| 90 | + } else { | |
| 91 | + console.error('path has to be a string'); | |
| 92 | + } | |
| 93 | +} // path: 'a.b[1].c[0]' => { id: 'a.b[].c[]' dataIndex: [1,0] } | |
| 94 | + | |
| 95 | +export function destructDataPath(path) { | |
| 96 | + var id; | |
| 97 | + var dataIndex; | |
| 98 | + | |
| 99 | + if (path === '#') { | |
| 100 | + return { | |
| 101 | + id: '#', | |
| 102 | + dataIndex: [] | |
| 103 | + }; | |
| 104 | + } | |
| 105 | + | |
| 106 | + if (typeof path !== 'string') { | |
| 107 | + throw Error("path ".concat(path, " is not a string!!! Something wrong here")); | |
| 108 | + } | |
| 109 | + | |
| 110 | + var pattern = /\[[0-9]+\]/g; | |
| 111 | + var matchList = path.match(pattern); | |
| 112 | + | |
| 113 | + if (!matchList) { | |
| 114 | + id = path; | |
| 115 | + } else { | |
| 116 | + id = path.replace(pattern, '[]'); // 这个是match下来的结果,可安全处理 | |
| 117 | + | |
| 118 | + dataIndex = matchList.map(function (item) { | |
| 119 | + return Number(item.substring(1, item.length - 1)); | |
| 120 | + }); | |
| 121 | + } | |
| 122 | + | |
| 123 | + return { | |
| 124 | + id: id, | |
| 125 | + dataIndex: dataIndex | |
| 126 | + }; | |
| 127 | +} // id: 'a.b[].c[]' dataIndex: [1,0] => 'a.b[1].c[0]' | |
| 128 | + | |
| 129 | +export function getDataPath(id, dataIndex) { | |
| 130 | + if (id === '#') { | |
| 131 | + return id; | |
| 132 | + } | |
| 133 | + | |
| 134 | + if (typeof id !== 'string') { | |
| 135 | + throw Error("id ".concat(id, " is not a string!!! Something wrong here")); | |
| 136 | + } | |
| 137 | + | |
| 138 | + var _id = id; | |
| 139 | + | |
| 140 | + if (Array.isArray(dataIndex)) { | |
| 141 | + // const matches = id.match(/\[\]/g) || []; | |
| 142 | + // const count = matches.length; | |
| 143 | + dataIndex.forEach(function (item) { | |
| 144 | + _id = _id.replace(/\[\]/, "[".concat(item, "]")); | |
| 145 | + }); | |
| 146 | + } | |
| 147 | + | |
| 148 | + return removeBrackets(_id); | |
| 149 | +} | |
| 150 | +export function isObjType(schema) { | |
| 151 | + return schema && schema.type === 'object' && schema.properties && !schema.widget; | |
| 152 | +} | |
| 153 | +export function isBlockType(schema) { | |
| 154 | + return schema && schema.type === 'block' && schema.widget; | |
| 155 | +} // TODO: to support case that item is not an object | |
| 156 | + | |
| 157 | +export function isListType(schema) { | |
| 158 | + return schema && schema.type === 'array' && isObjType(schema.items) && schema.enum === undefined; | |
| 159 | +} | |
| 160 | +export function orderProperties(properties) { | |
| 161 | + var orderKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'order'; | |
| 162 | + var orderHash = new Map(); // order不为数字的数据 | |
| 163 | + | |
| 164 | + var unsortedList = []; | |
| 165 | + | |
| 166 | + var insert = function insert(item) { | |
| 167 | + var _item = _slicedToArray(item, 2), | |
| 168 | + value = _item[1]; | |
| 169 | + | |
| 170 | + if (typeof value[orderKey] !== 'number') { | |
| 171 | + unsortedList.push(item); | |
| 172 | + return; | |
| 173 | + } | |
| 174 | + | |
| 175 | + if (orderHash.has(value[orderKey])) { | |
| 176 | + orderHash.get(value[orderKey]).push(item); | |
| 177 | + } else { | |
| 178 | + orderHash.set(value[orderKey], [item]); | |
| 179 | + } | |
| 180 | + }; | |
| 181 | + | |
| 182 | + properties.forEach(function (item) { | |
| 183 | + return insert(item); | |
| 184 | + }); | |
| 185 | + var sortedList = Array.from(orderHash.entries()).sort(function (_ref, _ref2) { | |
| 186 | + var _ref3 = _slicedToArray(_ref, 1), | |
| 187 | + order1 = _ref3[0]; | |
| 188 | + | |
| 189 | + var _ref4 = _slicedToArray(_ref2, 1), | |
| 190 | + order2 = _ref4[0]; | |
| 191 | + | |
| 192 | + return order1 - order2; | |
| 193 | + }) // order值越小越靠前 | |
| 194 | + .flatMap(function (_ref5) { | |
| 195 | + var _ref6 = _slicedToArray(_ref5, 2), | |
| 196 | + items = _ref6[1]; | |
| 197 | + | |
| 198 | + return items; | |
| 199 | + }); | |
| 200 | + return sortedList.concat(unsortedList); | |
| 201 | +} // TODO: more tests to make sure weird & wrong schema won't crush | |
| 202 | + | |
| 203 | +export function flattenSchema() { | |
| 204 | + var _schema = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | |
| 205 | + | |
| 206 | + var name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '#'; | |
| 207 | + var parent = arguments.length > 2 ? arguments[2] : undefined; | |
| 208 | + var result = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; | |
| 209 | + // 排序 | |
| 210 | + // _schema = orderBy(_schema, item => item.order, ['asc']); | |
| 211 | + var schema = clone(_schema); | |
| 212 | + var _name = name; | |
| 213 | + | |
| 214 | + if (!schema.$id) { | |
| 215 | + schema.$id = _name; // path as $id, for easy access to path in schema | |
| 216 | + } | |
| 217 | + | |
| 218 | + var children = []; | |
| 219 | + | |
| 220 | + if (isObjType(schema)) { | |
| 221 | + orderProperties(Object.entries(schema.properties)).forEach(function (_ref7) { | |
| 222 | + var _ref8 = _slicedToArray(_ref7, 2), | |
| 223 | + key = _ref8[0], | |
| 224 | + value = _ref8[1]; | |
| 225 | + | |
| 226 | + var _key = isListType(value) ? key + '[]' : key; | |
| 227 | + | |
| 228 | + var uniqueName = _name === '#' ? _key : _name + '.' + _key; | |
| 229 | + children.push(uniqueName); | |
| 230 | + flattenSchema(value, uniqueName, _name, result); | |
| 231 | + }); | |
| 232 | + schema.properties = {}; | |
| 233 | + } | |
| 234 | + | |
| 235 | + if (isListType(schema)) { | |
| 236 | + orderProperties(Object.entries(schema.items.properties)).forEach(function (_ref9) { | |
| 237 | + var _ref10 = _slicedToArray(_ref9, 2), | |
| 238 | + key = _ref10[0], | |
| 239 | + value = _ref10[1]; | |
| 240 | + | |
| 241 | + var _key = isListType(value) ? key + '[]' : key; | |
| 242 | + | |
| 243 | + var uniqueName = _name === '#' ? _key : _name + '.' + _key; | |
| 244 | + children.push(uniqueName); | |
| 245 | + flattenSchema(value, uniqueName, _name, result); | |
| 246 | + }); | |
| 247 | + schema.items.properties = {}; | |
| 248 | + } | |
| 249 | + | |
| 250 | + if (schema.type) { | |
| 251 | + result[_name] = { | |
| 252 | + parent: parent, | |
| 253 | + schema: schema, | |
| 254 | + children: children | |
| 255 | + }; | |
| 256 | + } | |
| 257 | + | |
| 258 | + return result; | |
| 259 | +} | |
| 260 | +export function getSchemaFromFlatten(flatten) { | |
| 261 | + var path = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '#'; | |
| 262 | + var schema = {}; | |
| 263 | + var item = clone(flatten[path]); | |
| 264 | + | |
| 265 | + if (item) { | |
| 266 | + schema = item.schema; // schema.$id && delete schema.$id; | |
| 267 | + | |
| 268 | + if (item.children.length > 0) { | |
| 269 | + item.children.forEach(function (child) { | |
| 270 | + if (!flatten[child]) return; | |
| 271 | + var key = getKeyFromPath(child); | |
| 272 | + | |
| 273 | + if (isObjType(schema)) { | |
| 274 | + schema.properties[key] = getSchemaFromFlatten(flatten, child); | |
| 275 | + } | |
| 276 | + | |
| 277 | + if (isListType(schema)) { | |
| 278 | + schema.items.properties[key] = getSchemaFromFlatten(flatten, child); | |
| 279 | + } | |
| 280 | + }); | |
| 281 | + } | |
| 282 | + } | |
| 283 | + | |
| 284 | + return schema; | |
| 285 | +} | |
| 286 | + | |
| 287 | +function stringContains(str, text) { | |
| 288 | + return str.indexOf(text) > -1; | |
| 289 | +} | |
| 290 | + | |
| 291 | +export var isObject = function isObject(a) { | |
| 292 | + return stringContains(Object.prototype.toString.call(a), 'Object'); | |
| 293 | +}; | |
| 294 | +export var clone = cloneDeep; // '3' => true, 3 => true, undefined => false | |
| 295 | + | |
| 296 | +export function isLooselyNumber(num) { | |
| 297 | + if (typeof num === 'number') return true; | |
| 298 | + | |
| 299 | + if (typeof num === 'string') { | |
| 300 | + return !Number.isNaN(Number(num)); | |
| 301 | + } | |
| 302 | + | |
| 303 | + return false; | |
| 304 | +} | |
| 305 | +export function isCssLength(str) { | |
| 306 | + if (typeof str !== 'string') return false; | |
| 307 | + return str.match(/^([0-9])*(%|px|rem|em)$/i); | |
| 308 | +} | |
| 309 | +export function isDeepEqual(param1, param2) { | |
| 310 | + if (param1 === undefined && param2 === undefined) return true;else if (param1 === undefined || param2 === undefined) return false; | |
| 311 | + if (param1 === null && param2 === null) return true;else if (param1 === null || param2 === null) return false;else if (param1.constructor !== param2.constructor) return false; | |
| 312 | + | |
| 313 | + if (param1.constructor === Array) { | |
| 314 | + if (param1.length !== param2.length) return false; | |
| 315 | + | |
| 316 | + for (var i = 0; i < param1.length; i++) { | |
| 317 | + if (param1[i].constructor === Array || param1[i].constructor === Object) { | |
| 318 | + if (!isDeepEqual(param1[i], param2[i])) return false; | |
| 319 | + } else if (param1[i] !== param2[i]) return false; | |
| 320 | + } | |
| 321 | + } else if (param1.constructor === Object) { | |
| 322 | + if (Object.keys(param1).length !== Object.keys(param2).length) return false; | |
| 323 | + | |
| 324 | + for (var _i2 = 0; _i2 < Object.keys(param1).length; _i2++) { | |
| 325 | + var key = Object.keys(param1)[_i2]; | |
| 326 | + | |
| 327 | + if (param1[key] && typeof param1[key] !== 'number' && (param1[key].constructor === Array || param1[key].constructor === Object)) { | |
| 328 | + if (!isDeepEqual(param1[key], param2[key])) return false; | |
| 329 | + } else if (param1[key] !== param2[key]) return false; | |
| 330 | + } | |
| 331 | + } else if (param1.constructor === String || param1.constructor === Number) { | |
| 332 | + return param1 === param2; | |
| 333 | + } | |
| 334 | + | |
| 335 | + return true; | |
| 336 | +} // export function getFormat(format) { | |
| 337 | +// let dateFormat; | |
| 338 | +// switch (format) { | |
| 339 | +// case 'date': | |
| 340 | +// dateFormat = 'YYYY-MM-DD'; | |
| 341 | +// break; | |
| 342 | +// case 'time': | |
| 343 | +// dateFormat = 'HH:mm:ss'; | |
| 344 | +// break; | |
| 345 | +// case 'dateTime': | |
| 346 | +// dateFormat = 'YYYY-MM-DD HH:mm:ss'; | |
| 347 | +// break; | |
| 348 | +// case 'week': | |
| 349 | +// dateFormat = 'YYYY-w'; | |
| 350 | +// break; | |
| 351 | +// case 'year': | |
| 352 | +// dateFormat = 'YYYY'; | |
| 353 | +// break; | |
| 354 | +// case 'quarter': | |
| 355 | +// dateFormat = 'YYYY-Q'; | |
| 356 | +// break; | |
| 357 | +// case 'month': | |
| 358 | +// dateFormat = 'YYYY-MM'; | |
| 359 | +// break; | |
| 360 | +// default: | |
| 361 | +// // dateTime | |
| 362 | +// if (typeof format === 'string') { | |
| 363 | +// dateFormat = format; | |
| 364 | +// } else { | |
| 365 | +// dateFormat = 'YYYY-MM-DD'; | |
| 366 | +// } | |
| 367 | +// } | |
| 368 | +// return dateFormat; | |
| 369 | +// } | |
| 370 | + | |
| 371 | +export function hasRepeat(list) { | |
| 372 | + return list.find(function (x, i, self) { | |
| 373 | + return i !== self.findIndex(function (y) { | |
| 374 | + return JSON.stringify(x) === JSON.stringify(y); | |
| 375 | + }); | |
| 376 | + }); | |
| 377 | +} | |
| 378 | +export function combineSchema() { | |
| 379 | + var propsSchema = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | |
| 380 | + var uiSchema = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; | |
| 381 | + var propList = getChildren(propsSchema); | |
| 382 | + var newList = propList.map(function (p) { | |
| 383 | + var name = p.name; | |
| 384 | + var _p$schema = p.schema, | |
| 385 | + type = _p$schema.type, | |
| 386 | + options = _p$schema.enum, | |
| 387 | + properties = _p$schema.properties, | |
| 388 | + items = _p$schema.items; | |
| 389 | + var isObj = type === 'object' && properties; | |
| 390 | + var isArr = type === 'array' && items && !options; // enum + array 代表的多选框,没有sub | |
| 391 | + | |
| 392 | + var ui = name && uiSchema[p.name]; | |
| 393 | + | |
| 394 | + if (!ui) { | |
| 395 | + return p; | |
| 396 | + } // 如果是list,递归合并items | |
| 397 | + | |
| 398 | + | |
| 399 | + if (isArr) { | |
| 400 | + var newItems = combineSchema(items, ui.items || {}); | |
| 401 | + return _objectSpread(_objectSpread({}, p), {}, { | |
| 402 | + schema: _objectSpread(_objectSpread(_objectSpread({}, p.schema), ui), {}, { | |
| 403 | + items: newItems | |
| 404 | + }) | |
| 405 | + }); | |
| 406 | + } // object递归合并整个schema | |
| 407 | + | |
| 408 | + | |
| 409 | + if (isObj) { | |
| 410 | + var newSchema = combineSchema(p.schema, ui); | |
| 411 | + return _objectSpread(_objectSpread({}, p), {}, { | |
| 412 | + schema: newSchema | |
| 413 | + }); | |
| 414 | + } | |
| 415 | + | |
| 416 | + return _objectSpread(_objectSpread({}, p), {}, { | |
| 417 | + schema: _objectSpread(_objectSpread({}, p.schema), ui) | |
| 418 | + }); | |
| 419 | + }); | |
| 420 | + var newObj = {}; | |
| 421 | + newList.forEach(function (s) { | |
| 422 | + newObj[s.name] = s.schema; | |
| 423 | + }); | |
| 424 | + var topLevelUi = {}; | |
| 425 | + Object.keys(uiSchema).forEach(function (key) { | |
| 426 | + if (typeof key === 'string' && key.substring(0, 3) === 'ui:') { | |
| 427 | + topLevelUi[key] = uiSchema[key]; | |
| 428 | + } | |
| 429 | + }); | |
| 430 | + | |
| 431 | + if (isEmpty(newObj)) { | |
| 432 | + return _objectSpread(_objectSpread({}, propsSchema), topLevelUi); | |
| 433 | + } | |
| 434 | + | |
| 435 | + return _objectSpread(_objectSpread(_objectSpread({}, propsSchema), topLevelUi), {}, { | |
| 436 | + properties: newObj | |
| 437 | + }); | |
| 438 | +} // export function isEmpty(obj) { | |
| 439 | +// return Object.keys(obj).length === 0; | |
| 440 | +// } | |
| 441 | + | |
| 442 | +function getChildren(schema) { | |
| 443 | + if (!schema) return []; | |
| 444 | + var properties = schema.properties, | |
| 445 | + items = schema.items, | |
| 446 | + type = schema.type; | |
| 447 | + | |
| 448 | + if (!properties && !items) { | |
| 449 | + return []; | |
| 450 | + } | |
| 451 | + | |
| 452 | + var schemaSubs = {}; | |
| 453 | + | |
| 454 | + if (type === 'object') { | |
| 455 | + schemaSubs = properties; | |
| 456 | + } | |
| 457 | + | |
| 458 | + if (type === 'array') { | |
| 459 | + schemaSubs = items; | |
| 460 | + } | |
| 461 | + | |
| 462 | + return Object.keys(schemaSubs).map(function (name) { | |
| 463 | + return { | |
| 464 | + schema: schemaSubs[name], | |
| 465 | + name: name | |
| 466 | + }; | |
| 467 | + }); | |
| 468 | +} | |
| 469 | + | |
| 470 | +export var parseString = function parseString(string) { | |
| 471 | + return Function('"use strict";return (' + string + ')')(); | |
| 472 | +}; | |
| 473 | +export var evaluateString = function evaluateString(string, formData, rootValue) { | |
| 474 | + return Function("\"use strict\";\n const rootValue = ".concat(JSON.stringify(rootValue), ";\n const formData = ").concat(JSON.stringify(formData), ";\n return (").concat(string, ")"))(); | |
| 475 | +}; | |
| 476 | +export function isExpression(func) { | |
| 477 | + // if (typeof func === 'function') { | |
| 478 | + // const funcString = func.toString(); | |
| 479 | + // return ( | |
| 480 | + // funcString.indexOf('formData') > -1 || | |
| 481 | + // funcString.indexOf('rootValue') > -1 | |
| 482 | + // ); | |
| 483 | + // } | |
| 484 | + if (typeof func !== 'string') return false; | |
| 485 | + var pattern = /^{{(.+)}}$/; | |
| 486 | + var reg1 = /^{{function\(.+}}$/; // const reg2 = /^{{(.+=>.+)}}$/; | |
| 487 | + | |
| 488 | + if (typeof func === 'string' && func.match(pattern) && !func.match(reg1)) { | |
| 489 | + return true; | |
| 490 | + } | |
| 491 | + | |
| 492 | + return false; | |
| 493 | +} | |
| 494 | +export var parseRootValueInSchema = function parseRootValueInSchema(schema, rootValue) { | |
| 495 | + var result = clone(schema); | |
| 496 | + | |
| 497 | + if (isObject(schema)) { | |
| 498 | + Object.keys(schema).forEach(function (key) { | |
| 499 | + var item = schema[key]; | |
| 500 | + | |
| 501 | + if (isObject(item)) { | |
| 502 | + result[key] = parseRootValueInSchema(item, rootValue); | |
| 503 | + } else if (typeof item === 'string') { | |
| 504 | + result[key] = parseSingleRootValue(item, rootValue); | |
| 505 | + } | |
| 506 | + }); | |
| 507 | + } else { | |
| 508 | + console.error('schema is not an object:', schema); | |
| 509 | + } | |
| 510 | + | |
| 511 | + return result; | |
| 512 | +}; // handle rootValue inside List | |
| 513 | + | |
| 514 | +export var parseSingleRootValue = function parseSingleRootValue(expression) { | |
| 515 | + var rootValue = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; | |
| 516 | + | |
| 517 | + if (typeof expression === 'string' && expression.indexOf('rootValue') > 0) { | |
| 518 | + var funcBody = expression.substring(2, expression.length - 2); | |
| 519 | + var str = "\n return ".concat(funcBody.replace(/rootValue/g, JSON.stringify(rootValue))); | |
| 520 | + | |
| 521 | + try { | |
| 522 | + return Function(str)(); | |
| 523 | + } catch (error) { | |
| 524 | + console.error(error, 'expression:', expression, 'rootValue:', rootValue); | |
| 525 | + return null; // 如果计算有错误,return null 最合适 | |
| 526 | + } | |
| 527 | + } else { | |
| 528 | + return expression; | |
| 529 | + } | |
| 530 | +}; | |
| 531 | +export function parseSingleExpression(func) { | |
| 532 | + var formData = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; | |
| 533 | + var dataPath = arguments.length > 2 ? arguments[2] : undefined; | |
| 534 | + var parentPath = getParentPath(dataPath); | |
| 535 | + var parent = getValueByPath(formData, parentPath) || {}; | |
| 536 | + | |
| 537 | + if (typeof func === 'string') { | |
| 538 | + var funcBody = func.substring(2, func.length - 2); | |
| 539 | + var str = "\n return ".concat(funcBody.replace(/formData/g, JSON.stringify(formData)).replace(/rootValue/g, JSON.stringify(parent))); | |
| 540 | + | |
| 541 | + try { | |
| 542 | + return Function(str)(); | |
| 543 | + } catch (error) { | |
| 544 | + console.log(error, func, dataPath); | |
| 545 | + return null; // 如果计算有错误,return null 最合适 | |
| 546 | + } // const funcBody = func.substring(2, func.length - 2); | |
| 547 | + // //TODO: 这样有问题,例如 a.b.indexOf(), 会把 a.b.indexOf 当做值 | |
| 548 | + // const match1 = /formData.([a-zA-Z0-9.$_\[\]]+)/g; | |
| 549 | + // const match2 = /rootValue.([a-zA-Z0-9.$_\[\]]+)/g; | |
| 550 | + // const str = ` | |
| 551 | + // return (${funcBody | |
| 552 | + // .replaceAll(match1, (v, m1) => | |
| 553 | + // JSON.stringify(getValueByPath(formData, m1)) | |
| 554 | + // ) | |
| 555 | + // .replaceAll(match2, (v, m1) => | |
| 556 | + // JSON.stringify(getValueByPath(parent, m1)) | |
| 557 | + // )})`; | |
| 558 | + // try { | |
| 559 | + // return Function(str)(); | |
| 560 | + // } catch (error) { | |
| 561 | + // console.log(error); | |
| 562 | + // return func; | |
| 563 | + // } | |
| 564 | + | |
| 565 | + } else return func; | |
| 566 | +} | |
| 567 | +export var schemaContainsExpression = function schemaContainsExpression(schema) { | |
| 568 | + if (isObject(schema)) { | |
| 569 | + return Object.keys(schema).some(function (key) { | |
| 570 | + var value = schema[key]; | |
| 571 | + | |
| 572 | + if (typeof value === 'string') { | |
| 573 | + return isExpression(value); | |
| 574 | + } else if (isObject(value)) { | |
| 575 | + return schemaContainsExpression(value); | |
| 576 | + } else { | |
| 577 | + return false; | |
| 578 | + } | |
| 579 | + }); | |
| 580 | + } | |
| 581 | + | |
| 582 | + return false; | |
| 583 | +}; | |
| 584 | +export var parseAllExpression = function parseAllExpression(_schema, formData, dataPath) { | |
| 585 | + var schema = clone(_schema); | |
| 586 | + Object.keys(schema).forEach(function (key) { | |
| 587 | + var value = schema[key]; | |
| 588 | + | |
| 589 | + if (isObject(value)) { | |
| 590 | + schema[key] = parseAllExpression(value, formData, dataPath); | |
| 591 | + } else if (isExpression(value)) { | |
| 592 | + schema[key] = parseSingleExpression(value, formData, dataPath); | |
| 593 | + } else if (typeof key === 'string' && key.toLowerCase().indexOf('props') > -1) { | |
| 594 | + // 有可能叫 xxxProps | |
| 595 | + var propsObj = schema[key]; | |
| 596 | + | |
| 597 | + if (isObject(propsObj)) { | |
| 598 | + Object.keys(propsObj).forEach(function (k) { | |
| 599 | + schema[key][k] = parseSingleExpression(propsObj[k], formData, dataPath); | |
| 600 | + }); | |
| 601 | + } | |
| 602 | + } | |
| 603 | + }); | |
| 604 | + return schema; | |
| 605 | +}; | |
| 606 | +export function isFunctionSchema(schema) { | |
| 607 | + return Object.keys(schema).some(function (key) { | |
| 608 | + if (typeof schema[key] === 'function') { | |
| 609 | + return true; | |
| 610 | + } else if (typeof schema[key] === 'string') { | |
| 611 | + return isExpression(schema[key]); | |
| 612 | + } else if (_typeof(schema[key]) === 'object') { | |
| 613 | + return isFunctionSchema(schema[key]); | |
| 614 | + } else { | |
| 615 | + return false; | |
| 616 | + } | |
| 617 | + }); | |
| 618 | +} | |
| 619 | +export var getParentProps = function getParentProps(propName, id, flatten) { | |
| 620 | + try { | |
| 621 | + var item = flatten[id]; | |
| 622 | + if (item.schema[propName] !== undefined) return item.schema[propName]; | |
| 623 | + | |
| 624 | + if (item && item.parent) { | |
| 625 | + var parentSchema = flatten[item.parent].schema; | |
| 626 | + | |
| 627 | + if (parentSchema[propName] !== undefined) { | |
| 628 | + return parentSchema[propName]; | |
| 629 | + } else { | |
| 630 | + return getParentProps(propName, item.parent, flatten); | |
| 631 | + } | |
| 632 | + } | |
| 633 | + } catch (error) { | |
| 634 | + return undefined; | |
| 635 | + } | |
| 636 | +}; | |
| 637 | +export var getSaveNumber = function getSaveNumber() { | |
| 638 | + var searchStr = localStorage.getItem('SAVES'); | |
| 639 | + | |
| 640 | + if (searchStr) { | |
| 641 | + try { | |
| 642 | + var saves = JSON.parse(searchStr); | |
| 643 | + var length = saves.length; | |
| 644 | + if (length) return length + 1; | |
| 645 | + } catch (error) { | |
| 646 | + return 1; | |
| 647 | + } | |
| 648 | + } else { | |
| 649 | + return 1; | |
| 650 | + } | |
| 651 | +}; | |
| 652 | +export function looseJsonParse(obj) { | |
| 653 | + return Function('"use strict";return (' + obj + ')')(); | |
| 654 | +} | |
| 655 | +export var isFunctionString = function isFunctionString(fString) { | |
| 656 | + return typeof fString === 'string' && fString.indexOf('function(') === 0; | |
| 657 | +}; | |
| 658 | +export function parseFunction(fString) { | |
| 659 | + if (isFunctionString(fString)) { | |
| 660 | + return Function('return ' + fString)(); | |
| 661 | + } | |
| 662 | + | |
| 663 | + return fString; | |
| 664 | +} // 获得propsSchema的children | |
| 665 | +// function getChildren2(schema) { | |
| 666 | +// if (!schema) return []; | |
| 667 | +// const { | |
| 668 | +// // object | |
| 669 | +// properties, | |
| 670 | +// // array | |
| 671 | +// items, | |
| 672 | +// type, | |
| 673 | +// } = schema; | |
| 674 | +// if (!properties && !items) { | |
| 675 | +// return []; | |
| 676 | +// } | |
| 677 | +// let schemaSubs = {}; | |
| 678 | +// if (type === 'object') { | |
| 679 | +// schemaSubs = properties; | |
| 680 | +// } | |
| 681 | +// if (type === 'array') { | |
| 682 | +// schemaSubs = items.properties; | |
| 683 | +// } | |
| 684 | +// return Object.keys(schemaSubs).map(name => ({ | |
| 685 | +// schema: schemaSubs[name], | |
| 686 | +// name, | |
| 687 | +// })); | |
| 688 | +// } | |
| 689 | + | |
| 690 | +export var oldSchemaToNew = function oldSchemaToNew(schema) { | |
| 691 | + if (schema && schema.propsSchema) { | |
| 692 | + var propsSchema = schema.propsSchema, | |
| 693 | + rest = _objectWithoutProperties(schema, _excluded); | |
| 694 | + | |
| 695 | + return _objectSpread({ | |
| 696 | + schema: propsSchema | |
| 697 | + }, rest); | |
| 698 | + } | |
| 699 | + | |
| 700 | + return schema; | |
| 701 | +}; | |
| 702 | +export var newSchemaToOld = function newSchemaToOld(setting) { | |
| 703 | + if (setting && setting.schema) { | |
| 704 | + var schema = setting.schema, | |
| 705 | + rest = _objectWithoutProperties(setting, _excluded2); | |
| 706 | + | |
| 707 | + return _objectSpread({ | |
| 708 | + propsSchema: schema | |
| 709 | + }, rest); | |
| 710 | + } | |
| 711 | + | |
| 712 | + return setting; | |
| 713 | +}; // from FR | |
| 714 | + | |
| 715 | +export var getEnum = function getEnum(schema) { | |
| 716 | + if (!schema) return undefined; | |
| 717 | + var itemEnum = schema && schema.items && schema.items.enum; | |
| 718 | + var schemaEnum = schema && schema.enum; | |
| 719 | + return itemEnum ? itemEnum : schemaEnum; | |
| 720 | +}; // export const getArray = (arr, defaultValue = []) => { | |
| 721 | +// if (Array.isArray(arr)) return arr; | |
| 722 | +// return defaultValue; | |
| 723 | +// }; | |
| 724 | + | |
| 725 | +export var isEmail = function isEmail(value) { | |
| 726 | + var regex = '^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$'; | |
| 727 | + | |
| 728 | + if (value && new RegExp(regex).test(value)) { | |
| 729 | + return true; | |
| 730 | + } | |
| 731 | + | |
| 732 | + return false; | |
| 733 | +}; | |
| 734 | +export function defaultGetValueFromEvent(valuePropName) { | |
| 735 | + var event = arguments.length <= 1 ? undefined : arguments[1]; | |
| 736 | + | |
| 737 | + if (event && event.target && valuePropName in event.target) { | |
| 738 | + return event.target[valuePropName]; | |
| 739 | + } | |
| 740 | + | |
| 741 | + return event; | |
| 742 | +} | |
| 743 | +export var getKeyFromPath = function getKeyFromPath() { | |
| 744 | + var path = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '#'; | |
| 745 | + | |
| 746 | + try { | |
| 747 | + var arr = path.split('.'); | |
| 748 | + var last = arr.slice(-1)[0]; | |
| 749 | + var result = last.replace('[]', ''); | |
| 750 | + return result; | |
| 751 | + } catch (error) { | |
| 752 | + console.error(error, 'getKeyFromPath'); | |
| 753 | + return ''; | |
| 754 | + } | |
| 755 | +}; // 更多的值获取 | |
| 756 | + | |
| 757 | +export var getDisplayValue = function getDisplayValue(value, schema) { | |
| 758 | + if (typeof value === 'boolean') { | |
| 759 | + return value ? 'yes' : 'no'; | |
| 760 | + } | |
| 761 | + | |
| 762 | + if (isObjType(schema) || isListType(schema)) { | |
| 763 | + return '-'; | |
| 764 | + } | |
| 765 | + | |
| 766 | + if (Array.isArray(schema.enum) && Array.isArray(schema.enumNames)) { | |
| 767 | + try { | |
| 768 | + return schema.enumNames[schema.enum.indexOf(value)]; | |
| 769 | + } catch (error) { | |
| 770 | + return value; | |
| 771 | + } | |
| 772 | + } | |
| 773 | + | |
| 774 | + if (_typeof(value) === 'object') { | |
| 775 | + return JSON.stringify(value); | |
| 776 | + } | |
| 777 | + | |
| 778 | + return value; | |
| 779 | +}; // 去掉数组里的空元素 {a: [null, {x:1}]} => {a: [{x:1}]} | |
| 780 | + | |
| 781 | +export var removeEmptyItemFromList = function removeEmptyItemFromList(formData) { | |
| 782 | + var result = {}; | |
| 783 | + | |
| 784 | + if (isObject(formData)) { | |
| 785 | + Object.keys(formData).forEach(function (key) { | |
| 786 | + result[key] = removeEmptyItemFromList(formData[key]); | |
| 787 | + }); | |
| 788 | + } else if (Array.isArray(formData)) { | |
| 789 | + result = formData.filter(function (item) { | |
| 790 | + if ([false, 0, ''].indexOf(item) > -1) return true; | |
| 791 | + | |
| 792 | + if (item && JSON.stringify(item) !== '{}') { | |
| 793 | + return true; | |
| 794 | + } | |
| 795 | + | |
| 796 | + return false; | |
| 797 | + }); | |
| 798 | + } else { | |
| 799 | + result = formData; | |
| 800 | + } | |
| 801 | + | |
| 802 | + return result; | |
| 803 | +}; | |
| 804 | +export var getDescriptorSimple = function getDescriptorSimple() { | |
| 805 | + var schema = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | |
| 806 | + var path = arguments.length > 1 ? arguments[1] : undefined; | |
| 807 | + var result = {}; | |
| 808 | + | |
| 809 | + if (isObject(schema)) { | |
| 810 | + if (schema.type) { | |
| 811 | + switch (schema.type) { | |
| 812 | + case 'range': | |
| 813 | + result.type = 'array'; | |
| 814 | + break; | |
| 815 | + | |
| 816 | + case 'html': | |
| 817 | + result.type = 'string'; | |
| 818 | + break; | |
| 819 | + | |
| 820 | + default: | |
| 821 | + result.type = schema.type; | |
| 822 | + break; | |
| 823 | + } | |
| 824 | + } | |
| 825 | + | |
| 826 | + ['pattern', 'min', 'max', 'len', 'required'].forEach(function (key) { | |
| 827 | + if (Object.keys(schema).indexOf(key) > -1) { | |
| 828 | + result[key] = schema[key]; | |
| 829 | + } | |
| 830 | + }); | |
| 831 | + | |
| 832 | + switch (schema.format) { | |
| 833 | + case 'email': | |
| 834 | + case 'url': | |
| 835 | + result.type = schema.format; | |
| 836 | + break; | |
| 837 | + | |
| 838 | + default: | |
| 839 | + break; | |
| 840 | + } | |
| 841 | + | |
| 842 | + var handleRegx = function handleRegx(desc) { | |
| 843 | + if (desc.pattern && typeof desc.pattern === 'string') { | |
| 844 | + desc.pattern = new RegExp(desc.pattern); | |
| 845 | + } | |
| 846 | + | |
| 847 | + return desc; | |
| 848 | + }; // result be array | |
| 849 | + | |
| 850 | + | |
| 851 | + if (schema.rules) { | |
| 852 | + if (Array.isArray(schema.rules)) { | |
| 853 | + var requiredRule = schema.rules.find(function (rule) { | |
| 854 | + return rule.required === true; | |
| 855 | + }); | |
| 856 | + | |
| 857 | + if (requiredRule) { | |
| 858 | + result = _objectSpread(_objectSpread({}, result), requiredRule); | |
| 859 | + } | |
| 860 | + | |
| 861 | + result = [result].concat(_toConsumableArray(schema.rules)); | |
| 862 | + result = result.map(function (r) { | |
| 863 | + return handleRegx(r); | |
| 864 | + }); | |
| 865 | + } else if (isObject(schema.rules)) { | |
| 866 | + result = [result, schema.rules]; | |
| 867 | + result = result.map(function (r) { | |
| 868 | + return handleRegx(r); | |
| 869 | + }); | |
| 870 | + } | |
| 871 | + } else { | |
| 872 | + result = [result]; | |
| 873 | + } | |
| 874 | + } | |
| 875 | + | |
| 876 | + return _defineProperty({}, path, result); | |
| 877 | +}; // _path 只供内部递归使用 | |
| 878 | + | |
| 879 | +export var generateDataSkeleton = function generateDataSkeleton(schema, formData) { | |
| 880 | + var _formData = clone(formData); | |
| 881 | + | |
| 882 | + var result = _formData; | |
| 883 | + | |
| 884 | + if (isObjType(schema)) { | |
| 885 | + if (_formData === undefined || _typeof(_formData) !== 'object') { | |
| 886 | + _formData = {}; | |
| 887 | + result = {}; | |
| 888 | + } | |
| 889 | + | |
| 890 | + Object.keys(schema.properties).forEach(function (key) { | |
| 891 | + var childSchema = schema.properties[key]; | |
| 892 | + var childData = _formData[key]; | |
| 893 | + var childResult = generateDataSkeleton(childSchema, childData); | |
| 894 | + result[key] = childResult; | |
| 895 | + }); | |
| 896 | + } else if (_formData !== undefined) {// result = _formData; | |
| 897 | + } else if (schema.default !== undefined) { | |
| 898 | + result = clone(schema.default); | |
| 899 | + } else if (isListType(schema)) { | |
| 900 | + result = [generateDataSkeleton(schema.items)]; | |
| 901 | + } else if (schema.type === 'boolean' && !schema.widget) { | |
| 902 | + // result = false; | |
| 903 | + result = undefined; | |
| 904 | + } else { | |
| 905 | + result = undefined; | |
| 906 | + } | |
| 907 | + | |
| 908 | + return result; | |
| 909 | +}; | |
| 910 | +export var translateMessage = function translateMessage(msg, schema) { | |
| 911 | + if (typeof msg !== 'string') { | |
| 912 | + return ''; | |
| 913 | + } | |
| 914 | + | |
| 915 | + if (!schema) return msg; | |
| 916 | + msg = msg.replace('${title}', schema.title); | |
| 917 | + msg = msg.replace('${type}', schema.format || schema.type); // 兼容代码 | |
| 918 | + | |
| 919 | + if (typeof schema.min === 'number') { | |
| 920 | + msg = msg.replace('${min}', schema.min); | |
| 921 | + } | |
| 922 | + | |
| 923 | + if (typeof schema.max === 'number') { | |
| 924 | + msg = msg.replace('${max}', schema.max); | |
| 925 | + } | |
| 926 | + | |
| 927 | + if (schema.rules) { | |
| 928 | + var minRule = schema.rules.find(function (r) { | |
| 929 | + return r.min !== undefined; | |
| 930 | + }); | |
| 931 | + | |
| 932 | + if (minRule) { | |
| 933 | + msg = msg.replace('${min}', minRule.min); | |
| 934 | + } | |
| 935 | + | |
| 936 | + var maxRule = schema.rules.find(function (r) { | |
| 937 | + return r.max !== undefined; | |
| 938 | + }); | |
| 939 | + | |
| 940 | + if (maxRule) { | |
| 941 | + msg = msg.replace('${max}', maxRule.max); | |
| 942 | + } | |
| 943 | + | |
| 944 | + var lenRule = schema.rules.find(function (r) { | |
| 945 | + return r.len !== undefined; | |
| 946 | + }); | |
| 947 | + | |
| 948 | + if (lenRule) { | |
| 949 | + msg = msg.replace('${len}', lenRule.len); | |
| 950 | + } | |
| 951 | + | |
| 952 | + var patternRule = schema.rules.find(function (r) { | |
| 953 | + return r.pattern !== undefined; | |
| 954 | + }); | |
| 955 | + | |
| 956 | + if (patternRule) { | |
| 957 | + msg = msg.replace('${pattern}', patternRule.pattern); | |
| 958 | + } | |
| 959 | + } | |
| 960 | + | |
| 961 | + return msg; | |
| 962 | +}; | |
| 963 | + | |
| 964 | +var changeSchema = function changeSchema(_schema, singleChange) { | |
| 965 | + var schema = clone(_schema); | |
| 966 | + schema = singleChange(schema); | |
| 967 | + | |
| 968 | + if (isObjType(schema)) { | |
| 969 | + var requiredKeys = []; | |
| 970 | + | |
| 971 | + if (Array.isArray(schema.required)) { | |
| 972 | + requiredKeys = schema.required; | |
| 973 | + delete schema.required; | |
| 974 | + } | |
| 975 | + | |
| 976 | + Object.keys(schema.properties).forEach(function (key) { | |
| 977 | + var item = schema.properties[key]; | |
| 978 | + | |
| 979 | + if (requiredKeys.indexOf(key) > -1) { | |
| 980 | + item.required = true; | |
| 981 | + } | |
| 982 | + | |
| 983 | + schema.properties[key] = changeSchema(item, singleChange); | |
| 984 | + }); | |
| 985 | + } else if (isListType(schema)) { | |
| 986 | + Object.keys(schema.items.properties).forEach(function (key) { | |
| 987 | + var item = schema.items.properties[key]; | |
| 988 | + schema.items.properties[key] = changeSchema(item, singleChange); | |
| 989 | + }); | |
| 990 | + } | |
| 991 | + | |
| 992 | + return schema; | |
| 993 | +}; | |
| 994 | + | |
| 995 | +export var updateSchemaToNewVersion = function updateSchemaToNewVersion(schema) { | |
| 996 | + return changeSchema(schema, updateSingleSchema); | |
| 997 | +}; | |
| 998 | + | |
| 999 | +var updateSingleSchema = function updateSingleSchema(schema) { | |
| 1000 | + try { | |
| 1001 | + schema.rules = schema.rules || []; | |
| 1002 | + schema.props = schema.props || {}; | |
| 1003 | + | |
| 1004 | + if (schema['ui:options']) { | |
| 1005 | + schema.props = schema['ui:options']; | |
| 1006 | + delete schema['ui:options']; | |
| 1007 | + } | |
| 1008 | + | |
| 1009 | + if (schema.pattern) { | |
| 1010 | + var validItem = { | |
| 1011 | + pattern: schema.pattern | |
| 1012 | + }; | |
| 1013 | + | |
| 1014 | + if (schema.message && schema.message.pattern) { | |
| 1015 | + validItem.message = schema.message.pattern; | |
| 1016 | + } | |
| 1017 | + | |
| 1018 | + schema.rules.push(validItem); | |
| 1019 | + delete schema.pattern; | |
| 1020 | + delete schema.message; | |
| 1021 | + } // min / max | |
| 1022 | + | |
| 1023 | + | |
| 1024 | + if (schema.minLength) { | |
| 1025 | + schema.min = schema.minLength; | |
| 1026 | + delete schema.minLength; | |
| 1027 | + } | |
| 1028 | + | |
| 1029 | + if (schema.maxLength) { | |
| 1030 | + schema.max = schema.maxLength; | |
| 1031 | + delete schema.maxLength; | |
| 1032 | + } | |
| 1033 | + | |
| 1034 | + if (schema.minItems) { | |
| 1035 | + schema.min = schema.minItems; | |
| 1036 | + delete schema.minItems; | |
| 1037 | + } | |
| 1038 | + | |
| 1039 | + if (schema.maxItems) { | |
| 1040 | + schema.max = schema.maxItems; | |
| 1041 | + delete schema.maxItems; | |
| 1042 | + } | |
| 1043 | + | |
| 1044 | + if (schema.step) { | |
| 1045 | + schema.props.step = schema.step; | |
| 1046 | + delete schema.step; | |
| 1047 | + } // ui:xxx | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + if (schema['ui:className']) { | |
| 1051 | + schema.className = schema['ui:className']; | |
| 1052 | + delete schema['ui:className']; | |
| 1053 | + } | |
| 1054 | + | |
| 1055 | + if (schema['ui:hidden']) { | |
| 1056 | + schema.hidden = schema['ui:hidden']; | |
| 1057 | + delete schema['ui:hidden']; | |
| 1058 | + } | |
| 1059 | + | |
| 1060 | + if (schema['ui:readonly']) { | |
| 1061 | + schema.readOnly = schema['ui:readonly']; // 改成驼峰了 | |
| 1062 | + | |
| 1063 | + delete schema['ui:readonly']; | |
| 1064 | + } | |
| 1065 | + | |
| 1066 | + if (schema['ui:disabled']) { | |
| 1067 | + schema.disabled = schema['ui:disabled']; | |
| 1068 | + delete schema['ui:disabled']; | |
| 1069 | + } | |
| 1070 | + | |
| 1071 | + if (schema['ui:width']) { | |
| 1072 | + schema.width = schema['ui:width']; | |
| 1073 | + delete schema['ui:width']; | |
| 1074 | + } | |
| 1075 | + | |
| 1076 | + if (schema['ui:displayType']) { | |
| 1077 | + schema.displayType = schema['ui:displayType']; | |
| 1078 | + delete schema['ui:displayType']; | |
| 1079 | + } | |
| 1080 | + | |
| 1081 | + if (schema['ui:column']) { | |
| 1082 | + schema.column = schema['ui:column']; | |
| 1083 | + delete schema['ui:column']; | |
| 1084 | + } | |
| 1085 | + | |
| 1086 | + if (schema['ui:widget']) { | |
| 1087 | + schema.widget = schema['ui:widget']; | |
| 1088 | + delete schema['ui:widget']; | |
| 1089 | + } | |
| 1090 | + | |
| 1091 | + if (schema['ui:labelWidth']) { | |
| 1092 | + schema.labelWidth = schema['ui:labelWidth']; | |
| 1093 | + delete schema['ui:labelWidth']; | |
| 1094 | + } | |
| 1095 | + | |
| 1096 | + if (schema.rules && schema.rules.length === 0) { | |
| 1097 | + delete schema.rules; | |
| 1098 | + } | |
| 1099 | + | |
| 1100 | + if (typeof schema.props === 'function' || isObject(schema.props) && Object.keys(schema.props).length > 0) {} else { | |
| 1101 | + delete schema.props; | |
| 1102 | + } | |
| 1103 | + | |
| 1104 | + return schema; | |
| 1105 | + } catch (error) { | |
| 1106 | + console.error('schema转换失败!', error); | |
| 1107 | + return schema; | |
| 1108 | + } | |
| 1109 | +}; // 检验一个string是 function(传统活箭头函数) | |
| 1110 | + | |
| 1111 | + | |
| 1112 | +export var parseFunctionString = function parseFunctionString(string) { | |
| 1113 | + if (typeof string !== 'string') return false; | |
| 1114 | + var reg1 = /^{{(function.+)}}$/; | |
| 1115 | + var reg2 = /^{{(.+=>.+)}}$/; | |
| 1116 | + | |
| 1117 | + if (string.match(reg1)) { | |
| 1118 | + return string.match(reg1)[1]; | |
| 1119 | + } | |
| 1120 | + | |
| 1121 | + if (string.match(reg2)) { | |
| 1122 | + return string.match(reg2)[1]; | |
| 1123 | + } | |
| 1124 | + | |
| 1125 | + return false; | |
| 1126 | +}; | |
| 1127 | +export var completeSchemaWithTheme = function completeSchemaWithTheme() { | |
| 1128 | + var schema = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | |
| 1129 | + var theme = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; | |
| 1130 | + var result = {}; | |
| 1131 | + | |
| 1132 | + if (isObject(schema)) { | |
| 1133 | + if (schema.theme && theme[schema.theme]) { | |
| 1134 | + result = _objectSpread(_objectSpread({}, schema), theme[schema.theme]); | |
| 1135 | + } | |
| 1136 | + | |
| 1137 | + Object.keys(schema).forEach(function (key) { | |
| 1138 | + result[key] = completeSchemaWithTheme(schema[key], theme); | |
| 1139 | + }); | |
| 1140 | + } else { | |
| 1141 | + result = schema; | |
| 1142 | + } | |
| 1143 | + | |
| 1144 | + return result; | |
| 1145 | +}; | |
| 1146 | +export var cleanEmpty = function cleanEmpty(obj) { | |
| 1147 | + if (Array.isArray(obj)) { | |
| 1148 | + return obj.map(function (v) { | |
| 1149 | + return v && isObject(v) ? cleanEmpty(v) : v; | |
| 1150 | + }).filter(function (v) { | |
| 1151 | + return !(v == undefined); | |
| 1152 | + }); | |
| 1153 | + } else if (isObject(obj)) { | |
| 1154 | + return Object.entries(obj).map(function (_ref12) { | |
| 1155 | + var _ref13 = _slicedToArray(_ref12, 2), | |
| 1156 | + k = _ref13[0], | |
| 1157 | + v = _ref13[1]; | |
| 1158 | + | |
| 1159 | + return [k, v && isObject(v) ? cleanEmpty(v) : v]; | |
| 1160 | + }).reduce(function (a, _ref14) { | |
| 1161 | + var _ref15 = _slicedToArray(_ref14, 2), | |
| 1162 | + k = _ref15[0], | |
| 1163 | + v = _ref15[1]; | |
| 1164 | + | |
| 1165 | + return v == undefined ? a : (a[k] = v, a); | |
| 1166 | + }, {}); | |
| 1167 | + } else { | |
| 1168 | + return obj; | |
| 1169 | + } | |
| 1170 | +}; // const x = { a: 1, b: { c: 2 }, d: [{ e: 3, f: [{ g: 5 }] }, { e: 4 }] }; | |
| 1171 | +// ['a', 'b.c', 'd[0].e', 'd[0].f[0].g', 'd[1].e'] | |
| 1172 | + | |
| 1173 | +export var dataToKeys = function dataToKeys(data) { | |
| 1174 | + var rootKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; | |
| 1175 | + var result = []; | |
| 1176 | + | |
| 1177 | + if (rootKey && rootKey.slice(-1) !== ']') { | |
| 1178 | + result.push(rootKey); | |
| 1179 | + } | |
| 1180 | + | |
| 1181 | + var isComplex = function isComplex(data) { | |
| 1182 | + return isObject(data) || Array.isArray(data); | |
| 1183 | + }; | |
| 1184 | + | |
| 1185 | + if (isObject(data)) { | |
| 1186 | + Object.keys(data).forEach(function (key) { | |
| 1187 | + var item = data[key]; | |
| 1188 | + var itemRootKey = rootKey ? rootKey + '.' + key : key; | |
| 1189 | + | |
| 1190 | + if (isComplex(item)) { | |
| 1191 | + var itemKeys = dataToKeys(item, itemRootKey); | |
| 1192 | + result = [].concat(_toConsumableArray(result), _toConsumableArray(itemKeys)); | |
| 1193 | + } else { | |
| 1194 | + result.push(itemRootKey); | |
| 1195 | + } | |
| 1196 | + }); | |
| 1197 | + } else if (Array.isArray(data)) { | |
| 1198 | + data.forEach(function (item, idx) { | |
| 1199 | + var itemRootKey = rootKey ? "".concat(rootKey, "[").concat(idx, "]") : "[".concat(idx, "]"); | |
| 1200 | + | |
| 1201 | + if (isComplex(item)) { | |
| 1202 | + var itemKeys = dataToKeys(item, itemRootKey); | |
| 1203 | + result = [].concat(_toConsumableArray(result), _toConsumableArray(itemKeys)); | |
| 1204 | + } else { | |
| 1205 | + result.push(itemRootKey); | |
| 1206 | + } | |
| 1207 | + }); | |
| 1208 | + } else {} | |
| 1209 | + | |
| 1210 | + return result; | |
| 1211 | +}; | |
| 1212 | +export var removeHiddenFromResult = function removeHiddenFromResult(data, flatten) { | |
| 1213 | + var result = clone(data); | |
| 1214 | + var keys = dataToKeys(result); | |
| 1215 | + keys.forEach(function (key) { | |
| 1216 | + var _destructDataPath = destructDataPath(key), | |
| 1217 | + id = _destructDataPath.id; | |
| 1218 | + | |
| 1219 | + if (flatten[id]) { | |
| 1220 | + var _ref16 = flatten[id].schema || {}, | |
| 1221 | + hidden = _ref16.hidden; | |
| 1222 | + | |
| 1223 | + if (isExpression(hidden)) { | |
| 1224 | + hidden = parseSingleExpression(hidden, result, key); | |
| 1225 | + } | |
| 1226 | + | |
| 1227 | + if (get(result, key) !== undefined && hidden) { | |
| 1228 | + set(result, key, undefined); | |
| 1229 | + } | |
| 1230 | + } | |
| 1231 | + }); | |
| 1232 | + return result; | |
| 1233 | +}; | |
| 1234 | +export var getHiddenData = function getHiddenData(data, flatten) { | |
| 1235 | + var result = clone(data); | |
| 1236 | + var hiddenData = {}; | |
| 1237 | + var keys = dataToKeys(result); | |
| 1238 | + keys.forEach(function (key) { | |
| 1239 | + var _destructDataPath2 = destructDataPath(key), | |
| 1240 | + id = _destructDataPath2.id; | |
| 1241 | + | |
| 1242 | + if (flatten[id]) { | |
| 1243 | + var _ref17 = flatten[id].schema || {}, | |
| 1244 | + hidden = _ref17.hidden; | |
| 1245 | + | |
| 1246 | + if (isExpression(hidden)) { | |
| 1247 | + hidden = parseSingleExpression(hidden, result, key); | |
| 1248 | + } | |
| 1249 | + | |
| 1250 | + if (hidden) { | |
| 1251 | + debugger; | |
| 1252 | + hiddenData[key] = result[key]; | |
| 1253 | + } | |
| 1254 | + } | |
| 1255 | + }); | |
| 1256 | + return hiddenData; | |
| 1257 | +}; | |
| 1258 | +export function msToTime(duration) { | |
| 1259 | + var seconds = Math.floor(duration / 1000 % 60); | |
| 1260 | + var minutes = Math.floor(duration / (1000 * 60) % 60); | |
| 1261 | + var hours = Math.floor(duration / (1000 * 60 * 60) % 24); | |
| 1262 | + hours = hours < 10 ? '0' + hours : hours; | |
| 1263 | + minutes = minutes < 10 ? '0' + minutes : minutes; | |
| 1264 | + seconds = seconds < 10 ? '0' + seconds : seconds; | |
| 1265 | + return hours + ':' + minutes + ':' + seconds; | |
| 1266 | +} | |
| 1267 | +export function yymmdd(timeStamp) { | |
| 1268 | + var date_ob = new Date(Number(timeStamp)); | |
| 1269 | + | |
| 1270 | + var adjustZero = function adjustZero(num) { | |
| 1271 | + return ('0' + num).slice(-2); | |
| 1272 | + }; | |
| 1273 | + | |
| 1274 | + var day = adjustZero(date_ob.getDate()); | |
| 1275 | + var month = adjustZero(date_ob.getMonth()); | |
| 1276 | + var year = date_ob.getFullYear(); | |
| 1277 | + var hours = adjustZero(date_ob.getHours()); | |
| 1278 | + var minutes = adjustZero(date_ob.getMinutes()); | |
| 1279 | + var seconds = adjustZero(date_ob.getSeconds()); | |
| 1280 | + return "".concat(year, "-").concat(month, "-").concat(day, " ").concat(hours, ":").concat(minutes, ":").concat(seconds); | |
| 1281 | +} | |
| 1282 | +export function allPromiseFinish(promiseList) { | |
| 1283 | + var hasError = false; | |
| 1284 | + var count = promiseList.length; | |
| 1285 | + var results = []; | |
| 1286 | + | |
| 1287 | + if (!promiseList.length) { | |
| 1288 | + return Promise.resolve([]); | |
| 1289 | + } | |
| 1290 | + | |
| 1291 | + return new Promise(function (resolve, reject) { | |
| 1292 | + promiseList.forEach(function (promise, index) { | |
| 1293 | + promise.catch(function (e) { | |
| 1294 | + hasError = true; | |
| 1295 | + return e; | |
| 1296 | + }).then(function (result) { | |
| 1297 | + count -= 1; | |
| 1298 | + results[index] = result; | |
| 1299 | + | |
| 1300 | + if (count > 0) { | |
| 1301 | + return; | |
| 1302 | + } | |
| 1303 | + | |
| 1304 | + if (hasError) { | |
| 1305 | + reject(results); | |
| 1306 | + } | |
| 1307 | + | |
| 1308 | + resolve(results); | |
| 1309 | + }); | |
| 1310 | + }); | |
| 1311 | + }); | |
| 1312 | +} | |
| 1313 | +export var removeDups = function removeDups(arr) { | |
| 1314 | + if (!Array.isArray(arr)) { | |
| 1315 | + console.log('in removeDups: param is not an array'); | |
| 1316 | + return; | |
| 1317 | + } | |
| 1318 | + | |
| 1319 | + var array = []; | |
| 1320 | + | |
| 1321 | + for (var i = 0; i < arr.length; i++) { | |
| 1322 | + if (array.indexOf(arr[i]) === -1) { | |
| 1323 | + array.push(arr[i]); | |
| 1324 | + } | |
| 1325 | + } | |
| 1326 | + | |
| 1327 | + return array; | |
| 1328 | +}; | |
| \ No newline at end of file | ... | ... |
es/form-render-core/src/validateMessage.js
renamed from
es/validateMessage.js
| ... | ... | @@ -2,7 +2,6 @@ var typeTemplate = '${title} is not a valid ${type}'; |
| 2 | 2 | export var defaultValidateMessages = { |
| 3 | 3 | default: 'Validation error on field ${title}', |
| 4 | 4 | required: '${title} is required', |
| 5 | - // enum: '${title} must be one of [${enum}]', | |
| 6 | 5 | whitespace: '${title} cannot be empty', |
| 7 | 6 | date: { |
| 8 | 7 | format: '${title} is invalid for format date', | ... | ... |
es/form-render-core/src/validateMessageCN.js
renamed from
es/validateMessageCN.js
| ... | ... | @@ -27,7 +27,7 @@ export var defaultValidateMessagesCN = { |
| 27 | 27 | len: '${title}长度不是${len}', |
| 28 | 28 | min: '${title}长度不能小于${min}', |
| 29 | 29 | max: '${title}长度不能大于${max}', |
| 30 | - range: '${title}长度需在${min}于${max}之间' | |
| 30 | + range: '${title}长度需在${min}与${max}之间' | |
| 31 | 31 | }, |
| 32 | 32 | number: { |
| 33 | 33 | len: '${title}不等于${len}', |
| ... | ... | @@ -39,7 +39,7 @@ export var defaultValidateMessagesCN = { |
| 39 | 39 | len: '${title}长度不是${len}', |
| 40 | 40 | min: '${title}长度不能小于${min}', |
| 41 | 41 | max: '${title}长度不能大于${max}', |
| 42 | - range: '${title}长度需在${min}于${max}之间' | |
| 42 | + range: '${title}长度需在${min}与${max}之间' | |
| 43 | 43 | }, |
| 44 | 44 | pattern: { |
| 45 | 45 | mismatch: '${title}未通过正则判断${pattern}' | ... | ... |