@bit-sun/business-component 2.4.19 → 2.4.21

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 (197) hide show
  1. package/.editorconfig +16 -16
  2. package/.fatherrc.ts +5 -5
  3. package/.gitlab-ci.yml +179 -179
  4. package/.prettierignore +7 -7
  5. package/.prettierrc +11 -11
  6. package/.umirc.ts +74 -74
  7. package/README.md +27 -27
  8. package/dist/index.esm.js +10 -6
  9. package/dist/index.js +10 -6
  10. package/docs/index.md +21 -21
  11. package/lib/assets/drag.svg +17 -17
  12. package/lib/assets/exportFail.svg +37 -37
  13. package/lib/assets/exportProcessing.svg +28 -28
  14. package/lib/assets/exportSuccess.svg +34 -34
  15. package/lib/assets/label_icon_bottom.svg +25 -25
  16. package/lib/assets/upExport.svg +22 -22
  17. package/package.json +79 -79
  18. package/src/assets/32.svg +27 -27
  19. package/src/assets/addIcon.svg +17 -17
  20. package/src/assets/allfunc.svg +27 -27
  21. package/src/assets/arrowRight.svg +24 -24
  22. package/src/assets/btn-delete.svg +29 -29
  23. package/src/assets/btn-edit.svg +19 -19
  24. package/src/assets/btn-more.svg +17 -17
  25. package/src/assets/btn-submit.svg +19 -19
  26. package/src/assets/caidan.svg +11 -11
  27. package/src/assets/close.svg +26 -26
  28. package/src/assets/drag.svg +17 -17
  29. package/src/assets/exportFail.svg +37 -37
  30. package/src/assets/exportProcessing.svg +28 -28
  31. package/src/assets/exportSuccess.svg +34 -34
  32. package/src/assets/fixed-left-active.svg +11 -11
  33. package/src/assets/fixed-left.svg +15 -15
  34. package/src/assets/fixed-right-active.svg +11 -11
  35. package/src/assets/fixed-right.svg +15 -15
  36. package/src/assets/guanbi.svg +15 -15
  37. package/src/assets/icon-quanping.svg +15 -15
  38. package/src/assets/icon-shezhi.svg +17 -17
  39. package/src/assets/label_icon_bottom.svg +25 -25
  40. package/src/assets/list-no-img.svg +21 -21
  41. package/src/assets/morentouxiang-32.svg +23 -23
  42. package/src/assets/scanning.svg +24 -24
  43. package/src/assets/upExport.svg +22 -22
  44. package/src/common/ENUM.ts +41 -41
  45. package/src/components/Business/AddSelectBusiness/index.md +162 -162
  46. package/src/components/Business/AddSelectBusiness/index.tsx +1061 -1061
  47. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +111 -111
  48. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  49. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  50. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  51. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  52. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  53. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  54. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  55. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  56. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  57. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  58. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  59. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  60. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -157
  61. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  62. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  63. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +155 -155
  64. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  65. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  66. package/src/components/Business/BsLayouts/index.less +79 -79
  67. package/src/components/Business/BsLayouts/index.tsx +1484 -1484
  68. package/src/components/Business/BsLayouts/service.ts +10 -10
  69. package/src/components/Business/BsLayouts/utils.tsx +203 -203
  70. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +566 -566
  71. package/src/components/Business/BsSulaQueryTable/index.less +221 -221
  72. package/src/components/Business/BsSulaQueryTable/index.tsx +558 -558
  73. package/src/components/Business/BsSulaQueryTable/setting.tsx +854 -854
  74. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  75. package/src/components/Business/BsSulaQueryTable/utils.tsx +690 -690
  76. package/src/components/Business/CommodityEntry/index.md +70 -70
  77. package/src/components/Business/CommodityEntry/index.tsx +80 -80
  78. package/src/components/Business/CommonAlert/index.tsx +23 -23
  79. package/src/components/Business/CommonGuideWrapper/index.less +111 -111
  80. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  81. package/src/components/Business/CommonGuideWrapper/index.tsx +83 -83
  82. package/src/components/Business/DetailPageWrapper/index.less +79 -79
  83. package/src/components/Business/DetailPageWrapper/index.tsx +315 -315
  84. package/src/components/Business/DetailPageWrapper/utils.tsx +100 -100
  85. package/src/components/Business/HomePageWrapper/index.less +33 -33
  86. package/src/components/Business/HomePageWrapper/index.md +45 -45
  87. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  88. package/src/components/Business/JsonQueryTable/components/FieldsModifyModal.tsx +824 -824
  89. package/src/components/Business/JsonQueryTable/components/FieldsSettingsTable.tsx +205 -205
  90. package/src/components/Business/JsonQueryTable/components/Formula.tsx +206 -206
  91. package/src/components/Business/JsonQueryTable/components/MaintainOptions.tsx +127 -127
  92. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  93. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  94. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  95. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  96. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  97. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  98. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  99. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  100. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  101. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  102. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  103. package/src/components/Business/JsonQueryTable/function.ts +62 -62
  104. package/src/components/Business/JsonQueryTable/index.less +16 -16
  105. package/src/components/Business/JsonQueryTable/index.md +328 -328
  106. package/src/components/Business/JsonQueryTable/index.tsx +537 -537
  107. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  108. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  109. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  110. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  111. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  112. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  113. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  114. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  115. package/src/components/Business/JsonQueryTable/static.ts +450 -450
  116. package/src/components/Business/SearchSelect/BusinessUtils.ts +2057 -2057
  117. package/src/components/Business/SearchSelect/common.ts +134 -134
  118. package/src/components/Business/SearchSelect/index.md +1444 -1444
  119. package/src/components/Business/SearchSelect/index.tsx +55 -55
  120. package/src/components/Business/SearchSelect/utils.ts +101 -101
  121. package/src/components/Business/StateFlow/index.less +130 -130
  122. package/src/components/Business/StateFlow/index.md +60 -60
  123. package/src/components/Business/StateFlow/index.tsx +29 -29
  124. package/src/components/Business/TreeSearchSelect/index.md +185 -185
  125. package/src/components/Business/TreeSearchSelect/index.tsx +33 -33
  126. package/src/components/Business/TreeSearchSelect/utils.ts +104 -104
  127. package/src/components/Business/columnSettingTable/columnSetting.tsx +766 -766
  128. package/src/components/Business/columnSettingTable/index.less +247 -247
  129. package/src/components/Business/columnSettingTable/index.md +357 -357
  130. package/src/components/Business/columnSettingTable/index.tsx +235 -234
  131. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +243 -242
  132. package/src/components/Business/columnSettingTable/utils.tsx +71 -71
  133. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  134. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  135. package/src/components/Business/moreTreeTable/index.less +99 -99
  136. package/src/components/Business/moreTreeTable/index.md +448 -448
  137. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  138. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  139. package/src/components/Functional/AddSelect/helps.ts +80 -80
  140. package/src/components/Functional/AddSelect/index.less +367 -367
  141. package/src/components/Functional/AddSelect/index.md +155 -155
  142. package/src/components/Functional/AddSelect/index.tsx +1171 -1171
  143. package/src/components/Functional/BillEntry/index.less +371 -371
  144. package/src/components/Functional/BillEntry/index.md +39 -39
  145. package/src/components/Functional/BillEntry/index.tsx +773 -773
  146. package/src/components/Functional/BsAntdSula/BsCascader/index.md +62 -62
  147. package/src/components/Functional/BsAntdSula/BsCascader/index.tsx +178 -178
  148. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  149. package/src/components/Functional/DataImport/index.less +63 -63
  150. package/src/components/Functional/DataImport/index.md +44 -44
  151. package/src/components/Functional/DataImport/index.tsx +696 -696
  152. package/src/components/Functional/DataValidation/index.less +63 -63
  153. package/src/components/Functional/DataValidation/index.md +39 -39
  154. package/src/components/Functional/DataValidation/index.tsx +688 -688
  155. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  156. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  157. package/src/components/Functional/EllipsisTooltip/index.md +30 -30
  158. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  159. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +60 -60
  160. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  161. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  162. package/src/components/Functional/QueryMutipleInput/index.tsx +128 -128
  163. package/src/components/Functional/SearchSelect/index.less +115 -115
  164. package/src/components/Functional/SearchSelect/index.md +141 -141
  165. package/src/components/Functional/SearchSelect/index.tsx +896 -896
  166. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  167. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  168. package/src/components/Functional/TreeSearchSelect/index.tsx +204 -204
  169. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  170. package/src/components/Solution/RuleComponent/InnerSelect.tsx +62 -62
  171. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  172. package/src/components/Solution/RuleComponent/index.js +2073 -2073
  173. package/src/components/Solution/RuleComponent/index.less +230 -230
  174. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  175. package/src/components/Solution/RuleComponent/ruleFiled.js +2281 -2281
  176. package/src/components/Solution/RuleComponent/services.ts +13 -13
  177. package/src/components/Solution/RuleComponent/util.js +143 -143
  178. package/src/index.ts +38 -38
  179. package/src/plugin/TableColumnSetting/index.less +247 -247
  180. package/src/plugin/TableColumnSetting/index.md +50 -50
  181. package/src/plugin/TableColumnSetting/index.tsx +725 -725
  182. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  183. package/src/styles/bsDefault.less +1912 -1912
  184. package/src/utils/CheckOneUser/index.md +39 -39
  185. package/src/utils/CheckOneUser/index.ts +51 -51
  186. package/src/utils/CustomLoginInfo.ts +55 -55
  187. package/src/utils/LocalstorageUtils.ts +95 -95
  188. package/src/utils/TableUtils.tsx +18 -18
  189. package/src/utils/checkUtils.ts +39 -39
  190. package/src/utils/enumConfig.ts +11 -11
  191. package/src/utils/getFormMode.js +12 -12
  192. package/src/utils/index.ts +4 -4
  193. package/src/utils/requestUtils.ts +166 -166
  194. package/src/utils/serialize.js +7 -7
  195. package/src/utils/utils.ts +195 -195
  196. package/tsconfig.json +29 -29
  197. package/typings.d.ts +4 -4
