@bit-sun/business-component 2.3.21 → 2.3.23

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 (202) 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/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.d.ts +1 -1
  9. package/dist/components/Business/BsLayouts/Components/CustomerMenu/index.d.ts +1 -1
  10. package/dist/components/Business/SearchSelect/index.d.ts +1 -1
  11. package/dist/components/Business/moreTreeTable/FixedScrollBar.d.ts +1 -1
  12. package/dist/components/Functional/AddSelect/helps.d.ts +13 -0
  13. package/dist/components/Functional/SearchSelect/index.d.ts +1 -1
  14. package/dist/index.esm.js +1338 -1258
  15. package/dist/index.js +1344 -1264
  16. package/dist/utils/utils.d.ts +1 -1
  17. package/docs/index.md +21 -21
  18. package/lib/assets/drag.svg +17 -17
  19. package/lib/assets/exportFail.svg +37 -37
  20. package/lib/assets/exportProcessing.svg +28 -28
  21. package/lib/assets/exportSuccess.svg +34 -34
  22. package/lib/assets/label_icon_bottom.svg +25 -25
  23. package/lib/assets/upExport.svg +22 -22
  24. package/package.json +78 -78
  25. package/src/assets/32.svg +27 -27
  26. package/src/assets/addIcon.svg +17 -17
  27. package/src/assets/allfunc.svg +27 -27
  28. package/src/assets/arrowRight.svg +24 -24
  29. package/src/assets/btn-delete.svg +29 -29
  30. package/src/assets/btn-edit.svg +19 -19
  31. package/src/assets/btn-more.svg +17 -17
  32. package/src/assets/btn-submit.svg +19 -19
  33. package/src/assets/caidan.svg +11 -11
  34. package/src/assets/close.svg +26 -26
  35. package/src/assets/drag.svg +17 -17
  36. package/src/assets/exportFail.svg +37 -37
  37. package/src/assets/exportProcessing.svg +28 -28
  38. package/src/assets/exportSuccess.svg +34 -34
  39. package/src/assets/fixed-left-active.svg +11 -11
  40. package/src/assets/fixed-left.svg +15 -15
  41. package/src/assets/fixed-right-active.svg +11 -11
  42. package/src/assets/fixed-right.svg +15 -15
  43. package/src/assets/guanbi.svg +15 -15
  44. package/src/assets/icon-quanping.svg +15 -15
  45. package/src/assets/icon-shezhi.svg +17 -17
  46. package/src/assets/label_icon_bottom.svg +25 -25
  47. package/src/assets/list-no-img.svg +21 -21
  48. package/src/assets/morentouxiang-32.svg +23 -23
  49. package/src/assets/scanning.svg +24 -24
  50. package/src/assets/upExport.svg +22 -22
  51. package/src/common/ENUM.ts +41 -41
  52. package/src/components/Business/AddSelectBusiness/index.md +162 -162
  53. package/src/components/Business/AddSelectBusiness/index.tsx +1060 -895
  54. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +111 -111
  55. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  56. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  57. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  58. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  59. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  60. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  61. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  62. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  63. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  64. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  65. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  66. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  67. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -157
  68. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  69. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  70. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +155 -155
  71. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  72. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  73. package/src/components/Business/BsLayouts/index.less +79 -79
  74. package/src/components/Business/BsLayouts/index.tsx +1484 -1484
  75. package/src/components/Business/BsLayouts/service.ts +10 -10
  76. package/src/components/Business/BsLayouts/utils.tsx +203 -203
  77. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +564 -564
  78. package/src/components/Business/BsSulaQueryTable/index.less +221 -221
  79. package/src/components/Business/BsSulaQueryTable/index.tsx +535 -535
  80. package/src/components/Business/BsSulaQueryTable/setting.tsx +852 -852
  81. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  82. package/src/components/Business/BsSulaQueryTable/utils.tsx +690 -690
  83. package/src/components/Business/CommodityEntry/index.md +70 -70
  84. package/src/components/Business/CommodityEntry/index.tsx +80 -80
  85. package/src/components/Business/CommonAlert/index.tsx +23 -23
  86. package/src/components/Business/CommonGuideWrapper/index.less +111 -111
  87. package/src/components/Business/CommonGuideWrapper/index.md +39 -39
  88. package/src/components/Business/CommonGuideWrapper/index.tsx +83 -83
  89. package/src/components/Business/DetailPageWrapper/index.less +79 -79
  90. package/src/components/Business/DetailPageWrapper/index.tsx +313 -313
  91. package/src/components/Business/DetailPageWrapper/utils.tsx +100 -100
  92. package/src/components/Business/HomePageWrapper/index.less +33 -33
  93. package/src/components/Business/HomePageWrapper/index.md +45 -45
  94. package/src/components/Business/HomePageWrapper/index.tsx +162 -162
  95. package/src/components/Business/JsonQueryTable/components/FieldsModifyModal.tsx +824 -824
  96. package/src/components/Business/JsonQueryTable/components/FieldsSettingsTable.tsx +205 -205
  97. package/src/components/Business/JsonQueryTable/components/Formula.tsx +205 -205
  98. package/src/components/Business/JsonQueryTable/components/MaintainOptions.tsx +127 -127
  99. package/src/components/Business/JsonQueryTable/configButton/index.js +20 -20
  100. package/src/components/Business/JsonQueryTable/configTree/component/compactArrayView.js +25 -25
  101. package/src/components/Business/JsonQueryTable/configTree/component/compactObjectView.js +30 -30
  102. package/src/components/Business/JsonQueryTable/configTree/index.js +82 -82
  103. package/src/components/Business/JsonQueryTable/configTree/index.less +44 -44
  104. package/src/components/Business/JsonQueryTable/configTree/parser/highlight.js +57 -57
  105. package/src/components/Business/JsonQueryTable/configTree/parser/index.js +124 -124
  106. package/src/components/Business/JsonQueryTable/configTree/render/iconRender.js +29 -29
  107. package/src/components/Business/JsonQueryTable/configTree/render/nameRender.js +22 -22
  108. package/src/components/Business/JsonQueryTable/configTree/treeNode.js +116 -116
  109. package/src/components/Business/JsonQueryTable/drawer/index.tsx +12 -12
  110. package/src/components/Business/JsonQueryTable/function.ts +62 -62
  111. package/src/components/Business/JsonQueryTable/index.less +16 -16
  112. package/src/components/Business/JsonQueryTable/index.md +328 -328
  113. package/src/components/Business/JsonQueryTable/index.tsx +535 -535
  114. package/src/components/Business/JsonQueryTable/jsonEditor/index.js +346 -346
  115. package/src/components/Business/JsonQueryTable/jsonEditor/index.less +22 -22
  116. package/src/components/Business/JsonQueryTable/jsonEditor/lint/basicType.js +147 -147
  117. package/src/components/Business/JsonQueryTable/jsonEditor/lint/index.js +389 -389
  118. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/actions.js +118 -118
  119. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/dependency.js +22 -22
  120. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/index.js +21 -21
  121. package/src/components/Business/JsonQueryTable/jsonEditor/suggestions/request.js +65 -65
  122. package/src/components/Business/JsonQueryTable/static.ts +390 -390
  123. package/src/components/Business/SearchSelect/BusinessUtils.ts +1762 -1762
  124. package/src/components/Business/SearchSelect/common.ts +75 -75
  125. package/src/components/Business/SearchSelect/index.md +1329 -1329
  126. package/src/components/Business/SearchSelect/index.tsx +55 -55
  127. package/src/components/Business/SearchSelect/utils.ts +100 -100
  128. package/src/components/Business/StateFlow/index.less +130 -130
  129. package/src/components/Business/StateFlow/index.md +60 -60
  130. package/src/components/Business/StateFlow/index.tsx +29 -29
  131. package/src/components/Business/TreeSearchSelect/index.md +156 -156
  132. package/src/components/Business/TreeSearchSelect/index.tsx +33 -33
  133. package/src/components/Business/TreeSearchSelect/utils.ts +75 -75
  134. package/src/components/Business/columnSettingTable/columnSetting.tsx +764 -764
  135. package/src/components/Business/columnSettingTable/index.less +247 -247
  136. package/src/components/Business/columnSettingTable/index.md +357 -357
  137. package/src/components/Business/columnSettingTable/index.tsx +232 -232
  138. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +240 -240
  139. package/src/components/Business/columnSettingTable/utils.tsx +71 -71
  140. package/src/components/Business/moreTreeTable/FixedScrollBar.tsx +87 -87
  141. package/src/components/Business/moreTreeTable/hooks/useSticky.ts +21 -21
  142. package/src/components/Business/moreTreeTable/index.less +99 -99
  143. package/src/components/Business/moreTreeTable/index.md +448 -448
  144. package/src/components/Business/moreTreeTable/index.tsx +387 -387
  145. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  146. package/src/components/Functional/AddSelect/helps.ts +79 -14
  147. package/src/components/Functional/AddSelect/index.less +367 -367
  148. package/src/components/Functional/AddSelect/index.md +155 -155
  149. package/src/components/Functional/AddSelect/index.tsx +1170 -1282
  150. package/src/components/Functional/BillEntry/index.less +371 -371
  151. package/src/components/Functional/BillEntry/index.md +39 -39
  152. package/src/components/Functional/BillEntry/index.tsx +772 -772
  153. package/src/components/Functional/BsAntdSula/BsCascader/index.md +62 -62
  154. package/src/components/Functional/BsAntdSula/BsCascader/index.tsx +178 -178
  155. package/src/components/Functional/BsAntdSula/index.ts +2 -2
  156. package/src/components/Functional/DataImport/index.less +63 -63
  157. package/src/components/Functional/DataImport/index.md +44 -44
  158. package/src/components/Functional/DataImport/index.tsx +695 -695
  159. package/src/components/Functional/DataValidation/index.less +63 -63
  160. package/src/components/Functional/DataValidation/index.md +39 -39
  161. package/src/components/Functional/DataValidation/index.tsx +687 -687
  162. package/src/components/Functional/EllipsisTooltip/index.d.ts +5 -5
  163. package/src/components/Functional/EllipsisTooltip/index.js +36 -36
  164. package/src/components/Functional/EllipsisTooltip/index.md +30 -30
  165. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  166. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +59 -59
  167. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  168. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  169. package/src/components/Functional/QueryMutipleInput/index.tsx +128 -128
  170. package/src/components/Functional/SearchSelect/index.less +115 -115
  171. package/src/components/Functional/SearchSelect/index.md +141 -141
  172. package/src/components/Functional/SearchSelect/index.tsx +879 -879
  173. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  174. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  175. package/src/components/Functional/TreeSearchSelect/index.tsx +199 -199
  176. package/src/components/Solution/RuleComponent/Formula.tsx +335 -335
  177. package/src/components/Solution/RuleComponent/index.d.ts +29 -29
  178. package/src/components/Solution/RuleComponent/index.js +2032 -2032
  179. package/src/components/Solution/RuleComponent/index.less +230 -230
  180. package/src/components/Solution/RuleComponent/renderSpecificAction.js +99 -99
  181. package/src/components/Solution/RuleComponent/ruleFiled.js +2107 -2107
  182. package/src/components/Solution/RuleComponent/services.ts +13 -13
  183. package/src/components/Solution/RuleComponent/util.js +139 -139
  184. package/src/index.ts +38 -38
  185. package/src/plugin/TableColumnSetting/index.less +247 -247
  186. package/src/plugin/TableColumnSetting/index.md +50 -50
  187. package/src/plugin/TableColumnSetting/index.tsx +724 -724
  188. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  189. package/src/styles/bsDefault.less +1912 -1912
  190. package/src/utils/CheckOneUser/index.md +39 -39
  191. package/src/utils/CheckOneUser/index.ts +51 -51
  192. package/src/utils/LocalstorageUtils.ts +95 -95
  193. package/src/utils/TableUtils.tsx +18 -18
  194. package/src/utils/checkUtils.ts +39 -39
  195. package/src/utils/enumConfig.ts +11 -11
  196. package/src/utils/getFormMode.js +12 -12
  197. package/src/utils/index.ts +4 -4
  198. package/src/utils/requestUtils.ts +34 -34
  199. package/src/utils/serialize.js +7 -7
  200. package/src/utils/utils.ts +212 -212
  201. package/tsconfig.json +29 -29
  202. package/typings.d.ts +4 -4
