tntd 2.7.7 → 2.7.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/es/button/button.js +46 -0
  2. package/es/button/button.js.map +1 -0
  3. package/es/button/index.js +2 -2
  4. package/es/button/index.js.map +1 -1
  5. package/es/form/form.js +58 -0
  6. package/es/form/form.js.map +1 -0
  7. package/es/form/index.js +2 -2
  8. package/es/form/index.js.map +1 -1
  9. package/es/handle/handle.js +102 -0
  10. package/es/handle/handle.js.map +1 -0
  11. package/es/handle/index.js +30 -0
  12. package/es/handle/index.js.map +1 -1
  13. package/es/table/table.js +42 -41
  14. package/es/table/table.js.map +1 -1
  15. package/es/tabs/index.js +2 -2
  16. package/es/tabs/index.js.map +1 -1
  17. package/es/tabs/tabPane.js +2 -0
  18. package/es/tabs/tabPane.js.map +1 -0
  19. package/es/tabs/tabs.js +71 -0
  20. package/es/tabs/tabs.js.map +1 -0
  21. package/es/tntd-modal/index.js +21 -54
  22. package/es/tntd-modal/index.js.map +1 -1
  23. package/es/tntd-modal/index.less +66 -82
  24. package/lib/button/button.d.ts +9 -0
  25. package/lib/button/button.d.ts.map +1 -0
  26. package/lib/button/button.js +67 -0
  27. package/lib/button/button.js.map +1 -0
  28. package/lib/button/index.d.ts +2 -2
  29. package/lib/button/index.d.ts.map +1 -1
  30. package/lib/button/index.js +3 -6
  31. package/lib/button/index.js.map +1 -1
  32. package/lib/form/form.d.ts +11 -0
  33. package/lib/form/form.d.ts.map +1 -0
  34. package/lib/form/form.js +79 -0
  35. package/lib/form/form.js.map +1 -0
  36. package/lib/form/index.d.ts +2 -2
  37. package/lib/form/index.d.ts.map +1 -1
  38. package/lib/form/index.js +3 -6
  39. package/lib/form/index.js.map +1 -1
  40. package/lib/handle/handle.d.ts +3 -0
  41. package/lib/handle/handle.d.ts.map +1 -0
  42. package/lib/handle/handle.js +130 -0
  43. package/lib/handle/handle.js.map +1 -0
  44. package/lib/handle/index.d.ts.map +1 -1
  45. package/lib/handle/index.js +30 -0
  46. package/lib/handle/index.js.map +1 -1
  47. package/lib/segmented/index.d.ts +1 -1
  48. package/lib/svg-components/illustration-403.d.ts +1 -1
  49. package/lib/svg-components/illustration-404.d.ts +1 -1
  50. package/lib/svg-components/illustration-500.d.ts +1 -1
  51. package/lib/svg-components/illustration-empty.d.ts +1 -1
  52. package/lib/svg-components/illustration-failure.d.ts +1 -1
  53. package/lib/svg-components/illustration-no-access.d.ts +1 -1
  54. package/lib/svg-components/illustration-no-chart.d.ts +1 -1
  55. package/lib/svg-components/illustration-no-result.d.ts +1 -1
  56. package/lib/svg-components/illustration-offline.d.ts +1 -1
  57. package/lib/svg-components/illustration-success.d.ts +1 -1
  58. package/lib/table/assets/image-loading-background.d.ts +1 -1
  59. package/lib/table/assets/image-loading.d.ts +1 -1
  60. package/lib/table/table.d.ts +1 -0
  61. package/lib/table/table.d.ts.map +1 -1
  62. package/lib/table/table.js +42 -41
  63. package/lib/table/table.js.map +1 -1
  64. package/lib/tabs/index.d.ts +2 -2
  65. package/lib/tabs/index.d.ts.map +1 -1
  66. package/lib/tabs/index.js +3 -6
  67. package/lib/tabs/index.js.map +1 -1
  68. package/lib/tabs/tabPane.d.ts +1 -0
  69. package/lib/tabs/tabPane.d.ts.map +1 -0
  70. package/lib/tabs/tabPane.js +2 -0
  71. package/lib/tabs/tabPane.js.map +1 -0
  72. package/lib/tabs/tabs.d.ts +11 -0
  73. package/lib/tabs/tabs.d.ts.map +1 -0
  74. package/lib/tabs/tabs.js +92 -0
  75. package/lib/tabs/tabs.js.map +1 -0
  76. package/lib/tntd-modal/index.d.ts +2 -15
  77. package/lib/tntd-modal/index.d.ts.map +1 -1
  78. package/lib/tntd-modal/index.js +23 -58
  79. package/lib/tntd-modal/index.js.map +1 -1
  80. package/lib/tntd-modal/index.less +66 -82
  81. package/package.json +1 -1
  82. package/es/query-form/Field/AloneSearch.js +0 -17
  83. package/es/query-form/Field/AloneSearch.js.map +0 -1
  84. package/es/tag/tag.less +0 -61
  85. package/es/tnt-second-page/index.js +0 -48
  86. package/es/tnt-second-page/index.js.map +0 -1
  87. package/es/tntd-layout/tntdLayout.stories.js +0 -289
  88. package/es/tntd-layout/tntdLayout.stories.js.map +0 -1
  89. package/lib/mention/index.d.ts +0 -5
  90. package/lib/mention/index.d.ts.map +0 -1
  91. package/lib/mention/index.js.map +0 -1
  92. package/lib/query-form/Field/AloneSearch.d.ts +0 -2
  93. package/lib/query-form/Field/AloneSearch.d.ts.map +0 -1
  94. package/lib/query-form/Field/AloneSearch.js +0 -22
  95. package/lib/query-form/Field/AloneSearch.js.map +0 -1
  96. package/lib/tag/tag.less +0 -61
  97. package/lib/tnt-second-page/index.d.ts +0 -17
  98. package/lib/tnt-second-page/index.d.ts.map +0 -1
  99. package/lib/tnt-second-page/index.js +0 -59
  100. package/lib/tnt-second-page/index.js.map +0 -1
  101. package/lib/tntd-form/TntdForm/components/Item.d.ts +0 -5
  102. package/lib/tntd-form/TntdForm/components/Item.d.ts.map +0 -1
  103. package/lib/tntd-form/TntdForm/components/Item.js.map +0 -1
  104. package/lib/tntd-form/TntdForm/components/ItemComp.d.ts +0 -5
  105. package/lib/tntd-form/TntdForm/components/ItemComp.d.ts.map +0 -1
  106. package/lib/tntd-form/TntdForm/components/ItemComp.js.map +0 -1
  107. package/lib/tntd-form/TntdForm/components/List.d.ts +0 -5
  108. package/lib/tntd-form/TntdForm/components/List.d.ts.map +0 -1
  109. package/lib/tntd-form/TntdForm/components/List.js.map +0 -1
  110. package/lib/tntd-form/TntdForm/index.d.ts +0 -10
  111. package/lib/tntd-form/TntdForm/index.d.ts.map +0 -1
  112. package/lib/tntd-form/TntdForm/index.js.map +0 -1
  113. package/lib/tntd-form/TntdForm/interface.d.ts +0 -93
  114. package/lib/tntd-form/TntdForm/interface.d.ts.map +0 -1
  115. package/lib/tntd-form/TntdForm/interface.js.map +0 -1
  116. package/lib/tntd-form/TntdForm/store.d.ts +0 -4
  117. package/lib/tntd-form/TntdForm/store.d.ts.map +0 -1
  118. package/lib/tntd-form/TntdForm/store.js.map +0 -1
  119. package/lib/tntd-form/TntdForm/utils.d.ts +0 -48
  120. package/lib/tntd-form/TntdForm/utils.d.ts.map +0 -1
  121. package/lib/tntd-form/TntdForm/utils.js.map +0 -1
  122. package/lib/tntd-layout/tntdLayout.stories.d.ts +0 -5
  123. package/lib/tntd-layout/tntdLayout.stories.d.ts.map +0 -1
  124. package/lib/tntd-layout/tntdLayout.stories.js +0 -326
  125. package/lib/tntd-layout/tntdLayout.stories.js.map +0 -1
