@douyinfe/semi-foundation 2.97.0 → 2.98.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 (171) hide show
  1. package/codeHighlight/codeHighlight.scss +1 -1
  2. package/datePicker/foundation.ts +7 -0
  3. package/datePicker/inputFoundation.ts +5 -0
  4. package/form/foundation.ts +48 -4
  5. package/inputNumber/foundation.ts +119 -3
  6. package/jsonViewer/jsonViewer.scss +2 -2
  7. package/lib/cjs/aiChatInput/aiChatInput.css +7 -7
  8. package/lib/cjs/anchor/anchor.css +3 -3
  9. package/lib/cjs/autoComplete/autoComplete.css +1 -1
  10. package/lib/cjs/avatar/avatar.css +5 -5
  11. package/lib/cjs/badge/badge.css +1 -1
  12. package/lib/cjs/breadcrumb/breadcrumb.css +2 -2
  13. package/lib/cjs/calendar/calendar.css +9 -9
  14. package/lib/cjs/cascader/cascader.css +6 -6
  15. package/lib/cjs/checkbox/checkbox.css +2 -2
  16. package/lib/cjs/codeHighlight/codeHighlight.css +1 -1
  17. package/lib/cjs/codeHighlight/codeHighlight.scss +1 -1
  18. package/lib/cjs/collapse/collapse.css +2 -2
  19. package/lib/cjs/datePicker/datePicker.css +8 -8
  20. package/lib/cjs/datePicker/foundation.d.ts +5 -0
  21. package/lib/cjs/datePicker/foundation.js +2 -0
  22. package/lib/cjs/datePicker/inputFoundation.d.ts +5 -0
  23. package/lib/cjs/descriptions/descriptions.css +6 -6
  24. package/lib/cjs/dropdown/dropdown.css +2 -2
  25. package/lib/cjs/form/form.css +4 -4
  26. package/lib/cjs/form/foundation.js +49 -3
  27. package/lib/cjs/hotKeys/hotKeys.css +2 -2
  28. package/lib/cjs/image/image.css +2 -2
  29. package/lib/cjs/input/input.css +8 -8
  30. package/lib/cjs/input/textarea.css +2 -2
  31. package/lib/cjs/inputNumber/foundation.d.ts +15 -0
  32. package/lib/cjs/inputNumber/foundation.js +113 -3
  33. package/lib/cjs/jsonViewer/jsonViewer.css +2 -2
  34. package/lib/cjs/jsonViewer/jsonViewer.scss +2 -2
  35. package/lib/cjs/list/list.css +1 -1
  36. package/lib/cjs/modal/modal.css +1 -1
  37. package/lib/cjs/navigation/navigation.css +2 -2
  38. package/lib/cjs/notification/notification.css +4 -4
  39. package/lib/cjs/pagination/pagination.css +5 -5
  40. package/lib/cjs/popconfirm/popconfirm.css +1 -1
  41. package/lib/cjs/popover/popover.css +1 -1
  42. package/lib/cjs/radio/radio.css +2 -2
  43. package/lib/cjs/scrollList/itemFoundation.js +12 -0
  44. package/lib/cjs/scrollList/scrollList.css +2 -2
  45. package/lib/cjs/select/select.css +6 -6
  46. package/lib/cjs/sideSheet/sideSheet.css +2 -2
  47. package/lib/cjs/sidebar/sidebar.css +11 -11
  48. package/lib/cjs/slider/foundation.js +46 -12
  49. package/lib/cjs/slider/rtl.scss +62 -0
  50. package/lib/cjs/slider/slider.css +45 -0
  51. package/lib/cjs/slider/slider.scss +2 -0
  52. package/lib/cjs/steps/steps.css +11 -11
  53. package/lib/cjs/table/foundation.d.ts +36 -0
  54. package/lib/cjs/table/foundation.js +162 -28
  55. package/lib/cjs/table/table.css +10 -2
  56. package/lib/cjs/table/table.scss +17 -0
  57. package/lib/cjs/tabs/tabs.css +2 -2
  58. package/lib/cjs/tag/tag.css +2 -2
  59. package/lib/cjs/tagInput/tagInput.css +2 -2
  60. package/lib/cjs/timePicker/timePicker.css +1 -1
  61. package/lib/cjs/timeline/timeline.css +2 -2
  62. package/lib/cjs/toast/toast.css +1 -1
  63. package/lib/cjs/tooltip/foundation.js +8 -5
  64. package/lib/cjs/tooltip/tooltip.css +1 -1
  65. package/lib/cjs/transfer/constants.d.ts +3 -1
  66. package/lib/cjs/transfer/constants.js +3 -1
  67. package/lib/cjs/transfer/foundation.d.ts +3 -0
  68. package/lib/cjs/transfer/foundation.js +4 -0
  69. package/lib/cjs/transfer/transfer.css +14 -5
  70. package/lib/cjs/transfer/transfer.scss +10 -0
  71. package/lib/cjs/tree/foundation.d.ts +3 -0
  72. package/lib/cjs/tree/foundation.js +31 -4
  73. package/lib/cjs/tree/tree.css +1 -1
  74. package/lib/cjs/treeSelect/foundation.d.ts +1 -0
  75. package/lib/cjs/treeSelect/foundation.js +8 -1
  76. package/lib/cjs/treeSelect/treeSelect.css +36 -4
  77. package/lib/cjs/treeSelect/treeSelect.scss +49 -1
  78. package/lib/cjs/typography/typography.css +8 -8
  79. package/lib/cjs/upload/upload.css +8 -8
  80. package/lib/cjs/utils/Store.d.ts +1 -1
  81. package/lib/cjs/utils/Store.js +1 -0
  82. package/lib/es/aiChatInput/aiChatInput.css +7 -7
  83. package/lib/es/anchor/anchor.css +3 -3
  84. package/lib/es/autoComplete/autoComplete.css +1 -1
  85. package/lib/es/avatar/avatar.css +5 -5
  86. package/lib/es/badge/badge.css +1 -1
  87. package/lib/es/breadcrumb/breadcrumb.css +2 -2
  88. package/lib/es/calendar/calendar.css +9 -9
  89. package/lib/es/cascader/cascader.css +6 -6
  90. package/lib/es/checkbox/checkbox.css +2 -2
  91. package/lib/es/codeHighlight/codeHighlight.css +1 -1
  92. package/lib/es/codeHighlight/codeHighlight.scss +1 -1
  93. package/lib/es/collapse/collapse.css +2 -2
  94. package/lib/es/datePicker/datePicker.css +8 -8
  95. package/lib/es/datePicker/foundation.d.ts +5 -0
  96. package/lib/es/datePicker/foundation.js +2 -0
  97. package/lib/es/datePicker/inputFoundation.d.ts +5 -0
  98. package/lib/es/descriptions/descriptions.css +6 -6
  99. package/lib/es/dropdown/dropdown.css +2 -2
  100. package/lib/es/form/form.css +4 -4
  101. package/lib/es/form/foundation.js +49 -3
  102. package/lib/es/hotKeys/hotKeys.css +2 -2
  103. package/lib/es/image/image.css +2 -2
  104. package/lib/es/input/input.css +8 -8
  105. package/lib/es/input/textarea.css +2 -2
  106. package/lib/es/inputNumber/foundation.d.ts +15 -0
  107. package/lib/es/inputNumber/foundation.js +113 -3
  108. package/lib/es/jsonViewer/jsonViewer.css +2 -2
  109. package/lib/es/jsonViewer/jsonViewer.scss +2 -2
  110. package/lib/es/list/list.css +1 -1
  111. package/lib/es/modal/modal.css +1 -1
  112. package/lib/es/navigation/navigation.css +2 -2
  113. package/lib/es/notification/notification.css +4 -4
  114. package/lib/es/pagination/pagination.css +5 -5
  115. package/lib/es/popconfirm/popconfirm.css +1 -1
  116. package/lib/es/popover/popover.css +1 -1
  117. package/lib/es/radio/radio.css +2 -2
  118. package/lib/es/scrollList/itemFoundation.js +12 -0
  119. package/lib/es/scrollList/scrollList.css +2 -2
  120. package/lib/es/select/select.css +6 -6
  121. package/lib/es/sideSheet/sideSheet.css +2 -2
  122. package/lib/es/sidebar/sidebar.css +11 -11
  123. package/lib/es/slider/foundation.js +46 -12
  124. package/lib/es/slider/rtl.scss +62 -0
  125. package/lib/es/slider/slider.css +45 -0
  126. package/lib/es/slider/slider.scss +2 -0
  127. package/lib/es/steps/steps.css +11 -11
  128. package/lib/es/table/foundation.d.ts +36 -0
  129. package/lib/es/table/foundation.js +162 -28
  130. package/lib/es/table/table.css +10 -2
  131. package/lib/es/table/table.scss +17 -0
  132. package/lib/es/tabs/tabs.css +2 -2
  133. package/lib/es/tag/tag.css +2 -2
  134. package/lib/es/tagInput/tagInput.css +2 -2
  135. package/lib/es/timePicker/timePicker.css +1 -1
  136. package/lib/es/timeline/timeline.css +2 -2
  137. package/lib/es/toast/toast.css +1 -1
  138. package/lib/es/tooltip/foundation.js +8 -5
  139. package/lib/es/tooltip/tooltip.css +1 -1
  140. package/lib/es/transfer/constants.d.ts +3 -1
  141. package/lib/es/transfer/constants.js +3 -1
  142. package/lib/es/transfer/foundation.d.ts +3 -0
  143. package/lib/es/transfer/foundation.js +4 -0
  144. package/lib/es/transfer/transfer.css +14 -5
  145. package/lib/es/transfer/transfer.scss +10 -0
  146. package/lib/es/tree/foundation.d.ts +3 -0
  147. package/lib/es/tree/foundation.js +31 -4
  148. package/lib/es/tree/tree.css +1 -1
  149. package/lib/es/treeSelect/foundation.d.ts +1 -0
  150. package/lib/es/treeSelect/foundation.js +8 -1
  151. package/lib/es/treeSelect/treeSelect.css +36 -4
  152. package/lib/es/treeSelect/treeSelect.scss +49 -1
  153. package/lib/es/typography/typography.css +8 -8
  154. package/lib/es/upload/upload.css +8 -8
  155. package/lib/es/utils/Store.d.ts +1 -1
  156. package/lib/es/utils/Store.js +1 -0
  157. package/package.json +19 -4
  158. package/scrollList/itemFoundation.ts +12 -0
  159. package/slider/foundation.ts +55 -15
  160. package/slider/rtl.scss +62 -0
  161. package/slider/slider.scss +2 -0
  162. package/table/foundation.ts +197 -29
  163. package/table/table.scss +17 -0
  164. package/tooltip/foundation.ts +8 -5
  165. package/transfer/constants.ts +3 -1
  166. package/transfer/foundation.ts +8 -1
  167. package/transfer/transfer.scss +10 -0
  168. package/tree/foundation.ts +34 -5
  169. package/treeSelect/foundation.ts +10 -1
  170. package/treeSelect/treeSelect.scss +49 -1
  171. package/utils/Store.ts +2 -1
