@zat-design/sisyphus-react 3.7.3-beta.9 → 3.8.0

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 (67) hide show
  1. package/dist/index.esm.css +21 -4
  2. package/dist/less.esm.css +21 -4
  3. package/es/ProEditTable/components/RenderField/index.js +1 -1
  4. package/es/ProEnum/components/Group.js +10 -2
  5. package/es/ProEnum/index.js +1 -1
  6. package/es/ProEnum/style/index.less +7 -1
  7. package/es/ProForm/components/combination/ProModalSelect/index.js +50 -45
  8. package/es/ProForm/components/combination/ProNumberRange/index.js +11 -4
  9. package/es/ProForm/components/combination/ProNumberRange/style/index.less +5 -1
  10. package/es/ProForm/components/render/ChangedWrapper.d.ts +1 -0
  11. package/es/ProForm/components/render/ChangedWrapper.js +26 -10
  12. package/es/ProForm/propsType.d.ts +1 -0
  13. package/es/ProForm/style/index.less +1 -1
  14. package/es/ProForm/utils/transformValue.js +17 -11
  15. package/es/ProSelect/index.js +3 -4
  16. package/es/ProSelect/utils/index.js +5 -4
  17. package/es/ProTable/components/FormatColumn/index.d.ts +7 -1
  18. package/es/ProTable/components/FormatColumn/index.js +14 -8
  19. package/es/ProTable/index.js +30 -13
  20. package/es/ProTable/propsType.d.ts +14 -1
  21. package/es/ProTable/style/index.less +1 -1
  22. package/es/ProTree/components/AdaptiveTooltip.d.ts +4 -0
  23. package/es/ProTree/components/AdaptiveTooltip.js +55 -0
  24. package/es/ProTree/components/List.js +15 -3
  25. package/es/ProTree/components/ProTreeSelect/index.js +25 -5
  26. package/es/ProTree/components/ProTreeSelect/propsType.d.ts +2 -0
  27. package/es/ProTree/components/SearchTitle.d.ts +2 -0
  28. package/es/ProTree/components/SearchTitle.js +17 -8
  29. package/es/ProTree/style/index.less +14 -0
  30. package/es/ProTreeModal/components/Tree.js +15 -17
  31. package/es/ProTreeModal/index.js +62 -7
  32. package/es/ProTreeModal/utils.d.ts +1 -0
  33. package/es/ProTreeModal/utils.js +21 -1
  34. package/es/style/theme/index.less +1 -1
  35. package/lib/ProEditTable/components/RenderField/index.js +1 -1
  36. package/lib/ProEnum/components/Group.js +10 -2
  37. package/lib/ProEnum/index.js +1 -1
  38. package/lib/ProEnum/style/index.less +7 -1
  39. package/lib/ProForm/components/combination/ProModalSelect/index.js +49 -44
  40. package/lib/ProForm/components/combination/ProNumberRange/index.js +11 -4
  41. package/lib/ProForm/components/combination/ProNumberRange/style/index.less +5 -1
  42. package/lib/ProForm/components/render/ChangedWrapper.d.ts +1 -0
  43. package/lib/ProForm/components/render/ChangedWrapper.js +27 -11
  44. package/lib/ProForm/propsType.d.ts +1 -0
  45. package/lib/ProForm/style/index.less +1 -1
  46. package/lib/ProForm/utils/transformValue.js +17 -11
  47. package/lib/ProSelect/index.js +3 -4
  48. package/lib/ProSelect/utils/index.js +5 -4
  49. package/lib/ProTable/components/FormatColumn/index.d.ts +7 -1
  50. package/lib/ProTable/components/FormatColumn/index.js +14 -8
  51. package/lib/ProTable/index.js +30 -13
  52. package/lib/ProTable/propsType.d.ts +14 -1
  53. package/lib/ProTable/style/index.less +1 -1
  54. package/lib/ProTree/components/AdaptiveTooltip.d.ts +4 -0
  55. package/lib/ProTree/components/AdaptiveTooltip.js +61 -0
  56. package/lib/ProTree/components/List.js +15 -3
  57. package/lib/ProTree/components/ProTreeSelect/index.js +25 -5
  58. package/lib/ProTree/components/ProTreeSelect/propsType.d.ts +2 -0
  59. package/lib/ProTree/components/SearchTitle.d.ts +2 -0
  60. package/lib/ProTree/components/SearchTitle.js +19 -7
  61. package/lib/ProTree/style/index.less +14 -0
  62. package/lib/ProTreeModal/components/Tree.js +15 -17
  63. package/lib/ProTreeModal/index.js +61 -6
  64. package/lib/ProTreeModal/utils.d.ts +1 -0
  65. package/lib/ProTreeModal/utils.js +20 -0
  66. package/lib/style/theme/index.less +1 -1
  67. package/package.json +1 -1
