@bit-sun/business-component 2.2.0-alpha.3 → 2.2.0-alpha.5

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 (180) 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 +277 -940
  9. package/dist/index.js +276 -939
  10. package/dist/utils/LocalstorageUtils.d.ts +6 -0
  11. package/dist/utils/enumConfig.d.ts +0 -1
  12. package/docs/index.md +21 -21
  13. package/lib/assets/drag.svg +17 -17
  14. package/lib/assets/exportFail.svg +37 -37
  15. package/lib/assets/exportProcessing.svg +28 -28
  16. package/lib/assets/exportSuccess.svg +34 -34
  17. package/lib/assets/label_icon_bottom.svg +25 -25
  18. package/lib/assets/upExport.svg +22 -22
  19. package/package.json +77 -77
  20. package/src/assets/32.svg +27 -27
  21. package/src/assets/addIcon.svg +17 -17
  22. package/src/assets/allfunc.svg +27 -27
  23. package/src/assets/arrowRight.svg +24 -24
  24. package/src/assets/btn-delete.svg +29 -29
  25. package/src/assets/btn-edit.svg +19 -19
  26. package/src/assets/btn-more.svg +17 -17
  27. package/src/assets/btn-submit.svg +19 -19
  28. package/src/assets/caidan.svg +11 -11
  29. package/src/assets/close.svg +26 -26
  30. package/src/assets/drag.svg +17 -17
  31. package/src/assets/exportFail.svg +37 -37
  32. package/src/assets/exportProcessing.svg +28 -28
  33. package/src/assets/exportSuccess.svg +34 -34
  34. package/src/assets/fixed-left-active.svg +11 -11
  35. package/src/assets/fixed-left.svg +15 -15
  36. package/src/assets/fixed-right-active.svg +11 -11
  37. package/src/assets/fixed-right.svg +15 -15
  38. package/src/assets/guanbi.svg +15 -15
  39. package/src/assets/icon-quanping.svg +15 -15
  40. package/src/assets/icon-shezhi.svg +17 -17
  41. package/src/assets/label_icon_bottom.svg +25 -25
  42. package/src/assets/list-no-img.svg +21 -21
  43. package/src/assets/morentouxiang-32.svg +23 -23
  44. package/src/assets/scanning.svg +24 -24
  45. package/src/assets/upExport.svg +22 -22
  46. package/src/components/Business/AddSelectBusiness/index.md +63 -63
  47. package/src/components/Business/AddSelectBusiness/index.tsx +344 -344
  48. package/src/components/Business/BsLayouts/Components/AllFunc/drawContent.tsx +111 -111
  49. package/src/components/Business/BsLayouts/Components/AllFunc/index.less +153 -153
  50. package/src/components/Business/BsLayouts/Components/AllFunc/index.tsx +70 -70
  51. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.less +90 -90
  52. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.tsx +37 -37
  53. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.tsx +242 -242
  54. package/src/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.tsx +384 -384
  55. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.tsx +285 -285
  56. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.tsx +74 -74
  57. package/src/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/drawContent.less +170 -170
  58. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.less +64 -64
  59. package/src/components/Business/BsLayouts/Components/CustomerMenu/index.tsx +153 -153
  60. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +72 -72
  61. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.tsx +157 -157
  62. package/src/components/Business/BsLayouts/Components/RightContent/LoginModal.tsx +85 -85
  63. package/src/components/Business/BsLayouts/Components/RightContent/home.less +218 -218
  64. package/src/components/Business/BsLayouts/Components/RightContent/index.tsx +156 -156
  65. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +160 -160
  66. package/src/components/Business/BsLayouts/Components/SearchFunc/index.tsx +75 -75
  67. package/src/components/Business/BsLayouts/index.less +79 -79
  68. package/src/components/Business/BsLayouts/index.tsx +1475 -1479
  69. package/src/components/Business/BsLayouts/service.ts +10 -10
  70. package/src/components/Business/BsLayouts/utils.tsx +225 -230
  71. package/src/components/Business/BsSulaQueryTable/index.less +219 -219
  72. package/src/components/Business/BsSulaQueryTable/index.tsx +471 -529
  73. package/src/components/Business/BsSulaQueryTable/setting.tsx +802 -802
  74. package/src/components/Business/BsSulaQueryTable/utils.less +65 -65
  75. package/src/components/Business/BsSulaQueryTable/utils.tsx +688 -688
  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 +313 -335
  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 +201 -205
  90. package/src/components/Business/JsonQueryTable/components/Formula.tsx +205 -205
  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 +320 -449
  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 +356 -356
  116. package/src/components/Business/SearchSelect/BusinessUtils.ts +1586 -1586
  117. package/src/components/Business/SearchSelect/common.ts +53 -53
  118. package/src/components/Business/SearchSelect/index.md +1254 -1254
  119. package/src/components/Business/SearchSelect/index.tsx +51 -51
  120. package/src/components/Business/SearchSelect/utils.ts +100 -100
  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 +126 -126
  125. package/src/components/Business/TreeSearchSelect/index.tsx +34 -34
  126. package/src/components/Business/TreeSearchSelect/utils.ts +60 -60
  127. package/src/components/Business/columnSettingTable/columnSetting.tsx +764 -764
  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 +232 -232
  131. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +240 -240
  132. package/src/components/Business/columnSettingTable/utils.tsx +68 -68
  133. package/src/components/Business/moreTreeTable/index.less +99 -99
  134. package/src/components/Business/moreTreeTable/index.md +508 -508
  135. package/src/components/Business/moreTreeTable/index.tsx +315 -315
  136. package/src/components/Business/moreTreeTable/utils.ts +126 -126
  137. package/src/components/Functional/AddSelect/index.less +367 -367
  138. package/src/components/Functional/AddSelect/index.md +155 -155
  139. package/src/components/Functional/AddSelect/index.tsx +1072 -1072
  140. package/src/components/Functional/BillEntry/index.less +371 -371
  141. package/src/components/Functional/BillEntry/index.md +39 -39
  142. package/src/components/Functional/BillEntry/index.tsx +766 -766
  143. package/src/components/Functional/DataImport/index.less +63 -63
  144. package/src/components/Functional/DataImport/index.md +44 -44
  145. package/src/components/Functional/DataImport/index.tsx +695 -695
  146. package/src/components/Functional/DataValidation/index.less +63 -63
  147. package/src/components/Functional/DataValidation/index.md +39 -39
  148. package/src/components/Functional/DataValidation/index.tsx +687 -687
  149. package/src/components/Functional/ExportFunctions/ExportIcon/index.md +37 -37
  150. package/src/components/Functional/ExportFunctions/ExportIcon/index.tsx +59 -59
  151. package/src/components/Functional/QueryMutipleInput/index.less +37 -37
  152. package/src/components/Functional/QueryMutipleInput/index.md +33 -33
  153. package/src/components/Functional/QueryMutipleInput/index.tsx +128 -128
  154. package/src/components/Functional/SearchSelect/index.less +115 -115
  155. package/src/components/Functional/SearchSelect/index.md +141 -141
  156. package/src/components/Functional/SearchSelect/index.tsx +813 -813
  157. package/src/components/Functional/SearchSelect/utils.ts +3 -3
  158. package/src/components/Functional/TreeSearchSelect/index.md +47 -47
  159. package/src/components/Functional/TreeSearchSelect/index.tsx +160 -160
  160. package/src/index.ts +34 -34
  161. package/src/plugin/TableColumnSetting/index.less +247 -247
  162. package/src/plugin/TableColumnSetting/index.md +50 -50
  163. package/src/plugin/TableColumnSetting/index.tsx +724 -724
  164. package/src/plugin/TableColumnSetting/utils.ts +19 -19
  165. package/src/styles/bsDefault.less +1912 -1906
  166. package/src/utils/CheckOneUser/index.md +39 -39
  167. package/src/utils/CheckOneUser/index.ts +51 -51
  168. package/src/utils/LocalstorageUtils.ts +58 -33
  169. package/src/utils/TableUtils.tsx +18 -18
  170. package/src/utils/checkUtils.ts +39 -39
  171. package/src/utils/enumConfig.ts +10 -11
  172. package/src/utils/getFormMode.js +12 -12
  173. package/src/utils/index.ts +2 -2
  174. package/src/utils/requestUtils.ts +34 -33
  175. package/src/utils/serialize.js +7 -7
  176. package/src/utils/utils.ts +183 -183
  177. package/tsconfig.json +29 -29
  178. package/typings.d.ts +4 -4
  179. package/dist/components/Business/BsSulaQueryTable/SearchItemSetting.d.ts +0 -59
  180. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +0 -538