@@ -25,7 +25,7 @@
25
25
  position: relative;
26
26
  font-size: 18px;
27
27
  line-height: 24px;
28
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
28
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
29
29
  font-weight: 600;
30
30
  width: 100%;
31
31
  overflow: hidden;
@@ -37,7 +37,7 @@
37
37
  .semi-steps .semi-steps-item .semi-steps-item-description {
38
38
  font-size: 14px;
39
39
  line-height: 20px;
40
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
40
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
41
41
  color: var(--semi-color-text-2);
42
42
  width: 100%;
43
43
  overflow: hidden;
@@ -128,7 +128,7 @@
128
128
  justify-content: center;
129
129
  font-size: 20px;
130
130
  line-height: 28px;
131
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
131
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
132
132
  font-weight: 600;
133
133
  flex-grow: 0;
134
134
  }
@@ -183,7 +183,7 @@
183
183
  .semi-steps-basic.semi-steps-horizontal .semi-steps-item .semi-steps-item-description {
184
184
  font-size: 12px;
185
185
  line-height: 16px;
186
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
186
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
187
187
  color: var(--semi-color-text-2);
188
188
  width: 100%;
189
189
  max-width: 268px;
@@ -250,7 +250,7 @@
250
250
  .semi-steps-basic.semi-steps-vertical .semi-steps-item .semi-steps-item-description {
251
251
  font-size: 12px;
252
252
  line-height: 16px;
253
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
253
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
254
254
  color: var(--semi-color-text-2);
255
255
  width: 100%;
256
256
  }
@@ -304,7 +304,7 @@
304
304
  height: 24px;
305
305
  font-size: 16px;
306
306
  line-height: 22px;
307
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
307
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
308
308
  font-weight: 600;
309
309
  background: var(--semi-color-primary);
310
310
  border-radius: var(--semi-border-radius-circle);
@@ -316,7 +316,7 @@
316
316
  display: inline-block;
317
317
  font-size: 16px;
318
318
  line-height: 22px;
319
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
319
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
320
320
  line-height: 24px;
321
321
  font-weight: 600;
322
322
  color: var(--semi-color-text-0);
@@ -366,7 +366,7 @@
366
366
  .semi-steps-basic.semi-steps-small .semi-steps-item .semi-steps-item-title {
367
367
  font-size: 14px;
368
368
  line-height: 20px;
369
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
369
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
370
370
  }
371
371
  .semi-steps-basic.semi-steps-small .semi-steps-item .semi-steps-item-left .semi-steps-item-icon {
372
372
  height: 20px;
@@ -374,7 +374,7 @@
374
374
  .semi-steps-basic.semi-steps-small .semi-steps-item .semi-steps-item-left .semi-steps-item-icon .semi-steps-item-number-icon {
375
375
  font-size: 12px;
376
376
  line-height: 16px;
377
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
377
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
378
378
  width: 20px;
379
379
  height: 20px;
380
380
  }
@@ -411,7 +411,7 @@
411
411
  .semi-steps-nav .semi-steps-item .semi-steps-item-title {
412
412
  font-size: 16px;
413
413
  line-height: 22px;
414
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
414
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
415
415
  max-width: 17em;
416
416
  overflow: hidden;
417
417
  text-overflow: ellipsis;
@@ -425,7 +425,7 @@
425
425
  .semi-steps-nav.semi-steps-small .semi-steps-item .semi-steps-item-title {
426
426
  font-size: 14px;
427
427
  line-height: 20px;
428
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
428
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
429
429
  }
430
430
 
431
431
  .semi-rtl .semi-steps,
@@ -55,8 +55,11 @@ export interface TableAdapter<RecordType> extends DefaultAdapter {
55
55
  setFlattenData: (flattenData: RecordType[]) => void;
56
56
  setAllRowKeys: (allRowKeys: BaseRowKeyType[]) => void;
57
57
  setHoveredRowKey: (hoveredRowKey: BaseRowKeyType) => void;
58
+ setHoveredRowKeys: (hoveredRowKeys: BaseRowKeyType[]) => void;
58
59
  setCachedFilteredSortedDataSource: (filteredSortedDataSource: RecordType[]) => void;
59
60
  setCachedFilteredSortedRowKeys: (filteredSortedRowKeys: BaseRowKeyType[]) => void;
61
+ setHalfCheckedRowKeys: (halfCheckedRowKeys: BaseRowKeyType[]) => void;
62
+ setKeyEntities: (keyEntities: BaseEntitys) => void;
60
63
  getCurrentPage: () => number;
61
64
  getCurrentPageSize: () => number;
62
65
  getCachedFilteredSortedDataSource: () => RecordType[];
@@ -65,6 +68,9 @@ export interface TableAdapter<RecordType> extends DefaultAdapter {
65
68
  setAllDisabledRowKeys: (allDisabledRowKeys: BaseRowKeyType[]) => void;
66
69
  getAllDisabledRowKeys: () => BaseRowKeyType[];
67
70
  getAllDisabledRowKeysSet: () => Set<BaseRowKeyType>;
71
+ getHalfCheckedRowKeys: () => BaseRowKeyType[];
72
+ getHalfCheckedRowKeysSet: () => Set<BaseRowKeyType>;
73
+ getKeyEntities: () => BaseEntitys;
68
74
  notifyFilterDropdownVisibleChange: (visible: boolean, dataIndex: string) => void;
69
75
  notifyChange: (changeInfo: {
70
76
  pagination: BasePagination;
@@ -90,6 +96,7 @@ export interface TableAdapter<RecordType> extends DefaultAdapter {
90
96
  getMergePagination: () => (pagination: BasePagination) => BasePagination;
91
97
  setBodyHasScrollbar: (bodyHasScrollBar: boolean) => void;
92
98
  getTableLayout: () => 'fixed' | 'auto';
99
+ getCheckRelation: () => CheckRelation;
93
100
  }
94
101
  declare class TableFoundation<RecordType> extends BaseFoundation<TableAdapter<RecordType>> {
95
102
  memoizedWithFnsColumns: (queries: BaseColumnProps<RecordType>[], cachedColumns: BaseColumnProps<RecordType>[], rowSelectionUpdate: boolean, hideExpandedColumn: boolean, bodyHasScrollBar: boolean) => BaseColumnProps<RecordType>[];
@@ -223,6 +230,23 @@ declare class TableFoundation<RecordType> extends BaseFoundation<TableAdapter<Re
223
230
  */
224
231
  getRecordKey(record: RecordType): string;
225
232
  isEmpty(dataSource: RecordType[]): boolean;
233
+ /**
234
+ * Build tree data entities for checkRelation
235
+ * @param dataSource
236
+ * @returns keyEntities map
237
+ */
238
+ buildKeyEntities(dataSource?: RecordType[]): BaseEntitys;
239
+ /**
240
+ * Calculate checked keys when checkRelation is 'related'
241
+ * @param realKey
242
+ * @param selected
243
+ * @param checkedKeys
244
+ * @param halfCheckedKeys
245
+ */
246
+ calcCheckedKeysForSelect(realKey: BaseRowKeyType, selected: boolean, checkedKeys: Set<string>, halfCheckedKeys: Set<string>): {
247
+ checkedKeys: Set<string>;
248
+ halfCheckedKeys: Set<string>;
249
+ };
226
250
  handleSelectRow(realKey: BaseRowKeyType, selected: boolean, e: any): void;
227
251
  /**
228
252
  * select all rows
@@ -381,4 +405,16 @@ export type BaseIncludeGroupRecord<RecordType> = RecordType | {
381
405
  export type BaseEllipsis = boolean | {
382
406
  showTitle: boolean;
383
407
  };
408
+ export type CheckRelation = 'related' | 'unRelated';
409
+ export interface BaseEntity {
410
+ key?: string | number;
411
+ level?: number;
412
+ children?: BaseEntity[];
413
+ parent?: BaseEntity | null;
414
+ data?: Record<string, any>;
415
+ [key: string]: any;
416
+ }
417
+ export interface BaseEntitys {
418
+ [key: string]: BaseEntity;
419
+ }
384
420
  export default TableFoundation;
@@ -22,6 +22,7 @@ var _foundation = _interopRequireDefault(require("../base/foundation"));
22
22
  var _constants = require("./constants");
23
23
  var _utils = require("./utils");
24
24
  var _array = require("../utils/array");
25
+ var _treeUtil = require("../tree/treeUtil");
25
26
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
26
27
  class TableFoundation extends _foundation.default {
27
28
  /**
@@ -594,29 +595,115 @@ class TableFoundation extends _foundation.default {
594
595
  dataSource = dataSource == null ? this.getProp('dataSource') : dataSource;
595
596
  return !(Array.isArray(dataSource) && dataSource.length > 0);
596
597
  }
598
+ /**
599
+ * Build tree data entities for checkRelation
600
+ * @param dataSource
601
+ * @returns keyEntities map
602
+ */
603
+ buildKeyEntities(dataSource) {
604
+ dataSource = dataSource == null ? this._getDataSource() : dataSource;
605
+ const childrenRecordName = this.getProp('childrenRecordName');
606
+ const rowKey = this.getProp('rowKey');
607
+ // Convert table data to tree data format
608
+ const convertToTreeData = data => {
609
+ return data.map(record => {
610
+ const key = typeof rowKey === 'function' ? rowKey(record) : (0, _get2.default)(record, rowKey);
611
+ const children = (0, _get2.default)(record, childrenRecordName);
612
+ const node = Object.assign({
613
+ key
614
+ }, record);
615
+ if (Array.isArray(children) && children.length) {
616
+ node.children = convertToTreeData(children);
617
+ }
618
+ return node;
619
+ });
620
+ };
621
+ const treeData = convertToTreeData(dataSource);
622
+ const {
623
+ keyEntities
624
+ } = (0, _treeUtil.convertDataToEntities)(treeData, {
625
+ key: 'key',
626
+ children: 'children'
627
+ });
628
+ return keyEntities;
629
+ }
630
+ /**
631
+ * Calculate checked keys when checkRelation is 'related'
632
+ * @param realKey
633
+ * @param selected
634
+ * @param checkedKeys
635
+ * @param halfCheckedKeys
636
+ */
637
+ calcCheckedKeysForSelect(realKey, selected, checkedKeys, halfCheckedKeys) {
638
+ const keyEntities = this._adapter.getKeyEntities();
639
+ const keyStr = String(realKey);
640
+ // If keyEntities doesn't contain this key, handle it as a simple add/remove
641
+ if (!keyEntities || !keyEntities[keyStr]) {
642
+ if (selected) {
643
+ checkedKeys.add(keyStr);
644
+ } else {
645
+ checkedKeys.delete(keyStr);
646
+ }
647
+ return {
648
+ checkedKeys,
649
+ halfCheckedKeys
650
+ };
651
+ }
652
+ if (selected) {
653
+ return (0, _treeUtil.calcCheckedKeysForChecked)(keyStr, keyEntities, checkedKeys, halfCheckedKeys);
654
+ } else {
655
+ return (0, _treeUtil.calcCheckedKeysForUnchecked)(keyStr, keyEntities, checkedKeys, halfCheckedKeys);
656
+ }
657
+ }
597
658
  handleSelectRow(realKey, selected, e) {
598
659
  this.stopPropagation(e);
599
660
  if (typeof selected === 'boolean' && realKey != null) {
661
+ const checkRelation = this._adapter.getCheckRelation();
600
662
  const selectedRowKeys = this._getSelectedRowKeys();
663
+ const halfCheckedRowKeys = [...(this._adapter.getHalfCheckedRowKeys() || [])];
601
664
  let foundIdx = -1;
602
665
  const selectedRow = this.getSelectedRows(null, [realKey])[0];
603
666
  let selectedRows;
604
- if ((foundIdx = selectedRowKeys.indexOf(realKey)) > -1 && selected === false) {
605
- selectedRowKeys.splice(foundIdx, 1);
606
- selectedRows = this.getSelectedRows(null, selectedRowKeys);
667
+ if (checkRelation === 'related') {
668
+ // When checkRelation is 'related', use tree selection logic
669
+ const keyEntities = this._adapter.getKeyEntities();
670
+ // Convert keys to strings for tree utility functions
671
+ const checkedKeysSet = new Set(selectedRowKeys.map(key => String(key)));
672
+ const halfCheckedKeysSet = new Set(halfCheckedRowKeys.map(key => String(key)));
673
+ const {
674
+ checkedKeys,
675
+ halfCheckedKeys
676
+ } = this.calcCheckedKeysForSelect(String(realKey), selected, checkedKeysSet, halfCheckedKeysSet);
677
+ const newSelectedRowKeys = [...checkedKeys];
678
+ const newHalfCheckedRowKeys = [...halfCheckedKeys];
679
+ selectedRows = this.getSelectedRows(null, newSelectedRowKeys);
680
+ // Always update halfCheckedRowKeys state for checkRelation='related' mode
681
+ // This is needed for rendering the half-checked state in the UI
682
+ this._adapter.setHalfCheckedRowKeys(newHalfCheckedRowKeys);
607
683
  if (!this._selectionIsControlled()) {
608
- this._adapter.setSelectedRowKeys(selectedRowKeys);
684
+ this._adapter.setSelectedRowKeys(newSelectedRowKeys);
609
685
  }
610
686
  this._adapter.notifySelect(selectedRow, selected, selectedRows, e);
611
- this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
612
- } else if (selectedRowKeys.indexOf(realKey) === -1 && selected === true) {
613
- selectedRowKeys.push(realKey);
614
- selectedRows = this.getSelectedRows(null, selectedRowKeys);
615
- if (!this._selectionIsControlled()) {
616
- this._adapter.setSelectedRowKeys(selectedRowKeys);
687
+ this._adapter.notifySelectionChange(newSelectedRowKeys, selectedRows);
688
+ } else {
689
+ // Original logic for unRelated mode
690
+ if ((foundIdx = selectedRowKeys.indexOf(realKey)) > -1 && selected === false) {
691
+ selectedRowKeys.splice(foundIdx, 1);
692
+ selectedRows = this.getSelectedRows(null, selectedRowKeys);
693
+ if (!this._selectionIsControlled()) {
694
+ this._adapter.setSelectedRowKeys(selectedRowKeys);
695
+ }
696
+ this._adapter.notifySelect(selectedRow, selected, selectedRows, e);
697
+ this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
698
+ } else if (selectedRowKeys.indexOf(realKey) === -1 && selected === true) {
699
+ selectedRowKeys.push(realKey);
700
+ selectedRows = this.getSelectedRows(null, selectedRowKeys);
701
+ if (!this._selectionIsControlled()) {
702
+ this._adapter.setSelectedRowKeys(selectedRowKeys);
703
+ }
704
+ this._adapter.notifySelect(selectedRow, selected, selectedRows, e);
705
+ this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
617
706
  }
618
- this._adapter.notifySelect(selectedRow, selected, selectedRows, e);
619
- this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
620
707
  }
621
708
  }
622
709
  }
@@ -628,6 +715,7 @@ class TableFoundation extends _foundation.default {
628
715
  handleSelectAllRow(selected, e) {
629
716
  this.stopPropagation(e);
630
717
  if (typeof selected === 'boolean') {
718
+ const checkRelation = this._adapter.getCheckRelation();
631
719
  const curSelectedRowKeys = this._getSelectedRowKeys();
632
720
  let selectedRowKeys = [...curSelectedRowKeys];
633
721
  const selectedRowKeysSet = this._getSelectedRowKeysSet();
@@ -635,26 +723,72 @@ class TableFoundation extends _foundation.default {
635
723
  const disabledRowKeys = this._adapter.getAllDisabledRowKeys();
636
724
  const disabledRowKeysSet = this._adapter.getAllDisabledRowKeysSet();
637
725
  let changedRowKeys;
638
- // Select all, if not disabled && not in selectedRowKeys
639
- if (selected) {
640
- for (const key of allRowKeys) {
641
- if (!disabledRowKeysSet.has(key) && !selectedRowKeysSet.has(key)) {
642
- selectedRowKeys.push(key);
726
+ if (checkRelation === 'related') {
727
+ // When checkRelation is 'related', use tree selection logic
728
+ const keyEntities = this._adapter.getKeyEntities();
729
+ const halfCheckedRowKeys = [...(this._adapter.getHalfCheckedRowKeys() || [])];
730
+ // Convert keys to strings for tree utility functions
731
+ let checkedKeysSet = new Set(selectedRowKeys.map(key => String(key)));
732
+ let halfCheckedKeysSet = new Set(halfCheckedRowKeys.map(key => String(key)));
733
+ if (selected) {
734
+ // Select all: add all non-disabled keys
735
+ const keysToAdd = allRowKeys.filter(key => !disabledRowKeysSet.has(key));
736
+ for (const key of keysToAdd) {
737
+ const keyStr = String(key);
738
+ if (!checkedKeysSet.has(keyStr) && keyEntities && keyEntities[keyStr]) {
739
+ const result = (0, _treeUtil.calcCheckedKeysForChecked)(keyStr, keyEntities, checkedKeysSet, halfCheckedKeysSet);
740
+ checkedKeysSet = result.checkedKeys;
741
+ halfCheckedKeysSet = result.halfCheckedKeys;
742
+ }
743
+ }
744
+ changedRowKeys = keysToAdd;
745
+ } else {
746
+ // Deselect all: remove all keys
747
+ const keysToRemove = [...checkedKeysSet];
748
+ for (const key of keysToRemove) {
749
+ if (keyEntities && keyEntities[key]) {
750
+ const result = (0, _treeUtil.calcCheckedKeysForUnchecked)(key, keyEntities, checkedKeysSet, halfCheckedKeysSet);
751
+ checkedKeysSet = result.checkedKeys;
752
+ halfCheckedKeysSet = result.halfCheckedKeys;
753
+ }
643
754
  }
755
+ changedRowKeys = [...curSelectedRowKeys];
644
756
  }
645
- allRowKeys = (0, _array.pullAll)(allRowKeys, [...disabledRowKeys, ...curSelectedRowKeys]);
646
- changedRowKeys = [...allRowKeys];
757
+ selectedRowKeys = [...checkedKeysSet];
758
+ const newHalfCheckedRowKeys = [...halfCheckedKeysSet];
759
+ const changedRows = this.getSelectedRows(null, changedRowKeys || []);
760
+ const selectedRows = this.getSelectedRows(null, selectedRowKeys || []);
761
+ // Always update halfCheckedRowKeys state for checkRelation='related' mode
762
+ // This is needed for rendering the half-checked state in the UI
763
+ this._adapter.setHalfCheckedRowKeys(newHalfCheckedRowKeys);
764
+ if (!this._selectionIsControlled()) {
765
+ this._adapter.setSelectedRowKeys(selectedRowKeys);
766
+ }
767
+ this._adapter.notifySelectAll(selected, selectedRows, changedRows, e);
768
+ this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
647
769
  } else {
648
- selectedRowKeys = (0, _array.pullAll)(selectedRowKeys, allRowKeys);
649
- changedRowKeys = [...curSelectedRowKeys];
650
- }
651
- const changedRows = this.getSelectedRows(null, changedRowKeys || []);
652
- const selectedRows = this.getSelectedRows(null, selectedRowKeys || []);
653
- if (!this._selectionIsControlled()) {
654
- this._adapter.setSelectedRowKeys(selectedRowKeys);
770
+ // Original logic for unRelated mode
771
+ // Select all, if not disabled && not in selectedRowKeys
772
+ if (selected) {
773
+ for (const key of allRowKeys) {
774
+ if (!disabledRowKeysSet.has(key) && !selectedRowKeysSet.has(key)) {
775
+ selectedRowKeys.push(key);
776
+ }
777
+ }
778
+ allRowKeys = (0, _array.pullAll)(allRowKeys, [...disabledRowKeys, ...curSelectedRowKeys]);
779
+ changedRowKeys = [...allRowKeys];
780
+ } else {
781
+ selectedRowKeys = (0, _array.pullAll)(selectedRowKeys, allRowKeys);
782
+ changedRowKeys = [...curSelectedRowKeys];
783
+ }
784
+ const changedRows = this.getSelectedRows(null, changedRowKeys || []);
785
+ const selectedRows = this.getSelectedRows(null, selectedRowKeys || []);
786
+ if (!this._selectionIsControlled()) {
787
+ this._adapter.setSelectedRowKeys(selectedRowKeys);
788
+ }
789
+ this._adapter.notifySelectAll(selected, selectedRows, changedRows, e);
790
+ this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
655
791
  }
656
- this._adapter.notifySelectAll(selected, selectedRows, changedRows, e);
657
- this._adapter.notifySelectionChange(selectedRowKeys, selectedRows);
658
792
  }
659
793
  }
660
794
  /**
@@ -22,7 +22,7 @@
22
22
  .semi-table-pagination-info {
23
23
  font-size: 14px;
24
24
  line-height: 20px;
25
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
25
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
26
26
  font-weight: 400;
27
27
  }
28
28
  .semi-table-pagination-outer {
@@ -48,7 +48,7 @@
48
48
  padding: 0;
49
49
  font-size: 14px;
50
50
  line-height: 20px;
51
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
51
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
52
52
  color: var(--semi-color-text-0);
53
53
  width: 100%;
54
54
  }
@@ -222,6 +222,14 @@
222
222
  display: table-row;
223
223
  background-color: var(--semi-color-bg-1);
224
224
  }
225
+ .semi-table-tbody > .semi-table-row.semi-table-row-hovered > .semi-table-row-cell {
226
+ background-image: linear-gradient(0deg, var(--semi-color-fill-0), var(--semi-color-fill-0));
227
+ background-color: var(--semi-color-bg-0);
228
+ }
229
+ .semi-table-tbody > .semi-table-row.semi-table-row-hovered > .semi-table-row-cell.semi-table-cell-fixed-left, .semi-table-tbody > .semi-table-row.semi-table-row-hovered > .semi-table-row-cell.semi-table-cell-fixed-right {
230
+ background-image: linear-gradient(0deg, var(--semi-color-fill-0), var(--semi-color-fill-0));
231
+ background-color: var(--semi-color-bg-1);
232
+ }
225
233
  .semi-table-tbody > .semi-table-row:hover > .semi-table-row-cell {
226
234
  background-image: linear-gradient(0deg, var(--semi-color-fill-0), var(--semi-color-fill-0));
227
235
  background-color: var(--semi-color-bg-0);
@@ -259,6 +259,23 @@ $module: #{$prefix}-table;
259
259
  display: table-row;
260
260
  background-color: $color-table_body-bg-default;
261
261
 
262
+ // Programmatic hover state (e.g. rowSpanHover feature)
263
+ // Keep visual effect consistent with native :hover
264
+ &.#{$module}-row-hovered {
265
+ & > .#{$module}-row-cell {
266
+ background-image: linear-gradient(0deg, $color-table_body-bg-hover, $color-table_body-bg-hover);
267
+ background-color: $color-table_cell-bg-hover;
268
+
269
+ &.#{$module}-cell-fixed {
270
+ &-left,
271
+ &-right {
272
+ background-image: linear-gradient(0deg, $color-table_body-bg-hover, $color-table_body-bg-hover);
273
+ background-color: $color-table_body-bg-default;
274
+ }
275
+ }
276
+ }
277
+ }
278
+
262
279
  &:hover {
263
280
  & > .#{$module}-row-cell {
264
281
  // $color-table_body-bg-hover has transparency,will reveal the background color $color-table_body-bg-default\
@@ -51,7 +51,7 @@
51
51
  .semi-tabs-bar .semi-tabs-tab {
52
52
  font-size: 14px;
53
53
  line-height: 20px;
54
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
54
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
55
55
  cursor: pointer;
56
56
  box-sizing: border-box;
57
57
  position: relative;
@@ -112,7 +112,7 @@
112
112
  .semi-tabs-tab-single.semi-tabs-tab {
113
113
  font-size: 14px;
114
114
  line-height: 20px;
115
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
115
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
116
116
  cursor: pointer;
117
117
  box-sizing: border-box;
118
118
  position: relative;
@@ -18,7 +18,7 @@
18
18
  .semi-tag-default, .semi-tag-small {
19
19
  font-size: 12px;
20
20
  line-height: 16px;
21
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
21
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
22
22
  height: 20px;
23
23
  padding: 2px 8px;
24
24
  }
@@ -34,7 +34,7 @@
34
34
  .semi-tag-large {
35
35
  font-size: 12px;
36
36
  line-height: 16px;
37
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
37
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
38
38
  padding: 4px 8px;
39
39
  height: 24px;
40
40
  }
@@ -232,7 +232,7 @@
232
232
  font-weight: 600;
233
233
  font-size: 14px;
234
234
  line-height: 20px;
235
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
235
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
236
236
  color: var(--semi-color-text-2);
237
237
  flex-shrink: 0;
238
238
  white-space: nowrap;
@@ -248,7 +248,7 @@
248
248
  white-space: nowrap;
249
249
  font-size: 14px;
250
250
  line-height: 20px;
251
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
251
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
252
252
  }
253
253
  .semi-tagInput-prefix-icon, .semi-tagInput-suffix-icon {
254
254
  color: var(--semi-color-text-2);
@@ -79,7 +79,7 @@
79
79
  .semi-timepicker .semi-timepicker-input {
80
80
  font-size: 14px;
81
81
  line-height: 20px;
82
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
82
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
83
83
  border-radius: var(--semi-border-radius-small);
84
84
  align-items: center;
85
85
  }
@@ -77,7 +77,7 @@
77
77
  .semi-timeline-item-content {
78
78
  font-size: 14px;
79
79
  line-height: 20px;
80
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
80
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
81
81
  position: relative;
82
82
  margin: 0 0 0 25px;
83
83
  word-break: break-word;
@@ -86,7 +86,7 @@
86
86
  .semi-timeline-item-content-extra, .semi-timeline-item-content-time {
87
87
  font-size: 12px;
88
88
  line-height: 16px;
89
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
89
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
90
90
  color: var(--semi-color-text-2);
91
91
  margin-top: 4px;
92
92
  }
@@ -34,7 +34,7 @@
34
34
  box-shadow: var(--semi-shadow-elevated);
35
35
  font-size: 14px;
36
36
  line-height: 20px;
37
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
37
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
38
38
  background-color: var(--semi-color-bg-3);
39
39
  border-radius: var(--semi-border-radius-medium);
40
40
  padding: 12px 8px 12px 8px;
@@ -333,7 +333,7 @@ class Tooltip extends _foundation.default {
333
333
  switch (types) {
334
334
  case 'focus':
335
335
  triggerEventSet[eventNames.focus] = () => {
336
- this.delayShow();
336
+ this.getProp('condition') !== false && this.delayShow();
337
337
  };
338
338
  triggerEventSet[eventNames.blur] = () => {
339
339
  this.delayHide();
@@ -343,7 +343,7 @@ class Tooltip extends _foundation.default {
343
343
  case 'click':
344
344
  triggerEventSet[eventNames.click] = () => {
345
345
  // this.delayShow();
346
- this.show();
346
+ this.getProp('condition') !== false && this.show();
347
347
  };
348
348
  portalEventSet = {};
349
349
  // Click outside needs special treatment, can not be directly tied to the trigger Element, need to be bound to the document
@@ -352,7 +352,7 @@ class Tooltip extends _foundation.default {
352
352
  triggerEventSet[eventNames.mouseEnter] = () => {
353
353
  // console.log(e);
354
354
  this.setCache('isClickToHide', false);
355
- this.delayShow();
355
+ this.getProp('condition') !== false && this.delayShow();
356
356
  // this.show('trigger');
357
357
  };
358
358
  triggerEventSet[eventNames.mouseLeave] = () => {
@@ -365,7 +365,7 @@ class Tooltip extends _foundation.default {
365
365
  const {
366
366
  disableFocusListener
367
367
  } = this.getProps();
368
- !disableFocusListener && this.delayShow();
368
+ this.getProp('condition') !== false && !disableFocusListener && this.delayShow();
369
369
  };
370
370
  triggerEventSet[eventNames.blur] = () => {
371
371
  const {
@@ -383,7 +383,7 @@ class Tooltip extends _foundation.default {
383
383
  if (this.getCache('isClickToHide')) {
384
384
  return;
385
385
  }
386
- this.delayShow();
386
+ this.getProp('condition') !== false && this.delayShow();
387
387
  };
388
388
  }
389
389
  break;
@@ -393,6 +393,9 @@ class Tooltip extends _foundation.default {
393
393
  break;
394
394
  case 'contextMenu':
395
395
  triggerEventSet[eventNames.contextMenu] = e => {
396
+ if (this.getProp('condition') === false) {
397
+ return;
398
+ }
396
399
  e.preventDefault();
397
400
  this.show();
398
401
  };
@@ -54,7 +54,7 @@
54
54
  overflow-wrap: break-word;
55
55
  font-size: 14px;
56
56
  line-height: 20px;
57
- font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif;
57
+ font-family: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif;
58
58
  opacity: 0;
59
59
  max-width: 240px;
60
60
  }
@@ -6,5 +6,7 @@ declare const strings: {
6
6
  TYPE_LIST: string;
7
7
  TYPE_TREE_TO_LIST: string;
8
8
  };
9
- declare const numbers: {};
9
+ declare const numbers: {
10
+ DEFAULT_PAGE_SIZE: number;
11
+ };
10
12
  export { cssClasses, strings, numbers };
@@ -13,4 +13,6 @@ const strings = exports.strings = {
13
13
  TYPE_LIST: 'list',
14
14
  TYPE_TREE_TO_LIST: 'treeList'
15
15
  };
16
- const numbers = exports.numbers = {};
16
+ const numbers = exports.numbers = {
17
+ DEFAULT_PAGE_SIZE: 10
18
+ };