tntd 2.0.19 → 2.0.20

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 (171) hide show
  1. package/es/array-input/style/index.js +1 -0
  2. package/es/array-input/style/index.js.map +1 -0
  3. package/es/auth-context/style/index.js +1 -0
  4. package/es/auth-context/style/index.js.map +1 -0
  5. package/es/development-login/style/index.js +1 -0
  6. package/es/development-login/style/index.js.map +1 -0
  7. package/es/ellipsis/style/index.js +1 -0
  8. package/es/ellipsis/style/index.js.map +1 -0
  9. package/es/empty/render-empty.js +22 -0
  10. package/es/empty/render-empty.js.map +1 -0
  11. package/es/empty/style/index.js +2 -0
  12. package/es/empty/style/index.js.map +1 -0
  13. package/es/handle/style/index.js +1 -0
  14. package/es/handle/style/index.js.map +1 -0
  15. package/es/icon-list/style/index.js +1 -0
  16. package/es/icon-list/style/index.js.map +1 -0
  17. package/es/img/style/index.js +1 -0
  18. package/es/img/style/index.js.map +1 -0
  19. package/es/loading-button/style/index.js +1 -0
  20. package/es/loading-button/style/index.js.map +1 -0
  21. package/es/page/style/index.js +1 -0
  22. package/es/page/style/index.js.map +1 -0
  23. package/es/query-form/style/index.js +1 -0
  24. package/es/query-form/style/index.js.map +1 -0
  25. package/es/query-list-scene/style/index.js +1 -0
  26. package/es/query-list-scene/style/index.js.map +1 -0
  27. package/es/render-empty/style/index.js +1 -0
  28. package/es/render-empty/style/index.js.map +1 -0
  29. package/es/table/style/index.js +2 -0
  30. package/es/table/style/index.js.map +1 -0
  31. package/es/table/table.js +4 -1
  32. package/es/table/table.js.map +1 -1
  33. package/es/table/table.less +7 -0
  34. package/es/title/style/index.js +1 -0
  35. package/es/title/style/index.js.map +1 -0
  36. package/es/tntd-icon/style/index.js +1 -0
  37. package/es/tntd-icon/style/index.js.map +1 -0
  38. package/es/tntd-layout/style/index.js +1 -0
  39. package/es/tntd-layout/style/index.js.map +1 -0
  40. package/es/tntd-modal/style/index.js +1 -0
  41. package/es/tntd-modal/style/index.js.map +1 -0
  42. package/es/tntd-select/style/index.js +1 -0
  43. package/es/tntd-select/style/index.js.map +1 -0
  44. package/lib/array-input/style/index.d.ts +1 -0
  45. package/lib/array-input/style/index.d.ts.map +1 -0
  46. package/lib/array-input/style/index.js +1 -0
  47. package/lib/array-input/style/index.js.map +1 -0
  48. package/lib/auth-context/style/index.d.ts +1 -0
  49. package/lib/auth-context/style/index.d.ts.map +1 -0
  50. package/lib/auth-context/style/index.js +1 -0
  51. package/lib/auth-context/style/index.js.map +1 -0
  52. package/lib/development-login/style/index.d.ts +1 -0
  53. package/lib/development-login/style/index.d.ts.map +1 -0
  54. package/lib/development-login/style/index.js +1 -0
  55. package/lib/development-login/style/index.js.map +1 -0
  56. package/lib/ellipsis/style/index.d.ts +1 -0
  57. package/lib/ellipsis/style/index.d.ts.map +1 -0
  58. package/lib/ellipsis/style/index.js +1 -0
  59. package/lib/ellipsis/style/index.js.map +1 -0
  60. package/lib/empty/render-empty.d.ts +3 -0
  61. package/lib/empty/render-empty.d.ts.map +1 -0
  62. package/lib/empty/render-empty.js +32 -0
  63. package/lib/empty/render-empty.js.map +1 -0
  64. package/lib/empty/style/index.d.ts +3 -0
  65. package/lib/empty/style/index.d.ts.map +1 -0
  66. package/lib/empty/style/index.js +4 -0
  67. package/lib/empty/style/index.js.map +1 -0
  68. package/lib/handle/style/index.d.ts +1 -0
  69. package/lib/handle/style/index.d.ts.map +1 -0
  70. package/lib/handle/style/index.js +1 -0
  71. package/lib/handle/style/index.js.map +1 -0
  72. package/lib/icon-list/style/index.d.ts +3 -0
  73. package/lib/icon-list/style/index.d.ts.map +1 -0
  74. package/lib/icon-list/style/index.js +8 -0
  75. package/lib/icon-list/style/index.js.map +1 -0
  76. package/lib/img/style/index.d.ts +1 -0
  77. package/lib/img/style/index.d.ts.map +1 -0
  78. package/lib/img/style/index.js +1 -0
  79. package/lib/img/style/index.js.map +1 -0
  80. package/lib/loading-button/style/index.d.ts +1 -0
  81. package/lib/loading-button/style/index.d.ts.map +1 -0
  82. package/lib/loading-button/style/index.js +1 -0
  83. package/lib/loading-button/style/index.js.map +1 -0
  84. package/lib/page/style/index.d.ts +1 -0
  85. package/lib/page/style/index.d.ts.map +1 -0
  86. package/lib/page/style/index.js +1 -0
  87. package/lib/page/style/index.js.map +1 -0
  88. package/lib/query-form/style/index.d.ts +1 -0
  89. package/lib/query-form/style/index.d.ts.map +1 -0
  90. package/lib/query-form/style/index.js +1 -0
  91. package/lib/query-form/style/index.js.map +1 -0
  92. package/lib/query-list-scene/style/index.d.ts +1 -0
  93. package/lib/query-list-scene/style/index.d.ts.map +1 -0
  94. package/lib/query-list-scene/style/index.js +1 -0
  95. package/lib/query-list-scene/style/index.js.map +1 -0
  96. package/lib/render-empty/style/index.d.ts +2 -0
  97. package/lib/render-empty/style/index.d.ts.map +1 -0
  98. package/lib/render-empty/style/index.js +3 -0
  99. package/lib/render-empty/style/index.js.map +1 -0
  100. package/lib/table/style/index.d.ts +3 -0
  101. package/lib/table/style/index.d.ts.map +1 -0
  102. package/lib/table/style/index.js +4 -0
  103. package/lib/table/style/index.js.map +1 -0
  104. package/lib/table/table.d.ts +2 -1
  105. package/lib/table/table.d.ts.map +1 -1
  106. package/lib/table/table.js +4 -2
  107. package/lib/table/table.js.map +1 -1
  108. package/lib/table/table.less +7 -0
  109. package/lib/title/style/index.d.ts +1 -0
  110. package/lib/title/style/index.d.ts.map +1 -0
  111. package/lib/title/style/index.js +1 -0
  112. package/lib/title/style/index.js.map +1 -0
  113. package/lib/tntd-icon/style/index.d.ts +1 -0
  114. package/lib/tntd-icon/style/index.d.ts.map +1 -0
  115. package/lib/tntd-icon/style/index.js +1 -0
  116. package/lib/tntd-icon/style/index.js.map +1 -0
  117. package/lib/tntd-layout/style/index.d.ts +1 -0
  118. package/lib/tntd-layout/style/index.d.ts.map +1 -0
  119. package/lib/tntd-layout/style/index.js +1 -0
  120. package/lib/tntd-layout/style/index.js.map +1 -0
  121. package/lib/tntd-modal/style/index.d.ts +1 -0
  122. package/lib/tntd-modal/style/index.d.ts.map +1 -0
  123. package/lib/tntd-modal/style/index.js +1 -0
  124. package/lib/tntd-modal/style/index.js.map +1 -0
  125. package/lib/tntd-select/style/index.d.ts +1 -0
  126. package/lib/tntd-select/style/index.d.ts.map +1 -0
  127. package/lib/tntd-select/style/index.js +1 -0
  128. package/lib/tntd-select/style/index.js.map +1 -0
  129. package/package.json +1 -1
  130. package/es/tntd-form/CustomForm/components/Item.js +0 -40
  131. package/es/tntd-form/CustomForm/components/Item.js.map +0 -1
  132. package/es/tntd-form/CustomForm/components/ItemComp.js +0 -149
  133. package/es/tntd-form/CustomForm/components/ItemComp.js.map +0 -1
  134. package/es/tntd-form/CustomForm/components/List.js +0 -75
  135. package/es/tntd-form/CustomForm/components/List.js.map +0 -1
  136. package/es/tntd-form/CustomForm/index.js +0 -48
  137. package/es/tntd-form/CustomForm/index.js.map +0 -1
  138. package/es/tntd-form/CustomForm/interface.js +0 -1
  139. package/es/tntd-form/CustomForm/interface.js.map +0 -1
  140. package/es/tntd-form/CustomForm/store.js +0 -2
  141. package/es/tntd-form/CustomForm/store.js.map +0 -1
  142. package/es/tntd-form/CustomForm/utils.js +0 -215
  143. package/es/tntd-form/CustomForm/utils.js.map +0 -1
  144. package/lib/tntd-form/CustomForm/components/Item.d.ts +0 -5
  145. package/lib/tntd-form/CustomForm/components/Item.d.ts.map +0 -1
  146. package/lib/tntd-form/CustomForm/components/Item.js +0 -50
  147. package/lib/tntd-form/CustomForm/components/Item.js.map +0 -1
  148. package/lib/tntd-form/CustomForm/components/ItemComp.d.ts +0 -5
  149. package/lib/tntd-form/CustomForm/components/ItemComp.d.ts.map +0 -1
  150. package/lib/tntd-form/CustomForm/components/ItemComp.js +0 -169
  151. package/lib/tntd-form/CustomForm/components/ItemComp.js.map +0 -1
  152. package/lib/tntd-form/CustomForm/components/List.d.ts +0 -5
  153. package/lib/tntd-form/CustomForm/components/List.d.ts.map +0 -1
  154. package/lib/tntd-form/CustomForm/components/List.js +0 -96
  155. package/lib/tntd-form/CustomForm/components/List.js.map +0 -1
  156. package/lib/tntd-form/CustomForm/index.d.ts +0 -10
  157. package/lib/tntd-form/CustomForm/index.d.ts.map +0 -1
  158. package/lib/tntd-form/CustomForm/index.js +0 -66
  159. package/lib/tntd-form/CustomForm/index.js.map +0 -1
  160. package/lib/tntd-form/CustomForm/interface.d.ts +0 -88
  161. package/lib/tntd-form/CustomForm/interface.d.ts.map +0 -1
  162. package/lib/tntd-form/CustomForm/interface.js +0 -5
  163. package/lib/tntd-form/CustomForm/interface.js.map +0 -1
  164. package/lib/tntd-form/CustomForm/store.d.ts +0 -4
  165. package/lib/tntd-form/CustomForm/store.d.ts.map +0 -1
  166. package/lib/tntd-form/CustomForm/store.js +0 -10
  167. package/lib/tntd-form/CustomForm/store.js.map +0 -1
  168. package/lib/tntd-form/CustomForm/utils.d.ts +0 -48
  169. package/lib/tntd-form/CustomForm/utils.d.ts.map +0 -1
  170. package/lib/tntd-form/CustomForm/utils.js +0 -235
  171. package/lib/tntd-form/CustomForm/utils.js.map +0 -1