@@ -1,449 +1,320 @@
1
- // @ts-nocheck
2
- import React, { useState, useRef, useEffect, Fragment } from 'react';
3
- import { message, Button, Table, Tabs } from 'antd';
4
- import Drawer from './drawer';
5
- import ConfigButton from './configButton';
6
- import Editor from './jsonEditor';
7
- import axios from 'axios';
8
- import FieldsSettingsTable from './components/FieldsSettingsTable';
9
- import { isEmpty } from "lodash"
10
- import './index.less';
11
-
12
- function iterFileds (fields) {
13
- let filedsValue = [];
14
-
15
- function iter(field) {
16
- if(Array.isArray(field.fields)) {
17
- field.fields.forEach(item => {
18
- const targetValue = iterFileds(item);
19
- if(targetValue){
20
- filedsValue.push(targetValue);
21
- }
22
- })
23
- } else {
24
- return {
25
- name: field.name,
26
- isStaticCode: true,
27
- label: field.label,
28
- }
29
- }
30
-
31
- return {
32
- container: {
33
- name: field?.container?.props?.name,
34
- title: field?.container?.props?.title
35
- },
36
- isStaticCode: true,
37
- fields: filedsValue,
38
- };
39
- }
40
-
41
- filedsValue = iter(fields)
42
-
43
- return filedsValue;
44
- }
45
-
46
- function flatFileds (fields) {
47
- let filedsValue = {
48
- };
49
- function iter(field, containerName) {
50
- if(Array.isArray(field.fields)) {
51
- if (field?.container?.props?.name) {
52
- filedsValue[field?.container?.props?.name] = {
53
- ...field,
54
- fields: []
55
- }
56
- }
57
- field.fields.forEach(item => {
58
- iter(item, field?.container?.props?.name)
59
- })
60
- } else {
61
- filedsValue[containerName ? (containerName + field.name) : field.name] = field
62
- }
63
- }
64
-
65
- iter(fields)
66
-
67
- return filedsValue;
68
- }
69
-
70
- function convertFileds (fields, falltValue, faltFieldRange, containerName) {
71
- let filedsValue = [];
72
-
73
- function iter(field) {
74
- if(Array.isArray(field.fields)) {
75
- field.fields.forEach(item => {
76
- const targetValue = convertFileds(item, falltValue, faltFieldRange, field?.container?.name);
77
- if(targetValue){
78
- filedsValue.push(targetValue)
79
- }
80
- })
81
- } else {
82
- const returnField = field.isStaticCode ? falltValue[containerName ? (containerName + field.name) : field.name] : faltFieldRange[field.name];
83
- if (returnField) {
84
- returnField.label = field?.label;
85
- if(Array.isArray(returnField.name)&&returnField.name?.includes("extensionFields")){
86
- returnField.notShowLabel = true;
87
- }
88
- } else {
89
- debugger
90
- }
91
- return returnField;
92
- }
93
-
94
- return {...falltValue[field?.container?.name], fields: filedsValue};
95
- }
96
-
97
- filedsValue = iter(fields)
98
-
99
- return filedsValue;
100
- }
101
-
102
- function faltColumns(columns) {
103
- let columnsValue = {}
104
-
105
- columns.forEach(item => {
106
- columnsValue[item.key] = {...item}
107
- })
108
-
109
- return columnsValue;
110
- }
111
-
112
- function faltCustomerFieldRange(fileds) {
113
- let columnsValue = {}
114
-
115
- fileds.forEach(item => {
116
- columnsValue[item.name] = {...item}
117
- })
118
-
119
- return columnsValue;
120
- }
121
-
122
- function hanleCallbackValue(codeProps, value, customerFields) {
123
- const faltFieldRange = faltCustomerFieldRange(customerFields)
124
- const falltValue = flatFileds({fields: codeProps.fields})
125
- let newCodeProps = {...codeProps};
126
- newCodeProps.fields = convertFileds({fields: value.fields}, falltValue, faltFieldRange).fields;
127
- if (codeProps.columns) {
128
- const faltColumnsValue = faltColumns(codeProps.columns)
129
- newCodeProps.columns = value.columns.map(item => {
130
- if (item.isStaticCode) {
131
- return faltColumnsValue[item.key]
132
- } else {
133
- //自定义字段-列字段
134
- if(item?.key&&item?.key.includes('extensionFields')&&item?.key.includes(',')){
135
- return {
136
- ...item,
137
- render: ({ record }: any) => {
138
- try{
139
- const lastName1= item?.key.split(',')[1]; //兼容没有fieldName的情况
140
- const lastName2 = `${lastName1}Name`;
141
- const target = record?.extensionFields || {};
142
- return target[lastName2] || target[lastName1] || '';
143
- }catch(e){
144
- console.log('e',e);
145
- }
146
- }
147
- }
148
- }else{
149
- return {
150
- ...item
151
- }
152
- }
153
- }
154
- });
155
-
156
- //进行列表搜索项自定义字段name替换 (排除是编辑表单的fields)
157
- newCodeProps.fields = newCodeProps.fields.map(item => {
158
- if(Array.isArray(item?.name)){
159
- return {
160
- ...item,
161
- name: item?.realSearchName || item?.name
162
- }
163
- }
164
- return item;
165
- });
166
-
167
- }
168
-
169
- return newCodeProps;
170
- }
171
-
172
- function isAdmin() {
173
- const username = JSON.parse(localStorage.getItem('userInfo') || '{}')
174
- ?.accountPersonDetail?.username;
175
-
176
- return username === 'admin' || username === 'uiuiui'
177
- }
178
-
179
- const tableStyleList = [
180
- {
181
- type: '快速搜索',
182
- img: 'https://img.alicdn.com/tfs/TB1al1JqHr1gK0jSZR0XXbP8XXa-40-40.svg',
183
- url: '/list/singlesearch',
184
- },
185
- {
186
- type: '高级搜索',
187
- img: 'https://img.alicdn.com/tfs/TB1QgKIqQL0gK0jSZFtXXXQCXXa-40-40.svg',
188
- url: '/list/advancedsearch',
189
- },
190
- {
191
- type: '一般搜索',
192
- img: 'https://img.alicdn.com/tfs/TB1xHCPqRr0gK0jSZFnXXbRRXXa-40-40.svg',
193
- url: '/list/basic',
194
- },
195
- {
196
- type: '无分页表格',
197
- img: 'https://img.alicdn.com/tfs/TB1txuMqQL0gK0jSZFxXXXWHVXa-40-40.svg',
198
- url: '/list/nopagination',
199
- },
200
- {
201
- type: '分步查询表格',
202
- img: 'https://img.alicdn.com/tfs/TB10IOmGkL0gK0jSZFAXXcA9pXa-53-46.svg',
203
- url: '/list/stepquerytable',
204
- },
205
- ];
206
- const JsonQueryTable = React.memo(props => {
207
- const {
208
- callBack, // 主保存函数回调
209
- codeProps, // 整体的配置数据
210
- customerFields, //可选的配置字段
211
- initialSetting, //上一次添加自定义字段后保存的数据
212
- pageType, //页面权限code
213
- detailTablesSetting = [], //详情明细表格列配置数据
214
- saveTableCallBack, //详情明细保存函数回调
215
- } = props;
216
-
217
- let codeFilter = {};
218
- if (codeProps.columns) { // table
219
- codeFilter.columns = codeProps.columns.map(item => ({
220
- key: item.key,
221
- isStaticCode: true,
222
- title: item.title
223
- }))
224
-
225
- codeFilter.fields = codeProps.fields.map(item => ({
226
- name: item.name,
227
- isStaticCode: true,
228
- label: item.label,
229
- notShowLabel: item.notShowLabel || false
230
- }))
231
- } else {
232
- codeFilter.fields = iterFileds({fields: codeProps.fields}).fields
233
- }
234
-
235
- const styleRef = useRef(null);
236
-
237
- const [visible, setVisible] = useState(false)
238
- const [code, setCode] = useState(codeProps);
239
- const [init, setInit] = useState(true);
240
- const [jsonEditorVal, setJsonEditorVal] = useState(initialSetting || codeFilter);
241
- const [moduleParams, setModuleParams] = useState({});
242
- const [activeKey, setActiveKey] = useState('main'); //默认详情页配置
243
- const [tablesConfigParams, setTablesConfigParams] = useState({});
244
- const [tableJsonEditorValsArr, setTableJsonEditorValsArr] = useState([]);
245
-
246
- useEffect(()=>{
247
- Promise.all([
248
- axios.get(`/basic/flow/businessFieldGroup/one?moduleType=2&layoutPoint=${pageType}`),
249
- ]).then(([res] )=> {
250
- const { code, data } = res?.data || {};
251
- if (code === '000000') {
252
- if(data){
253
- const { businessType, code:fieldGroup, moduleType, moduleRelationId } = data;
254
- setModuleParams({
255
- businessType,
256
- fieldGroup,
257
- moduleType,
258
- moduleRelationId
259
- });
260
- }
261
- }
262
- })
263
- },[]);
264
-
265
- useEffect(()=>{
266
- //明细表的配置数据
267
- const axiosArr = detailTablesSetting.map((item:any) => axios.get(`/basic/flow/businessFieldGroup/one?moduleType=2&layoutPoint=${item.tableCode}`));
268
- Promise.all(axiosArr).then(([...resArr])=> {
269
- detailTablesSetting.map((item:any, index:number)=>{
270
- const { code, data } = resArr[index]?.data || {};
271
- if(data){
272
- const { businessType, code:fieldGroup, moduleType } = data;
273
- setTablesConfigParams({
274
- ...tablesConfigParams,
275
- [item.tableCode]: {
276
- businessType,
277
- fieldGroup,
278
- moduleType,
279
- tableFlag: true
280
- }
281
- });
282
- }
283
- })
284
- })
285
-
286
- const detailTableCodeFilter = detailTablesSetting.map(item => {
287
- if(item?.initialSetting && item?.initialSetting.length){
288
- return {
289
- ...item,
290
- columns: item?.initialSetting
291
- }
292
- }
293
- return {
294
- ...item,
295
- columns: item?.columns.map(childItem => ({
296
- key: childItem.key || childItem.dataIndex,
297
- dataIndex: childItem.dataIndex || childItem.key,
298
- isStaticCode: true,
299
- title: childItem.title
300
- }))
301
- }
302
- });
303
- setTableJsonEditorValsArr([...detailTableCodeFilter]);
304
- detailTableCodeFilter.map(item => {
305
- if(item?.initialSetting && item?.initialSetting.length){
306
- onClickRunDetailTables(item.initialSetting, false, item.tableCode, detailTableCodeFilter);
307
- }
308
- })
309
- },[detailTablesSetting.length]);
310
-
311
- const onClickRun = (value, isSave) => {
312
- setJsonEditorVal(value);
313
-
314
- try {
315
- setCode(value);
316
- callBack(hanleCallbackValue(codeProps, value, customerFields), isSave, value);
317
- } catch (e) {
318
- message.error(e);
319
- }
320
- };
321
-
322
- //明细表保存
323
- const onClickRunDetailTables = (value, isSave, tableCode, tableSouce) =>{
324
- const targetCode = tableCode || activeKey;
325
- const targetTableSource = tableSouce || tableJsonEditorValsArr;
326
- const newArr = targetTableSource.map(item => {
327
- if(item.tableCode == targetCode){
328
- return {
329
- ...item,
330
- columns: value
331
- }
332
- }
333
- return item
334
- });
335
- setTableJsonEditorValsArr([...newArr]);
336
-
337
- try {
338
- const target = targetTableSource.find(item=>item.tableCode == targetCode);
339
- const codeProps = {
340
- fields: [],
341
- columns: target?.columns,
342
- };
343
- const newValue = {
344
- fields: [],
345
- columns: value
346
- };
347
- const result = hanleCallbackValue(codeProps, newValue, target?.customerFields);
348
- saveTableCallBack({ columns: result.columns, tableCode: targetCode }, isSave, value);
349
- } catch (e) {
350
- message.error(e);
351
- }
352
- }
353
-
354
- React.useEffect(() => {
355
- localStorage.setItem('jsonEditorVal',JSON.stringify(jsonEditorVal||{}))
356
- }, [jsonEditorVal]);
357
-
358
- React.useEffect(() => {
359
- if (initialSetting) {
360
- onClickRun(initialSetting);
361
- setJsonEditorVal(initialSetting)
362
- }
363
- }, [initialSetting]);
364
-
365
- const height =
366
- styleRef?.current?.clientHeight || styleRef?.current?.offsetHeight;
367
-
368
- const tableParams = {
369
- ...moduleParams,
370
- jsonEditorVal,
371
- codeProps,
372
- };
373
-
374
- return (
375
- <div>
376
- <Drawer visible={visible} width={800} onClose={() => setVisible(false)} className={'customFieldsDrawer'}>
377
- {
378
- detailTablesSetting.length == 0 &&(
379
- <Fragment>
380
- {
381
- isEmpty(moduleParams)?(
382
- <div style={{padding:"10px 0", fontSize:"16px", fontWeight:"bolder"}}>
383
- 提示:业务对象未维护,请在通用单据对应业务类型下维护业务对象
384
- </div>
385
- ):(
386
- <FieldsSettingsTable {...tableParams}/>
387
- )
388
- }
389
- <Editor
390
- type="table"
391
- onRun={onClickRun}
392
- value={jsonEditorVal}
393
- shallowHeight={height}
394
- />
395
- </Fragment>
396
- )
397
- }
398
- {
399
- detailTablesSetting.length > 0 && (
400
- <Tabs defaultActiveKey={activeKey} onChange={(v: any) => setActiveKey(v)}>
401
- <Tabs.TabPane tab="详情页配置" key="main">
402
- {
403
- isEmpty(moduleParams)?(
404
- <div style={{padding:"10px 0", fontSize:"16px", fontWeight:"bolder"}}>
405
- 提示:业务对象未维护,请在通用单据对应业务类型下维护业务对象
406
- </div>
407
- ):(
408
- <FieldsSettingsTable {...tableParams}/>
409
- )
410
- }
411
- <Editor
412
- type="table"
413
- onRun={onClickRun}
414
- value={jsonEditorVal}
415
- shallowHeight={height}
416
- />
417
- </Tabs.TabPane>
418
- {
419
- tableJsonEditorValsArr.map((k:any)=>(
420
- <Tabs.TabPane tab={k.title} key={k.tableCode}>
421
- {
422
- !tablesConfigParams[k.tableCode]?(
423
- <div style={{padding:"10px 0", fontSize:"16px", fontWeight:"bolder"}}>
424
- 提示:业务对象未维护,请在通用单据对应业务类型下维护业务对象
425
- </div>
426
- ):(
427
- <FieldsSettingsTable {...tablesConfigParams[k.tableCode]}/>
428
- )
429
- }
430
- <Editor
431
- type="table"
432
- onRun={onClickRunDetailTables}
433
- value={k.columns}
434
- shallowHeight={height}
435
- />
436
- </Tabs.TabPane>
437
- ))
438
- }
439
- </Tabs>
440
- )
441
- }
442
- </Drawer>
443
-
444
- {!visible && isAdmin() && <ConfigButton type='primary' onClick={() => setVisible(true)}>setting</ConfigButton>}
445
- </div>
446
- );
447
- });
448
-
449
- export default JsonQueryTable;
1
+ // @ts-nocheck
2
+ import React, { useState, useRef, useEffect } from 'react';
3
+ import { message, Button, Table } from 'antd';
4
+ import Drawer from './drawer';
5
+ import ConfigButton from './configButton';
6
+ import Editor from './jsonEditor';
7
+ import axios from 'axios';
8
+ import FieldsSettingsTable from './components/FieldsSettingsTable';
9
+ import { isEmpty } from "lodash"
10
+ import './index.less';
11
+
12
+ function iterFileds (fields) {
13
+ let filedsValue = [];
14
+
15
+ function iter(field) {
16
+ if(Array.isArray(field.fields)) {
17
+ field.fields.forEach(item => {
18
+ const targetValue = iterFileds(item);
19
+ if(targetValue){
20
+ filedsValue.push(targetValue);
21
+ }
22
+ })
23
+ } else {
24
+ return {
25
+ name: field.name,
26
+ isStaticCode: true,
27
+ label: field.label,
28
+ }
29
+ }
30
+
31
+ return {
32
+ container: {
33
+ name: field?.container?.props?.name,
34
+ title: field?.container?.props?.title
35
+ },
36
+ isStaticCode: true,
37
+ fields: filedsValue,
38
+ };
39
+ }
40
+
41
+ filedsValue = iter(fields)
42
+
43
+ return filedsValue;
44
+ }
45
+
46
+ function flatFileds (fields) {
47
+ let filedsValue = {
48
+ };
49
+ function iter(field, containerName) {
50
+ if(Array.isArray(field.fields)) {
51
+ if (field?.container?.props?.name) {
52
+ filedsValue[field?.container?.props?.name] = {
53
+ ...field,
54
+ fields: []
55
+ }
56
+ }
57
+ field.fields.forEach(item => {
58
+ iter(item, field?.container?.props?.name)
59
+ })
60
+ } else {
61
+ filedsValue[containerName ? (containerName + field.name) : field.name] = field
62
+ }
63
+ }
64
+
65
+ iter(fields)
66
+
67
+ return filedsValue;
68
+ }
69
+
70
+ function convertFileds (fields, falltValue, faltFieldRange, containerName) {
71
+ let filedsValue = [];
72
+
73
+ function iter(field) {
74
+ if(Array.isArray(field.fields)) {
75
+ field.fields.forEach(item => {
76
+ const targetValue = convertFileds(item, falltValue, faltFieldRange, field?.container?.name);
77
+ if(targetValue){
78
+ filedsValue.push(targetValue)
79
+ }
80
+ })
81
+ } else {
82
+ const returnField = field.isStaticCode ? falltValue[containerName ? (containerName + field.name) : field.name] : faltFieldRange[field.name];
83
+ if (returnField) {
84
+ returnField.label = field?.label;
85
+ if(Array.isArray(returnField.name)&&returnField.name?.includes("extensionFields")){
86
+ returnField.notShowLabel = true;
87
+ }
88
+ } else {
89
+ debugger
90
+ }
91
+ return returnField;
92
+ }
93
+
94
+ return {...falltValue[field?.container?.name], fields: filedsValue};
95
+ }
96
+
97
+ filedsValue = iter(fields)
98
+
99
+ return filedsValue;
100
+ }
101
+
102
+ function faltColumns(columns) {
103
+ let columnsValue = {}
104
+
105
+ columns.forEach(item => {
106
+ columnsValue[item.key] = {...item}
107
+ })
108
+
109
+ return columnsValue;
110
+ }
111
+
112
+ function faltCustomerFieldRange(fileds) {
113
+ let columnsValue = {}
114
+
115
+ fileds.forEach(item => {
116
+ columnsValue[item.name] = {...item}
117
+ })
118
+
119
+ return columnsValue;
120
+ }
121
+
122
+ function hanleCallbackValue(codeProps, value, customerFields) {
123
+ const faltFieldRange = faltCustomerFieldRange(customerFields)
124
+ const falltValue = flatFileds({fields: codeProps.fields})
125
+ let newCodeProps = {...codeProps};
126
+ newCodeProps.fields = convertFileds({fields: value.fields}, falltValue, faltFieldRange).fields;
127
+ if (codeProps.columns) {
128
+ const faltColumnsValue = faltColumns(codeProps.columns)
129
+ newCodeProps.columns = value.columns.map(item => {
130
+ if (item.isStaticCode) {
131
+ return faltColumnsValue[item.key]
132
+ } else {
133
+ //自定义字段-列字段
134
+ if(item?.key&&item?.key.includes('extensionFields')&&item?.key.includes(',')){
135
+ return {
136
+ ...item,
137
+ render: ({ record }: any) => {
138
+ try{
139
+ const lastName1= item?.key.split(',')[1]; //兼容没有fieldName的情况
140
+ const lastName2 = `${lastName1}Name`;
141
+ const target = record?.extensionFields || {};
142
+ return target[lastName2] || target[lastName1] || '';
143
+ }catch(e){
144
+ console.log('e',e);
145
+ }
146
+ }
147
+ }
148
+ }else{
149
+ return {
150
+ ...item
151
+ }
152
+ }
153
+ }
154
+ });
155
+
156
+ //进行列表搜索项自定义字段name替换 (排除是编辑表单的fields)
157
+ newCodeProps.fields = newCodeProps.fields.map(item => {
158
+ if(Array.isArray(item?.name)){
159
+ return {
160
+ ...item,
161
+ name: item?.realSearchName || item?.name
162
+ }
163
+ }
164
+ return item;
165
+ });
166
+
167
+ }
168
+
169
+ return newCodeProps;
170
+ }
171
+
172
+ function isAdmin() {
173
+ const username = JSON.parse(localStorage.getItem('userInfo') || '{}')
174
+ ?.accountPersonDetail?.username;
175
+
176
+ return username === 'admin' || username === 'uiuiui'
177
+ }
178
+
179
+ const tableStyleList = [
180
+ {
181
+ type: '快速搜索',
182
+ img: 'https://img.alicdn.com/tfs/TB1al1JqHr1gK0jSZR0XXbP8XXa-40-40.svg',
183
+ url: '/list/singlesearch',
184
+ },
185
+ {
186
+ type: '高级搜索',
187
+ img: 'https://img.alicdn.com/tfs/TB1QgKIqQL0gK0jSZFtXXXQCXXa-40-40.svg',
188
+ url: '/list/advancedsearch',
189
+ },
190
+ {
191
+ type: '一般搜索',
192
+ img: 'https://img.alicdn.com/tfs/TB1xHCPqRr0gK0jSZFnXXbRRXXa-40-40.svg',
193
+ url: '/list/basic',
194
+ },
195
+ {
196
+ type: '无分页表格',
197
+ img: 'https://img.alicdn.com/tfs/TB1txuMqQL0gK0jSZFxXXXWHVXa-40-40.svg',
198
+ url: '/list/nopagination',
199
+ },
200
+ {
201
+ type: '分步查询表格',
202
+ img: 'https://img.alicdn.com/tfs/TB10IOmGkL0gK0jSZFAXXcA9pXa-53-46.svg',
203
+ url: '/list/stepquerytable',
204
+ },
205
+ ];
206
+ const JsonQueryTable = React.memo(props => {
207
+ const {
208
+ callBack,
209
+ codeProps,
210
+ customerFields,
211
+ initialSetting,
212
+ pageType
213
+ } = props;
214
+
215
+ let codeFilter = {};
216
+ if (codeProps.columns) { // table
217
+ codeFilter.columns = codeProps.columns.map(item => ({
218
+ key: item.key,
219
+ isStaticCode: true,
220
+ title: item.title
221
+ }))
222
+
223
+ codeFilter.fields = codeProps.fields.map(item => ({
224
+ name: item.name,
225
+ isStaticCode: true,
226
+ label: item.label,
227
+ notShowLabel: item.notShowLabel || false
228
+ }))
229
+ } else {
230
+ codeFilter.fields = iterFileds({fields: codeProps.fields}).fields
231
+ }
232
+ console.log('codeFilter',codeFilter)
233
+
234
+ const styleRef = useRef(null);
235
+
236
+ const [visible, setVisible] = useState(false)
237
+ const [code, setCode] = useState(codeProps);
238
+ const [init, setInit] = useState(true);
239
+ const [jsonEditorVal, setJsonEditorVal] = useState(initialSetting || codeFilter);
240
+ const [moduleParams, setModuleParams] = useState({});
241
+
242
+ useEffect(()=>{
243
+ Promise.all([
244
+ axios.get(`/basic/flow/businessFieldGroup/one?moduleType=2&layoutPoint=${pageType}`),
245
+ ]).then(([res] )=> {
246
+ const { code, data } = res?.data || {};
247
+ if (code === '000000') {
248
+ if(data){
249
+ const { businessType, code:fieldGroup, moduleType, moduleRelationId } = data;
250
+ setModuleParams({
251
+ businessType,
252
+ fieldGroup,
253
+ moduleType,
254
+ moduleRelationId
255
+ });
256
+ }
257
+ }
258
+ })
259
+ },[]);
260
+
261
+ const onClickRun = (value, isSave) => {
262
+ setJsonEditorVal(value);
263
+
264
+ try {
265
+ setCode(value);
266
+ callBack(hanleCallbackValue(codeProps, value, customerFields), isSave, value);
267
+ } catch (e) {
268
+ message.error(e);
269
+ }
270
+ };
271
+
272
+ React.useEffect(() => {
273
+ localStorage.setItem('jsonEditorVal',JSON.stringify(jsonEditorVal||{}))
274
+ }, [jsonEditorVal]);
275
+
276
+ React.useEffect(() => {
277
+ if (initialSetting) {
278
+ onClickRun(initialSetting);
279
+ setJsonEditorVal(initialSetting)
280
+ }
281
+ }, [initialSetting]);
282
+
283
+ const height =
284
+ styleRef?.current?.clientHeight || styleRef?.current?.offsetHeight;
285
+
286
+ const tableParams = {
287
+ ...moduleParams,
288
+ jsonEditorVal,
289
+ codeProps,
290
+ };
291
+
292
+ return (
293
+ <div>
294
+ <Drawer visible={visible} width={800} onClose={() => setVisible(false)} className={'customFieldsDrawer'}>
295
+ <div ref={styleRef}>
296
+
297
+ </div>
298
+ {
299
+ isEmpty(moduleParams)?(
300
+ <div style={{padding:"10px 0", fontSize:"16px", fontWeight:"bolder"}}>
301
+ 提示:业务对象未维护,请在通用单据对应业务类型下维护业务对象
302
+ </div>
303
+ ):(
304
+ <FieldsSettingsTable {...tableParams}/>
305
+ )
306
+ }
307
+ <Editor
308
+ type="table"
309
+ onRun={onClickRun}
310
+ value={jsonEditorVal}
311
+ shallowHeight={height}
312
+ />
313
+ </Drawer>
314
+
315
+ {!visible && isAdmin() && <ConfigButton type='primary' onClick={() => setVisible(true)}>setting</ConfigButton>}
316
+ </div>
317
+ );
318
+ });
319
+
320
+ export default JsonQueryTable;