@bit-sun/business-component 4.2.0-alpha.0 → 4.2.0-alpha.10

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 (99) hide show
  1. package/.umirc.ts +9 -9
  2. package/dist/components/Business/AddSelectBusiness/index.d.ts +3 -4
  3. package/dist/components/Business/BsLayouts/Components/AllFunc/drawContent.d.ts +1 -2
  4. package/dist/components/Business/BsLayouts/Components/ChooseStore/index.d.ts +1 -2
  5. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/index.d.ts +1 -1
  6. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/leftTree.d.ts +1 -1
  7. package/dist/components/Business/BsLayouts/Components/CustomerMenu/MenuSetting/rightTree.d.ts +2 -2
  8. package/dist/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/DrawContent.d.ts +1 -2
  9. package/dist/components/Business/BsLayouts/Components/CustomerMenu/globalMenu/customMenuHeader.d.ts +1 -2
  10. package/dist/components/Business/BsLayouts/Components/CustomerMenu/index.d.ts +1 -1
  11. package/dist/components/Business/BsLayouts/Components/GlobalHeader/index.d.ts +1 -2
  12. package/dist/components/Business/BsLayouts/Components/RightContent/LoginModal.d.ts +1 -2
  13. package/dist/components/Business/BsLayouts/index.d.ts +1 -1
  14. package/dist/components/Business/BsSulaQueryTable/SearchItemSetting.d.ts +5 -5
  15. package/dist/components/Business/BsSulaQueryTable/index.d.ts +1 -2
  16. package/dist/components/Business/BsSulaQueryTable/setting.d.ts +6 -6
  17. package/dist/components/Business/BsSulaQueryTable/utils.d.ts +14 -15
  18. package/dist/components/Business/CommodityEntry/index.d.ts +1 -2
  19. package/dist/components/Business/CommonAlert/index.d.ts +1 -2
  20. package/dist/components/Business/CommonGuideWrapper/index.d.ts +3 -3
  21. package/dist/components/Business/DetailPageWrapper/index.d.ts +12 -12
  22. package/dist/components/Business/HomePageWrapper/index.d.ts +1 -2
  23. package/dist/components/Business/ItemPropertySelector/index.d.ts +1 -2
  24. package/dist/components/Business/JsonQueryTable/components/FieldsModifyModal.d.ts +1 -2
  25. package/dist/components/Business/JsonQueryTable/components/FieldsSettingsTable.d.ts +1 -2
  26. package/dist/components/Business/JsonQueryTable/components/Formula.d.ts +1 -2
  27. package/dist/components/Business/JsonQueryTable/components/MaintainOptions.d.ts +1 -2
  28. package/dist/components/Business/JsonQueryTable/drawer/index.d.ts +1 -2
  29. package/dist/components/Business/PropertyModal/index.d.ts +1 -2
  30. package/dist/components/Business/PropertyModal/propertyGroup.d.ts +1 -1
  31. package/dist/components/Business/SearchSelect/index.d.ts +1 -1
  32. package/dist/components/Business/StateFlow/index.d.ts +1 -2
  33. package/dist/components/Business/SystemLog/index.d.ts +78 -0
  34. package/dist/components/Business/TreeSearchSelect/index.d.ts +1 -1
  35. package/dist/components/Business/columnSettingTable/columnSetting.d.ts +6 -6
  36. package/dist/components/Business/columnSettingTable/components/TableSumComponent.d.ts +1 -2
  37. package/dist/components/Business/columnSettingTable/index.d.ts +3 -3
  38. package/dist/components/Business/columnSettingTable/sulaSettingTable.d.ts +3 -3
  39. package/dist/components/Business/columnSettingTable/utils.d.ts +1 -2
  40. package/dist/components/Business/moreTreeTable/FixedScrollBar.d.ts +1 -1
  41. package/dist/components/Common/ParagraphCopier/index.d.ts +1 -1
  42. package/dist/components/Common/Section/index.d.ts +1 -1
  43. package/dist/components/Functional/AddSelect/index.d.ts +1 -2
  44. package/dist/components/Functional/AuthButton/index.d.ts +1 -2
  45. package/dist/components/Functional/DataImport/index.d.ts +3 -3
  46. package/dist/components/Functional/DataValidation/index.d.ts +5 -5
  47. package/dist/components/Functional/ExportFunctions/ExportIcon/index.d.ts +1 -2
  48. package/dist/components/Functional/QueryMutipleInput/index.d.ts +3 -3
  49. package/dist/components/Functional/QueryMutipleSelect/index.d.ts +1 -2
  50. package/dist/components/Functional/SearchSelect/index.d.ts +1 -1
  51. package/dist/components/Functional/SearchSelect/utils.d.ts +2 -3
  52. package/dist/components/Functional/TreeSearchSelect/index.d.ts +1 -2
  53. package/dist/components/Solution/RuleComponent/CustomPlugin/CustomSelector/CustomSelectorModal.d.ts +1 -1
  54. package/dist/components/Solution/RuleComponent/CustomPlugin/CustomSelector/index.d.ts +1 -2
  55. package/dist/components/Solution/RuleComponent/Formula.d.ts +1 -2
  56. package/dist/components/Solution/RuleComponent/InnerSelect.d.ts +1 -2
  57. package/dist/components/Solution/RuleComponent/RenderCompItem.d.ts +1 -2
  58. package/dist/components/Solution/RuleSetter/RuleInstance.d.ts +1 -2
  59. package/dist/components/Solution/RuleSetter/baseRule.d.ts +1 -1
  60. package/dist/components/Solution/RuleSetter/index.d.ts +1 -1
  61. package/dist/index.d.ts +3 -0
  62. package/dist/index.esm.js +2072 -1246
  63. package/dist/index.js +2071 -1241
  64. package/dist/plugin/TableColumnSetting/index.d.ts +6 -5
  65. package/dist/utils/TableUtils.d.ts +18 -19
  66. package/dist/utils/utils.d.ts +41 -0
  67. package/docs/flow-control-readme.md +283 -0
  68. package/package.json +11 -11
  69. package/src/components/Business/AddSelectBusiness/index.md +8 -2
  70. package/src/components/Business/AddSelectBusiness/index.tsx +3 -0
  71. package/src/components/Business/BsLayouts/Components/GlobalHeader/index.less +1 -1
  72. package/src/components/Business/BsLayouts/Components/RightContent/home.less +1 -1
  73. package/src/components/Business/BsLayouts/Components/SearchFunc/index.less +2 -2
  74. package/src/components/Business/BsSulaQueryTable/SearchItemSetting.tsx +1 -1
  75. package/src/components/Business/BsSulaQueryTable/index.md +57 -4
  76. package/src/components/Business/BsSulaQueryTable/index.tsx +164 -7
  77. package/src/components/Business/BsSulaQueryTable/setting.tsx +6 -0
  78. package/src/components/Business/BsSulaQueryTable/utils.less +1 -1
  79. package/src/components/Business/DetailPageWrapper/index.tsx +81 -1
  80. package/src/components/Business/DetailPageWrapper/readme.md +89 -0
  81. package/src/components/Business/SearchSelect/BusinessUtils.tsx +363 -41
  82. package/src/components/Business/SystemLog/index.md +37 -0
  83. package/src/components/Business/SystemLog/index.tsx +87 -0
  84. package/src/components/Business/columnSettingTable/index.tsx +7 -6
  85. package/src/components/Business/columnSettingTable/sulaSettingTable.tsx +23 -22
  86. package/src/components/Functional/AddSelect/index.tsx +112 -3
  87. package/src/components/Functional/DataValidation/index.tsx +22 -3
  88. package/src/components/Functional/QueryMutipleInput/index.tsx +12 -3
  89. package/src/components/Functional/SearchSelect/index.tsx +68 -10
  90. package/src/components/Functional/SearchSelect/utils.tsx +4 -1
  91. package/src/components/Solution/RuleComponent/InnerSelect.tsx +1 -0
  92. package/src/components/Solution/RuleComponent/RenderCompItem.tsx +11 -2
  93. package/src/components/Solution/RuleComponent/RenderCompItem_README.md +189 -0
  94. package/src/components/Solution/RuleComponent/index.js +16 -3
  95. package/src/components/Solution/RuleComponent/ruleFiled.js +25 -1
  96. package/src/index.ts +7 -0
  97. package/src/plugin/TableColumnSetting/index.tsx +75 -9
  98. package/src/utils/TableUtils.less +1 -1
  99. package/src/utils/utils.ts +41 -1