@@ -1,215 +0,0 @@
1
- /**
2
- * 将xx.xx.xx 转换为数组
3
- * @param {*} name
4
- * @returns
5
- */
6
- export const getNames = name => {
7
- let attrs = [];
8
- if (Array.isArray(name)) {
9
- const [str, ...rest] = name;
10
- attrs = str.split('.').concat(rest);
11
- } else {
12
- attrs = typeof name === 'string' ? name.split('.') : [];
13
- }
14
- return attrs;
15
- };
16
- /**
17
- * 对数据进行校验
18
- * @param {*} list
19
- * @param {*} dataLevel
20
- * @param {*} formData
21
- * @returns
22
- */
23
- export const recursionCheck = (list, dataLevel, formData, errorList = []) => {
24
- try {
25
- if (Array.isArray(list)) {
26
- list.forEach(item => {
27
- const key = item.name;
28
- const attrs = Object.keys(formData[key]);
29
- attrs.forEach(attr => {
30
- var _a;
31
- const error = (_a = formData[item.name][attr]) === null || _a === void 0 ? void 0 : _a.checkItem();
32
- if (error) {
33
- errorList.push(`${[item.name + '.' + attr]}:`, error);
34
- }
35
- });
36
- if (dataLevel[key]) {
37
- recursionCheck(dataLevel[key], dataLevel, formData, errorList);
38
- }
39
- });
40
- }
41
- return errorList;
42
- } catch (e) {
43
- if (typeof e === 'string') {
44
- throw e.toUpperCase();
45
- } else if (e instanceof Error) {
46
- throw e.message;
47
- }
48
- throw e;
49
- }
50
- };
51
- /**
52
- * 将数据进行排序
53
- * @param {*} list
54
- * @param {*} dataLevel
55
- * @param {*} formData
56
- * @param {*} errorList
57
- * @returns
58
- */
59
- export const recursionSort = (list, dataLevel, formData) => {
60
- try {
61
- if (Array.isArray(list)) {
62
- const values = list.reduce((total, item, index) => {
63
- const attrObj = {};
64
- const key = item.name;
65
- const prefixs = key.split('.');
66
- const attrs = Object.keys(formData[key]);
67
- attrs.forEach(attr => {
68
- var _a;
69
- attrObj[attr] = (_a = formData[key][attr]) === null || _a === void 0 ? void 0 : _a.value;
70
- });
71
- let children = [];
72
- if (dataLevel[key]) {
73
- children = recursionSort(dataLevel[key], dataLevel, formData);
74
- }
75
- const len = prefixs.length - 2;
76
- if (total[prefixs[len]]) {
77
- total[prefixs[len]][index] = Object.assign(Object.assign({}, attrObj), children || []);
78
- } else {
79
- total[prefixs[len]] = [Object.assign(Object.assign({}, attrObj), children || [])];
80
- }
81
- return total;
82
- }, {});
83
- return values;
84
- }
85
- } catch (e) {
86
- if (typeof e === 'string') {
87
- console.error(e.toUpperCase());
88
- throw e.toUpperCase();
89
- } else if (e instanceof Error) {
90
- console.error(e.message);
91
- throw e.message;
92
- }
93
- throw e;
94
- }
95
- };
96
- /**
97
- * 获取form表单的value
98
- * @param {*} formCurrent
99
- * @returns
100
- */
101
- export const getFieldsValue = formCurrent => {
102
- try {
103
- const {
104
- formData,
105
- dataLevel
106
- } = formCurrent;
107
- let firstKey = '';
108
- // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序
109
- for (const i in dataLevel) {
110
- firstKey = i;
111
- break;
112
- }
113
- const recursionStart = dataLevel[firstKey];
114
- const values = recursionSort(recursionStart, dataLevel, formData);
115
- return values;
116
- } catch (e) {
117
- if (typeof e === 'string') {
118
- console.error(e.toUpperCase());
119
- return e.toUpperCase();
120
- } else if (e instanceof Error) {
121
- console.error(e.message);
122
- return e.message;
123
- }
124
- return e;
125
- }
126
- };
127
- /**
128
- * 获取form表单的value
129
- * @param {*} formCurrent
130
- * @returns
131
- */
132
- export const getFieldValue = (formCurrent, field) => {
133
- var _a, _b;
134
- try {
135
- const {
136
- formData
137
- } = formCurrent;
138
- return formData && ((_b = (_a = formData === null || formData === void 0 ? void 0 : formData[field[0]]) === null || _a === void 0 ? void 0 : _a[field[1]]) === null || _b === void 0 ? void 0 : _b.value);
139
- } catch (e) {
140
- if (typeof e === 'string') {
141
- return e.toUpperCase();
142
- } else if (e instanceof Error) {
143
- return e.message;
144
- }
145
- return e;
146
- }
147
- };
148
- /**
149
- * 提交时候校验的方法
150
- * @param {*} formCurrent
151
- * @returns
152
- */
153
- export const validateFields = formCurrent => {
154
- return new Promise(resolve => {
155
- const {
156
- formData,
157
- dataLevel
158
- } = formCurrent;
159
- let firstKey = '';
160
- // 这里不直接用Object.keys的原因是Object.keys并不能保证一定是按照属性顺序
161
- for (const i in dataLevel) {
162
- firstKey = i;
163
- break;
164
- }
165
- const recursionStart = dataLevel[firstKey];
166
- const errorList = recursionCheck(recursionStart, dataLevel, formData);
167
- if (Array.isArray(errorList) && errorList.length) {
168
- console.error(JSON.stringify(errorList));
169
- } else {
170
- resolve(recursionSort(recursionStart, dataLevel, formData));
171
- }
172
- });
173
- };
174
- /** 获取初始化的值 */
175
- export const getInitValue = (initialValues, names) => {
176
- let keys;
177
- if (Array.isArray(names)) {
178
- const [str, ...rest] = names;
179
- keys = str.split('.').concat(rest);
180
- }
181
- if (Array.isArray(keys)) {
182
- keys.forEach(i => {
183
- initialValues = ['', null, undefined].includes(initialValues === null || initialValues === void 0 ? void 0 : initialValues[i]) ? undefined : initialValues === null || initialValues === void 0 ? void 0 : initialValues[i];
184
- });
185
- }
186
- return initialValues;
187
- };
188
- /** 校验表单是否正确的方法 */
189
- export const handleCheckItem = (value, rules) => {
190
- try {
191
- if (Array.isArray(rules)) {
192
- rules.forEach(i => {
193
- // @ts-ignore
194
- if (i.required && ['', null, undefined].includes(value)) {
195
- throw new Error((i === null || i === void 0 ? void 0 : i.message) || 'error');
196
- }
197
- if (i === null || i === void 0 ? void 0 : i.validator) {
198
- i.validator(rules, value, function (_errorMsg) {
199
- throw new Error(_errorMsg);
200
- });
201
- }
202
- });
203
- }
204
- return;
205
- } catch (e) {
206
- if (typeof e === 'string') {
207
- return e.toUpperCase();
208
- } else if (e instanceof Error) {
209
- return e.message;
210
- }
211
- }
212
- };
213
- export const isValidKey = (key, object) => {
214
- return key in object;
215
- };
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/tntd-form/CustomForm/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import type { TinitialValueType, ValidationRule, IForm, ILevel, IFormData } from './interface';\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: 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: ILevel[], formData: IFormData) => {\n try {\n if (Array.isArray(list)) {\n const values = list.reduce((total, item, index) => {\n const attrObj = {};\n const key = item.name;\n const prefixs = key.split('.');\n const attrs = 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 firstKey = i;\n break;\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 firstKey = i;\n break;\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 = (initialValues: object | undefined, names: string[] | string) => {\n let keys;\n if (Array.isArray(names)) {\n const [str, ...rest] = names;\n keys = str.split('.').concat(rest);\n }\n\n if (Array.isArray(keys)) {\n keys.forEach((i) => {\n initialValues = ['', null, undefined].includes(initialValues?.[i])\n ? undefined\n : initialValues?.[i];\n });\n }\n\n return initialValues;\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\nexport const isValidKey = (\n key: string | number | symbol,\n object: object,\n): key is keyof typeof object => {\n return key in object;\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/CustomForm/components/Item.tsx"],"names":[],"mappings":"AAQA,OAAO,KAA2B,MAAM,OAAO,CAAC;AAGhD,OAAO,KAAK,EAAE,SAAS,EAAgB,MAAM,cAAc,CAAC;;AAiC5D,wBAA0B"}
@@ -1,50 +0,0 @@
1
- "use strict";
2
-
3
- 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); }
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports["default"] = void 0;
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _ItemComp = _interopRequireDefault(require("./ItemComp"));
10
- var _store = require("../store");
11
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
12
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
13
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
14
- /*
15
- * @Descripttion: CustomForm.Item
16
- * @Author: 郑泳健
17
- * @Date: 2023-02-22 23:25:24
18
- * @LastEditors: 郑泳健
19
- * @LastEditTime: 2023-03-17 16:50:32
20
- */
21
-
22
- var Item = function Item(_ref) {
23
- var name = _ref.name,
24
- children = _ref.children,
25
- style = _ref.style,
26
- rules = _ref.rules,
27
- shouldUpdate = _ref.shouldUpdate,
28
- initialValue = _ref.initialValue,
29
- dependencies = _ref.dependencies;
30
- var _useContext = (0, _react.useContext)(_store.FormContext),
31
- form = _useContext.form,
32
- initialValues = _useContext.initialValues,
33
- currentChangeKeys = _useContext.currentChangeKeys,
34
- setCurrentChangeKeys = _useContext.setCurrentChangeKeys;
35
- return _react["default"].createElement(_ItemComp["default"], Object.assign({}, {
36
- style: style,
37
- rules: rules,
38
- name: name,
39
- children: children,
40
- form: form,
41
- currentChangeKeys: currentChangeKeys,
42
- setCurrentChangeKeys: setCurrentChangeKeys,
43
- initialValues: initialValues,
44
- initialValue: initialValue,
45
- shouldUpdate: shouldUpdate,
46
- dependencies: dependencies
47
- }));
48
- };
49
- var _default = (0, _react.memo)(Item);
50
- exports["default"] = _default;
@@ -1 +0,0 @@
1
- {"version":3,"file":"Item.js","sourceRoot":"","sources":["../../../../src/tntd-form/CustomForm/components/Item.tsx"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,+CAAgD;AAChD,0DAAkC;AAClC,oCAAuC;AAGvC,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,iBAAiB,EAAE,oBAAoB,EAAE,GACpE,IAAA,kBAAU,EAAe,mBAAW,CAAC,CAAC;IAExC,OAAO,CACL,8BAAC,kBAAQ,oBACH;QACF,KAAK;QACL,KAAK;QACL,IAAI;QACJ,QAAQ;QACR,IAAI;QACJ,iBAAiB;QACjB,oBAAoB;QACpB,aAAa;QACb,YAAY;QACZ,YAAY;QACZ,YAAY;KACb,EACD,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,kBAAe,IAAA,YAAI,EAAC,IAAI,CAAC,CAAC","sourcesContent":["/*\n * @Descripttion: CustomForm.Item\n * @Author: 郑泳健\n * @Date: 2023-02-22 23:25:24\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-03-17 16:50:32\n */\n\nimport React, { useContext, memo } from 'react';\nimport ItemComp from './ItemComp';\nimport { FormContext } from '../store';\nimport type { IFormItem, IFormContext } from '../interface';\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, currentChangeKeys, setCurrentChangeKeys } =\n useContext<IFormContext>(FormContext);\n\n return (\n <ItemComp\n {...{\n style,\n rules,\n name,\n children,\n form,\n currentChangeKeys,\n setCurrentChangeKeys,\n initialValues,\n initialValue,\n shouldUpdate,\n dependencies,\n }}\n />\n );\n};\n\nexport default memo(Item);\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/CustomForm/components/ItemComp.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAoC,MAAM,OAAO,CAAC;AAGzD,OAAO,KAAK,EAAE,SAAS,EAAoC,MAAM,cAAc,CAAC;;AAsKhF,wBAA6C"}
@@ -1,169 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports["default"] = void 0;
7
- var _isEqual2 = _interopRequireDefault(require("lodash/isEqual"));
8
- var _react = _interopRequireWildcard(require("react"));
9
- var _utils = require("../utils");
10
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
11
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
12
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
13
- 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); }
14
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
15
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
16
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
17
- function _toArray(arr) { return _arrayWithHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableRest(); }
18
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
19
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
20
- 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."); }
21
- 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); }
22
- 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; }
23
- function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
24
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
25
- var ItemComp = function ItemComp(_ref) {
26
- var form = _ref.form,
27
- name = _ref.name,
28
- children = _ref.children,
29
- style = _ref.style,
30
- initialValues = _ref.initialValues,
31
- initialValue = _ref.initialValue,
32
- rules = _ref.rules,
33
- setCurrentChangeKeys = _ref.setCurrentChangeKeys;
34
- var _useState = (0, _react.useState)(undefined),
35
- _useState2 = _slicedToArray(_useState, 2),
36
- value = _useState2[0],
37
- setValue = _useState2[1];
38
- var _useState3 = (0, _react.useState)(undefined),
39
- _useState4 = _slicedToArray(_useState3, 2),
40
- errorMsg = _useState4[0],
41
- setErrorMsg = _useState4[1];
42
- /**
43
- * 动态修改form内部的值,为啥不在useEffect里面处理的原因是子组件的useEffect会比父组件useEffect先执行,需要保证在子组件useEffect监听value变化的时候获取到的formData永远是最新的
44
- * @param name
45
- * @param value
46
- * @returns
47
- */
48
- var generateFormData = function generateFormData(name, value) {
49
- if (!name || !form) return;
50
- var _name = _toArray(name),
51
- str = _name[0],
52
- rest = _name.slice(1);
53
- rest.forEach(function (i) {
54
- if (form.formData[str]) {
55
- form.formData[str][i].value = value;
56
- form.formData[str][i].checkItem = function () {
57
- var error = (0, _utils.handleCheckItem)(value, rules);
58
- setErrorMsg(error);
59
- return error;
60
- };
61
- } else {
62
- form.formData[str] = _defineProperty({}, i, {
63
- value: value,
64
- checkItem: function checkItem() {
65
- var error = (0, _utils.handleCheckItem)(value, rules);
66
- setErrorMsg(error);
67
- return error;
68
- },
69
- setItemValue: function setItemValue() {},
70
- errorMsg: undefined
71
- });
72
- }
73
- });
74
- };
75
- // 为了给最外层提供方法去校验,比如保存的时候.
76
- // 这里依赖不要添加value,因为子组件的useEffect会比父组件useEffect先执行,如果添加了依赖value会导致子组件获取到的formData永远是上一次的
77
- (0, _react.useEffect)(function () {
78
- if (!name || !form) return;
79
- var _name2 = _toArray(name),
80
- str = _name2[0],
81
- rest = _name2.slice(1);
82
- var addItem = {
83
- setItemValue: function setItemValue(_val, callback) {
84
- var error = (0, _utils.handleCheckItem)(_val, rules);
85
- setValue(_val);
86
- setErrorMsg(error);
87
- callback === null || callback === void 0 ? void 0 : callback();
88
- },
89
- checkItem: function checkItem() {
90
- var error = (0, _utils.handleCheckItem)(value, rules);
91
- setErrorMsg(error);
92
- return error;
93
- },
94
- value: value,
95
- errorMsg: errorMsg
96
- };
97
- rest.forEach(function (i) {
98
- if (form.formData[str]) {
99
- form.formData[str][i] = addItem;
100
- } else {
101
- form.formData[str] = _defineProperty({}, i, addItem);
102
- }
103
- });
104
- }, [rules, name, errorMsg, form]);
105
- /** 这段代码不能删除,当增加/删除列的时候有些默认值需要更新 */
106
- (0, _react.useEffect)(function () {
107
- if (initialValue) {
108
- setValue(initialValue);
109
- generateFormData(name, initialValue);
110
- }
111
- }, [initialValue]);
112
- // 初始化设置默认值,
113
- (0, _react.useEffect)(function () {
114
- var _a;
115
- var initValue = (0, _utils.getInitValue)(initialValues, name);
116
- // @ts-ignore
117
- var _value = ['', null, undefined].includes(initValue) ? initialValue : initValue;
118
- setValue(_value);
119
- generateFormData(name, _value);
120
- if (name) {
121
- setCurrentChangeKeys([(_a = (0, _utils.getNames)(name)) === null || _a === void 0 ? void 0 : _a.join('.')]);
122
- }
123
- }, []);
124
- // 默认方法
125
- var handleChange = function handleChange(e) {
126
- var _a, _b;
127
- var val;
128
- if (_typeof(e) === 'object') {
129
- val = (_a = e === null || e === void 0 ? void 0 : e.target) === null || _a === void 0 ? void 0 : _a.value;
130
- } else {
131
- val = e;
132
- }
133
- setValue(val);
134
- generateFormData(name, val);
135
- var error = (0, _utils.handleCheckItem)(val, rules);
136
- setErrorMsg(error);
137
- if (name) {
138
- setCurrentChangeKeys([(_b = (0, _utils.getNames)(name)) === null || _b === void 0 ? void 0 : _b.join('.')]);
139
- }
140
- };
141
- return _react["default"].createElement("div", {
142
- className: errorMsg ? 'has-error custom-form-item-wrapper' : 'custom-form-item-wrapper',
143
- style: style
144
- }, _react["default"].Children.map(children, function (child) {
145
- var _a;
146
- if (_react["default"].isValidElement(child)) {
147
- return _react["default"].cloneElement(child, Object.assign({
148
- value: value,
149
- form: form,
150
- onChange: handleChange,
151
- 'data-key': (_a = (0, _utils.getNames)(name)) === null || _a === void 0 ? void 0 : _a.join('.')
152
- }, child.props));
153
- }
154
- return null;
155
- }), errorMsg && _react["default"].createElement("div", {
156
- className: "ant-form-explain ant-form-item-explain-error"
157
- }, errorMsg));
158
- };
159
- function arePropsEqual(prevProps, nextProps) {
160
- if (Array.isArray(nextProps.currentChangeKeys) && nextProps.currentChangeKeys.length && (0, _isEqual2["default"])(prevProps.initialValues, nextProps.initialValues) && !nextProps.currentChangeKeys.includes((0, _utils.getNames)(nextProps.name).join('.')) && !nextProps.shouldUpdate && Array.isArray(nextProps.dependencies) && nextProps.dependencies.every(function (i) {
161
- var _a;
162
- return !((_a = nextProps.currentChangeKeys) === null || _a === void 0 ? void 0 : _a.includes((0, _utils.getNames)(i).join('.')));
163
- })) {
164
- return true;
165
- }
166
- return false;
167
- }
168
- var _default = (0, _react.memo)(ItemComp, arePropsEqual);
169
- exports["default"] = _default;
@@ -1 +0,0 @@
1
- {"version":3,"file":"ItemComp.js","sourceRoot":"","sources":["../../../../src/tntd-form/CustomForm/components/ItemComp.tsx"],"names":[],"mappings":"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","sourcesContent":["/*\n * @Descripttion: 对CustomForm.Item进行性能优化\n * @Author: 郑泳健\n * @Date: 2023-02-23 12:47:28\n * @LastEditors: 郑泳健\n * @LastEditTime: 2023-03-17 16:55:35\n */\n\nimport React, { useState, memo, useEffect } from 'react';\nimport { isEqual } from 'lodash';\nimport { getNames, handleCheckItem, getInitValue } from '../utils';\nimport type { IFormItem, IFormItemData, TinitialValueType } from '../interface';\n\nconst ItemComp: React.FC<IFormItem> = ({\n form,\n name,\n children,\n style,\n initialValues,\n initialValue,\n rules,\n setCurrentChangeKeys,\n}) => {\n const [value, setValue] = useState<TinitialValueType>(undefined);\n const [errorMsg, setErrorMsg] = useState<string | undefined>(undefined);\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) 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) 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 },\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 }\n }, [initialValue]);\n\n // 初始化设置默认值,\n useEffect(() => {\n const initValue = getInitValue(initialValues, name) as TinitialValueType;\n // @ts-ignore\n const _value = ['', null, undefined].includes(initValue) ? initialValue : initValue;\n\n setValue(_value);\n generateFormData(name, _value);\n if (name) {\n setCurrentChangeKeys([getNames(name)?.join('.')]);\n }\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 if (name) {\n setCurrentChangeKeys([getNames(name)?.join('.')]);\n }\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\nfunction arePropsEqual(prevProps: IFormItem, nextProps: IFormItem) {\n if (\n Array.isArray(nextProps.currentChangeKeys) &&\n nextProps.currentChangeKeys.length &&\n isEqual(prevProps.initialValues, nextProps.initialValues) &&\n !nextProps.currentChangeKeys.includes(getNames(nextProps.name).join('.')) &&\n !nextProps.shouldUpdate &&\n Array.isArray(nextProps.dependencies) &&\n nextProps.dependencies.every(\n (i) => !nextProps.currentChangeKeys?.includes(getNames(i).join('.')),\n )\n ) {\n return true;\n }\n return false;\n}\n\nexport default memo(ItemComp, arePropsEqual);\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/CustomForm/components/List.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAwD,MAAM,OAAO,CAAC;AAI7E,OAAO,KAAK,EAAE,cAAc,EAAsC,MAAM,cAAc,CAAC;;AA0DvF,wBAKG"}
@@ -1,96 +0,0 @@
1
- "use strict";
2
-
3
- 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); }
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports["default"] = void 0;
8
- var _isEqual2 = _interopRequireDefault(require("lodash/isEqual"));
9
- var _cloneDeep2 = _interopRequireDefault(require("lodash/cloneDeep"));
10
- var _react = _interopRequireWildcard(require("react"));
11
- var _utils = require("../utils");
12
- var _store = require("../store");
13
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
14
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
15
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
16
- function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
17
- function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
18
- 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."); }
19
- 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); }
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
- function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0) { ; } } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
22
- function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
23
- var List = function List(_ref) {
24
- var name = _ref.name,
25
- children = _ref.children;
26
- var maxRef = (0, _react.useRef)(-1);
27
- var _useContext = (0, _react.useContext)(_store.FormContext),
28
- form = _useContext.form,
29
- initialValues = _useContext.initialValues;
30
- var _useState = (0, _react.useState)([]),
31
- _useState2 = _slicedToArray(_useState, 2),
32
- dataLevel = _useState2[0],
33
- setDataLevel = _useState2[1];
34
- (0, _react.useEffect)(function () {
35
- var key = Array.isArray(name) ? name === null || name === void 0 ? void 0 : name[0] : name;
36
- if (form && form.dataLevel) {
37
- form.dataLevel[key] = dataLevel;
38
- }
39
- }, [form, dataLevel, name]);
40
- /** 根据默认数值自动生成dataLevel */
41
- (0, _react.useEffect)(function () {
42
- var dataSource = initialValues;
43
- var attrs = (0, _utils.getNames)(name);
44
- var _iterator = _createForOfIteratorHelper(attrs),
45
- _step;
46
- try {
47
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
48
- var key = _step.value;
49
- dataSource = (dataSource === null || dataSource === void 0 ? void 0 : dataSource[key]) || [{}];
50
- }
51
- } catch (err) {
52
- _iterator.e(err);
53
- } finally {
54
- _iterator.f();
55
- }
56
- if (Array.isArray(dataSource)) {
57
- var _level = dataSource.map(function (i, index) {
58
- return {
59
- key: index,
60
- name: "".concat(attrs.join('.'), ".").concat(index)
61
- };
62
- });
63
- setDataLevel(_level);
64
- maxRef.current = dataSource.length - 1;
65
- }
66
- }, [initialValues, name]);
67
- /** 新增一列 */
68
- var handleAdd = function handleAdd(index) {
69
- var tempDataLevel = (0, _cloneDeep2["default"])(dataLevel);
70
- maxRef.current++;
71
- var attrs = (0, _utils.getNames)(name);
72
- tempDataLevel.splice(index + 1, 0, {
73
- key: maxRef.current,
74
- name: "".concat(attrs === null || attrs === void 0 ? void 0 : attrs.join('.'), ".").concat(maxRef.current)
75
- });
76
- setDataLevel(tempDataLevel);
77
- };
78
- /** 删除一列 */
79
- var handleDel = function handleDel(index) {
80
- var temp = (0, _cloneDeep2["default"])(dataLevel);
81
- temp.splice(index, 1);
82
- setDataLevel(temp);
83
- };
84
- return _react["default"].createElement(_react["default"].Fragment, null, children === null || children === void 0 ? void 0 : children(dataLevel, {
85
- add: handleAdd,
86
- remove: handleDel
87
- }));
88
- };
89
- // name 没有改变就不需要重复render
90
- var _default = (0, _react.memo)(List, function (nextProps, prevProps) {
91
- if ((0, _isEqual2["default"])(nextProps.name, prevProps.name) && !!prevProps.name) {
92
- return true;
93
- }
94
- return false;
95
- });
96
- exports["default"] = _default;
@@ -1 +0,0 @@
1
- {"version":3,"file":"List.js","sourceRoot":"","sources":["../../../../src/tntd-form/CustomForm/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-03-17 16:50:57\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 } from '../interface';\n\nconst List: React.FC<IFormListProps> = ({ name, children }) => {\n const maxRef = useRef(-1);\n const { form, initialValues } = useContext<IFormContext>(FormContext);\n const [dataLevel, setDataLevel] = useState<ILevel[]>([]);\n\n useEffect(() => {\n const key: string = Array.isArray(name) ? name?.[0] : name;\n if (form && form.dataLevel) {\n form.dataLevel[key] = dataLevel;\n }\n }, [form, dataLevel, name]);\n\n /** 根据默认数值自动生成dataLevel */\n useEffect(() => {\n let dataSource = initialValues;\n const attrs = getNames(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 }\n }, [initialValues, name]);\n\n /** 新增一列 */\n const handleAdd: TAddOrRemove = (index) => {\n const tempDataLevel = cloneDeep(dataLevel);\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 };\n\n /** 删除一列 */\n const handleDel: TAddOrRemove = (index) => {\n const temp = cloneDeep(dataLevel);\n temp.splice(index, 1);\n setDataLevel(temp);\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"]}