@@ -1,205 +1,205 @@
1
- import { Button, Modal, Row, Col, Input } from 'antd';
2
- import React, { useState, useEffect } from 'react';
3
- import { CloseCircleOutlined } from '@ant-design/icons';
4
- import {
5
- SortableContainer,
6
- SortableElement,
7
- SortableHandle,
8
- } from 'react-sortable-hoc';
9
- import { arrayMoveImmutable } from 'array-move';
10
- import { ModalForm, request } from 'bssula';
11
-
12
-
13
- const App = ({
14
- record,
15
- setValue,
16
- formula
17
- }:{
18
- record:any,
19
- setValue:any,
20
- formula:any,
21
- }) => {
22
- const [formul, setFormul] = useState(record.formula)
23
- const [state, UpdateState]:any = useState([])
24
- const [fieldList, UpdateFiedList] = useState([])
25
-
26
- useEffect(() => {
27
- request({
28
- url: '/basic/flow/businessField/listNoPage',
29
- params: {
30
- 'qp-businessType-eq': record.businessType,
31
- 'qp-fieldGroup-eq': record.fieldGroup,
32
- },
33
- converter: ({ response, data }:any) => {
34
- if (response.code === '000000') {
35
- // UpdateFiedList(data.filter(item => item.valueType == 20 || item.valueType == 21 || item.valueType == 22))
36
- const resData = data.filter((item:any) => item.inputType != 40 && (item.valueType == 20 || item.valueType == 21 || item.valueType == 22)).map((item:any) => ({value: item.code, name: item.name}))
37
- UpdateFiedList(resData)
38
- let res:any = [];
39
- formul && formul.replace(/(\w+|\+|\-|\*|\/|\(|\))/g, (item:any) => {
40
- if (resData.filter((initem:any) => initem.value === item).length) {
41
- res = res.concat(resData.filter((initem:any) => initem.value === item))
42
- } else {
43
- res = res.concat(['+', '-', '*', '/', '(', ')'].filter(initem => initem === item).map(item => ({value: item, name: item})))
44
- }
45
- })
46
-
47
- UpdateState(res)
48
- }
49
- }
50
- })
51
- }, [])
52
-
53
- const [isModalVisible, setIsModalVisible] = useState(false);
54
-
55
- const showModal = () => {
56
- setIsModalVisible(true);
57
- };
58
-
59
- const handleOk = () => {
60
- setIsModalVisible(false);
61
- setValue(state);
62
- setFormul(state.map((item:any) => {
63
- if (['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1) {
64
- return `{${item.value}}`
65
- }
66
- return item.value;
67
- }).join(''))
68
- };
69
-
70
- const handleCancel = () => {
71
- setIsModalVisible(false);
72
- };
73
-
74
-
75
- const onSortEnd = ({ oldIndex, newIndex }:any) => {
76
- UpdateState(arrayMoveImmutable(state, oldIndex, newIndex))
77
- };
78
-
79
- const deleteItem = (value:any, indexOrder:any) => {
80
- UpdateState([].concat(state).filter((item, index) => index !== indexOrder))
81
-
82
- }
83
-
84
- const SortableItem = SortableElement(({ value, sortIndex }:any) => {
85
- debugger
86
- return <span style={{
87
- // height: '100px',
88
- padding: '5px 10px',
89
- margin: '10px',
90
- height: '40px',
91
- lineHeight: '30px',
92
- flexBasis: '1',
93
- border: '1px solid #e8eaee',
94
- borderRadius: '5px',
95
- cursor: 'pointer',
96
- }}>{value} &nbsp; <CloseCircleOutlined onClick={(e) => {
97
- deleteItem(value, sortIndex)
98
- }} /></span>
99
- });
100
-
101
- const SortableList = SortableContainer(({ items }:any) => {
102
- return (
103
- <div style={{ display: 'flex', flexWrap: 'wrap' }}>
104
- {items.map((value:any, index:any) => (
105
- <>
106
- {/* @ts-ignore */}
107
- <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
108
- </>
109
- ))}
110
- </div>
111
- );
112
- });
113
-
114
- const add = ((item:any) => {
115
- UpdateState([...state, item])
116
- })
117
-
118
- const formatFormul = () => {
119
- if (!fieldList.length || !formul) return '';
120
- let res = formul.replace(/\w+/g, (item:any) => {
121
- // @ts-ignore
122
- return fieldList.filter((inneritem:any) => inneritem.value === item)[0].name
123
- })
124
-
125
- return res.replace(/(\{|\})/g, '')
126
- }
127
-
128
-
129
- return (
130
- <>
131
- <>
132
- <Input value={formatFormul()} style={{width: '540px'}} disabled />
133
- <Button type="primary" onClick={showModal}>
134
- 编辑表达式
135
- </Button>
136
- <Modal title="编辑表达式" visible={isModalVisible} onOk={handleOk} onCancel={handleCancel} width={1000}>
137
- <div style={{ height: '600px' }}>
138
- <Row>
139
- <Col span={6}>
140
- <div style={{
141
- border: '1px solid #e8eaee',
142
- padding: '10px',
143
- display: 'flex',
144
- justifyContent: 'space-around',
145
- borderRadius: '5px',
146
- flexWrap: 'wrap',
147
- overflow: 'auto',
148
- maxHeight: '600px'
149
- }}
150
- >
151
- {[...fieldList].map((item:any) => (
152
- <span onClick={() => { add(item) }} style={{
153
- width: '80px',
154
- // height: '100px',
155
- padding: '10px',
156
- margin: '10px 0px',
157
- flexBasis: '1',
158
- border: '1px solid #e8eaee',
159
- borderRadius: '5px',
160
- cursor: 'pointer',
161
- }}>{item.name}</span>
162
- ))}
163
- </div>
164
- </Col>
165
- <Col span={18}>
166
- <Row>
167
- <div>
168
- {['+', '-', '*', '/', '(', ')'].map(item => <span onClick={() => { add({name: item, value: item}) }} style={{
169
- width: '50px',
170
- textAlign: 'center',
171
- display: 'inline-block',
172
- padding: '5px 10px',
173
- margin: '10px',
174
- height: '40px',
175
- lineHeight: '30px',
176
- flexBasis: '1',
177
- border: '1px solid #e8eaee',
178
- borderRadius: '5px',
179
- cursor: 'pointer',
180
- }}>{item}</span>)}
181
- </div>
182
- </Row>
183
- <Row>
184
- <div style={{
185
- width: '700px',
186
- padding: '10px',
187
- marginLeft: '10px',
188
- flexBasis: '1',
189
- border: '1px solid #e8eaee',
190
- minHeight: '560px'
191
- }}>
192
- {/* @ts-ignore */}
193
- <SortableList distance={20} helperClass="row-dragging" items={state} axis='xy' onSortEnd={onSortEnd} />
194
- </div>
195
- </Row>
196
- </Col>
197
- </Row>
198
- </div>
199
- </Modal>
200
- </>
201
- </>
202
- );
203
- };
204
-
205
- export default App;
1
+ import { Button, Modal, Row, Col, Input } from 'antd';
2
+ import React, { useState, useEffect } from 'react';
3
+ import { CloseCircleOutlined } from '@ant-design/icons';
4
+ import {
5
+ SortableContainer,
6
+ SortableElement,
7
+ SortableHandle,
8
+ } from 'react-sortable-hoc';
9
+ import { arrayMoveImmutable } from 'array-move';
10
+ import { ModalForm, request } from 'bssula';
11
+
12
+
13
+ const App = ({
14
+ record,
15
+ setValue,
16
+ formula
17
+ }:{
18
+ record:any,
19
+ setValue:any,
20
+ formula:any,
21
+ }) => {
22
+ const [formul, setFormul] = useState(record.formula)
23
+ const [state, UpdateState]:any = useState([])
24
+ const [fieldList, UpdateFiedList] = useState([])
25
+
26
+ useEffect(() => {
27
+ request({
28
+ url: '/basic/flow/businessField/listNoPage',
29
+ params: {
30
+ 'qp-businessType-eq': record.businessType,
31
+ 'qp-fieldGroup-eq': record.fieldGroup,
32
+ },
33
+ converter: ({ response, data }:any) => {
34
+ if (response.code === '000000') {
35
+ // UpdateFiedList(data.filter(item => item.valueType == 20 || item.valueType == 21 || item.valueType == 22))
36
+ const resData = data.filter((item:any) => item.inputType != 40 && (item.valueType == 20 || item.valueType == 21 || item.valueType == 22)).map((item:any) => ({value: item.code, name: item.name}))
37
+ UpdateFiedList(resData)
38
+ let res:any = [];
39
+ formul && formul.replace(/(\w+|\+|\-|\*|\/|\(|\))/g, (item:any) => {
40
+ if (resData.filter((initem:any) => initem.value === item).length) {
41
+ res = res.concat(resData.filter((initem:any) => initem.value === item))
42
+ } else {
43
+ res = res.concat(['+', '-', '*', '/', '(', ')'].filter(initem => initem === item).map(item => ({value: item, name: item})))
44
+ }
45
+ })
46
+
47
+ UpdateState(res)
48
+ }
49
+ }
50
+ })
51
+ }, [])
52
+
53
+ const [isModalVisible, setIsModalVisible] = useState(false);
54
+
55
+ const showModal = () => {
56
+ setIsModalVisible(true);
57
+ };
58
+
59
+ const handleOk = () => {
60
+ setIsModalVisible(false);
61
+ setValue(state);
62
+ setFormul(state.map((item:any) => {
63
+ if (['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1) {
64
+ return `{${item.value}}`
65
+ }
66
+ return item.value;
67
+ }).join(''))
68
+ };
69
+
70
+ const handleCancel = () => {
71
+ setIsModalVisible(false);
72
+ };
73
+
74
+
75
+ const onSortEnd = ({ oldIndex, newIndex }:any) => {
76
+ UpdateState(arrayMoveImmutable(state, oldIndex, newIndex))
77
+ };
78
+
79
+ const deleteItem = (value:any, indexOrder:any) => {
80
+ UpdateState([].concat(state).filter((item, index) => index !== indexOrder))
81
+
82
+ }
83
+
84
+ const SortableItem = SortableElement(({ value, sortIndex }:any) => {
85
+ debugger
86
+ return <span style={{
87
+ // height: '100px',
88
+ padding: '5px 10px',
89
+ margin: '10px',
90
+ height: '40px',
91
+ lineHeight: '30px',
92
+ flexBasis: '1',
93
+ border: '1px solid #e8eaee',
94
+ borderRadius: '5px',
95
+ cursor: 'pointer',
96
+ }}>{value} &nbsp; <CloseCircleOutlined onClick={(e) => {
97
+ deleteItem(value, sortIndex)
98
+ }} /></span>
99
+ });
100
+
101
+ const SortableList = SortableContainer(({ items }:any) => {
102
+ return (
103
+ <div style={{ display: 'flex', flexWrap: 'wrap' }}>
104
+ {items.map((value:any, index:any) => (
105
+ <>
106
+ {/* @ts-ignore */}
107
+ <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
108
+ </>
109
+ ))}
110
+ </div>
111
+ );
112
+ });
113
+
114
+ const add = ((item:any) => {
115
+ UpdateState([...state, item])
116
+ })
117
+
118
+ const formatFormul = () => {
119
+ if (!fieldList.length || !formul) return '';
120
+ let res = formul.replace(/\w+/g, (item:any) => {
121
+ // @ts-ignore
122
+ return fieldList.filter((inneritem:any) => inneritem.value === item)[0].name
123
+ })
124
+
125
+ return res.replace(/(\{|\})/g, '')
126
+ }
127
+
128
+
129
+ return (
130
+ <>
131
+ <>
132
+ <Input value={formatFormul()} style={{width: '540px'}} disabled />
133
+ <Button type="primary" onClick={showModal}>
134
+ 编辑表达式
135
+ </Button>
136
+ <Modal title="编辑表达式" visible={isModalVisible} onOk={handleOk} onCancel={handleCancel} width={1000}>
137
+ <div style={{ height: '600px' }}>
138
+ <Row>
139
+ <Col span={6}>
140
+ <div style={{
141
+ border: '1px solid #e8eaee',
142
+ padding: '10px',
143
+ display: 'flex',
144
+ justifyContent: 'space-around',
145
+ borderRadius: '5px',
146
+ flexWrap: 'wrap',
147
+ overflow: 'auto',
148
+ maxHeight: '600px'
149
+ }}
150
+ >
151
+ {[...fieldList].map((item:any) => (
152
+ <span onClick={() => { add(item) }} style={{
153
+ width: '80px',
154
+ // height: '100px',
155
+ padding: '10px',
156
+ margin: '10px 0px',
157
+ flexBasis: '1',
158
+ border: '1px solid #e8eaee',
159
+ borderRadius: '5px',
160
+ cursor: 'pointer',
161
+ }}>{item.name}</span>
162
+ ))}
163
+ </div>
164
+ </Col>
165
+ <Col span={18}>
166
+ <Row>
167
+ <div>
168
+ {['+', '-', '*', '/', '(', ')'].map(item => <span onClick={() => { add({name: item, value: item}) }} style={{
169
+ width: '50px',
170
+ textAlign: 'center',
171
+ display: 'inline-block',
172
+ padding: '5px 10px',
173
+ margin: '10px',
174
+ height: '40px',
175
+ lineHeight: '30px',
176
+ flexBasis: '1',
177
+ border: '1px solid #e8eaee',
178
+ borderRadius: '5px',
179
+ cursor: 'pointer',
180
+ }}>{item}</span>)}
181
+ </div>
182
+ </Row>
183
+ <Row>
184
+ <div style={{
185
+ width: '700px',
186
+ padding: '10px',
187
+ marginLeft: '10px',
188
+ flexBasis: '1',
189
+ border: '1px solid #e8eaee',
190
+ minHeight: '560px'
191
+ }}>
192
+ {/* @ts-ignore */}
193
+ <SortableList distance={20} helperClass="row-dragging" items={state} axis='xy' onSortEnd={onSortEnd} />
194
+ </div>
195
+ </Row>
196
+ </Col>
197
+ </Row>
198
+ </div>
199
+ </Modal>
200
+ </>
201
+ </>
202
+ );
203
+ };
204
+
205
+ export default App;
@@ -1,127 +1,127 @@
1
- import React, { useRef } from 'react';
2
- import { Button, Input, Modal } from 'antd';
3
- import { Table } from 'bssula';
4
- import { uuid } from '@/utils/utils';
5
-
6
- export default (props: any) => {
7
- const tableRef:any = useRef(null);
8
- const { onParentOk, record } = props;
9
- const config = {
10
- initialDataSource:
11
- Object.keys(record.choiceInfo || {})?.map((d: any) => ({
12
- text: record.choiceInfo[d],
13
- value: d,
14
- id: uuid(),
15
- })) || [],
16
- columns: [
17
- {
18
- key: 'value',
19
- title: '值',
20
- render: ({ text, record }: any) => {
21
- return (
22
- <Input
23
- onChange={(e) => {
24
- record['value'] = e.target.value;
25
- }}
26
- value={text}
27
- />
28
- );
29
- },
30
- },
31
- {
32
- key: 'text',
33
- title: '文本',
34
- render: ({ record, text }: any) => {
35
- return (
36
- <Input
37
- onChange={(e) => {
38
- record['text'] = e.target.value;
39
- }}
40
- value={text}
41
- />
42
- );
43
- },
44
- },
45
- {
46
- key: 'operation',
47
- title: '操作',
48
- render: [
49
- {
50
- type: 'link',
51
- props: {
52
- children: '删除',
53
- },
54
- action: ({ record, table }: any) => {
55
- table.setDataSource(
56
- table.getDataSource().filter((d: any) => d.id !== record.id),
57
- );
58
- },
59
- },
60
- ],
61
- },
62
- ],
63
- rowKey: 'id',
64
- onChange: (pag:any) => {
65
- tableRef?.current?.setPagination(pag);
66
- },
67
- footer: () => {
68
- return (
69
- <div>
70
- <Button
71
- type={'primary'}
72
- onClick={() => {
73
- const data = tableRef?.current?.getDataSource();
74
- tableRef?.current?.setDataSource([
75
- ...data,
76
- {
77
- id: uuid(),
78
- },
79
- ]);
80
- }}
81
- >
82
- 添加一行
83
- </Button>
84
- <Button
85
- onClick={() => {
86
- const data = tableRef?.current?.getDataSource();
87
- tableRef?.current?.setDataSource([
88
- ...data,
89
- {
90
- id: uuid(),
91
- },
92
- {
93
- id: uuid(),
94
- },
95
- {
96
- id: uuid(),
97
- },
98
- {
99
- id: uuid(),
100
- },
101
- {
102
- id: uuid(),
103
- },
104
- ]);
105
- }}
106
- >
107
- 添加五行
108
- </Button>
109
- </div>
110
- );
111
- },
112
- };
113
- return (
114
- <Modal
115
- {...props}
116
- maskClosable={false}
117
- onOk={() => {
118
- onParentOk(
119
- tableRef?.current?.getDataSource().filter((d: any) => d.text && d.value),
120
- );
121
- }}
122
- >
123
- <Table {...config} style={{ width: '500px' }} ref={tableRef} />
124
- </Modal>
125
- );
126
- };
127
-
1
+ import React, { useRef } from 'react';
2
+ import { Button, Input, Modal } from 'antd';
3
+ import { Table } from 'bssula';
4
+ import { uuid } from '@/utils/utils';
5
+
6
+ export default (props: any) => {
7
+ const tableRef:any = useRef(null);
8
+ const { onParentOk, record } = props;
9
+ const config = {
10
+ initialDataSource:
11
+ Object.keys(record.choiceInfo || {})?.map((d: any) => ({
12
+ text: record.choiceInfo[d],
13
+ value: d,
14
+ id: uuid(),
15
+ })) || [],
16
+ columns: [
17
+ {
18
+ key: 'value',
19
+ title: '值',
20
+ render: ({ text, record }: any) => {
21
+ return (
22
+ <Input
23
+ onChange={(e) => {
24
+ record['value'] = e.target.value;
25
+ }}
26
+ value={text}
27
+ />
28
+ );
29
+ },
30
+ },
31
+ {
32
+ key: 'text',
33
+ title: '文本',
34
+ render: ({ record, text }: any) => {
35
+ return (
36
+ <Input
37
+ onChange={(e) => {
38
+ record['text'] = e.target.value;
39
+ }}
40
+ value={text}
41
+ />
42
+ );
43
+ },
44
+ },
45
+ {
46
+ key: 'operation',
47
+ title: '操作',
48
+ render: [
49
+ {
50
+ type: 'link',
51
+ props: {
52
+ children: '删除',
53
+ },
54
+ action: ({ record, table }: any) => {
55
+ table.setDataSource(
56
+ table.getDataSource().filter((d: any) => d.id !== record.id),
57
+ );
58
+ },
59
+ },
60
+ ],
61
+ },
62
+ ],
63
+ rowKey: 'id',
64
+ onChange: (pag:any) => {
65
+ tableRef?.current?.setPagination(pag);
66
+ },
67
+ footer: () => {
68
+ return (
69
+ <div>
70
+ <Button
71
+ type={'primary'}
72
+ onClick={() => {
73
+ const data = tableRef?.current?.getDataSource();
74
+ tableRef?.current?.setDataSource([
75
+ ...data,
76
+ {
77
+ id: uuid(),
78
+ },
79
+ ]);
80
+ }}
81
+ >
82
+ 添加一行
83
+ </Button>
84
+ <Button
85
+ onClick={() => {
86
+ const data = tableRef?.current?.getDataSource();
87
+ tableRef?.current?.setDataSource([
88
+ ...data,
89
+ {
90
+ id: uuid(),
91
+ },
92
+ {
93
+ id: uuid(),
94
+ },
95
+ {
96
+ id: uuid(),
97
+ },
98
+ {
99
+ id: uuid(),
100
+ },
101
+ {
102
+ id: uuid(),
103
+ },
104
+ ]);
105
+ }}
106
+ >
107
+ 添加五行
108
+ </Button>
109
+ </div>
110
+ );
111
+ },
112
+ };
113
+ return (
114
+ <Modal
115
+ {...props}
116
+ maskClosable={false}
117
+ onOk={() => {
118
+ onParentOk(
119
+ tableRef?.current?.getDataSource().filter((d: any) => d.text && d.value),
120
+ );
121
+ }}
122
+ >
123
+ <Table {...config} style={{ width: '500px' }} ref={tableRef} />
124
+ </Modal>
125
+ );
126
+ };
127
+