@@ -0,0 +1,37 @@
1
+ ---
2
+ nav:
3
+ title: '组件'
4
+ order: 1
5
+ group:
6
+ title: 业务组件
7
+ order: 1
8
+ title: 日志组件
9
+ order: 1
10
+ ---
11
+
12
+ # SystemLog
13
+
14
+
15
+ ## 日志业务组件
16
+
17
+ ```tsx
18
+ import React, { useState } from 'react';
19
+ import { SystemLog } from '../../../index.ts';
20
+
21
+ export default () => {
22
+ const [modeType, setModeType] = useState('view');
23
+ const renderLogRef = useRef<any>();
24
+
25
+ return {
26
+ fields: [
27
+ SystemLog({
28
+ modeType,
29
+ code: '123',
30
+ containerName: 'Test_Log_Info',
31
+ renderLogRef,
32
+ extraParams: {},
33
+ })
34
+ ],
35
+ };
36
+ };
37
+ ```
@@ -0,0 +1,87 @@
1
+ import { handleCommonTimeRender } from '@/utils/TableUtils';
2
+ import { formContainerAndItemLayout, handleConvertResponse } from '@/utils/utils';
3
+ import { Table as BsTable } from 'bssula';
4
+ import React from 'react';
5
+
6
+ //操作日志
7
+ const SystemLog = ({
8
+ modeType,
9
+ code,
10
+ containerName,
11
+ renderLogRef = {},
12
+ extraParams = {},
13
+ }: {
14
+ modeType: string,
15
+ code: any
16
+ containerName: string,
17
+ renderLogRef: object,
18
+ extraParams?: object,
19
+ }) => {
20
+ return {
21
+ ...formContainerAndItemLayout('table', '操作日志', containerName),
22
+ initialVisible: modeType != 'create',
23
+ fields: [
24
+ {
25
+ name: 'table',
26
+ label: false,
27
+ itemLayout: {
28
+ span: 24,
29
+ labelCol: {
30
+ span: 0,
31
+ },
32
+ wrapperCol: {
33
+ span: 24,
34
+ },
35
+ },
36
+ field: (ctx: any) => {
37
+ return code && <BsTable
38
+ remoteDataSource={{
39
+ url: `/oms-ops/logInfo?qp-businessCode-eq=${code}`,
40
+ convertParams: ({ params }: any) => {
41
+ return {
42
+ pageSize: params.pageSize,
43
+ currentPage: params.current,
44
+ ...extraParams,
45
+ };
46
+ },
47
+ converter: ({ data }: any) => {
48
+ return {
49
+ ...handleConvertResponse(data.list, data.total || data.totalCount),
50
+ };
51
+ },
52
+ }}
53
+ columns={[
54
+ {
55
+ title: '操作人',
56
+ dataIndex: 'handlerName',
57
+ },
58
+ {
59
+ title: '操作名称',
60
+ dataIndex: 'handlerType',
61
+ },
62
+ {
63
+ title: '操作时间',
64
+ dataIndex: 'handlerTime',
65
+ render: ({ text }: { text: any }) => handleCommonTimeRender(text)
66
+ },
67
+ {
68
+ title: '操作内容',
69
+ dataIndex: 'logcontent',
70
+ },
71
+ ]}
72
+ style={{ width: '100%', marginTop: '-16px', padding: '0px' }}
73
+ rowKey="id"
74
+ scroll={{ x: 'max-content' }}
75
+ pagination={{
76
+ showTotal: (total: any) => `共 ${total} 条`,
77
+ showQuickJumper: true,
78
+ hideOnSinglePage: true,
79
+ }}
80
+ ref={renderLogRef}
81
+ />
82
+ },
83
+ },
84
+ ],
85
+ }
86
+ }
87
+ export default SystemLog
@@ -1,3 +1,4 @@
1
+ // @ts-nocheck
1
2
  import React, { useState } from 'react';
