@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,206 +1,206 @@
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
- import { judgeIsRequestSuccess } from '@/utils/requestUtils';
12
-
13
-
14
- const App = ({
15
- record,
16
- setValue,
17
- formula
18
- }:{
19
- record:any,
20
- setValue:any,
21
- formula:any,
22
- }) => {
23
- const [formul, setFormul] = useState(record.formula)
24
- const [state, UpdateState]:any = useState([])
25
- const [fieldList, UpdateFiedList] = useState([])
26
-
27
- useEffect(() => {
28
- request({
29
- url: '/basic/flow/businessField/listNoPage',
30
- params: {
31
- 'qp-businessType-eq': record.businessType,
32
- 'qp-fieldGroup-eq': record.fieldGroup,
33
- },
34
- converter: ({ response, data }:any) => {
35
- if (judgeIsRequestSuccess(response)) {
36
- // UpdateFiedList(data.filter(item => item.valueType == 20 || item.valueType == 21 || item.valueType == 22))
37
- 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}))
38
- UpdateFiedList(resData)
39
- let res:any = [];
40
- formul && formul.replace(/(\w+|\+|\-|\*|\/|\(|\))/g, (item:any) => {
41
- if (resData.filter((initem:any) => initem.value === item).length) {
42
- res = res.concat(resData.filter((initem:any) => initem.value === item))
43
- } else {
44
- res = res.concat(['+', '-', '*', '/', '(', ')'].filter(initem => initem === item).map(item => ({value: item, name: item})))
45
- }
46
- })
47
-
48
- UpdateState(res)
49
- }
50
- }
51
- })
52
- }, [])
53
-
54
- const [isModalVisible, setIsModalVisible] = useState(false);
55
-
56
- const showModal = () => {
57
- setIsModalVisible(true);
58
- };
59
-
60
- const handleOk = () => {
61
- setIsModalVisible(false);
62
- setValue(state);
63
- setFormul(state.map((item:any) => {
64
- if (['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1) {
65
- return `{${item.value}}`
66
- }
67
- return item.value;
68
- }).join(''))
69
- };
70
-
71
- const handleCancel = () => {
72
- setIsModalVisible(false);
73
- };
74
-
75
-
76
- const onSortEnd = ({ oldIndex, newIndex }:any) => {
77
- UpdateState(arrayMoveImmutable(state, oldIndex, newIndex))
78
- };
79
-
80
- const deleteItem = (value:any, indexOrder:any) => {
81
- UpdateState([].concat(state).filter((item, index) => index !== indexOrder))
82
-
83
- }
84
-
85
- const SortableItem = SortableElement(({ value, sortIndex }:any) => {
86
- debugger
87
- return <span style={{
88
- // height: '100px',
89
- padding: '5px 10px',
90
- margin: '10px',
91
- height: '40px',
92
- lineHeight: '30px',
93
- flexBasis: '1',
94
- border: '1px solid #e8eaee',
95
- borderRadius: '5px',
96
- cursor: 'pointer',
97
- }}>{value} &nbsp; <CloseCircleOutlined onClick={(e) => {
98
- deleteItem(value, sortIndex)
99
- }} /></span>
100
- });
101
-
102
- const SortableList = SortableContainer(({ items }:any) => {
103
- return (
104
- <div style={{ display: 'flex', flexWrap: 'wrap' }}>
105
- {items.map((value:any, index:any) => (
106
- <>
107
- {/* @ts-ignore */}
108
- <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
109
- </>
110
- ))}
111
- </div>
112
- );
113
- });
114
-
115
- const add = ((item:any) => {
116
- UpdateState([...state, item])
117
- })
118
-
119
- const formatFormul = () => {
120
- if (!fieldList.length || !formul) return '';
121
- let res = formul.replace(/\w+/g, (item:any) => {
122
- // @ts-ignore
123
- return fieldList.filter((inneritem:any) => inneritem.value === item)[0].name
124
- })
125
-
126
- return res.replace(/(\{|\})/g, '')
127
- }
128
-
129
-
130
- return (
131
- <>
132
- <>
133
- <Input value={formatFormul()} style={{width: '540px'}} disabled />
134
- <Button type="primary" onClick={showModal}>
135
- 编辑表达式
136
- </Button>
137
- <Modal title="编辑表达式" visible={isModalVisible} onOk={handleOk} onCancel={handleCancel} width={1000}>
138
- <div style={{ height: '600px' }}>
139
- <Row>
140
- <Col span={6}>
141
- <div style={{
142
- border: '1px solid #e8eaee',
143
- padding: '10px',
144
- display: 'flex',
145
- justifyContent: 'space-around',
146
- borderRadius: '5px',
147
- flexWrap: 'wrap',
148
- overflow: 'auto',
149
- maxHeight: '600px'
150
- }}
151
- >
152
- {[...fieldList].map((item:any) => (
153
- <span onClick={() => { add(item) }} style={{
154
- width: '80px',
155
- // height: '100px',
156
- padding: '10px',
157
- margin: '10px 0px',
158
- flexBasis: '1',
159
- border: '1px solid #e8eaee',
160
- borderRadius: '5px',
161
- cursor: 'pointer',
162
- }}>{item.name}</span>
163
- ))}
164
- </div>
165
- </Col>
166
- <Col span={18}>
167
- <Row>
168
- <div>
169
- {['+', '-', '*', '/', '(', ')'].map(item => <span onClick={() => { add({name: item, value: item}) }} style={{
170
- width: '50px',
171
- textAlign: 'center',
172
- display: 'inline-block',
173
- padding: '5px 10px',
174
- margin: '10px',
175
- height: '40px',
176
- lineHeight: '30px',
177
- flexBasis: '1',
178
- border: '1px solid #e8eaee',
179
- borderRadius: '5px',
180
- cursor: 'pointer',
181
- }}>{item}</span>)}
182
- </div>
183
- </Row>
184
- <Row>
185
- <div style={{
186
- width: '700px',
187
- padding: '10px',
188
- marginLeft: '10px',
189
- flexBasis: '1',
190
- border: '1px solid #e8eaee',
191
- minHeight: '560px'
192
- }}>
193
- {/* @ts-ignore */}
194
- <SortableList distance={20} helperClass="row-dragging" items={state} axis='xy' onSortEnd={onSortEnd} />
195
- </div>
196
- </Row>
197
- </Col>
198
- </Row>
199
- </div>
200
- </Modal>
201
- </>
202
- </>
203
- );
204
- };
205
-
206
- 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
+ import { judgeIsRequestSuccess } from '@/utils/requestUtils';
12
+
13
+
14
+ const App = ({
15
+ record,
16
+ setValue,
17
+ formula
18
+ }:{
19
+ record:any,
20
+ setValue:any,
21
+ formula:any,
22
+ }) => {
23
+ const [formul, setFormul] = useState(record.formula)
24
+ const [state, UpdateState]:any = useState([])
25
+ const [fieldList, UpdateFiedList] = useState([])
26
+
27
+ useEffect(() => {
28
+ request({
29
+ url: '/basic/flow/businessField/listNoPage',
30
+ params: {
31
+ 'qp-businessType-eq': record.businessType,
32
+ 'qp-fieldGroup-eq': record.fieldGroup,
33
+ },
34
+ converter: ({ response, data }:any) => {
35
+ if (judgeIsRequestSuccess(response)) {
36
+ // UpdateFiedList(data.filter(item => item.valueType == 20 || item.valueType == 21 || item.valueType == 22))
37
+ 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}))
38
+ UpdateFiedList(resData)
39
+ let res:any = [];
40
+ formul && formul.replace(/(\w+|\+|\-|\*|\/|\(|\))/g, (item:any) => {
41
+ if (resData.filter((initem:any) => initem.value === item).length) {
42
+ res = res.concat(resData.filter((initem:any) => initem.value === item))
43
+ } else {
44
+ res = res.concat(['+', '-', '*', '/', '(', ')'].filter(initem => initem === item).map(item => ({value: item, name: item})))
45
+ }
46
+ })
47
+
48
+ UpdateState(res)
49
+ }
50
+ }
51
+ })
52
+ }, [])
53
+
54
+ const [isModalVisible, setIsModalVisible] = useState(false);
55
+
56
+ const showModal = () => {
57
+ setIsModalVisible(true);
58
+ };
59
+
60
+ const handleOk = () => {
61
+ setIsModalVisible(false);
62
+ setValue(state);
63
+ setFormul(state.map((item:any) => {
64
+ if (['+', '-', '*', '/', '(', ')'].indexOf(item.value) == -1) {
65
+ return `{${item.value}}`
66
+ }
67
+ return item.value;
68
+ }).join(''))
69
+ };
70
+
71
+ const handleCancel = () => {
72
+ setIsModalVisible(false);
73
+ };
74
+
75
+
76
+ const onSortEnd = ({ oldIndex, newIndex }:any) => {
77
+ UpdateState(arrayMoveImmutable(state, oldIndex, newIndex))
78
+ };
79
+
80
+ const deleteItem = (value:any, indexOrder:any) => {
81
+ UpdateState([].concat(state).filter((item, index) => index !== indexOrder))
82
+
83
+ }
84
+
85
+ const SortableItem = SortableElement(({ value, sortIndex }:any) => {
86
+ debugger
87
+ return <span style={{
88
+ // height: '100px',
89
+ padding: '5px 10px',
90
+ margin: '10px',
91
+ height: '40px',
92
+ lineHeight: '30px',
93
+ flexBasis: '1',
94
+ border: '1px solid #e8eaee',
95
+ borderRadius: '5px',
96
+ cursor: 'pointer',
97
+ }}>{value} &nbsp; <CloseCircleOutlined onClick={(e) => {
98
+ deleteItem(value, sortIndex)
99
+ }} /></span>
100
+ });
101
+
102
+ const SortableList = SortableContainer(({ items }:any) => {
103
+ return (
104
+ <div style={{ display: 'flex', flexWrap: 'wrap' }}>
105
+ {items.map((value:any, index:any) => (
106
+ <>
107
+ {/* @ts-ignore */}
108
+ <SortableItem key={`item-${value.value}`} sortIndex={index} index={index} value={value.name} />
109
+ </>
110
+ ))}
111
+ </div>
112
+ );
113
+ });
114
+
115
+ const add = ((item:any) => {
116
+ UpdateState([...state, item])
117
+ })
118
+
119
+ const formatFormul = () => {
120
+ if (!fieldList.length || !formul) return '';
121
+ let res = formul.replace(/\w+/g, (item:any) => {
122
+ // @ts-ignore
123
+ return fieldList.filter((inneritem:any) => inneritem.value === item)[0].name
124
+ })
125
+
126
+ return res.replace(/(\{|\})/g, '')
127
+ }
128
+
129
+
130
+ return (
131
+ <>
132
+ <>
133
+ <Input value={formatFormul()} style={{width: '540px'}} disabled />
134
+ <Button type="primary" onClick={showModal}>
135
+ 编辑表达式
136
+ </Button>
137
+ <Modal title="编辑表达式" visible={isModalVisible} onOk={handleOk} onCancel={handleCancel} width={1000}>
138
+ <div style={{ height: '600px' }}>
139
+ <Row>
140
+ <Col span={6}>
141
+ <div style={{
142
+ border: '1px solid #e8eaee',
143
+ padding: '10px',
144
+ display: 'flex',
145
+ justifyContent: 'space-around',
146
+ borderRadius: '5px',
147
+ flexWrap: 'wrap',
148
+ overflow: 'auto',
149
+ maxHeight: '600px'
150
+ }}
151
+ >
152
+ {[...fieldList].map((item:any) => (
153
+ <span onClick={() => { add(item) }} style={{
154
+ width: '80px',
155
+ // height: '100px',
156
+ padding: '10px',
157
+ margin: '10px 0px',
158
+ flexBasis: '1',
159
+ border: '1px solid #e8eaee',
160
+ borderRadius: '5px',
161
+ cursor: 'pointer',
162
+ }}>{item.name}</span>
163
+ ))}
164
+ </div>
165
+ </Col>
166
+ <Col span={18}>
167
+ <Row>
168
+ <div>
169
+ {['+', '-', '*', '/', '(', ')'].map(item => <span onClick={() => { add({name: item, value: item}) }} style={{
170
+ width: '50px',
171
+ textAlign: 'center',
172
+ display: 'inline-block',
173
+ padding: '5px 10px',
174
+ margin: '10px',
175
+ height: '40px',
176
+ lineHeight: '30px',
177
+ flexBasis: '1',
178
+ border: '1px solid #e8eaee',
179
+ borderRadius: '5px',
180
+ cursor: 'pointer',
181
+ }}>{item}</span>)}
182
+ </div>
183
+ </Row>
184
+ <Row>
185
+ <div style={{
186
+ width: '700px',
187
+ padding: '10px',
188
+ marginLeft: '10px',
189
+ flexBasis: '1',
190
+ border: '1px solid #e8eaee',
191
+ minHeight: '560px'
192
+ }}>
193
+ {/* @ts-ignore */}
194
+ <SortableList distance={20} helperClass="row-dragging" items={state} axis='xy' onSortEnd={onSortEnd} />
195
+ </div>
196
+ </Row>
197
+ </Col>
198
+ </Row>
199
+ </div>
200
+ </Modal>
201
+ </>
202
+ </>
203
+ );
204
+ };
205
+
206
+ 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
+