@@ -1,335 +1,335 @@
1
- import { Button, Modal, Row, Col, Input, message, Divider } from 'antd';
2
- import React, { useState, useEffect } from 'react';
3
- import { CloseCircleOutlined } from '@ant-design/icons';
4
- import {
5
- SortableContainer,
6
- SortableElement,
7
- } from 'react-sortable-hoc';
8
- import { arrayMoveImmutable } from 'array-move';
9
-
10
- const App = ({ setValue, formula, record, sourceData, disabled }: {
11
- setValue: any,
12
- record: any,
13
- sourceData: any,
14
- formula?: any,
15
- disabled?: boolean
16
- }) => {
17
- const [formul, setFormul] = useState(record.expression);
18
- const [state, UpdateState] = useState([]);
19
- const [fieldList, UpdateFiedList] = useState([]);
20
- const [isStaticNumber, setIsStaticNumber] = useState(false);
21
-
22
- useEffect(() => {
23
- if (sourceData) {
24
- setInitialData(sourceData);
25
- return;
26
- }
27
- }, [sourceData]);
28
-
29
- const setInitialData = (fieldData: any) => {
30
- UpdateFiedList(fieldData);
31
- let res: any = [];
32
- let handleResData: any = [];
33
- fieldData.forEach((i: any) => {
34
- if (i?.propertyList?.length) {
35
- handleResData = handleResData.concat(i.propertyList);
36
- }
37
- });
38
- formul &&
39
- formul.replace(
40
- /([a-zA-Z_]+\.\w+)|\+|\-|\*|\/|\(|\)|((\d+\.\d+)|\d+)/g,
41
- (item: any) => {
42
- const numberReg = new RegExp(/^\d+/);
43
- if (numberReg.test(item)) {
44
- res = res.concat([{ name: item, value: item }]);
45
- return;
46
- }
47
- if (handleResData.filter((initem: any) => initem.value === item).length) {
48
- res = res.concat(
49
- handleResData.filter((initem: any) => initem.value === item),
50
- );
51
- } else {
52
- res = res.concat(
53
- ['+', '-', '*', '/', '(', ')']
54
- .filter((initem) => initem === item)
55
- .map((item) => ({ value: item, name: item })),
56
- );
57
- }
58
- },
59
- );
60
- UpdateState(res);
61
- };
62
-
63
- const [isModalVisible, setIsModalVisible] = useState(false);
64
-
65
- const showModal = () => {
66
- setIsModalVisible(true);
67
- };
68
-
69
- const handleOk = () => {
70
- setIsModalVisible(false);
71
- let formulString = state
72
- .map((item: any) => {
73
- if (
74
- ['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1 &&
75
- typeof item.value != 'number'
76
- ) {
77
- return `{${item.value}}`;
78
- }
79
- return item.value;
80
- })
81
- .join('');
82
- setFormul(formulString);
83
- setValue(state, formatFormul(formulString));
84
- };
85
-
86
- const handleCancel = () => {
87
- setIsModalVisible(false);
88
- };
89
-
90
- const onSortEnd = ({ oldIndex, newIndex }: { oldIndex: number, newIndex: number }) => {
91
- UpdateState(arrayMoveImmutable(state, oldIndex, newIndex));
92
- };
93
-
94
- const deleteItem = (value: any, indexOrder: number) => {
95
- UpdateState([].concat(state).filter((item, index) => index !== indexOrder));
96
- };
97
-
98
- const SortableItem = SortableElement(({ value, sortIndex }: {value: string, sortIndex: number}) => {
99
- return (
100
- <span
101
- style={{
102
- // height: '100px',
103
- padding: '5px 10px',
104
- margin: '10px',
105
- height: '40px',
106
- lineHeight: '30px',
107
- flexBasis: '1',
108
- border: '1px solid #e8eaee',
109
- borderRadius: '5px',
110
- cursor: 'pointer',
111
- }}
112
- >
113
- {value} &nbsp;{' '}
114
- <CloseCircleOutlined
115
- onClick={(e) => {
116
- deleteItem(value, sortIndex);
117
- }}
118
- />
119
- </span>
120
- );
121
- });
122
-
123
- const SortableList = SortableContainer(({ items }: any) => {
124
- return (
125
- <div style={{ display: 'flex', flexWrap: 'wrap' }}>
126
- {items.map((value: any, index: any) => (
127
- <>
128
- {/* @ts-ignore */}
129
- <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
130
- </>
131
- ))}
132
- </div>
133
- );
134
- });
135
-
136
- const add = (item: any) => {
137
- {/* @ts-ignore */}
138
- UpdateState([...state, item]);
139
- };
140
-
141
- const formatFormul = (formulaString?: string) => {
142
- let tempFormulaString = formulaString || formul;
143
- if (!fieldList.length || !tempFormulaString) return '';
144
- let flattedFieldList: any = [];
145
- fieldList.forEach((i: any) => {
146
- if (i?.propertyList?.length) {
147
- flattedFieldList = flattedFieldList.concat(i.propertyList);
148
- }
149
- });
150
- let res = tempFormulaString.replace(/[a-zA-Z_]+\.\w+/g, (item: any) => {
151
- // 支持固定值也就是数字,所以排除了数字
152
- return flattedFieldList.filter((inneritem: any) => inneritem.value === item)[0]
153
- ?.name;
154
- });
155
- return res.replace(/(\{|\})/g, '');
156
- };
157
-
158
- return (
159
- <>
160
- <>
161
- <Input value={formatFormul()} style={{ width: '540px' }} disabled />
162
- <Button type="primary" onClick={showModal} disabled={disabled}>
163
- 编辑表达式
164
- </Button>
165
- <Modal
166
- title="编辑表达式"
167
- visible={isModalVisible}
168
- onOk={handleOk}
169
- onCancel={handleCancel}
170
- width={1000}
171
- >
172
- <div style={{ height: '600px' }}>
173
- <Row>
174
- <Col span={6}>
175
- <div
176
- style={{
177
- border: '1px solid #e8eaee',
178
- padding: '10px',
179
- borderRadius: '5px',
180
- overflow: 'auto',
181
- maxHeight: '600px',
182
- }}
183
- >
184
- {[...fieldList].map((item: any) => (
185
- <div key={item.id}>
186
- <div style={{ fontWeight: 'bolder', fontSize: '14px' }}>
187
- {item.name}
188
- </div>
189
- <div
190
- style={{
191
- display: 'flex',
192
- justifyContent: 'space-around',
193
- flexWrap: 'wrap',
194
- }}
195
- >
196
- {(item?.propertyList || []).map((s: any) => (
197
- <span
198
- key={`${item.id}${s.id}`}
199
- onClick={() => {
200
- add(s);
201
- }}
202
- style={{
203
- width: '80px',
204
- // height: '100px',
205
- padding: '10px',
206
- margin: '10px 0px',
207
- flexBasis: '1',
208
- border: '1px solid #e8eaee',
209
- borderRadius: '5px',
210
- cursor: 'pointer',
211
- }}
212
- >
213
- {s.name}
214
- </span>
215
- ))}
216
- </div>
217
- <Divider />
218
- </div>
219
- ))}
220
- </div>
221
- </Col>
222
- <Col span={18}>
223
- 表达式
224
- <Row>
225
- <div>
226
- {['+', '-', '*', '/', '(', ')'].map((item) => (
227
- <span
228
- onClick={() => {
229
- add({ name: item, value: item });
230
- }}
231
- style={{
232
- width: '50px',
233
- textAlign: 'center',
234
- display: 'inline-block',
235
- padding: '5px 10px',
236
- margin: '10px',
237
- height: '40px',
238
- lineHeight: '30px',
239
- flexBasis: '1',
240
- border: '1px solid #e8eaee',
241
- borderRadius: '5px',
242
- cursor: 'pointer',
243
- }}
244
- >
245
- {item}
246
- </span>
247
- ))}
248
- <span
249
- onClick={(e) => {
250
- setIsStaticNumber(!isStaticNumber);
251
- }}
252
- style={{
253
- width: isStaticNumber ? '110px' : '65px',
254
- textAlign: 'center',
255
- display: 'inline-block',
256
- padding: '5px 10px',
257
- margin: '10px',
258
- height: '40px',
259
- lineHeight: '30px',
260
- flexBasis: '1',
261
- border: '1px solid #e8eaee',
262
- borderRadius: '5px',
263
- cursor: 'pointer',
264
- }}
265
- >
266
- {isStaticNumber ? (
267
- <Input
268
- autoFocus={true}
269
- onClick={(e) => e.stopPropagation()}
270
- onPressEnter={(e: any) => {
271
- const value = Number(e.target.value);
272
- if (Object.is(value, NaN)) {
273
- message.warn('包含非数字');
274
- return;
275
- }
276
- if (value < 0) {
277
- message.warn('不支持负数,请使用减号');
278
- return;
279
- }
280
- if (!value) {
281
- setIsStaticNumber(false);
282
- return;
283
- }
284
- add({ name: value, value: e.target.value });
285
- setIsStaticNumber(false);
286
- }}
287
- onBlur={(e) => {
288
- const value = Number(e.target.value);
289
- if (Object.is(value, NaN)) {
290
- message.warn('包含非数字');
291
- return;
292
- }
293
- if (value < 0) {
294
- message.warn('不支持负数,请使用减号');
295
- return;
296
- }
297
- if (!value) {
298
- setIsStaticNumber(false);
299
- return;
300
- }
301
- add({ name: value, value: e.target.value });
302
- setIsStaticNumber(false);
303
- }}
304
- />
305
- ) : (
306
- '固定值'
307
- )}
308
- </span>
309
- </div>
310
- </Row>
311
- <Row>
312
- <div
313
- style={{
314
- width: '700px',
315
- padding: '10px',
316
- marginLeft: '10px',
317
- flexBasis: '1',
318
- border: '1px solid #e8eaee',
319
- minHeight: '560px',
320
- }}
321
- >
322
- {/* @ts-ignore */}
323
- <SortableList distance={20} helperClass="row-dragging" items={state} axis="xy" onSortEnd={onSortEnd} />
324
- </div>
325
- </Row>
326
- </Col>
327
- </Row>
328
- </div>
329
- </Modal>
330
- </>
331
- </>
332
- );
333
- };
334
-
335
- export default App;
1
+ import { Button, Modal, Row, Col, Input, message, Divider } from 'antd';
2
+ import React, { useState, useEffect } from 'react';
3
+ import { CloseCircleOutlined } from '@ant-design/icons';
4
+ import {
5
+ SortableContainer,
6
+ SortableElement,
7
+ } from 'react-sortable-hoc';
8
+ import { arrayMoveImmutable } from 'array-move';
9
+
10
+ const App = ({ setValue, formula, record, sourceData, disabled }: {
11
+ setValue: any,
12
+ record: any,
13
+ sourceData: any,
14
+ formula?: any,
15
+ disabled?: boolean
16
+ }) => {
17
+ const [formul, setFormul] = useState(record.expression);
18
+ const [state, UpdateState] = useState([]);
19
+ const [fieldList, UpdateFiedList] = useState([]);
20
+ const [isStaticNumber, setIsStaticNumber] = useState(false);
21
+
22
+ useEffect(() => {
23
+ if (sourceData) {
24
+ setInitialData(sourceData);
25
+ return;
26
+ }
27
+ }, [sourceData]);
28
+
29
+ const setInitialData = (fieldData: any) => {
30
+ UpdateFiedList(fieldData);
31
+ let res: any = [];
32
+ let handleResData: any = [];
33
+ fieldData.forEach((i: any) => {
34
+ if (i?.propertyList?.length) {
35
+ handleResData = handleResData.concat(i.propertyList);
36
+ }
37
+ });
38
+ formul &&
39
+ formul.replace(
40
+ /([a-zA-Z_]+\.\w+)|\+|\-|\*|\/|\(|\)|((\d+\.\d+)|\d+)/g,
41
+ (item: any) => {
42
+ const numberReg = new RegExp(/^\d+/);
43
+ if (numberReg.test(item)) {
44
+ res = res.concat([{ name: item, value: item }]);
45
+ return;
46
+ }
47
+ if (handleResData.filter((initem: any) => initem.value === item).length) {
48
+ res = res.concat(
49
+ handleResData.filter((initem: any) => initem.value === item),
50
+ );
51
+ } else {
52
+ res = res.concat(
53
+ ['+', '-', '*', '/', '(', ')']
54
+ .filter((initem) => initem === item)
55
+ .map((item) => ({ value: item, name: item })),
56
+ );
57
+ }
58
+ },
59
+ );
60
+ UpdateState(res);
61
+ };
62
+
63
+ const [isModalVisible, setIsModalVisible] = useState(false);
64
+
65
+ const showModal = () => {
66
+ setIsModalVisible(true);
67
+ };
68
+
69
+ const handleOk = () => {
70
+ setIsModalVisible(false);
71
+ let formulString = state
72
+ .map((item: any) => {
73
+ if (
74
+ ['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1 &&
75
+ typeof item.value != 'number'
76
+ ) {
77
+ return `{${item.value}}`;
78
+ }
79
+ return item.value;
80
+ })
81
+ .join('');
82
+ setFormul(formulString);
83
+ setValue(state, formatFormul(formulString));
84
+ };
85
+
86
+ const handleCancel = () => {
87
+ setIsModalVisible(false);
88
+ };
89
+
90
+ const onSortEnd = ({ oldIndex, newIndex }: { oldIndex: number, newIndex: number }) => {
91
+ UpdateState(arrayMoveImmutable(state, oldIndex, newIndex));
92
+ };
93
+
94
+ const deleteItem = (value: any, indexOrder: number) => {
95
+ UpdateState([].concat(state).filter((item, index) => index !== indexOrder));
96
+ };
97
+
98
+ const SortableItem = SortableElement(({ value, sortIndex }: {value: string, sortIndex: number}) => {
99
+ return (
100
+ <span
101
+ style={{
102
+ // height: '100px',
103
+ padding: '5px 10px',
104
+ margin: '10px',
105
+ height: '40px',
106
+ lineHeight: '30px',
107
+ flexBasis: '1',
108
+ border: '1px solid #e8eaee',
109
+ borderRadius: '5px',
110
+ cursor: 'pointer',
111
+ }}
112
+ >
113
+ {value} &nbsp;{' '}
114
+ <CloseCircleOutlined
115
+ onClick={(e) => {
116
+ deleteItem(value, sortIndex);
117
+ }}
118
+ />
119
+ </span>
120
+ );
121
+ });
122
+
123
+ const SortableList = SortableContainer(({ items }: any) => {
124
+ return (
125
+ <div style={{ display: 'flex', flexWrap: 'wrap' }}>
126
+ {items.map((value: any, index: any) => (
127
+ <>
128
+ {/* @ts-ignore */}
129
+ <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
130
+ </>
131
+ ))}
132
+ </div>
133
+ );
134
+ });
135
+
136
+ const add = (item: any) => {
137
+ {/* @ts-ignore */}
138
+ UpdateState([...state, item]);
139
+ };
140
+
141
+ const formatFormul = (formulaString?: string) => {
142
+ let tempFormulaString = formulaString || formul;
143
+ if (!fieldList.length || !tempFormulaString) return '';
144
+ let flattedFieldList: any = [];
145
+ fieldList.forEach((i: any) => {
146
+ if (i?.propertyList?.length) {
147
+ flattedFieldList = flattedFieldList.concat(i.propertyList);
148
+ }
149
+ });
150
+ let res = tempFormulaString.replace(/[a-zA-Z_]+\.\w+/g, (item: any) => {
151
+ // 支持固定值也就是数字,所以排除了数字
152
+ return flattedFieldList.filter((inneritem: any) => inneritem.value === item)[0]
153
+ ?.name;
154
+ });
155
+ return res.replace(/(\{|\})/g, '');
156
+ };
157
+
158
+ return (
159
+ <>
160
+ <>
161
+ <Input value={formatFormul()} style={{ width: '540px' }} disabled />
162
+ <Button type="primary" onClick={showModal} disabled={disabled}>
163
+ 编辑表达式
164
+ </Button>
165
+ <Modal
166
+ title="编辑表达式"
167
+ visible={isModalVisible}
168
+ onOk={handleOk}
169
+ onCancel={handleCancel}
170
+ width={1000}
171
+ >
172
+ <div style={{ height: '600px' }}>
173
+ <Row>
174
+ <Col span={6}>
175
+ <div
176
+ style={{
177
+ border: '1px solid #e8eaee',
178
+ padding: '10px',
179
+ borderRadius: '5px',
180
+ overflow: 'auto',
181
+ maxHeight: '600px',
182
+ }}
183
+ >
184
+ {[...fieldList].map((item: any) => (
185
+ <div key={item.id}>
186
+ <div style={{ fontWeight: 'bolder', fontSize: '14px' }}>
187
+ {item.name}
188
+ </div>
189
+ <div
190
+ style={{
191
+ display: 'flex',
192
+ justifyContent: 'space-around',
193
+ flexWrap: 'wrap',
194
+ }}
195
+ >
196
+ {(item?.propertyList || []).map((s: any) => (
197
+ <span
198
+ key={`${item.id}${s.id}`}
199
+ onClick={() => {
200
+ add(s);
201
+ }}
202
+ style={{
203
+ width: '80px',
204
+ // height: '100px',
205
+ padding: '10px',
206
+ margin: '10px 0px',
207
+ flexBasis: '1',
208
+ border: '1px solid #e8eaee',
209
+ borderRadius: '5px',
210
+ cursor: 'pointer',
211
+ }}
212
+ >
213
+ {s.name}
214
+ </span>
215
+ ))}
216
+ </div>
217
+ <Divider />
218
+ </div>
219
+ ))}
220
+ </div>
221
+ </Col>
222
+ <Col span={18}>
223
+ 表达式
224
+ <Row>
225
+ <div>
226
+ {['+', '-', '*', '/', '(', ')'].map((item) => (
227
+ <span
228
+ onClick={() => {
229
+ add({ name: item, value: item });
230
+ }}
231
+ style={{
232
+ width: '50px',
233
+ textAlign: 'center',
234
+ display: 'inline-block',
235
+ padding: '5px 10px',
236
+ margin: '10px',
237
+ height: '40px',
238
+ lineHeight: '30px',
239
+ flexBasis: '1',
240
+ border: '1px solid #e8eaee',
241
+ borderRadius: '5px',
242
+ cursor: 'pointer',
243
+ }}
244
+ >
245
+ {item}
246
+ </span>
247
+ ))}
248
+ <span
249
+ onClick={(e) => {
250
+ setIsStaticNumber(!isStaticNumber);
251
+ }}
252
+ style={{
253
+ width: isStaticNumber ? '110px' : '65px',
254
+ textAlign: 'center',
255
+ display: 'inline-block',
256
+ padding: '5px 10px',
257
+ margin: '10px',
258
+ height: '40px',
259
+ lineHeight: '30px',
260
+ flexBasis: '1',
261
+ border: '1px solid #e8eaee',
262
+ borderRadius: '5px',
263
+ cursor: 'pointer',
264
+ }}
265
+ >
266
+ {isStaticNumber ? (
267
+ <Input
268
+ autoFocus={true}
269
+ onClick={(e) => e.stopPropagation()}
270
+ onPressEnter={(e: any) => {
271
+ const value = Number(e.target.value);
272
+ if (Object.is(value, NaN)) {
273
+ message.warn('包含非数字');
274
+ return;
275
+ }
276
+ if (value < 0) {
277
+ message.warn('不支持负数,请使用减号');
278
+ return;
279
+ }
280
+ if (!value) {
281
+ setIsStaticNumber(false);
282
+ return;
283
+ }
284
+ add({ name: value, value: e.target.value });
285
+ setIsStaticNumber(false);
286
+ }}
287
+ onBlur={(e) => {
288
+ const value = Number(e.target.value);
289
+ if (Object.is(value, NaN)) {
290
+ message.warn('包含非数字');
291
+ return;
292
+ }
293
+ if (value < 0) {
294
+ message.warn('不支持负数,请使用减号');
295
+ return;
296
+ }
297
+ if (!value) {
298
+ setIsStaticNumber(false);
299
+ return;
300
+ }
301
+ add({ name: value, value: e.target.value });
302
+ setIsStaticNumber(false);
303
+ }}
304
+ />
305
+ ) : (
306
+ '固定值'
307
+ )}
308
+ </span>
309
+ </div>
310
+ </Row>
311
+ <Row>
312
+ <div
313
+ style={{
314
+ width: '700px',
315
+ padding: '10px',
316
+ marginLeft: '10px',
317
+ flexBasis: '1',
318
+ border: '1px solid #e8eaee',
319
+ minHeight: '560px',
320
+ }}
321
+ >
322
+ {/* @ts-ignore */}
323
+ <SortableList distance={20} helperClass="row-dragging" items={state} axis="xy" onSortEnd={onSortEnd} />
324
+ </div>
325
+ </Row>
326
+ </Col>
327
+ </Row>
328
+ </div>
329
+ </Modal>
330
+ </>
331
+ </>
332
+ );
333
+ };
334
+
335
+ export default App;