@@ -1,22 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = AloneSearch;
7
- var _react = require("react");
8
- var _input = _interopRequireDefault(require("../../input"));
9
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
10
- var Search = _input["default"].Search;
11
- function AloneSearch(props) {
12
- var onPressEnter = props.onPressEnter;
13
- var onSearch = (0, _react.useCallback)(function (value) {
14
- onPressEnter({
15
- target: value
16
- });
17
- }, [onPressEnter]);
18
- return React.createElement(Search, Object.assign({}, props, {
19
- onSearch: onSearch,
20
- allowClear: true
21
- }));
22
- }
@@ -1 +0,0 @@
1
- {"version":3,"file":"AloneSearch.js","sourceRoot":"","sources":["../../../src/query-form/Field/AloneSearch.js"],"names":[],"mappings":";;;;;AAAA,iCAAoC;AACpC,wDAA+B;AAE/B,MAAM,MAAM,GAAG,eAAK,CAAC,MAAM,CAAC;AAE5B,SAAwB,WAAW,CAAE,KAAK;IACxC,MAAM,EAAE,YAAY,EAAE,GAAG,KAAK,CAAC;IAE/B,MAAM,QAAQ,GAAG,IAAA,mBAAW,EAAC,CAAC,KAAK,EAAE,EAAE;QACrC,YAAY,CAAC;YACX,MAAM,EAAE,KAAK;SACd,CAAC,CAAA;IACJ,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;IAElB,OAAO,oBAAC,MAAM,oBAAK,KAAK,IAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,UAAG,CAAA;AAC7D,CAAC;AAVD,8BAUC","sourcesContent":["import { useCallback } from 'react';\nimport Input from '../../input'\n\nconst Search = Input.Search;\n\nexport default function AloneSearch (props) {\n const { onPressEnter } = props;\n\n const onSearch = useCallback((value) => {\n onPressEnter({\n target: value\n })\n }, [onPressEnter])\n\n return <Search {...props} onSearch={onSearch} allowClear />\n}"]}
package/lib/tag/tag.less DELETED
@@ -1,61 +0,0 @@
1
- @tag-prefix-cls: ~'@{ant-prefix}-tag';
2
-
3
- .@{tag-prefix-cls} {
4
- border-color: transparent;
5
- line-height: 22px;
6
- min-width: 44px;
7
- padding: 0 8px;
8
- border-radius: 1px;
9
- text-align: center;
10
-
11
- &.@{tag-prefix-cls}-red {
12
- border-color: inherit;
13
- }
14
-
15
- &.@{tag-prefix-cls}-checkable {
16
- cursor: pointer;
17
- }
18
-
19
- &.@{tag-prefix-cls}-rounded {
20
- padding: 0 12px;
21
- border-radius: 12px;
22
- }
23
-
24
- &.@{tag-prefix-cls}-dot {
25
- display: inline-flex;
26
- align-items: center;
27
- background-color: transparent;
28
- padding: 0;
29
- }
30
-
31
- .@{tag-prefix-cls}-icon {
32
- display: inline-flex;
33
- align-items: center;
34
- margin-right: 4px;
35
- }
36
-
37
- .@{tag-prefix-cls}-dot-symbol {
38
- content: '';
39
- display: inline-block;
40
- width: 6px;
41
- height: 6px;
42
- border-radius: 50%;
43
- margin-right: 8px;
44
- }
45
-
46
- .@{iconfont-css-prefix}-close {
47
- margin-left: 4px;
48
- color: #8b919e;
49
- }
50
-
51
- .make-border-inherit-classes(@i: length(@preset-colors)) when (@i > 0) {
52
- .make-border-inherit-classes(@i - 1);
53
- @color: extract(@preset-colors, @i);
54
-
55
- &-@{color} {
56
- border-color: inherit;
57
- }
58
- }
59
-
60
- .make-border-inherit-classes();
61
- }
@@ -1,17 +0,0 @@
1
- /// <reference types="react" />
2
- import './index.less';
3
- export default function FullModal({ title, header, toolBar, footer, visible, destroyOnClose, onBack, isFixed, inTab, loading, children, className, }: {
4
- title: any;
5
- header: any;
6
- toolBar?: null | undefined;
7
- footer: any;
8
- visible: any;
9
- destroyOnClose: any;
10
- onBack?: (() => void) | undefined;
11
- isFixed?: boolean | undefined;
12
- inTab?: boolean | undefined;
13
- loading?: boolean | undefined;
14
- children: any;
15
- className: any;
16
- }): JSX.Element | null;
17
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tnt-second-page/index.tsx"],"names":[],"mappings":";AAIA,OAAO,cAAc,CAAA;AAGrB,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAChC,KAAK,EACL,MAAM,EACN,OAAc,EACd,MAAM,EACN,OAAO,EACP,cAAc,EACd,MAAc,EACd,OAAc,EACd,KAAa,EACb,OAAe,EACf,QAAQ,EACR,SAAS,GACV;;;;;;;;;;;;;CAAA,sBAkCA"}
@@ -1,59 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = FullModal;
7
- var _react = _interopRequireDefault(require("react"));
8
- var _classnames = _interopRequireDefault(require("classnames"));
9
- var _icon = _interopRequireDefault(require("../icon"));
10
- var _spin = _interopRequireDefault(require("../spin"));
11
- require("./index.less");
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
- var empty = function empty() {};
14
- function FullModal(_ref) {
15
- var title = _ref.title,
16
- header = _ref.header,
17
- _ref$toolBar = _ref.toolBar,
18
- toolBar = _ref$toolBar === void 0 ? null : _ref$toolBar,
19
- footer = _ref.footer,
20
- visible = _ref.visible,
21
- destroyOnClose = _ref.destroyOnClose,
22
- _ref$onBack = _ref.onBack,
23
- onBack = _ref$onBack === void 0 ? empty : _ref$onBack,
24
- _ref$isFixed = _ref.isFixed,
25
- isFixed = _ref$isFixed === void 0 ? true : _ref$isFixed,
26
- _ref$inTab = _ref.inTab,
27
- inTab = _ref$inTab === void 0 ? false : _ref$inTab,
28
- _ref$loading = _ref.loading,
29
- loading = _ref$loading === void 0 ? false : _ref$loading,
30
- children = _ref.children,
31
- className = _ref.className;
32
- if (!visible && destroyOnClose) {
33
- return null;
34
- }
35
- return _react["default"].createElement("div", {
36
- className: (0, _classnames["default"])('tnt-second-page', className, {
37
- 'tnt-second-page-intab': inTab,
38
- 'tnt-second-page-fixed': isFixed,
39
- 'tnt-second-page-hidden': !visible
40
- })
41
- }, _react["default"].createElement(_spin["default"], {
42
- spinning: loading
43
- }, _react["default"].createElement("div", {
44
- className: "tnt-second-page-header"
45
- }, header ? header : _react["default"].createElement(_react["default"].Fragment, null, _react["default"].createElement("a", {
46
- className: "tnt-second-page-header-back",
47
- onClick: onBack
48
- }, _react["default"].createElement(_icon["default"], {
49
- type: "left"
50
- }), "\u8FD4\u56DE"), _react["default"].createElement("span", {
51
- className: "tnt-second-page-header-title"
52
- }, title), toolBar)), _react["default"].createElement("div", {
53
- className: "tnt-second-page-body"
54
- }, _react["default"].createElement("div", {
55
- className: "tnt-second-page-inner"
56
- }, children)), footer && _react["default"].createElement("div", {
57
- className: "tnt-second-page-footer"
58
- }, footer)));
59
- }
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tnt-second-page/index.tsx"],"names":[],"mappings":";;;;;AAAA,kDAAyB;AACzB,4DAA2B;AAC3B,mDAA0B;AAC1B,mDAA0B;AAC1B,wBAAqB;AACrB,MAAM,KAAK,GAAG,GAAG,EAAE,GAAE,CAAC,CAAA;AAEtB,SAAwB,SAAS,CAAC,EAChC,KAAK,EACL,MAAM,EACN,OAAO,GAAG,IAAI,EACd,MAAM,EACN,OAAO,EACP,cAAc,EACd,MAAM,GAAG,KAAK,EACd,OAAO,GAAG,IAAI,EACd,KAAK,GAAG,KAAK,EACb,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,SAAS,GACV;IACC,IAAI,CAAC,OAAO,IAAI,cAAc,EAAE;QAC9B,OAAO,IAAI,CAAA;KACZ;IACD,OAAO,CACL,uCACE,SAAS,EAAE,IAAA,oBAAE,EAAC,iBAAiB,EAAE,SAAS,EAAE;YAC1C,uBAAuB,EAAE,KAAK;YAC9B,uBAAuB,EAAE,OAAO;YAChC,wBAAwB,EAAE,CAAC,OAAO;SACnC,CAAC;QAEF,8BAAC,cAAI,IAAC,QAAQ,EAAE,OAAO;YACrB,uCAAK,SAAS,EAAC,wBAAwB,IACpC,MAAM,CAAC,CAAC,CAAC,CACR,MAAM,CACP,CAAC,CAAC,CAAC,CACF;gBACE,qCAAG,SAAS,EAAC,6BAA6B,EAAC,OAAO,EAAE,MAAM;oBACxD,8BAAC,cAAI,IAAC,IAAI,EAAC,MAAM,GAAG;mCAElB;gBACJ,wCAAM,SAAS,EAAC,8BAA8B,IAAE,KAAK,CAAQ;gBAC5D,OAAO,CACP,CACJ,CACG;YACN,uCAAK,SAAS,EAAC,sBAAsB;gBACnC,uCAAK,SAAS,EAAC,uBAAuB,IAAE,QAAQ,CAAO,CACnD;YACL,MAAM,IAAI,uCAAK,SAAS,EAAC,wBAAwB,IAAE,MAAM,CAAO,CAC5D,CACH,CACP,CAAA;AACH,CAAC;AA/CD,4BA+CC","sourcesContent":["import React from 'react'\nimport cn from 'classnames'\nimport Icon from '../icon'\nimport Spin from '../spin'\nimport './index.less'\nconst empty = () => {}\n\nexport default function FullModal({\n title,\n header,\n toolBar = null,\n footer,\n visible,\n destroyOnClose,\n onBack = empty,\n isFixed = true,\n inTab = false,\n loading = false,\n children,\n className,\n}) {\n if (!visible && destroyOnClose) {\n return null\n }\n return (\n <div\n className={cn('tnt-second-page', className, {\n 'tnt-second-page-intab': inTab,\n 'tnt-second-page-fixed': isFixed,\n 'tnt-second-page-hidden': !visible,\n })}\n >\n <Spin spinning={loading}>\n <div className=\"tnt-second-page-header\">\n {header ? (\n header\n ) : (\n <>\n <a className=\"tnt-second-page-header-back\" onClick={onBack}>\n <Icon type=\"left\" />\n 返回\n </a>\n <span className=\"tnt-second-page-header-title\">{title}</span>\n {toolBar}\n </>\n )}\n </div>\n <div className=\"tnt-second-page-body\">\n <div className=\"tnt-second-page-inner\">{children}</div>\n </div>\n {footer && <div className=\"tnt-second-page-footer\">{footer}</div>}\n </Spin>\n </div>\n )\n}\n"]}
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- import type { IFormItem } from '../interface';
3
- declare const _default: React.NamedExoticComponent<IFormItem>;
4
- export default _default;
5
- //# sourceMappingURL=Item.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Item.d.ts","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/Item.tsx"],"names":[],"mappings":"AAQA,OAAO,KAA8C,MAAM,OAAO,CAAA;AAIlE,OAAO,KAAK,EAAE,SAAS,EAAkC,MAAM,cAAc,CAAA;;AAyC7E,wBAKE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"Item.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/Item.tsx"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,+CAAkE;AAClE,mCAAgC;AAChC,0DAAiC;AACjC,oCAAsC;AAEtC,oCAAmC;AAEnC,MAAM,IAAI,GAAwB,CAAC,EACjC,IAAI,EACJ,QAAQ,EACR,KAAK,EACL,KAAK,EACL,YAAY,EACZ,YAAY,EACZ,YAAY,GACb,EAAE,EAAE;IACH,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,IAAA,kBAAU,EAAe,mBAAW,CAAC,CAAA;IAC5F,MAAM,GAAG,GAAG,IAAA,cAAM,GAAoB,CAAA;IAEtC,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,SAAS,CAAC,OAAO,CAAC,IAAA,gBAAQ,EAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,EAAE;;YACjD,MAAA,MAAA,GAAG,CAAC,OAAO,0CAAE,SAAS,kDAAI,CAAA;QAC5B,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAA;IAErB,OAAO,CACL,8BAAC,kBAAQ,oBACH;QACF,IAAI;QACJ,aAAa;QACb,UAAU;QACV,SAAS;QACT,KAAK;QACL,KAAK;QACL,IAAI;QACJ,GAAG;QACH,QAAQ;QACR,YAAY;QACZ,YAAY;QACZ,YAAY;KACb,EACD,CACH,CAAA;AACH,CAAC,CAAA;AAED,kBAAe,IAAA,YAAI,EAAC,IAAI,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE;IACjD,IAAI,IAAA,gBAAO,EAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE;QAC/D,OAAO,IAAI,CAAA;KACZ;IACD,OAAO,KAAK,CAAA;AACd,CAAC,CAAC,CAAA","sourcesContent":["/*\n * @Descripttion: TntdForm.Item\n * @Author: 郑泳健\n * @Date: 2023-02-22 23:25:24\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 17:46:57\n */\n\nimport React, { memo, useRef, useContext, useEffect } from 'react'\nimport { isEqual } from 'lodash'\nimport ItemComp from './ItemComp'\nimport { FormContext } from '../store'\nimport type { IFormItem, IFormContext, IChildrenCompFun } from '../interface'\nimport { getNames } from '../utils'\n\nconst Item: React.FC<IFormItem> = ({\n name,\n children,\n style,\n rules,\n shouldUpdate,\n initialValue,\n dependencies,\n}) => {\n const { form, initialValues, updateRefs, compsRefs } = useContext<IFormContext>(FormContext)\n const ref = useRef<IChildrenCompFun>()\n\n useEffect(() => {\n compsRefs.current[getNames(name).join('.')] = () => {\n ref.current?.onRefresh?.()\n }\n }, [compsRefs, name])\n\n return (\n <ItemComp\n {...{\n form,\n initialValues,\n updateRefs,\n compsRefs,\n style,\n rules,\n name,\n ref,\n children,\n initialValue,\n shouldUpdate,\n dependencies,\n }}\n />\n )\n}\n\nexport default memo(Item, (nextProps, prevProps) => {\n if (isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {\n return true\n }\n return false\n})\n"]}
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- import type { IFormItem } from '../interface';
3
- declare const _default: React.NamedExoticComponent<IFormItem>;
4
- export default _default;
5
- //# sourceMappingURL=ItemComp.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ItemComp.d.ts","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/ItemComp.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAyD,MAAM,OAAO,CAAA;AAE7E,OAAO,KAAK,EAAE,SAAS,EAAsD,MAAM,cAAc,CAAA;;AAiNjG,wBAA6B"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"ItemComp.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/ItemComp.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: TntdForm.Item进行性能优化\n * @Author: 郑泳健\n * @Date: 2023-02-23 12:47:28\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 17:45:35\n */\n\nimport React, { useState, memo, useEffect, useImperativeHandle } from 'react'\nimport { getNames, handleCheckItem, getInitValue } from '../utils'\nimport type { IFormItem, IFormItemData, TinitialValueType, IChildrenCompFun } from '../interface'\n\nconst ItemComp: React.FC<IFormItem> = React.forwardRef<IChildrenCompFun, IFormItem>(\n (\n {\n name,\n children,\n style,\n initialValue,\n rules,\n shouldUpdate,\n dependencies,\n form,\n updateRefs,\n initialValues,\n compsRefs,\n },\n ref\n ) => {\n const [value, setValue] = useState<TinitialValueType>(undefined)\n const [errorMsg, setErrorMsg] = useState<string | undefined>(undefined)\n const [refresh, setRefresh] = useState<boolean>(false)\n\n useImperativeHandle(ref, () => ({\n onRefresh: () => {\n setRefresh(!refresh)\n },\n }))\n\n /** 根据shouldUpdate 和 dependencies收集修改某个字段后需要同步更新的字段 */\n useEffect(() => {\n const nameStr = getNames(name)?.join('.')\n if (shouldUpdate) {\n updateRefs.current.shouldUpdateList.push(nameStr)\n }\n\n if (Array.isArray(dependencies)) {\n const arr = dependencies.map((i) => getNames(i).join('.'))\n if (Array.isArray(arr)) {\n arr.forEach((i) => {\n if (Array.isArray(updateRefs.current.dependencies[i])) {\n updateRefs.current.dependencies[i] = [\n ...updateRefs.current.dependencies[i],\n getNames(name).join('.'),\n ]\n } else {\n updateRefs.current.dependencies[i] = [getNames(name).join('.')]\n }\n })\n }\n }\n }, [shouldUpdate, dependencies, name, updateRefs])\n\n const updateRender = () => {\n if (Array.isArray(updateRefs.current.shouldUpdateList)) {\n updateRefs.current.shouldUpdateList.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n const list = updateRefs.current.dependencies[getNames(name).join('.')]\n\n if (Array.isArray(list)) {\n list.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n }\n\n /**\n * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的\n * @param name\n * @param value\n * @returns\n */\n const generateFormData = (name: string[] | string, value: TinitialValueType) => {\n if (!name || !form || typeof name !== 'object') return\n const [str, ...rest] = name\n\n rest.forEach((i) => {\n if (form.formData[str]) {\n form.formData[str][i].value = value\n form.formData[str][i].checkItem = () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n }\n } else {\n form.formData[str] = {\n [i]: {\n value,\n checkItem: () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n },\n setItemValue: () => {},\n errorMsg: undefined,\n },\n }\n }\n })\n }\n\n // 为了给最外层提供方法去校验,比如保存的时候.\n // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的\n useEffect(() => {\n if (!name || !form || typeof name !== 'object') return\n const [str, ...rest] = name\n\n const addItem: IFormItemData = {\n setItemValue: (_val, callback) => {\n const error = handleCheckItem(_val, rules)\n setValue(_val)\n setErrorMsg(error)\n callback?.()\n updateRender()\n },\n checkItem: () => {\n const error = handleCheckItem(value, rules)\n setErrorMsg(error)\n return error\n },\n value,\n errorMsg,\n }\n rest.forEach((i) => {\n if (form.formData[str]) {\n form.formData[str][i] = addItem\n } else {\n form.formData[str] = {\n [i]: addItem,\n }\n }\n })\n }, [rules, name, errorMsg, form])\n\n /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */\n useEffect(() => {\n if (initialValue) {\n setValue(initialValue)\n generateFormData(name, initialValue)\n updateRender()\n }\n }, [initialValue])\n\n // 初始化设置默认值,\n useEffect(() => {\n const initValue = getInitValue(initialValues, name)\n // @ts-ignore\n const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue\n\n setValue(_value)\n generateFormData(name, _value)\n updateRender()\n }, [])\n\n // 默认方法\n const handleChange = (\n e:\n | React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement>\n | string\n | number\n | undefined\n ) => {\n let val\n if (typeof e === 'object') {\n val = (e as React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement>)\n ?.target?.value\n } else {\n val = e\n }\n setValue(val)\n generateFormData(name, val)\n const error = handleCheckItem(val, rules)\n setErrorMsg(error)\n updateRender()\n }\n\n return (\n <div\n className={errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper'}\n style={style}\n >\n {React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n return React.cloneElement(child, {\n value,\n form,\n onChange: handleChange,\n 'data-key': getNames(name)?.join('.'),\n ...child.props,\n })\n }\n return null\n })}\n {errorMsg && <div className=\"ant-form-explain ant-form-item-explain-error\">{errorMsg}</div>}\n </div>\n )\n }\n)\n\nfunction arePropsEqual(prevProps: IFormItem, nextProps: IFormItem) {\n if (!nextProps.shouldUpdate && Array.isArray(nextProps.dependencies)) {\n return true\n }\n\n return false\n}\n\nexport default memo(ItemComp)\n"]}
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- import type { IFormListProps } from '../interface';
3
- declare const _default: React.NamedExoticComponent<IFormListProps>;
4
- export default _default;
5
- //# sourceMappingURL=List.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"List.d.ts","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/List.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAwD,MAAM,OAAO,CAAA;AAI5E,OAAO,KAAK,EAAE,cAAc,EAA+C,MAAM,cAAc,CAAA;;AAmF/F,wBAKE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"List.js","sourceRoot":"","sources":["../../../../src/tntd-form/TntdForm/components/List.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: FormList\n * @Author: 郑泳健\n * @Date: 2023-03-06 18:42:08\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 17:42:31\n */\n\nimport React, { useState, useEffect, useRef, useContext, memo } from 'react'\nimport { cloneDeep, isEqual } from 'lodash'\nimport { getNames } from '../utils'\nimport { FormContext } from '../store'\nimport type { IFormListProps, IFormContext, ILevel, TAddOrRemove, IObject } from '../interface'\n\nconst List: React.FC<IFormListProps> = ({ name, children }) => {\n const maxRef = useRef(-1)\n const { form, initialValues, compsRefs, updateRefs } = useContext<IFormContext>(FormContext)\n const [dataLevel, setDataLevel] = useState<ILevel[]>([])\n\n /** 根据一开始记录的渲染shouldUpdate 和 dependencies组件 */\n const updateRender = () => {\n if (Array.isArray(updateRefs.current.shouldUpdateList)) {\n updateRefs.current.shouldUpdateList.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n\n const list = updateRefs.current.dependencies[getNames(name).join('.')]\n\n if (Array.isArray(list)) {\n list.forEach((i) => {\n compsRefs?.current?.[i]?.()\n })\n }\n }\n\n /** 根据默认数值自动生成dataLevel */\n useEffect(() => {\n let dataSource = initialValues\n const attrs = getNames(name)\n const key: string = Array.isArray(name) ? name?.[0] : name\n\n for (const key of attrs) {\n dataSource = dataSource?.[key] || [{}]\n }\n\n if (Array.isArray(dataSource)) {\n const _level = dataSource.map((i, index) => {\n return {\n key: index,\n name: `${attrs.join('.')}.${index}`,\n }\n })\n setDataLevel(_level)\n maxRef.current = dataSource.length - 1\n if (form) {\n form.dataLevel[key] = _level\n }\n updateRender()\n }\n }, [form, initialValues, name])\n\n /** 新增一列 */\n const handleAdd: TAddOrRemove = (index) => {\n const tempDataLevel = cloneDeep(dataLevel)\n const key: string = Array.isArray(name) ? name?.[0] : name\n maxRef.current++\n const attrs = getNames(name)\n tempDataLevel.splice(index + 1, 0, {\n key: maxRef.current,\n name: `${attrs?.join('.')}.${maxRef.current}`,\n })\n setDataLevel(tempDataLevel)\n if (form) {\n form.dataLevel[key] = tempDataLevel\n }\n updateRender()\n }\n\n /** 删除一列 */\n const handleDel: TAddOrRemove = (index) => {\n const temp = cloneDeep(dataLevel)\n const key: string = Array.isArray(name) ? name?.[0] : name\n temp.splice(index, 1)\n setDataLevel(temp)\n if (form) {\n form.dataLevel[key] = temp\n }\n updateRender()\n }\n\n return <>{children?.(dataLevel, { add: handleAdd, remove: handleDel })}</>\n}\n\n// name 没有改变就不需要重复render\nexport default memo(List, (nextProps, prevProps) => {\n if (isEqual(nextProps.name, prevProps.name) && !!prevProps.name) {\n return true\n }\n return false\n})\n"]}
@@ -1,10 +0,0 @@
1
- import React from 'react';
2
- import type { IForm, ITntdFormProps } from './interface';
3
- declare const TntdForm: {
4
- ({ form, initialValues, children }: ITntdFormProps): JSX.Element;
5
- useForm(): IForm[];
6
- List: React.NamedExoticComponent<import("./interface").IFormListProps>;
7
- Item: React.NamedExoticComponent<import("./interface").IFormItem>;
8
- };
9
- export default TntdForm;
10
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/index.tsx"],"names":[],"mappings":"AAOA,OAAO,KAA2B,MAAM,OAAO,CAAA;AAG/C,OAAO,KAAK,EAAE,KAAK,EAAE,cAAc,EAA0C,MAAM,aAAa,CAAA;AAIhG,QAAA,MAAM,QAAQ;wCAAuC,cAAc;;;;CAoBlE,CAAA;AA4BD,eAAe,QAAQ,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;GAMG;AACH,+CAA+C;AAC/C,mCAAuE;AACvE,mCAAqC;AAErC,6DAAoC;AACpC,6DAAoC;AAEpC,MAAM,QAAQ,GAAG,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAkB,EAAE,EAAE;IACrE,MAAM,UAAU,GAAG,IAAA,cAAM,EAAa;QACpC,gBAAgB,EAAE,EAAE;QACpB,YAAY,EAAE,EAAE;KACjB,CAAC,CAAA;IAEF,MAAM,SAAS,GAAG,IAAA,cAAM,EAAC,EAAE,CAAC,CAAA;IAE5B,OAAO,CACL,8BAAC,mBAAW,CAAC,QAAQ,IACnB,KAAK,EAAE;YACL,IAAI;YACJ,aAAa;YACb,UAAU;YACV,SAAS;SACV,IAEA,QAAQ,CACY,CACxB,CAAA;AACH,CAAC,CAAA;AAED,QAAQ,CAAC,OAAO,GAAG,GAAG,EAAE;IACtB,MAAM,IAAI,GAAuB,IAAA,cAAM,EAAQ;QAC7C,SAAS,EAAE,EAAE;QACb,QAAQ,EAAE,EAAE;QACZ,cAAc,EAAE,GAAG,EAAE,CAAC,IAAA,sBAAc,EAAC,IAAI,CAAC,OAAO,CAAC;QAClD,cAAc,EAAE,GAAG,EAAE,CAAC,IAAA,sBAAc,EAAC,IAAI,CAAC,OAAO,CAAC;QAClD,aAAa,EAAE,CAAC,KAAoB,EAAE,EAAE,CAAC,IAAA,qBAAa,EAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;QAC3E,cAAc,EAAE,CAAC,GAA+B,EAAE,EAAE;YAClD,KAAK,MAAM,CAAC,IAAI,GAAG,EAAE;gBACnB,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE;oBAChD,MAAM,MAAM,GAAG,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,KAAK,CAAC,GAAG,CAAC,KAAI,EAAE,CAAA;oBAClC,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,EAAE,CAAA;oBACzB,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;wBACzD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;qBACnE;iBACF;aACF;QACH,CAAC;KACF,CAAC,CAAA;IAEF,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;AACvB,CAAC,CAAA;AAED,QAAQ,CAAC,IAAI,GAAG,cAAI,CAAA;AACpB,QAAQ,CAAC,IAAI,GAAG,cAAI,CAAA;AAEpB,kBAAe,QAAQ,CAAA","sourcesContent":["/*\n * @Descripttion: 高性能动态增删form表单\n * @Author: 郑泳健\n * @Date: 2023-02-16 10:43:03\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-04-06 15:32:07\n */\nimport React, { useState, useRef } from 'react'\nimport { validateFields, getFieldsValue, getFieldValue } from './utils'\nimport { FormContext } from './store'\nimport type { IForm, ITntdFormProps, IObject, TinitialValueType, IUpdateObj } from './interface'\nimport List from './components/List'\nimport Item from './components/Item'\n\nconst TntdForm = ({ form, initialValues, children }: ITntdFormProps) => {\n const updateRefs = useRef<IUpdateObj>({\n shouldUpdateList: [],\n dependencies: {},\n })\n\n const compsRefs = useRef({})\n\n return (\n <FormContext.Provider\n value={{\n form,\n initialValues,\n updateRefs,\n compsRefs,\n }}\n >\n {children}\n </FormContext.Provider>\n )\n}\n\nTntdForm.useForm = () => {\n const form: { current: IForm } = useRef<IForm>({\n dataLevel: {},\n formData: {},\n validateFields: () => validateFields(form.current),\n getFieldsValue: () => getFieldsValue(form.current),\n getFieldValue: (field: Array<string>) => getFieldValue(form.current, field),\n setFieldsValue: (obj: IObject<TinitialValueType>) => {\n for (const i in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, i)) {\n const prefix = i?.split('.') || []\n const attr = prefix.pop()\n if (attr && form.current.formData[prefix.join('.')][attr]) {\n form.current.formData[prefix.join('.')][attr].setItemValue(obj[i])\n }\n }\n }\n },\n })\n\n return [form.current]\n}\n\nTntdForm.List = List\nTntdForm.Item = Item\n\nexport default TntdForm\n"]}
@@ -1,93 +0,0 @@
1
- /// <reference types="react" />
2
- /**
3
- * 层级
4
- */
5
- export interface ILevel {
6
- key?: number;
7
- name?: string;
8
- }
9
- export interface IObject<T> {
10
- [key: string]: T;
11
- }
12
- export declare type TinitialValueType = null | undefined | string | number | boolean;
13
- /**
14
- * 每一个单元格的信息
15
- */
16
- export interface IFormItemData {
17
- /** 每个formItem的值 */
18
- value: TinitialValueType;
19
- /** 每个formItem的错误信息 */
20
- errorMsg: string | undefined;
21
- /** 每个formItem的校验方法, 返回值为该formItem的错误信息,同时会在formItem下面显示错误信息 */
22
- checkItem: () => string | undefined;
23
- /** 给某个formItem设置值 */
24
- setItemValue: (value: TinitialValueType, callback?: () => void) => void;
25
- }
26
- export interface IForm {
27
- /** 记录每一层级的顺序 */
28
- dataLevel: IObject<ILevel[]>;
29
- /** 整个form的数据,{content.0: { id: IFormItemData, value: IFormItemData }} */
30
- formData: IFormData;
31
- /** 先校验,并将结果返回 */
32
- validateFields: () => Promise<any>;
33
- /** 获取form表单的数据 */
34
- getFieldsValue: () => object;
35
- /** 获取formItem的数据 */
36
- getFieldValue: (field: Array<string>) => any;
37
- /** 给某些formItem设置数据 */
38
- setFieldsValue: (fileds: IObject<TinitialValueType>) => void;
39
- }
40
- /**
41
- * TntdForm的props
42
- */
43
- export interface ITntdFormProps {
44
- form: IForm;
45
- initialValues: object;
46
- children: React.ReactNode;
47
- }
48
- export interface IUpdateObj {
49
- shouldUpdateList: Array<string>;
50
- dependencies: IObject<string[] | string>;
51
- }
52
- export interface IFormContext {
53
- form?: IForm;
54
- initialValues?: IObject<any>;
55
- updateRefs: React.MutableRefObject<IUpdateObj>;
56
- compsRefs: React.MutableRefObject<IObject<() => void>>;
57
- }
58
- /** formList的props */
59
- export interface IFormListProps {
60
- name: string[] | string;
61
- children: (dataLevel: ILevel[], { add, remove }: {
62
- add: TAddOrRemove;
63
- remove: TAddOrRemove;
64
- }) => void;
65
- }
66
- /** 增删事件 */
67
- export declare type TAddOrRemove = (index: number) => void;
68
- export declare type IFormItem = {
69
- name: string[] | string;
70
- children: React.ReactChild | React.ReactChild[];
71
- style: React.CSSProperties;
72
- rules: ValidationRule;
73
- shouldUpdate: boolean;
74
- initialValue: TinitialValueType;
75
- dependencies?: Array<string[] | string>;
76
- } & IFormContext;
77
- export interface ValidationRule {
78
- /** validation error message */
79
- message?: React.ReactNode;
80
- /** indicates whether field is required */
81
- required?: boolean;
82
- /** custom validate function (Note: callback must be called) */
83
- validator?: (rule: any, value: any, callback: any) => any;
84
- }
85
- export interface IFormData {
86
- [name: string]: {
87
- [attr: string]: IFormItemData;
88
- };
89
- }
90
- export interface IChildrenCompFun {
91
- onRefresh: () => void;
92
- }
93
- //# sourceMappingURL=interface.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/interface.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"interface.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/interface.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * 层级\n */\nexport interface ILevel {\n key?: number\n name?: string\n}\n\nexport interface IObject<T> {\n [key: string]: T\n}\n\nexport type TinitialValueType = null | undefined | string | number | boolean\n\n/**\n * 每一个单元格的信息\n */\nexport interface IFormItemData {\n /** 每个formItem的值 */\n value: TinitialValueType\n /** 每个formItem的错误信息 */\n errorMsg: string | undefined\n /** 每个formItem的校验方法, 返回值为该formItem的错误信息,同时会在formItem下面显示错误信息 */\n checkItem: () => string | undefined\n /** 给某个formItem设置值 */\n setItemValue: (value: TinitialValueType, callback?: () => void) => void\n}\n\nexport interface IForm {\n /** 记录每一层级的顺序 */\n dataLevel: IObject<ILevel[]>\n /** 整个form的数据,{content.0: { id: IFormItemData, value: IFormItemData }} */\n formData: IFormData\n /** 先校验,并将结果返回 */\n validateFields: () => Promise<any>\n /** 获取form表单的数据 */\n getFieldsValue: () => object\n /** 获取formItem的数据 */\n getFieldValue: (field: Array<string>) => any\n /** 给某些formItem设置数据 */\n setFieldsValue: (fileds: IObject<TinitialValueType>) => void\n}\n\n/**\n * TntdForm的props\n */\nexport interface ITntdFormProps {\n form: IForm\n initialValues: object\n children: React.ReactNode\n}\n\nexport interface IUpdateObj {\n shouldUpdateList: Array<string>\n dependencies: IObject<string[] | string>\n}\n\nexport interface IFormContext {\n form?: IForm\n initialValues?: IObject<any>\n updateRefs: React.MutableRefObject<IUpdateObj>\n compsRefs: React.MutableRefObject<IObject<() => void>>\n}\n\n/** formList的props */\nexport interface IFormListProps {\n name: string[] | string\n children: (\n dataLevel: ILevel[],\n { add, remove }: { add: TAddOrRemove; remove: TAddOrRemove }\n ) => void\n}\n\n/** 增删事件 */\nexport type TAddOrRemove = (index: number) => void\n\nexport type IFormItem = {\n name: string[] | string\n children: React.ReactChild | React.ReactChild[]\n style: React.CSSProperties\n rules: ValidationRule\n shouldUpdate: boolean\n initialValue: TinitialValueType\n dependencies?: Array<string[] | string>\n} & IFormContext\n\n/** 将某个不可选属性变成必选 */\ntype CustomRequired<T, K extends keyof T> = {\n [P in K]-?: T[P]\n} & Omit<T, K>\n\nexport interface ValidationRule {\n /** validation error message */\n message?: React.ReactNode\n /** indicates whether field is required */\n required?: boolean\n /** custom validate function (Note: callback must be called) */\n validator?: (rule: any, value: any, callback: any) => any\n}\n\nexport interface IFormData {\n [name: string]: {\n [attr: string]: IFormItemData\n }\n}\n\nexport interface IChildrenCompFun {\n onRefresh: () => void\n}\n"]}
@@ -1,4 +0,0 @@
1
- import React from 'react';
2
- import type { IFormContext } from './interface';
3
- export declare const FormContext: React.Context<IFormContext>;
4
- //# sourceMappingURL=store.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAE/C,eAAO,MAAM,WAAW,6BAAwD,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/store.ts"],"names":[],"mappings":";;;;;;AAAA,kDAAyB;AAGZ,QAAA,WAAW,GAAG,eAAK,CAAC,aAAa,CAAe,EAAkB,CAAC,CAAA","sourcesContent":["import React from 'react'\nimport type { IFormContext } from './interface'\n\nexport const FormContext = React.createContext<IFormContext>({} as IFormContext)\n"]}
@@ -1,48 +0,0 @@
1
- import type { TinitialValueType, ValidationRule, IForm, IObject, ILevel, IFormData } from './interface';
2
- export declare const isValidKey: (key: string | number | symbol, object: object) => key is never;
3
- /**
4
- * 将xx.xx.xx 转换为数组
5
- * @param {*} name
6
- * @returns
7
- */
8
- export declare const getNames: (name: string[] | string) => string[];
9
- /**
10
- * 对数据进行校验
11
- * @param {*} list
12
- * @param {*} dataLevel
13
- * @param {*} formData
14
- * @returns
15
- */
16
- export declare const recursionCheck: (list: any, dataLevel: IObject<ILevel[]>, formData: IFormData, errorList?: string[]) => string[];
17
- /**
18
- * 将数据进行排序
19
- * @param {*} list
20
- * @param {*} dataLevel
21
- * @param {*} formData
22
- * @param {*} errorList
23
- * @returns
24
- */
25
- export declare const recursionSort: (list: any, dataLevel: IObject<ILevel[]>, formData: IFormData) => any;
26
- /**
27
- * 获取form表单的value
28
- * @param {*} formCurrent
29
- * @returns
30
- */
31
- export declare const getFieldsValue: (formCurrent: IForm) => any;
32
- /**
33
- * 获取form表单的value
34
- * @param {*} formCurrent
35
- * @returns
36
- */
37
- export declare const getFieldValue: (formCurrent: IForm, field: string[]) => any;
38
- /**
39
- * 提交时候校验的方法
40
- * @param {*} formCurrent
41
- * @returns
42
- */
43
- export declare const validateFields: (formCurrent: IForm) => Promise<unknown>;
44
- /** 获取初始化的值 */
45
- export declare const getInitValue: (initialValues: IObject<any> | undefined, names: string[] | string) => TinitialValueType;
46
- /** 校验表单是否正确的方法 */
47
- export declare const handleCheckItem: (value: TinitialValueType, rules: ValidationRule) => string | undefined;
48
- //# sourceMappingURL=utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,cAAc,EACd,KAAK,EACL,OAAO,EACP,MAAM,EACN,SAAS,EACV,MAAM,aAAa,CAAA;AAEpB,eAAO,MAAM,UAAU,QAChB,MAAM,GAAG,MAAM,GAAG,MAAM,UACrB,MAAM,iBAGf,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,QAAQ,SAAU,MAAM,EAAE,GAAG,MAAM,aAS/C,CAAA;AAED;;;;;;GAMG;AACH,eAAO,MAAM,cAAc,SACnB,GAAG,aACE,QAAQ,MAAM,EAAE,CAAC,YAClB,SAAS,cACR,MAAM,EAAE,aA4BpB,CAAA;AAED;;;;;;;GAOG;AACH,eAAO,MAAM,aAAa,SAAU,GAAG,aAAa,QAAQ,MAAM,EAAE,CAAC,YAAY,SAAS,QA6CzF,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,cAAc,gBAAiB,KAAK,QAwBhD,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,aAAa,gBAAiB,KAAK,SAAS,MAAM,EAAE,QAYhE,CAAA;AAED;;;;GAIG;AACH,eAAO,MAAM,cAAc,gBAAiB,KAAK,qBAmBhD,CAAA;AAED,cAAc;AACd,eAAO,MAAM,YAAY,kBACR,QAAQ,GAAG,CAAC,GAAG,SAAS,SAChC,MAAM,EAAE,GAAG,MAAM,KACvB,iBAgBF,CAAA;AAED,kBAAkB;AAClB,eAAO,MAAM,eAAe,UAAW,iBAAiB,SAAS,cAAc,uBAuB9E,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/tntd-form/TntdForm/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n TinitialValueType,\n ValidationRule,\n IForm,\n IObject,\n ILevel,\n IFormData,\n} from './interface'\n\nexport const isValidKey = (\n key: string | number | symbol,\n object: object\n): key is keyof typeof object => {\n return key in object\n}\n\n/**\n * 将xx.xx.xx 转换为数组\n * @param {*} name\n * @returns\n */\nexport const getNames = (name: string[] | string) => {\n let attrs = []\n if (Array.isArray(name)) {\n const [str, ...rest] = name\n attrs = str.split('.').concat(rest)\n } else {\n attrs = typeof name === 'string' ? name.split('.') : []\n }\n return attrs\n}\n\n/**\n * 对数据进行校验\n * @param {*} list\n * @param {*} dataLevel\n * @param {*} formData\n * @returns\n */\nexport const recursionCheck = (\n list: any,\n dataLevel: IObject<ILevel[]>,\n formData: IFormData,\n errorList: string[] = []\n) => {\n try {\n if (Array.isArray(list)) {\n list.forEach((item) => {\n const key = item.name\n const attrs = Object.keys(formData[key])\n\n attrs.forEach((attr) => {\n const error = formData[item.name][attr]?.checkItem()\n if (error) {\n errorList.push(`${[item.name + '.' + attr]}:`, error)\n }\n })\n if (dataLevel[key]) {\n recursionCheck(dataLevel[key], dataLevel, formData, errorList)\n }\n })\n }\n return errorList\n } catch (e) {\n if (typeof e === 'string') {\n throw e.toUpperCase()\n } else if (e instanceof Error) {\n throw e.message\n }\n throw e\n }\n}\n\n/**\n * 将数据进行排序\n * @param {*} list\n * @param {*} dataLevel\n * @param {*} formData\n * @param {*} errorList\n * @returns\n */\nexport const recursionSort = (list: any, dataLevel: IObject<ILevel[]>, formData: IFormData) => {\n try {\n if (Array.isArray(list)) {\n const values = list.reduce((total, item, index) => {\n const attrObj: IObject<TinitialValueType> = {}\n const key = item.name\n const prefixs = key.split('.')\n const attrs = formData[key] ? Object.keys(formData[key]) : []\n\n attrs.forEach((attr) => {\n attrObj[attr] = formData[key][attr]?.value\n })\n let children = []\n if (dataLevel[key]) {\n children = recursionSort(dataLevel[key], dataLevel, formData)\n }\n\n const len = prefixs.length - 2\n if (total[prefixs[len]]) {\n total[prefixs[len]][index] = {\n ...attrObj,\n ...(children || []),\n }\n } else {\n total[prefixs[len]] = [\n {\n ...attrObj,\n ...(children || []),\n },\n ]\n }\n return total\n }, {})\n return values\n }\n } catch (e) {\n if (typeof e === 'string') {\n console.error(e.toUpperCase())\n throw e.toUpperCase()\n } else if (e instanceof Error) {\n console.error(e.message)\n throw e.message\n }\n throw e\n }\n}\n\n/**\n * 获取form表单的value\n * @param {*} formCurrent\n * @returns\n */\nexport const getFieldsValue = (formCurrent: IForm) => {\n try {\n const { formData, dataLevel } = formCurrent\n let firstKey = ''\n // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序\n for (const i in dataLevel) {\n if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {\n firstKey = i\n break\n }\n }\n const recursionStart = dataLevel[firstKey]\n const values = recursionSort(recursionStart, dataLevel, formData)\n return values\n } catch (e) {\n if (typeof e === 'string') {\n console.error(e.toUpperCase())\n return e.toUpperCase()\n } else if (e instanceof Error) {\n console.error(e.message)\n return e.message\n }\n return e\n }\n}\n\n/**\n * 获取form表单的value\n * @param {*} formCurrent\n * @returns\n */\nexport const getFieldValue = (formCurrent: IForm, field: string[]) => {\n try {\n const { formData } = formCurrent\n return formData && formData?.[field[0]]?.[field[1]]?.value\n } catch (e) {\n if (typeof e === 'string') {\n return e.toUpperCase()\n } else if (e instanceof Error) {\n return e.message\n }\n return e\n }\n}\n\n/**\n * 提交时候校验的方法\n * @param {*} formCurrent\n * @returns\n */\nexport const validateFields = (formCurrent: IForm) => {\n return new Promise((resolve) => {\n const { formData, dataLevel } = formCurrent\n let firstKey = ''\n // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序\n for (const i in dataLevel) {\n if (Object.prototype.hasOwnProperty.call(dataLevel, i)) {\n firstKey = i\n break\n }\n }\n const recursionStart = dataLevel[firstKey]\n const errorList = recursionCheck(recursionStart, dataLevel, formData)\n if (Array.isArray(errorList) && errorList.length) {\n console.error(JSON.stringify(errorList))\n } else {\n resolve(recursionSort(recursionStart, dataLevel, formData))\n }\n })\n}\n\n/** 获取初始化的值 */\nexport const getInitValue = (\n initialValues: IObject<any> | undefined,\n names: string[] | string\n): TinitialValueType => {\n let keys: string[] = []\n if (Array.isArray(names)) {\n const [str, ...rest] = names\n keys = str.split('.').concat(rest)\n }\n\n if (Array.isArray(keys) && !!keys.length) {\n keys.forEach((i) => {\n initialValues = ['', null, undefined].includes(initialValues?.[i])\n ? undefined\n : initialValues?.[i]\n })\n }\n\n return initialValues as TinitialValueType\n}\n\n/** 校验表单是否正确的方法 */\nexport const handleCheckItem = (value: TinitialValueType, rules: ValidationRule) => {\n try {\n if (Array.isArray(rules)) {\n rules.forEach((i) => {\n // @ts-ignore\n if (i.required && ['', null, undefined].includes(value)) {\n throw new Error(i?.message || 'error')\n }\n if (i?.validator) {\n i.validator(rules, value, function (_errorMsg: string) {\n throw new Error(_errorMsg)\n })\n }\n })\n }\n return\n } catch (e) {\n if (typeof e === 'string') {\n return e.toUpperCase()\n } else if (e instanceof Error) {\n return e.message\n }\n }\n}\n"]}
@@ -1,5 +0,0 @@
1
- import type { Meta, Story } from '@tntd/storybook-react-storykit';
2
- declare const _default: Meta<import("@tntd/storybook-react-storykit").Args>;
3
- export default _default;
4
- export declare const Common: Story<{}>;
5
- //# sourceMappingURL=tntdLayout.stories.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tntdLayout.stories.d.ts","sourceRoot":"","sources":["../../src/tntd-layout/tntdLayout.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,gCAAgC,CAAA;;AAQjE,wBAGS;AA0TT,eAAO,MAAM,MAAM,WAAoB,CAAA"}