@@ -6,10 +6,9 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.transformValue = exports.default = void 0;
8
8
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
9
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
10
9
  var _lodash = require("lodash");
11
10
  var _utils = require("../utils");
12
- var _excluded = ["value"];
11
+ var _utils2 = require("../../utils");
13
12
  var transformValue = exports.transformValue = function transformValue(names, form, fieldName, _normalize, _getValueProps) {
14
13
  return {
15
14
  normalize: function normalize(value) {
@@ -29,23 +28,30 @@ var transformValue = exports.transformValue = function transformValue(names, for
29
28
  return _value;
30
29
  },
31
30
  getValueProps: function getValueProps(value) {
31
+ var _curValue;
32
32
  var _value = [];
33
33
  names.forEach(function (name, index) {
34
34
  var value = form.getFieldValue(name);
35
35
  _value[index] = value;
36
36
  });
37
37
  // 支持外部传入转换函数
38
- var _ref = (_getValueProps === null || _getValueProps === void 0 ? void 0 : _getValueProps(_value)) || {
39
- value: _value
40
- },
41
- cusValue = _ref.value,
42
- cusRest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
38
+ var res = (_getValueProps === null || _getValueProps === void 0 ? void 0 : _getValueProps(_value)) || {
39
+ value: _value
40
+ };
41
+ // 如果数组中值都为空, 则值置为空
42
+ var curValue = res === null || res === void 0 ? void 0 : res.value;
43
43
  // @ts-ignore
44
- (0, _lodash.set)(form.getFieldsValue(true), fieldName, cusValue);
44
+ if ((_curValue = curValue) === null || _curValue === void 0 ? void 0 : _curValue.every(function (item) {
45
+ return (0, _utils2.isEmpty)(item);
46
+ })) {
47
+ curValue = undefined;
48
+ }
49
+ // @ts-ignore
50
+ (0, _lodash.set)(form.getFieldsValue(true), fieldName, curValue);
45
51
  // 如果表单里的值和组合得到的值不全等 更新表单里的值、
46
- return (0, _objectSpread2.default)({
47
- value: cusValue
48
- }, cusRest);
52
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, res), {}, {
53
+ value: curValue
54
+ });
49
55
  },
50
56
  shouldUpdate: function shouldUpdate(prevValues, curValues) {
51
57
  return (0, _utils.diffField)(prevValues, curValues, names);
@@ -297,8 +297,8 @@ var ProSelect = exports.ProSelect = function ProSelect(props, ref) {
297
297
  showArrow: true,
298
298
  loading: fetchFunction === null || fetchFunction === void 0 ? void 0 : fetchFunction.loading,
299
299
  onChange: handleChange,
300
- optionLabelProp: "children" // 解决warning报错,添加默认值
301
- ,
300
+ optionLabelProp: (otherProps === null || otherProps === void 0 ? void 0 : otherProps.isDiffChange) ? 'label' : 'children',
301
+ // optionLabelProp="label" // 解决warning报错,添加默认值
302
302
  showSearch: true,
303
303
  filterOption: (0, _lodash.isFunction)(_onSearch) ? false : function (input, option) {
304
304
  var _option$children, _option$children$prop;
@@ -315,16 +315,15 @@ var ProSelect = exports.ProSelect = function ProSelect(props, ref) {
315
315
  value: transformValue(),
316
316
  children: Array.isArray(newSelectList) && newSelectList.map(function (item) {
317
317
  return (0, _jsxRuntime.jsx)(Option, {
318
+ label: item[label],
318
319
  value: item[code],
319
320
  record: item,
320
321
  disabled: !!item.disabled,
321
322
  children: (0, _jsxRuntime.jsx)(TooltipOption, {
322
323
  title: OptionRender ? OptionRender(item) : selectProps.showCodeName ? "".concat(item[code], "-").concat(item[label]) : item[label],
323
324
  children: OptionRender ? (0, _jsxRuntime.jsx)("span", {
324
- title: OptionRender(item),
325
325
  children: OptionRender(item)
326
326
  }) : (0, _jsxRuntime.jsx)("span", {
327
- title: selectProps.showCodeName ? "".concat(item[code], "-").concat(item[label]) : item[label],
328
327
  children: selectProps.showCodeName ? "".concat(item[code], "-").concat(item[label]) : item[label]
329
328
  })
330
329
  }, item[code])
@@ -38,7 +38,7 @@ var findSelectNameValues = function findSelectNameValues(_ref) {
38
38
  _iterator.f();
39
39
  }
40
40
  if (mode === 'multiple') {
41
- selectValues = [].concat((0, _toConsumableArray2.default)(selectValues), (0, _toConsumableArray2.default)(result));
41
+ selectValues = [].concat((0, _toConsumableArray2.default)(selectValues), (0, _toConsumableArray2.default)(result || []));
42
42
  } else {
43
43
  selectValues.push(result);
44
44
  }
@@ -61,13 +61,14 @@ var getSelectList = exports.getSelectList = function getSelectList(_ref2) {
61
61
  if (!otherProps) {
62
62
  return null;
63
63
  }
64
- var listName = otherProps.listName,
64
+ var name = otherProps.name,
65
+ listName = otherProps.listName,
65
66
  form = otherProps.form;
66
67
  var firstNumberIndex = listName.lastIndexOf(listName.findLast(function (item) {
67
68
  return typeof item === 'number';
68
69
  }));
69
- var fatherName = listName.slice(0, firstNumberIndex);
70
- var selectName = listName.slice(firstNumberIndex + 1);
70
+ var fatherName = (name || listName).slice(0, firstNumberIndex);
71
+ var selectName = (name || listName).slice(firstNumberIndex + 1);
71
72
  return findSelectNameValues({
72
73
  list: form.getFieldValue(fatherName) || [],
73
74
  selectName: selectName,
@@ -1,6 +1,12 @@
1
1
  import React from 'react';
2
2
  import { ProTableColumn } from '../../propsType';
3
- export declare const formatColumn: (column: ProTableColumn, originalObj: any, dataSourceObj: any, rowKey: any) => void;
3
+ export declare const formatColumn: ({ column, originalObj, dataSourceObj, rowKey, diffToolTip, }: {
4
+ column: ProTableColumn;
5
+ originalObj: any;
6
+ dataSourceObj: any;
7
+ rowKey: any;
8
+ diffToolTip?: boolean;
9
+ }) => void;
4
10
  /**
5
11
  * 查找最近的父级className
6
12
  * @param element 当前node节点
@@ -17,7 +17,12 @@ var _RenderColumn = _interopRequireDefault(require("../RenderColumn"));
17
17
  var _utils2 = require("../../utils");
18
18
  var _getEnumLabel = _interopRequireDefault(require("../../../ProEnum/utils/getEnumLabel"));
19
19
  var _ProForm = _interopRequireDefault(require("../../../ProForm"));
20
- var formatColumn = exports.formatColumn = function formatColumn(column, originalObj, dataSourceObj, rowKey) {
20
+ var formatColumn = exports.formatColumn = function formatColumn(_ref) {
21
+ var column = _ref.column,
22
+ originalObj = _ref.originalObj,
23
+ dataSourceObj = _ref.dataSourceObj,
24
+ rowKey = _ref.rowKey,
25
+ diffToolTip = _ref.diffToolTip;
21
26
  var title = column.title,
22
27
  valueType = column.valueType,
23
28
  _column$format = column.format,
@@ -37,6 +42,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
37
42
  originalDiffTip = _column$originalDiffT === void 0 ? true : _column$originalDiffT,
38
43
  _column$toolTipProps = column.toolTipProps,
39
44
  toolTipProps = _column$toolTipProps === void 0 ? {} : _column$toolTipProps;
45
+ var _originalDiffTip = diffToolTip !== null && diffToolTip !== void 0 ? diffToolTip : originalDiffTip;
40
46
  // 前缀处理
41
47
  var prefixNode = function prefixNode(value, record, index) {
42
48
  if (!prefix) {
@@ -104,7 +110,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
104
110
  node: node,
105
111
  value: value,
106
112
  currentValue: renderValue,
107
- originalDiffTip: originalDiffTip,
113
+ originalDiffTip: _originalDiffTip,
108
114
  toolTipProps: toolTipProps
109
115
  });
110
116
  };
@@ -134,7 +140,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
134
140
  node: node,
135
141
  value: value,
136
142
  currentValue: renderValue,
137
- originalDiffTip: originalDiffTip,
143
+ originalDiffTip: _originalDiffTip,
138
144
  toolTipProps: toolTipProps
139
145
  });
140
146
  };
@@ -187,7 +193,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
187
193
  node: node,
188
194
  value: value,
189
195
  currentValue: renderValue,
190
- originalDiffTip: originalDiffTip,
196
+ originalDiffTip: _originalDiffTip,
191
197
  toolTipProps: toolTipProps
192
198
  });
193
199
  };
@@ -225,7 +231,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
225
231
  node: node,
226
232
  value: value,
227
233
  currentValue: renderValue,
228
- originalDiffTip: originalDiffTip,
234
+ originalDiffTip: _originalDiffTip,
229
235
  toolTipProps: toolTipProps
230
236
  });
231
237
  };
@@ -252,7 +258,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
252
258
  node: node,
253
259
  value: value,
254
260
  currentValue: renderValue,
255
- originalDiffTip: originalDiffTip,
261
+ originalDiffTip: _originalDiffTip,
256
262
  toolTipProps: toolTipProps
257
263
  });
258
264
  };
@@ -329,7 +335,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
329
335
  node: value,
330
336
  value: value,
331
337
  currentValue: value || '-',
332
- originalDiffTip: originalDiffTip,
338
+ originalDiffTip: _originalDiffTip,
333
339
  toolTipProps: toolTipProps
334
340
  }), suffixNode(value, record, index)]
335
341
  });
@@ -352,7 +358,7 @@ var formatColumn = exports.formatColumn = function formatColumn(column, original
352
358
  node: node,
353
359
  value: value,
354
360
  currentValue: value || '-',
355
- originalDiffTip: originalDiffTip,
361
+ originalDiffTip: _originalDiffTip,
356
362
  toolTipProps: toolTipProps
357
363
  });
358
364
  };
@@ -27,7 +27,7 @@ var _reset = _interopRequireDefault(require("../assets/reset.svg"));
27
27
  var _customColumn = _interopRequireDefault(require("../assets/customColumn.svg"));
28
28
  var _utils = require("./utils");
29
29
  var _locale = _interopRequireDefault(require("../locale"));
30
- var _excluded = ["tableId", "headerRender", "footerRender", "quickConfig", "stripe", "columns", "className", "draggable", "disabled", "isView", "rowDisabled", "summary", "emptyText", "originalDataSource", "onDragStart", "onDragEnd"],
30
+ var _excluded = ["tableId", "headerRender", "footerRender", "quickConfig", "stripe", "columns", "className", "draggable", "disabled", "isView", "rowDisabled", "summary", "emptyText", "diffConfig", "onDragStart", "onDragEnd"],
31
31
  _excluded2 = ["resizeColumn", "columnConfig", "cacheTime", "storage"];
32
32
  var defaultCacheTime = 1; // columns 配置保存时间为一天
33
33
  // 全局上下文
@@ -59,10 +59,15 @@ function ProTable(props) {
59
59
  summary = props.summary,
60
60
  _props$emptyText = props.emptyText,
61
61
  emptyText = _props$emptyText === void 0 ? _locale.default === null || _locale.default === void 0 ? void 0 : (_locale$ProTable = _locale.default.ProTable) === null || _locale$ProTable === void 0 ? void 0 : _locale$ProTable.noData : _props$emptyText,
62
- originalDataSource = props.originalDataSource,
62
+ diffConfig = props.diffConfig,
63
63
  onDragStartGuard = props.onDragStart,
64
64
  onDragEndGuard = props.onDragEnd,
65
65
  restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
66
+ var _ref3 = diffConfig || {},
67
+ originalDataSource = _ref3.originalDataSource,
68
+ changeTipColor = _ref3.changeTipColor,
69
+ addTipColor = _ref3.addTipColor,
70
+ toolTip = _ref3.toolTip;
66
71
  var quickTableConfig = quickConfig ? (0, _objectSpread4.default)({
67
72
  columnConfig: true,
68
73
  cacheTime: true
@@ -78,10 +83,10 @@ function ProTable(props) {
78
83
  _quickTableConfig$sto = quickTableConfig.storage,
79
84
  storage = _quickTableConfig$sto === void 0 ? configStorage : _quickTableConfig$sto,
80
85
  tableProps = (0, _objectWithoutProperties2.default)(quickTableConfig, _excluded2);
81
- var _ref3 = tableProps || {},
82
- pagination = _ref3.pagination,
83
- dataSource = _ref3.dataSource,
84
- rowKey = _ref3.rowKey;
86
+ var _ref4 = tableProps || {},
87
+ pagination = _ref4.pagination,
88
+ dataSource = _ref4.dataSource,
89
+ rowKey = _ref4.rowKey;
85
90
  var initDataSource = dataSource === null || dataSource === void 0 ? void 0 : dataSource.map(function (item) {
86
91
  return (0, _objectSpread4.default)((0, _objectSpread4.default)({}, item), {}, {
87
92
  rowKey: (0, _utils.getRowKey)(rowKey, item)
@@ -164,8 +169,8 @@ function ProTable(props) {
164
169
  };
165
170
  // 列宽resize函数
166
171
  var handleResize = function handleResize(index) {
167
- return function (e, _ref4) {
168
- var size = _ref4.size;
172
+ return function (e, _ref5) {
173
+ var size = _ref5.size;
169
174
  var nextColumns = (0, _toConsumableArray2.default)(curColumns);
170
175
  nextColumns[index] = (0, _objectSpread4.default)((0, _objectSpread4.default)({}, nextColumns[index]), {}, {
171
176
  width: size.width
@@ -195,7 +200,13 @@ function ProTable(props) {
195
200
  return !(item === null || item === void 0 ? void 0 : item.delete);
196
201
  });
197
202
  newColumns === null || newColumns === void 0 ? void 0 : newColumns.forEach(function (item) {
198
- (0, _FormatColumn.formatColumn)(item, originalObj, dataSourceObj, 'rowKey');
203
+ (0, _FormatColumn.formatColumn)({
204
+ column: item,
205
+ originalObj: originalObj,
206
+ dataSourceObj: dataSourceObj,
207
+ rowKey: 'rowKey',
208
+ diffToolTip: toolTip
209
+ });
199
210
  });
200
211
  return newColumns;
201
212
  }, [curColumns, handleResize]);
@@ -212,7 +223,7 @@ function ProTable(props) {
212
223
  });
213
224
  }, [columns]);
214
225
  var handleColumnConfig = /*#__PURE__*/function () {
215
- var _ref5 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(checkList) {
226
+ var _ref6 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(checkList) {
216
227
  var newColumns, _columnConfig$onColum, catchColumns;
217
228
  return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
218
229
  while (1) switch (_context.prev = _context.next) {
@@ -248,7 +259,7 @@ function ProTable(props) {
248
259
  }, _callee);
249
260
  }));
250
261
  return function handleColumnConfig(_x) {
251
- return _ref5.apply(this, arguments);
262
+ return _ref6.apply(this, arguments);
252
263
  };
253
264
  }();
254
265
  (0, _ahooks.useDebounceEffect)(function () {
@@ -321,7 +332,7 @@ function ProTable(props) {
321
332
  return _rowSelection;
322
333
  };
323
334
  var onDataSourceChange = /*#__PURE__*/function () {
324
- var _ref6 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee2(nextDataSource) {
335
+ var _ref7 = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee2(nextDataSource) {
325
336
  return (0, _regeneratorRuntime2.default)().wrap(function _callee2$(_context2) {
326
337
  while (1) switch (_context2.prev = _context2.next) {
327
338
  case 0:
@@ -337,7 +348,7 @@ function ProTable(props) {
337
348
  }, _callee2);
338
349
  }));
339
350
  return function onDataSourceChange(_x2) {
340
- return _ref6.apply(this, arguments);
351
+ return _ref7.apply(this, arguments);
341
352
  };
342
353
  }();
343
354
  var _rowClassName = function _rowClassName(record, index) {
@@ -346,6 +357,11 @@ function ProTable(props) {
346
357
  }
347
358
  };
348
359
  var TableComponent = draggable ? _RcTable.DraggableTable : _RcTable.BaseTable;
360
+ // 标记样式
361
+ var tagStyle = {
362
+ '--zaui-contract-bg': changeTipColor,
363
+ '--zaui-contract-bg-add': addTipColor
364
+ };
349
365
  return (0, _jsxRuntime.jsx)(TableContext.Provider, {
350
366
  value: {
351
367
  pathKey: pathKey,
@@ -369,6 +385,7 @@ function ProTable(props) {
369
385
  }
370
386
  }), (0, _jsxRuntime.jsxs)("div", {
371
387
  className: "pro-table-container",
388
+ style: tagStyle,
372
389
  children: [(0, _jsxRuntime.jsx)(TableComponent, (0, _objectSpread4.default)((0, _objectSpread4.default)({}, restProps), {}, {
373
390
  draggableProps: {
374
391
  onChange: onDataSourceChange,
@@ -59,6 +59,16 @@ export interface DragStartGuardProps {
59
59
  activeObject: any;
60
60
  currentDataSource: any[];
61
61
  }
62
+ export interface TableDiffConfigProps {
63
+ /** 比对原始数据源 */
64
+ originalDataSource: any[];
65
+ /** 是否显示对比值气泡 */
66
+ toolTip?: boolean;
67
+ /** 变更提示颜色 */
68
+ changeTipColor?: string;
69
+ /** 新增提示颜色 */
70
+ addTipColor?: string;
71
+ }
62
72
  export interface ProTableProps<T = any> extends Omit<TableProps<any>, 'summary' | 'columns'> {
63
73
  tableId?: string;
64
74
  rowKey?: string | GetRowKey<any>;
@@ -84,7 +94,10 @@ export interface ProTableProps<T = any> extends Omit<TableProps<any>, 'summary'
84
94
  */
85
95
  stripe?: boolean;
86
96
  columns: ProTableColumn[];
87
- originalDataSource?: any[];
97
+ /**
98
+ * 比对配置
99
+ */
100
+ diffConfig?: TableDiffConfigProps;
88
101
  /**
89
102
  * 拖拽额外配置
90
103
  */
@@ -270,7 +270,7 @@
270
270
  .@{ant-prefix}-table-cell .varied-cell {
271
271
  margin-left: -8px;
272
272
  padding: var(--zaui-space-size-xs, 4px) var(--zaui-space-size-sm, 8px);
273
- background: var(--zaui-contract-bg, #fffaa1);
273
+ background: var(--zaui-contract-bg; #fffaa1) !important;
274
274
  border-radius: var(--zaui-border-radius, 8px);
275
275
  }
276
276
 
@@ -0,0 +1,4 @@
1
+ declare const AdaptiveTooltip: ({ children }: {
2
+ children: any;
3
+ }) => import("react/jsx-runtime").JSX.Element;
4
+ export default AdaptiveTooltip;
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
9
+ var _jsxRuntime = require("react/jsx-runtime");
10
+ var _antd = require("antd");
11
+ var _react = require("react");
12
+ /*
13
+ * @Author: za-xuwenli xuwenli@zhongan.io
14
+ * @Date: 2024-09-20 10:26:04
15
+ * @LastEditors: za-xuwenli xuwenli@zhongan.io
16
+ * @LastEditTime: 2024-09-26 14:12:44
17
+ * @FilePath: /za-material-warehouse/src/ProTree/components/AdaptiveTooltip.tsx
18
+ * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
19
+ */
20
+
21
+ var AdaptiveTooltip = function AdaptiveTooltip(_ref) {
22
+ var children = _ref.children;
23
+ var _useState = (0, _react.useState)('right'),
24
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
25
+ placement = _useState2[0],
26
+ setPlacement = _useState2[1];
27
+ (0, _react.useEffect)(function () {
28
+ var handleResize = function handleResize() {
29
+ var tooltipElement = document.getElementById('adaptive-tooltip');
30
+ if (tooltipElement) {
31
+ var boundingRect = tooltipElement.getBoundingClientRect();
32
+ var windowWidth = window.innerWidth;
33
+ if (windowWidth - boundingRect.right < 150) {
34
+ setPlacement('left');
35
+ } else {
36
+ setPlacement('right');
37
+ }
38
+ }
39
+ };
40
+ window.addEventListener('resize', handleResize);
41
+ handleResize();
42
+ return function () {
43
+ window.removeEventListener('resize', handleResize);
44
+ };
45
+ }, [children]);
46
+ return (0, _jsxRuntime.jsx)(_antd.Tooltip, {
47
+ placement: placement,
48
+ title: (0, _jsxRuntime.jsx)("div", {
49
+ onMouseDown: function onMouseDown(e) {
50
+ return e.stopPropagation();
51
+ },
52
+ children: children
53
+ }),
54
+ id: "adaptive-tooltip",
55
+ children: (0, _jsxRuntime.jsxs)("span", {
56
+ className: "pro-tree-wrap-ellipse",
57
+ children: [" ", children]
58
+ })
59
+ });
60
+ };
61
+ var _default = exports.default = AdaptiveTooltip;
@@ -5,11 +5,22 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.default = void 0;
8
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
9
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
8
10
  var _jsxRuntime = require("react/jsx-runtime");
9
11
  var _react = require("react");
10
12
  var _antd = require("antd");
11
13
  var _SearchTitle = _interopRequireDefault(require("./SearchTitle"));
12
14
  var _CloseIcon = _interopRequireDefault(require("./CloseIcon"));
15
+ var _excluded = ["checkedValues", "disabled", "treeData", "searchStr", "showCodeName", "mode", "fieldNames", "handleOnChange", "handleFilterClose", "optionRender"];
16
+ /*
17
+ * @Author: za-xuwenli xuwenli@zhongan.io
18
+ * @Date: 2024-07-03 11:02:19
19
+ * @LastEditors: za-xuwenli xuwenli@zhongan.io
20
+ * @LastEditTime: 2024-09-26 14:30:26
21
+ * @FilePath: /za-material-warehouse/src/ProTree/components/List.tsx
22
+ * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
23
+ */
13
24
  function List(props) {
14
25
  var checkedValues = props.checkedValues,
15
26
  disabled = props.disabled,
@@ -21,7 +32,8 @@ function List(props) {
21
32
  fieldNames = props.fieldNames,
22
33
  handleOnChange = props.handleOnChange,
23
34
  handleFilterClose = props.handleFilterClose,
24
- optionRender = props.optionRender;
35
+ optionRender = props.optionRender,
36
+ other = (0, _objectWithoutProperties2.default)(props, _excluded);
25
37
  var fieldNameLabel = fieldNames.label;
26
38
  var fieldNameValue = fieldNames.value;
27
39
  if (mode === 'render') {
@@ -43,10 +55,10 @@ function List(props) {
43
55
  value: item[fieldNameValue],
44
56
  disabled: item.disabled,
45
57
  children: (0, _jsxRuntime.jsx)("span", {
46
- children: optionRender ? optionRender(item, searchStr) : (0, _jsxRuntime.jsx)(_SearchTitle.default, {
58
+ children: optionRender ? optionRender(item, searchStr) : (0, _jsxRuntime.jsx)(_SearchTitle.default, (0, _objectSpread2.default)({
47
59
  label: title,
48
60
  searchStr: searchStr
49
- })
61
+ }, other))
50
62
  })
51
63
  })
52
64
  }, item[fieldNameValue]);
@@ -17,6 +17,7 @@ var _react = require("react");
17
17
  var _lodash = require("lodash");
18
18
  var _ProConfigProvider = require("../../../ProConfigProvider");
19
19
  var _Container = _interopRequireDefault(require("../../../ProForm/components/Container"));
20
+ var _AdaptiveTooltip = _interopRequireDefault(require("../AdaptiveTooltip"));
20
21
  var _excluded = ["disabled", "code", "dataSource", "defaultDisableValue", "onChange", "useRequest", "transformResponse", "fieldNames", "tooltip", "showSearch", "filterTreeNode", "treeNodeFilterProp", "defaultExpandAll", "expandedKeys", "treeCheckable", "onSearch", "otherProps", "width", "dropdownStyle", "popupClassName", "style", "allowClear", "listHeight", "showCodeName", "className", "checkStrictly", "checkable"],
21
22
  _excluded2 = ["children"];
22
23
  /* eslint-disable react/no-danger */
@@ -74,9 +75,14 @@ var ProTreeSelect = exports.ProTreeSelect = function ProTreeSelect(props, ref) {
74
75
  selectProps = (0, _objectWithoutProperties2.default)(props, _excluded);
75
76
  var _props$value = props.value,
76
77
  value = _props$value === void 0 ? undefined : _props$value;
77
- var _ref2 = otherProps || {},
78
- isView = _ref2.isView,
79
- viewEmpty = _ref2.viewEmpty;
78
+ var _props$showEllipse = props.showEllipse,
79
+ showEllipse = _props$showEllipse === void 0 ? true : _props$showEllipse;
80
+ var _ref2 = otherProps !== null && otherProps !== void 0 ? otherProps : {},
81
+ isDiffChange = _ref2.isDiffChange;
82
+ var _showEllipse = showEllipse && !isDiffChange;
83
+ var _ref3 = otherProps || {},
84
+ isView = _ref3.isView,
85
+ viewEmpty = _ref3.viewEmpty;
80
86
  if (fieldNames && Object.keys(fieldNames).length) {
81
87
  code = fieldNames.value || 'value';
82
88
  label = fieldNames.label || 'label';
@@ -209,8 +215,8 @@ var ProTreeSelect = exports.ProTreeSelect = function ProTreeSelect(props, ref) {
209
215
  return undefined;
210
216
  }
211
217
  // 如果配置手动加载,不执行请求
212
- var _ref3 = (useRequest === null || useRequest === void 0 ? void 0 : useRequest.options) || {},
213
- defaultParams = _ref3.defaultParams;
218
+ var _ref4 = (useRequest === null || useRequest === void 0 ? void 0 : useRequest.options) || {},
219
+ defaultParams = _ref4.defaultParams;
214
220
  // 执行用户配置的枚举服务,拉取枚举数据进行更新
215
221
  fetchFunction.run(defaultParams);
216
222
  }, [useRequest === null || useRequest === void 0 ? void 0 : useRequest.service, defaultDisableValue]);
@@ -312,6 +318,20 @@ var ProTreeSelect = exports.ProTreeSelect = function ProTreeSelect(props, ref) {
312
318
  children: (0, _jsxRuntime.jsx)(Icon, {})
313
319
  }) : null]
314
320
  });
321
+ if (_showEllipse) {
322
+ title = (0, _jsxRuntime.jsx)(_AdaptiveTooltip.default, {
323
+ children: treeCheckable ? titleHtml : (0, _jsxRuntime.jsxs)("span", {
324
+ className: "check-option-text",
325
+ children: [(0, _jsxRuntime.jsx)("span", {
326
+ className: "check-option-text-content",
327
+ children: titleHtml
328
+ }), !disabled ? (0, _jsxRuntime.jsx)("span", {
329
+ className: "check-mark-icon",
330
+ children: (0, _jsxRuntime.jsx)(Icon, {})
331
+ }) : null]
332
+ })
333
+ });
334
+ }
315
335
  if (!children) {
316
336
  return (0, _jsxRuntime.jsx)(_antd.TreeSelect.TreeNode, {
317
337
  value: value,
@@ -73,6 +73,8 @@ export interface PropTreeSelectProps extends Omit<TreeSelectProps, 'onSearch'> {
73
73
  expandedKeys?: any[];
74
74
  checkStrictly?: boolean;
75
75
  checkable?: boolean;
76
+ showEllipse?: boolean;
77
+ isDiffChange?: boolean;
76
78
  }
77
79
  export interface ProSelectAction {
78
80
  /** 获取发生请求的 useRequest 的 ref */
@@ -1,9 +1,11 @@
1
1
  /// <reference types="react" />
2
+ import { ProFormOtherProps } from '../../ProForm/propsType';
2
3
  declare function SearchTitle(props: {
3
4
  searchStr?: string;
4
5
  label?: string;
5
6
  showEllipse?: boolean;
6
7
  ellipseWidth?: string;
8
+ otherProps?: ProFormOtherProps;
7
9
  }): import("react/jsx-runtime").JSX.Element;
8
10
  declare const _default: import("react").MemoExoticComponent<typeof SearchTitle>;
9
11
  export default _default;
@@ -1,18 +1,32 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
3
4
  Object.defineProperty(exports, "__esModule", {
4
5
  value: true
5
6
  });
6
7
  exports.default = void 0;
7
8
  var _jsxRuntime = require("react/jsx-runtime");
8
9
  var _react = require("react");
9
- var _antd = require("antd");
10
+ var _AdaptiveTooltip = _interopRequireDefault(require("./AdaptiveTooltip"));
11
+ /*
12
+ * @Author: za-xuwenli xuwenli@zhongan.io
13
+ * @Date: 2024-09-26 14:37:00
14
+ * @LastEditors: za-xuwenli xuwenli@zhongan.io
15
+ * @LastEditTime: 2024-09-26 17:50:59
16
+ * @FilePath: /za-material-warehouse/src/ProTree/components/SearchTitle.tsx
17
+ * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
18
+ */
19
+
10
20
  function SearchTitle(props) {
11
21
  var label = props.label,
12
22
  _props$searchStr = props.searchStr,
13
23
  searchStr = _props$searchStr === void 0 ? '' : _props$searchStr,
14
24
  showEllipse = props.showEllipse,
15
- ellipseWidth = props.ellipseWidth;
25
+ ellipseWidth = props.ellipseWidth,
26
+ otherProps = props.otherProps;
27
+ var _ref = otherProps !== null && otherProps !== void 0 ? otherProps : {},
28
+ _ref$isDiffChange = _ref.isDiffChange,
29
+ isDiffChange = _ref$isDiffChange === void 0 ? false : _ref$isDiffChange;
16
30
  var strTitle = label;
17
31
  var index = strTitle === null || strTitle === void 0 ? void 0 : strTitle.indexOf(searchStr);
18
32
  var beforeStr = strTitle === null || strTitle === void 0 ? void 0 : strTitle.substring(0, index);
@@ -45,11 +59,9 @@ function SearchTitle(props) {
45
59
  style: style,
46
60
  children: strTitle
47
61
  });
48
- if (classEllipse) {
49
- return (0, _jsxRuntime.jsx)(_antd.Tooltip, {
50
- title: titleTips,
51
- placement: "rightTop",
52
- children: title
62
+ if (classEllipse && !isDiffChange) {
63
+ return (0, _jsxRuntime.jsx)(_AdaptiveTooltip.default, {
64
+ children: titleTips
53
65
  });
54
66
  }
55
67
  return title;
@@ -1,6 +1,15 @@
1
1
  @root-entry-name: 'default';
2
2
  @import (reference) '~antd/es/style/themes/index.less';
3
3
 
4
+ .pro-tree-wrap-ellipse {
5
+ display: block;
6
+ width: 100%;
7
+ overflow: hidden;
8
+ white-space: nowrap;
9
+ text-overflow: ellipsis;
10
+ word-break: keep-all;
11
+ }
12
+
4
13
  .pro-tree {
5
14
  height: 100%; // tree auto css
6
15
  .@{ant-prefix}-tree-iconEle{
@@ -368,3 +377,8 @@
368
377
  }
369
378
 
370
379
 
380
+ .@{ant-prefix}-select-tree-node-content-wrapper {
381
+ &:has(.pro-tree-wrap-ellipse){
382
+ overflow: hidden;
383
+ }
384
+ }