2
3
  import { Table, Tooltip, Typography } from 'antd';
3
4
  import { Resizable } from 'react-resizable';
@@ -81,9 +82,9 @@ export default class ColumnSettingTable extends React.Component {
81
82
 
82
83
  /**
83
84
  * 新增函数,用于根据传入的小数位数进行四舍五入
84
- * @param number
85
- * @param decimalPlaces
86
- * @returns
85
+ * @param number
86
+ * @param decimalPlaces
87
+ * @returns
87
88
  */
88
89
  roundToDecimalPlaces = (number: any, decimalPlaces: number) => {
89
90
  const factor = Math.pow(10, (decimalPlaces || 2));
@@ -92,7 +93,7 @@ export default class ColumnSettingTable extends React.Component {
92
93
 
93
94
  /**
94
95
  * 合计行逻辑
95
- * @returns
96
+ * @returns
96
97
  */
97
98
  getTableSummaryInfo = () => {
98
99
  const { summary = undefined, rowSelection, expandable, modeType, dataSource, isSpecial = false, }: any = this.props;
@@ -232,7 +233,7 @@ export default class ColumnSettingTable extends React.Component {
232
233
 
233
234
  /**
234
235
  * 处理行点击事件
235
- * @param record
236
+ * @param record
236
237
  */
237
238
  handleRowClick = (record: any) => {
238
239
  const { selectedRowKeys, selectedRows, } = this.state;
@@ -316,7 +317,7 @@ export default class ColumnSettingTable extends React.Component {
316
317
  ...propRowSelection,
317
318
  selectedRowKeys: this.state.selectedRowKeys,
318
319
  onChange: (selectedRowKeys: any, selectedRows: any) => {
319
- this.setState({
320
+ this.setState({
320
321
  selectedRowKeys,
321
322
  selectedRows
322
323
  });
@@ -1,3 +1,4 @@
1
+ // @ts-nocheck
1
2
  import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';
2
3
  import { Table as SulaTable, request } from 'bssula';
3
4
  import { Resizable } from 'react-resizable';
@@ -22,7 +23,7 @@ export default class ColumnSettingSulaTable extends React.Component {
22
23
  showColumns: [],
23
24
  selectedRowKeys: [], // 新增状态,用于跟踪选中的行的键
24
25
  selectedRows: [],
25
- showSummary: null
26
+ showSummary: null
26
27
  }
27
28
  this.sulaTableRef = React.createRef<any>();
28
29
  }
@@ -79,9 +80,9 @@ export default class ColumnSettingSulaTable extends React.Component {
79
80
 
80
81
  /**
81
82
  * 新增函数,用于根据传入的小数位数进行四舍五入
82
- * @param number
83
- * @param decimalPlaces
84
- * @returns
83
+ * @param number
84
+ * @param decimalPlaces
85
+ * @returns
85
86
  */
86
87
  roundToDecimalPlaces = (number: any, decimalPlaces: number) => {
87
88
  const factor = Math.pow(10, (decimalPlaces || 2));
@@ -90,7 +91,7 @@ export default class ColumnSettingSulaTable extends React.Component {
90
91
 
91
92
  /**
92
93
  * 合计行逻辑
93
- * @returns
94
+ * @returns
94
95
  */
95
96
  getTableSummaryInfo = () => {
96
97
  const { summary = undefined, rowSelection, expandable, isSpecial = false, modeType }: any = this.props;
@@ -167,10 +168,10 @@ export default class ColumnSettingSulaTable extends React.Component {
167
168
  </Table.Summary.Row>
168
169
  </Table.Summary>
169
170
  );
170
-
171
+
171
172
  return () => summaryDom;
172
- };
173
-
173
+ };
174
+
174
175
  handledynamicColumns = (col: any[]) => {
175
176
  let { dynamicColumns, modeType }: any = this.props;
176
177
  col = col.map((item: any) => {
@@ -205,7 +206,7 @@ export default class ColumnSettingSulaTable extends React.Component {
205
206
 
206
207
  ResizeableTitle = (props: any) => {
207
208
  const { onResize, width, ...restProps } = props;
208
-
209
+
209
210
  const [innerWidth, setInnerWidth] = useState(width);
210
211
  const [isResizing, setIsResizing] = useState(false); // 标记是否正在拖拽
211
212
  const [isDragging, setIsDragging] = useState(false); // 标记拖拽句柄是否被拖拽
@@ -213,9 +214,9 @@ export default class ColumnSettingSulaTable extends React.Component {
213
214
  const markerPosition = useRef({ left: 0, top: 0 });
214
215
  const currentStart = useRef(0);
215
216
  const uuidref = useRef(uuid());
216
-
217
+
217
218
  const prevWidthRef = useRef(width);
218
-
219
+
219
220
  const handleMouseDown = (e: any) => {
220
221
  currentStart.current = e.clientX;
221
222
  markerPosition.current = { left: e.clientX, top: e.clientY }
@@ -223,35 +224,35 @@ export default class ColumnSettingSulaTable extends React.Component {
223
224
  document.addEventListener('mousemove', handleMouseMove);
224
225
  document.addEventListener('mouseup', handleMouseUp);
225
226
  };
226
-
227
+
227
228
  const handleMouseMove = (e: any) => {
228
229
  e.stopPropagation();
229
230
  e.preventDefault();
230
231
  // 更新标记位置
231
232
  markerPosition.current = { left: e.clientX, top: e.clientY }
232
233
  const dom: HTMLElement | null = document.getElementById('text1');
233
-
234
+
234
235
  if (dom && dom.style) {
235
236
  dom.style.left = `${e.clientX}px`;
236
237
  dom.style.top = `${e.clientY - 20}px`;
237
238
  }
238
239
  };
239
-
240
+
240
241
  const handleMouseUp = (e: any) => {
241
242
  document.removeEventListener('mousemove', handleMouseMove);
242
243
  document.removeEventListener('mouseup', handleMouseUp);
243
244
  setIsResizing(false);
244
245
  };
245
-
246
+
246
247
  const handleresize = (e: any, data: any, title: string) => {
247
248
  const newWidth = data?.size?.width || 0;
248
249
  setInnerWidth(newWidth); // 更新内部分宽度
249
250
  };
250
-
251
+
251
252
  const handleResizeStart = () => {
252
253
  setIsResizing(true);
253
254
  };
254
-
255
+
255
256
  const handleResizeStop = (e: any, data: any) => {
256
257
  setIsResizing(false);
257
258
  if (onResize) {
@@ -265,11 +266,11 @@ export default class ColumnSettingSulaTable extends React.Component {
265
266
  setInnerWidth(width);
266
267
  }
267
268
  }, [width]);
268
-
269
+
269
270
  const thStyle = {
270
271
  boxShadow: isResizing ? '2px 2px 10px rgba(0, 0, 0, 0.3)' : 'none',
271
272
  };
272
-
273
+
273
274
  return (
274
275
  <Resizable
275
276
  width={innerWidth}
@@ -333,7 +334,7 @@ export default class ColumnSettingSulaTable extends React.Component {
333
334
 
334
335
  /**
335
336
  * 处理行点击事件
336
- * @param record
337
+ * @param record
337
338
  */
338
339
  handleRowClick = (record: any) => {
339
340
  const { selectedRowKeys, selectedRows, } = this.state;
@@ -420,7 +421,7 @@ export default class ColumnSettingSulaTable extends React.Component {
420
421
  ...propRowSelection,
421
422
  selectedRowKeys: this.state.selectedRowKeys,
422
423
  onChange: (selectedRowKeys: any, selectedRows: any) => {
423
- this.setState({
424
+ this.setState({
424
425
  selectedRowKeys,
425
426
  selectedRows
426
427
  });
@@ -436,7 +437,7 @@ export default class ColumnSettingSulaTable extends React.Component {
436
437
  };
437
438
  },
438
439
  }
439
-
440
+
440
441
  return (
441
442
  <div style={{ position: 'relative' }}>
442
443
  <span style={{ position: 'absolute', zIndex: '10', right: '8px', top: '10px' }} className="ant-dropdown-link">
@@ -87,7 +87,9 @@ const AddSelect = (props: any) => {
87
87
  tableCodeList = [], // 非必填 默认取组件定义code,如需自定义----数组第一位为供选择商品的table的code,第二位为已选择商品的table的code
88
88
  businessType = 'sku',
89
89
  isAllowRepeatedSelect = false,
90
- clearTitle
90
+ clearTitle,
91
+ batchFormatCallback,
92
+ batchFormatBtnTitle,
91
93
  } = props;
92
94
  const { url, method = 'get', sourceKey, otherParams, isMap, mappingValueField = 'code', extralHeaders = {} } = requestConfig || {};
93
95
  const realButtonProps = {type: "primary", ...buttonProps};
@@ -214,9 +216,108 @@ const AddSelect = (props: any) => {
214
216
  // precision: unitAccuracy
215
217
  }
216
218
  }
219
+ // 如果属性为函数时,则执行该函数
220
+ const inputProps = Object.keys(item?.inputProps || {})?.reduce((acc, key) => {
221
+ const value = item?.inputProps?.[key];
222
+ acc[key] = typeof value === 'function' ? value?.(record) : value;
223
+ return acc;
224
+ }, {});
225
+
226
+ // 可输入非数字字符
227
+ if(item.canInputString) {
228
+ return (
229
+ <InputNumber
230
+ min={0}
231
+ precision={0}
232
+ controls={false}
233
+ {...inputProps}
234
+ value={text || ''}
235
+ keyboard={false}
236
+ onPressEnter={(e: any) => {
237
+ e.target.blur();
238
+ }}
239
+ onBlur={async (e: any) => {
240
+ const {
241
+ target: { value },
242
+ } = e;
243
+ record[item.dataIndex] = value
244
+ editRecord(record)
245
+ }}
246
+ onKeyDown={(e) => {
247
+ if(e.keyCode === 13 && e.ctrlKey) {
248
+ handleOk(true)
249
+ document.getElementById("first-query")?.focus()
250
+ }
251
+ if(e.keyCode === 8 && e.ctrlKey) {
252
+ message.success('删除当前行')
253
+ e.stopPropagation();
254
+ e.preventDefault();
255
+ let dom = e.nativeEvent.path[5].children[index + 2]?.getElementsByTagName('input')[currentIndex]
256
+ if (dom) {
257
+ dom.select();
258
+ dom.focus();
259
+ dom.scrollIntoView(false)
260
+ }
261
+ dom = null
262
+ deleteRecord(record, popvalue);
263
+ }
264
+ if (e.keyCode === 37 && e.shiftKey) { // 左滑动
265
+ e.stopPropagation();
266
+ e.preventDefault();
267
+ let dom = e.nativeEvent.path[5].children[index + 1]?.getElementsByTagName('input')[currentIndex - 1]
268
+ if (dom) {
269
+ dom.select();
270
+ dom.focus();
271
+ dom.scrollIntoView(false)
272
+ }
273
+ dom = null
274
+ }
275
+ if (e.keyCode === 39 && e.shiftKey) { // 右滑
276
+ e.stopPropagation();
277
+ e.preventDefault();
278
+ let dom = e.nativeEvent.path[5].children[index + 1]?.getElementsByTagName('input')[currentIndex + 1]
279
+ if (dom) {
280
+ dom.select();
281
+ dom.focus();
282
+ dom.scrollIntoView(false)
283
+ }
284
+ dom = null
285
+ }
286
+ if (e.keyCode === 40) {
287
+ e.stopPropagation();
288
+ e.preventDefault();
289
+ let dom = e.nativeEvent.path[5].children[index + 2]?.getElementsByTagName('input')[currentIndex]
290
+ if (dom) {
291
+ dom.select();
292
+ dom.focus();
293
+ dom.scrollIntoView(false)
294
+ }
295
+ dom = null
296
+ } else if (e.keyCode === 38) {
297
+ e.stopPropagation();
298
+ e.preventDefault();
299
+ let dom1 = e.nativeEvent.path[5].children[index]?.getElementsByTagName('input')[currentIndex]
300
+ if (dom1) {
301
+ // dom1.value=""
302
+ // dom1.setSelectionRange(100, 0);
303
+ dom1.select();
304
+ dom1.focus();
305
+ dom1.scrollIntoViewIfNeeded(false)
306
+ // dom1.value=record['count']
307
+ }
308
+ dom1 = null
309
+ } else if (e.keyCode === 9 && index === selectedRowKeys.length - 1 && currentIndex === inputLength - 1) {
310
+ e.stopPropagation();
311
+ e.preventDefault();
312
+ }
313
+ }}
314
+ />
315
+ );
316
+ }
317
+
217
318
  return (
218
319
  <InputNumber
219
- {...item.inputProps}
320
+ {...inputProps}
220
321
  value={text || ''}
221
322
  min={0}
222
323
  autoFocus={record.needFocus}
@@ -615,6 +716,11 @@ const AddSelect = (props: any) => {
615
716
  }, 50)
616
717
  };
617
718
 
719
+ // 将格式化完的数据回显到 表格中
720
+ const batchFormatCallbackHandler = () => {
721
+ setPopValue([...batchFormatCallback?.(popvalue)]);
722
+ }
723
+
618
724
  const handleShowModal = () => {
619
725
  if(beforeShowModal) {
620
726
  beforeShowModal(popvalue).then(res => {
@@ -1049,7 +1155,10 @@ const AddSelect = (props: any) => {
1049
1155
  settingImgAttribute={{ width: 20, style: { marginTop: -2 } }}
1050
1156
  />
1051
1157
  </span>
1052
- <div style={{ marginRight: 8 }}><span onClick={deleteSelectRows} style={{ ...themeColor, cursor: 'pointer' }}>{clearTitle??'清空所选商品'}</span></div>
1158
+ <div style={{ marginRight: 8, display: 'flex', gap: '5px' }}>
1159
+ <span hidden={!batchFormatCallback} onClick={batchFormatCallbackHandler} style={{ cursor: 'pointer' }}>{batchFormatBtnTitle ?? '一键填充'}</span>
1160
+ <span onClick={deleteSelectRows} style={{ ...themeColor, cursor: 'pointer' }}>{clearTitle ?? '清空所选商品'}</span>
1161
+ </div>
1053
1162
  </div>
1054
1163
  </div>
1055
1164
  <Table
@@ -477,9 +477,10 @@ customSort = (a, b) => {
477
477
  });
478
478
  }
479
479
 
480
- resetData = () => {
481
- const { validDataUrl, validDataParams, updateData, columns, isBrandAuth, isCheckStockNum = true, customerColumnsMapping } = this.props;
482
- const resultData = this.getData().filter(d => {
480
+ resetData = async () => {
481
+ const { validDataUrl, validDataParams, updateData, columns, isBrandAuth, isCheckStockNum = true, customerColumnsMapping, checkSharedValue, beforeCheckCallback } = this.props;
482
+
483
+ let resultData = this.getData().filter(d => {
483
484
  return _.compact(Object.values(d)).length
484
485
  })
485
486
 
@@ -491,6 +492,24 @@ customSort = (a, b) => {
491
492
  otherParams = { brandAuth: 'ctl-withAuth' }
492
493
  }
493
494
 
495
+ // 处理校验参数,隐藏校验参数(公用的部分)
496
+ if(checkSharedValue){
497
+ resultData = resultData.map(d => {
498
+ return {
499
+ ...d,
500
+ ...checkSharedValue,
501
+ }
502
+ })
503
+ }
504
+
505
+ // 调用回调函数
506
+ if(beforeCheckCallback){
507
+ resultData = await beforeCheckCallback(resultData);
508
+ if(!resultData){
509
+ return;
510
+ }
511
+ }
512
+
494
513
  request
495
514
  .post(validDataUrl, {
496
515
  ...otherParams,
@@ -11,9 +11,9 @@ import { useDebounceFn } from 'ahooks';
11
11
  import { Input, Button, Modal, ConfigProvider } from 'antd';
12
12
  import './index.less';
13
13
 
14
- const QueryMutipleInput = ({ onValueChange,onPressEnter }) => {
14
+ const QueryMutipleInput = ({ onValueChange,onPressEnter, value: initialValue }) => {
15
15
  const [isModalVisible, setIsModalVisible] = useState(false);
16
- const [value, setValue] = useState('');
16
+ const [value, setValue] = useState(initialValue);
17
17
  const [popvalue, setPopValue] = useState('');
18
18
  const { run } = useDebounceFn(
19
19
  () => {
@@ -24,6 +24,14 @@ const QueryMutipleInput = ({ onValueChange,onPressEnter }) => {
24
24
  },
25
25
  );
26
26
 
27
+ /**
28
+ * 初始化参数
29
+ * 处理参数不展示和清空不同步的问题
30
+ */
31
+ useEffect(() => {
32
+ setValue(initialValue);
33
+ }, [initialValue]);
34
+
27
35
  useEffect(() => {
28
36
  setPopValue(value);
29
37
  onValueChange(value);
@@ -32,7 +40,7 @@ const QueryMutipleInput = ({ onValueChange,onPressEnter }) => {
32
40
  const showModal = () => {
33
41
  setIsModalVisible(true);
34
42
  //弹窗打开时 默认搜索内容换行显示
35
- setPopValue(data => data.replace(/,/g, '\n'));
43
+ setPopValue(data => data?.replace?.(/,/g, '\n'));
36
44
  };
37
45
 
38
46
  const handleOk = () => {
@@ -67,6 +75,7 @@ const QueryMutipleInput = ({ onValueChange,onPressEnter }) => {
67
75
  <Input
68
76
  value={value}
69
77
  onChange={outerChange}
78
+ allowClear
70
79
  onBlur={(e) => {
71
80
  formaData(e.target.value);
72
81
  }}