iov-design 2.15.59 → 2.15.61

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 (250) hide show
  1. package/README.md +148 -148
  2. package/lib/alert.js +24 -105
  3. package/lib/aside.js +24 -34
  4. package/lib/autocomplete.js +36 -240
  5. package/lib/avatar.js +21 -20
  6. package/lib/backtop.js +27 -52
  7. package/lib/badge.js +30 -58
  8. package/lib/breadcrumb-item.js +24 -53
  9. package/lib/breadcrumb.js +24 -37
  10. package/lib/button-group.js +24 -29
  11. package/lib/button.js +38 -60
  12. package/lib/calendar.js +29 -146
  13. package/lib/card.js +24 -51
  14. package/lib/carousel-item.js +30 -68
  15. package/lib/carousel.js +27 -159
  16. package/lib/cascader-panel.js +41 -64
  17. package/lib/cascader.js +37 -470
  18. package/lib/checkbox-button.js +28 -164
  19. package/lib/checkbox-group.js +24 -37
  20. package/lib/checkbox.js +35 -189
  21. package/lib/col.js +1 -0
  22. package/lib/collapse-item.js +27 -125
  23. package/lib/collapse.js +24 -37
  24. package/lib/color-picker.js +104 -424
  25. package/lib/container.js +24 -34
  26. package/lib/date-picker.js +126 -1981
  27. package/lib/descriptions-item.js +1 -0
  28. package/lib/descriptions.js +1 -0
  29. package/lib/dialog.js +24 -137
  30. package/lib/divider.js +29 -64
  31. package/lib/drawer.js +24 -139
  32. package/lib/dropdown-item.js +27 -45
  33. package/lib/dropdown-menu.js +24 -51
  34. package/lib/dropdown.js +21 -20
  35. package/lib/empty.js +24 -61
  36. package/lib/footer.js +24 -34
  37. package/lib/form-item.js +42 -128
  38. package/lib/form.js +27 -40
  39. package/lib/header.js +24 -34
  40. package/lib/icon.js +24 -29
  41. package/lib/image.js +36 -220
  42. package/lib/index.js +1 -1
  43. package/lib/infinite-scroll.js +1 -0
  44. package/lib/input-number.js +30 -163
  45. package/lib/input.js +42 -274
  46. package/lib/iov-design.common.js +1638 -11132
  47. package/lib/link.js +33 -55
  48. package/lib/loading.js +24 -77
  49. package/lib/locale/format.js +10 -10
  50. package/lib/main.js +24 -29
  51. package/lib/menu-item-group.js +24 -40
  52. package/lib/menu-item.js +27 -83
  53. package/lib/menu.js +21 -20
  54. package/lib/message-box.js +24 -321
  55. package/lib/message.js +30 -82
  56. package/lib/mixins/migrating.js +20 -20
  57. package/lib/notification.js +24 -109
  58. package/lib/option-group.js +24 -50
  59. package/lib/option.js +27 -76
  60. package/lib/page-header.js +24 -56
  61. package/lib/pagination.js +24 -97
  62. package/lib/popconfirm.js +24 -97
  63. package/lib/popover.js +24 -89
  64. package/lib/progress.js +30 -133
  65. package/lib/radio-button.js +29 -111
  66. package/lib/radio-group.js +24 -39
  67. package/lib/radio.js +36 -152
  68. package/lib/rate.js +24 -94
  69. package/lib/result.js +72 -187
  70. package/lib/row.js +1 -0
  71. package/lib/scrollbar.js +1 -0
  72. package/lib/select.js +48 -637
  73. package/lib/skeleton-item.js +36 -68
  74. package/lib/skeleton.js +28 -70
  75. package/lib/slider.js +36 -267
  76. package/lib/spinner.js +24 -51
  77. package/lib/statistic.js +24 -76
  78. package/lib/step.js +29 -118
  79. package/lib/steps.js +27 -40
  80. package/lib/submenu.js +21 -20
  81. package/lib/switch.js +24 -130
  82. package/lib/tab-pane.js +24 -52
  83. package/lib/table-column.js +1 -0
  84. package/lib/table.js +93 -633
  85. package/lib/tabs.js +34 -49
  86. package/lib/tag.js +22 -21
  87. package/lib/theme-chalk/base.css +1 -1
  88. package/lib/theme-chalk/button.css +1 -1
  89. package/lib/theme-chalk/calendar.css +1 -1
  90. package/lib/theme-chalk/cascader-panel.css +1 -1
  91. package/lib/theme-chalk/cascader.css +1 -1
  92. package/lib/theme-chalk/dropdown.css +1 -1
  93. package/lib/theme-chalk/index.css +1 -1
  94. package/lib/theme-chalk/iovfont.css +1 -1
  95. package/lib/theme-chalk/link.css +1 -1
  96. package/lib/theme-chalk/message-box.css +1 -1
  97. package/lib/theme-chalk/pagination.css +1 -1
  98. package/lib/theme-chalk/radio.css +1 -1
  99. package/lib/theme-chalk/select.css +1 -1
  100. package/lib/theme-chalk/table-column.css +1 -1
  101. package/lib/theme-chalk/table.css +1 -1
  102. package/lib/theme-chalk/tabs.css +1 -1
  103. package/lib/theme-chalk/tag.css +1 -1
  104. package/lib/theme-chalk/transfer.css +1 -1
  105. package/lib/time-picker.js +58 -820
  106. package/lib/time-select.js +42 -303
  107. package/lib/timeline-item.js +29 -75
  108. package/lib/timeline.js +21 -20
  109. package/lib/tooltip.js +1 -0
  110. package/lib/transfer.js +36 -299
  111. package/lib/tree.js +54 -243
  112. package/lib/upload.js +86 -654
  113. package/lib/utils/clickoutside.js +7 -7
  114. package/lib/utils/vue-popper.js +7 -7
  115. package/package.json +154 -154
  116. package/packages/autocomplete/src/autocomplete-suggestions.vue +76 -76
  117. package/packages/autocomplete/src/autocomplete.vue +285 -285
  118. package/packages/button/src/button.vue +90 -90
  119. package/packages/calendar/src/date-table.vue +200 -200
  120. package/packages/calendar/src/main.vue +280 -280
  121. package/packages/carousel/src/item.vue +138 -138
  122. package/packages/carousel/src/main.vue +315 -315
  123. package/packages/cascader/src/cascader.vue +776 -776
  124. package/packages/cascader-panel/src/cascader-menu.vue +138 -138
  125. package/packages/cascader-panel/src/cascader-node.vue +246 -246
  126. package/packages/cascader-panel/src/cascader-panel.vue +391 -391
  127. package/packages/cascader-panel/src/node.js +166 -166
  128. package/packages/cascader-panel/src/store.js +58 -58
  129. package/packages/checkbox/src/checkbox-button.vue +199 -199
  130. package/packages/checkbox/src/checkbox-group.vue +49 -49
  131. package/packages/checkbox/src/checkbox.vue +225 -225
  132. package/packages/collapse/src/collapse-item.vue +114 -114
  133. package/packages/color-picker/src/components/picker-dropdown.vue +121 -121
  134. package/packages/color-picker/src/main.vue +188 -188
  135. package/packages/date-picker/src/basic/date-table.vue +441 -441
  136. package/packages/date-picker/src/basic/month-table.vue +269 -269
  137. package/packages/date-picker/src/basic/time-spinner.vue +304 -304
  138. package/packages/date-picker/src/basic/year-table.vue +111 -111
  139. package/packages/date-picker/src/panel/date-range.vue +680 -680
  140. package/packages/date-picker/src/panel/date.vue +609 -609
  141. package/packages/date-picker/src/panel/month-range.vue +289 -289
  142. package/packages/date-picker/src/panel/time-range.vue +248 -248
  143. package/packages/date-picker/src/panel/time-select.vue +178 -178
  144. package/packages/date-picker/src/panel/time.vue +186 -186
  145. package/packages/date-picker/src/picker.vue +967 -967
  146. package/packages/descriptions/src/index.js +180 -180
  147. package/packages/dialog/src/component.vue +262 -262
  148. package/packages/drawer/src/main.vue +205 -205
  149. package/packages/dropdown/src/dropdown-item.vue +37 -37
  150. package/packages/dropdown/src/dropdown-menu.vue +63 -63
  151. package/packages/dropdown/src/dropdown.vue +293 -293
  152. package/packages/empty/src/index.vue +70 -70
  153. package/packages/form/src/form-item.vue +324 -324
  154. package/packages/form/src/form.vue +182 -182
  155. package/packages/image/src/image-viewer.vue +330 -330
  156. package/packages/image/src/main.vue +249 -249
  157. package/packages/infinite-scroll/src/main.js +150 -150
  158. package/packages/input/src/input.vue +477 -477
  159. package/packages/input-number/src/input-number.vue +283 -283
  160. package/packages/link/src/main.vue +2 -0
  161. package/packages/loading/src/directive.js +133 -133
  162. package/packages/loading/src/index.js +106 -106
  163. package/packages/menu/src/menu-item.vue +112 -112
  164. package/packages/menu/src/menu.vue +325 -325
  165. package/packages/menu/src/submenu.vue +349 -349
  166. package/packages/message/src/main.js +91 -91
  167. package/packages/message-box/src/main.js +216 -216
  168. package/packages/message-box/src/main.vue +333 -333
  169. package/packages/notification/src/main.js +94 -94
  170. package/packages/page-header/src/main.vue +30 -30
  171. package/packages/pagination/src/pagination.js +390 -390
  172. package/packages/popconfirm/src/main.vue +104 -104
  173. package/packages/popover/src/main.vue +239 -239
  174. package/packages/radio/src/radio-button.vue +115 -115
  175. package/packages/radio/src/radio-group.vue +115 -115
  176. package/packages/radio/src/radio.vue +148 -148
  177. package/packages/rate/src/main.vue +348 -348
  178. package/packages/scrollbar/src/bar.js +92 -92
  179. package/packages/scrollbar/src/main.js +130 -130
  180. package/packages/select/src/option-group.vue +60 -60
  181. package/packages/select/src/option.vue +171 -171
  182. package/packages/select/src/select-dropdown.vue +74 -74
  183. package/packages/select/src/select.vue +979 -979
  184. package/packages/slider/src/button.vue +238 -238
  185. package/packages/slider/src/main.vue +427 -427
  186. package/packages/statistic/src/main.vue +204 -204
  187. package/packages/steps/src/steps.vue +68 -68
  188. package/packages/switch/src/component.vue +182 -182
  189. package/packages/table/src/config.js +153 -153
  190. package/packages/table/src/filter-panel.vue +194 -194
  191. package/packages/table/src/store/current.js +76 -76
  192. package/packages/table/src/store/helper.js +41 -41
  193. package/packages/table/src/store/index.js +147 -147
  194. package/packages/table/src/store/watcher.js +502 -502
  195. package/packages/table/src/table-body.js +469 -469
  196. package/packages/table/src/table-column.js +328 -328
  197. package/packages/table/src/table-header.js +571 -571
  198. package/packages/table/src/table-layout.js +249 -249
  199. package/packages/table/src/table-row.js +101 -101
  200. package/packages/table/src/table.vue +740 -740
  201. package/packages/table/src/util.js +273 -273
  202. package/packages/tabs/src/tab-bar.vue +57 -57
  203. package/packages/tabs/src/tab-nav.vue +294 -294
  204. package/packages/tabs/src/tabs.vue +201 -201
  205. package/packages/tag/src/tag.vue +1 -1
  206. package/packages/theme-chalk/src/button.scss +416 -416
  207. package/packages/theme-chalk/src/cascader.scss +252 -252
  208. package/packages/theme-chalk/src/checkbox.scss +419 -419
  209. package/packages/theme-chalk/src/common/var.scss +795 -816
  210. package/packages/theme-chalk/src/form.scss +201 -201
  211. package/packages/theme-chalk/src/input.scss +591 -591
  212. package/packages/theme-chalk/src/iovfont.scss +803 -784
  213. package/packages/theme-chalk/src/link.scss +36 -19
  214. package/packages/theme-chalk/src/message-box.scss +207 -207
  215. package/packages/theme-chalk/src/mixins/_button.scss +136 -136
  216. package/packages/theme-chalk/src/mixins/mixins.scss +190 -190
  217. package/packages/theme-chalk/src/radio-button.scss +115 -115
  218. package/packages/theme-chalk/src/radio.scss +1 -0
  219. package/packages/theme-chalk/src/select.scss +270 -270
  220. package/packages/theme-chalk/src/table.scss +1 -2
  221. package/packages/theme-chalk/src/tabs.scss +755 -750
  222. package/packages/theme-chalk/src/tag.scss +4 -4
  223. package/packages/theme-chalk/src/upload.scss +568 -568
  224. package/packages/tooltip/src/main.js +242 -242
  225. package/packages/transfer/src/main.vue +231 -231
  226. package/packages/transfer/src/transfer-panel.vue +251 -251
  227. package/packages/tree/src/model/node.js +484 -484
  228. package/packages/tree/src/tree-node.vue +279 -279
  229. package/packages/tree/src/tree.vue +496 -496
  230. package/packages/upload/src/index.vue +420 -420
  231. package/packages/upload/src/upload-file.vue +98 -98
  232. package/packages/upload/src/upload-list.vue +115 -115
  233. package/packages/upload/src/upload-picture.vue +98 -98
  234. package/packages/upload/src/upload.vue +231 -231
  235. package/packages/upload/src/utils.js +31 -31
  236. package/src/directives/repeat-click.js +26 -26
  237. package/src/index.js +259 -259
  238. package/src/locale/format.js +46 -46
  239. package/src/locale/index.js +48 -48
  240. package/src/locale/lang/lo-LA.js +126 -126
  241. package/src/mixins/locale.js +9 -9
  242. package/src/mixins/migrating.js +54 -54
  243. package/src/transitions/collapse-transition.js +77 -77
  244. package/src/utils/clickoutside.js +76 -76
  245. package/src/utils/date-util.js +282 -282
  246. package/src/utils/popup/index.js +218 -218
  247. package/src/utils/popup/popup-manager.js +194 -194
  248. package/src/utils/util.js +245 -245
  249. package/src/utils/vdom.js +5 -5
  250. package/src/utils/vue-popper.js +198 -198
@@ -1,502 +1,502 @@
1
- import Vue from 'vue';
2
- import merge from 'iov-design/src/utils/merge';
3
- import { getKeysMap, getRowIdentity, getColumnById, getColumnByKey, orderBy, toggleRowStatus } from '../util';
4
- import expand from './expand';
5
- import current from './current';
6
- import tree from './tree';
7
-
8
- const sortData = (data, states) => {
9
- const sortingColumn = states.sortingColumn;
10
- if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
11
- return data;
12
- }
13
- return orderBy(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod, sortingColumn.sortBy);
14
- };
15
-
16
- const doFlattenColumns = (columns) => {
17
- const result = [];
18
- columns.forEach((column) => {
19
- if (column.children) {
20
- result.push.apply(result, doFlattenColumns(column.children));
21
- } else {
22
- result.push(column);
23
- }
24
- });
25
- return result;
26
- };
27
-
28
- export default Vue.extend({
29
- data() {
30
- return {
31
- states: {
32
- // 3.0 版本后要求必须设置该属性
33
- rowKey: null,
34
-
35
- // 渲染的数据来源,是对 table 中的 data 过滤排序后的结果
36
- data: [],
37
-
38
- // 是否包含固定列
39
- isComplex: false,
40
-
41
- // 列
42
- _columns: [], // 不可响应的
43
- originColumns: [],
44
- columns: [],
45
- fixedColumns: [],
46
- rightFixedColumns: [],
47
- leafColumns: [],
48
- fixedLeafColumns: [],
49
- rightFixedLeafColumns: [],
50
- leafColumnsLength: 0,
51
- fixedLeafColumnsLength: 0,
52
- rightFixedLeafColumnsLength: 0,
53
-
54
- // 选择
55
- isAllSelected: false,
56
- selection: [],
57
- reserveSelection: false,
58
- selectOnIndeterminate: false,
59
- selectable: null,
60
-
61
- // 跨页全选标记
62
- isCrossPageSelection: false,
63
- // 全选下拉出现/隐藏事件
64
- showSelectionDropdown: false,
65
- // 已取消勾选的数据
66
- unSelectionData: [],
67
-
68
- // 过滤
69
- filters: {}, // 不可响应的
70
- filteredData: null,
71
-
72
- // 排序
73
- sortingColumn: null,
74
- sortProp: null,
75
- sortOrder: null,
76
-
77
- hoverRow: null
78
- }
79
- };
80
- },
81
-
82
- mixins: [expand, current, tree],
83
-
84
- methods: {
85
- // 检查 rowKey 是否存在
86
- assertRowKey() {
87
- const rowKey = this.states.rowKey;
88
- if (!rowKey) throw new Error('[ElTable] prop row-key is required');
89
- },
90
-
91
- // 更新列
92
- updateColumns() {
93
- const states = this.states;
94
- const _columns = states._columns || [];
95
- states.fixedColumns = _columns.filter((column) => column.fixed === true || column.fixed === 'left');
96
- states.rightFixedColumns = _columns.filter((column) => column.fixed === 'right');
97
-
98
- if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
99
- _columns[0].fixed = true;
100
- states.fixedColumns.unshift(_columns[0]);
101
- }
102
-
103
- const notFixedColumns = _columns.filter(column => !column.fixed);
104
- states.originColumns = [].concat(states.fixedColumns).concat(notFixedColumns).concat(states.rightFixedColumns);
105
-
106
- const leafColumns = doFlattenColumns(notFixedColumns);
107
- const fixedLeafColumns = doFlattenColumns(states.fixedColumns);
108
- const rightFixedLeafColumns = doFlattenColumns(states.rightFixedColumns);
109
-
110
- states.leafColumnsLength = leafColumns.length;
111
- states.fixedLeafColumnsLength = fixedLeafColumns.length;
112
- states.rightFixedLeafColumnsLength = rightFixedLeafColumns.length;
113
-
114
- states.columns = [].concat(fixedLeafColumns).concat(leafColumns).concat(rightFixedLeafColumns);
115
- states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
116
- },
117
-
118
- // 更新 DOM
119
- scheduleLayout(needUpdateColumns) {
120
- if (needUpdateColumns) {
121
- this.updateColumns();
122
- }
123
- this.table.debouncedUpdateLayout();
124
- },
125
-
126
- // 选择
127
- isSelected(row) {
128
- const { selection = [] } = this.states;
129
- return selection.indexOf(row) > -1;
130
- },
131
-
132
- clearSelection(emitChange = true) {
133
- const states = this.states;
134
- states.isAllSelected = false;
135
- const oldSelection = states.selection;
136
-
137
- // 表格中有选中的数据项是disabled状态时,清空时保留该数据
138
- const isDisabledSelection = states.data.filter((row, index) => {
139
- // 判断selectable是不可选中状态, 且当前数据项已被选中
140
- if (states.selectable && !states.selectable.call(null, row, index) && oldSelection.some(item => item[states.rowKey] === row[states.rowKey])) {
141
- return row;
142
- }
143
- });
144
- if (oldSelection.length) {
145
- states.selection = isDisabledSelection;
146
- emitChange && this.table.$emit('selection-change', states.selection, states.isCrossPageSelection);
147
- }
148
- },
149
-
150
- cleanSelection() {
151
- const states = this.states;
152
- const { data, rowKey, selection } = states;
153
- let deleted;
154
- if (rowKey) {
155
- deleted = [];
156
- const selectedMap = getKeysMap(selection, rowKey);
157
- const dataMap = getKeysMap(data, rowKey);
158
- for (let key in selectedMap) {
159
- if (selectedMap.hasOwnProperty(key) && !dataMap[key]) {
160
- deleted.push(selectedMap[key].row);
161
- }
162
- }
163
- } else {
164
- deleted = selection.filter(item => data.indexOf(item) === -1);
165
- }
166
- if (deleted.length) {
167
- const newSelection = selection.filter(item => deleted.indexOf(item) === -1);
168
- states.selection = newSelection;
169
- this.table.$emit('selection-change', newSelection.slice(), false);
170
- }
171
- },
172
-
173
- toggleRowSelection(row, selected, emitChange = true) {
174
- const changed = toggleRowStatus(this.states.selection, row, selected);
175
- if (changed) {
176
- const newSelection = (this.states.selection || []).slice();
177
- // 调用 API 修改选中值,不触发 select 事件
178
- if (emitChange) {
179
- this.getUnSelectedRow(newSelection);
180
- this.table.$emit('select', newSelection, row);
181
- }
182
- if (this.states.isCrossPageSelection) {
183
- this.table.$emit('selection-change', this.states.unSelectionData, true);
184
- } else {
185
- this.table.$emit('selection-change', newSelection, false);
186
- }
187
- }
188
- },
189
-
190
- /**
191
- * 选择数据事件
192
- * @param {num} command 选择事件类型 1-全选当前页 2-清空当前页 3-全选所有页 4-清空所有页
193
- */
194
- onSelectionChange(command) {
195
- switch (command) {
196
- // 全选当前页
197
- case 1:
198
- this.onChangeCurrentPage(true, command);
199
- break;
200
- // 清空当前页
201
- case 2:
202
- this.onChangeCurrentPage(false, command);
203
- break;
204
- // 全选所有页
205
- case 3:
206
- this.states.isCrossPageSelection = true;
207
- this.states.unSelectionData = [];
208
- this.onChangeCurrentPage(true, command);
209
- break;
210
- // 清空所有页
211
- case 4:
212
- this.onChangeCurrentPage(false, command);
213
- break;
214
- default:
215
- break;
216
- }
217
- },
218
-
219
- onChangeCurrentPage(selected, command) {
220
- const states = this.states;
221
- const { data = [], selection } = states;
222
- data.forEach((row, index) => {
223
- if (states.selectable) {
224
- if (states.selectable.call(null, row, index)) {
225
- toggleRowStatus(selection, row, selected);
226
- }
227
- } else {
228
- toggleRowStatus(selection, row, selected);
229
- }
230
- });
231
- this.updateAllSelected();
232
-
233
- // 先点击跨页全选,再点击清空当前页/取消几条勾选数据, 最后点击全选当前页
234
- if (states.isCrossPageSelection) {
235
- // 重新计算未选中数据
236
- this.getUnSelectedRow(states.selection);
237
- }
238
-
239
- if (command === 4) {
240
- states.isCrossPageSelection = false;
241
- this.clearSelection(false);
242
- states.unSelectionData = [];
243
- }
244
-
245
- // 触发el-table的'selection-change'事件
246
- if (states.isCrossPageSelection) {
247
- this.table.$listeners['selection-change'](states.unSelectionData, states.isCrossPageSelection);
248
- } else {
249
- this.table.$listeners['selection-change'](states.selection, states.isCrossPageSelection);
250
- }
251
- },
252
-
253
- /**
254
- * 获取取消勾选数据项
255
- * @param {arr} selection 当前已选择所有数据项
256
- */
257
- getUnSelectedRow(selection) {
258
- if (!this.states.isCrossPageSelection) return;
259
-
260
- const { rowKey } = this.states;
261
-
262
- // 从全部勾选数据中过滤出当前页勾选的数据
263
- const selected = this.states.data.filter(item => selection.some(row => row[rowKey] === item[rowKey]));
264
- // 通过当前页数据与当前页已勾选的数据, 过滤出当前页未勾选的数据
265
- const unselected = this.states.data.filter((item) => !selected.some((row) => row[rowKey] === item[rowKey]));
266
-
267
- // 取消勾选数据中是否存在当页面已勾选的数据项, 如有则删除
268
- const index = [];
269
- this.states.unSelectionData.forEach((item, i) => {
270
- if (selected.some(s => s[rowKey] === item[rowKey])) {
271
- index.push(i);
272
- }
273
- });
274
- this.states.unSelectionData = this.states.unSelectionData.filter((item, i) => !index.includes(i));
275
-
276
- // 取消勾选数据中如果不存在当前页未勾选的数据, 则将当前未勾选的数据添push到取消勾选数据中
277
- unselected.forEach(item => {
278
- if (!this.states.unSelectionData.some(s => s[rowKey] === item[rowKey])) {
279
- this.states.unSelectionData.push(item);
280
- }
281
- });
282
- },
283
-
284
- _toggleAllSelection() {
285
- const states = this.states;
286
- const { data = [], selection } = states;
287
- // when only some rows are selected (but not all), select or deselect all of them
288
- // depending on the value of selectOnIndeterminate
289
- const value = states.selectOnIndeterminate
290
- ? !states.isAllSelected
291
- : !(states.isAllSelected || selection.length);
292
- states.isAllSelected = value;
293
-
294
- let selectionChanged = false;
295
- data.forEach((row, index) => {
296
- if (states.selectable) {
297
- if (states.selectable.call(null, row, index) && toggleRowStatus(selection, row, value)) {
298
- selectionChanged = true;
299
- }
300
- } else {
301
- if (toggleRowStatus(selection, row, value)) {
302
- selectionChanged = true;
303
- }
304
- }
305
- });
306
-
307
- const newSelection = (this.states.selection || []).slice();
308
-
309
- if (selectionChanged) {
310
- if (states.isCrossPageSelection) {
311
- this.getUnSelectedRow(newSelection);
312
- this.table.$emit('selection-change', states.unSelectionData || [], true);
313
- } else {
314
- this.table.$emit('selection-change', selection ? selection.slice() : [], false);
315
- }
316
- }
317
- this.table.$emit('select-all', selection);
318
- },
319
-
320
- updateSelectionByRowKey() {
321
- const states = this.states;
322
- const { selection, rowKey, data } = states;
323
- const selectedMap = getKeysMap(selection, rowKey);
324
- data.forEach(row => {
325
- const rowId = getRowIdentity(row, rowKey);
326
- const rowInfo = selectedMap[rowId];
327
- if (rowInfo) {
328
- selection[rowInfo.index] = row;
329
- }
330
- });
331
- },
332
-
333
- updateAllSelected() {
334
- const states = this.states;
335
- const { selection, rowKey, selectable } = states;
336
- // data 为 null 时,解构时的默认值会被忽略
337
- const data = states.data || [];
338
- if (data.length === 0) {
339
- states.isAllSelected = false;
340
- return;
341
- }
342
-
343
- let selectedMap;
344
- if (rowKey) {
345
- selectedMap = getKeysMap(selection, rowKey);
346
- }
347
- const isSelected = function(row) {
348
- if (selectedMap) {
349
- return !!selectedMap[getRowIdentity(row, rowKey)];
350
- } else {
351
- return selection.indexOf(row) !== -1;
352
- }
353
- };
354
- let isAllSelected = true;
355
- let selectedCount = 0;
356
- for (let i = 0, j = data.length; i < j; i++) {
357
- const item = data[i];
358
- const isRowSelectable = selectable && selectable.call(null, item, i);
359
- if (!isSelected(item)) {
360
- if (!selectable || isRowSelectable) {
361
- isAllSelected = false;
362
- break;
363
- }
364
- } else {
365
- selectedCount++;
366
- }
367
- }
368
-
369
- if (selectedCount === 0) isAllSelected = false;
370
- states.isAllSelected = isAllSelected;
371
- },
372
-
373
- // 过滤与排序
374
- updateFilters(columns, values) {
375
- if (!Array.isArray(columns)) {
376
- columns = [columns];
377
- }
378
- const states = this.states;
379
- const filters = {};
380
- columns.forEach(col => {
381
- states.filters[col.id] = values;
382
- filters[col.columnKey || col.id] = values;
383
- });
384
-
385
- return filters;
386
- },
387
-
388
- updateSort(column, prop, order) {
389
- if (this.states.sortingColumn && this.states.sortingColumn !== column) {
390
- this.states.sortingColumn.order = null;
391
- }
392
- this.states.sortingColumn = column;
393
- this.states.sortProp = prop;
394
- this.states.sortOrder = order;
395
- },
396
-
397
- execFilter() {
398
- const states = this.states;
399
- const { _data, filters } = states;
400
- let data = _data;
401
-
402
- Object.keys(filters).forEach((columnId) => {
403
- const values = states.filters[columnId];
404
- if (!values || values.length === 0) return;
405
- const column = getColumnById(this.states, columnId);
406
- if (column && column.filterMethod) {
407
- data = data.filter((row) => {
408
- return values.some(value => column.filterMethod.call(null, value, row, column));
409
- });
410
- }
411
- });
412
-
413
- states.filteredData = data;
414
- },
415
-
416
- execSort() {
417
- const states = this.states;
418
- states.data = sortData(states.filteredData, states);
419
- },
420
-
421
- // 根据 filters 与 sort 去过滤 data
422
- execQuery(ignore) {
423
- if (!(ignore && ignore.filter)) {
424
- this.execFilter();
425
- }
426
- this.execSort();
427
- },
428
-
429
- clearFilter(columnKeys) {
430
- const states = this.states;
431
- const { tableHeader, fixedTableHeader, rightFixedTableHeader } = this.table.$refs;
432
-
433
- let panels = {};
434
- if (tableHeader) panels = merge(panels, tableHeader.filterPanels);
435
- if (fixedTableHeader) panels = merge(panels, fixedTableHeader.filterPanels);
436
- if (rightFixedTableHeader) panels = merge(panels, rightFixedTableHeader.filterPanels);
437
-
438
- const keys = Object.keys(panels);
439
- if (!keys.length) return;
440
-
441
- if (typeof columnKeys === 'string') {
442
- columnKeys = [columnKeys];
443
- }
444
-
445
- if (Array.isArray(columnKeys)) {
446
- const columns = columnKeys.map(key => getColumnByKey(states, key));
447
- keys.forEach(key => {
448
- const column = columns.find(col => col.id === key);
449
- if (column) {
450
- // TODO: 优化这里的代码
451
- panels[key].filteredValue = [];
452
- }
453
- });
454
- this.commit('filterChange', {
455
- column: columns,
456
- values: [],
457
- silent: true,
458
- multi: true
459
- });
460
- } else {
461
- keys.forEach(key => {
462
- // TODO: 优化这里的代码
463
- panels[key].filteredValue = [];
464
- });
465
-
466
- states.filters = {};
467
- this.commit('filterChange', {
468
- column: {},
469
- values: [],
470
- silent: true
471
- });
472
- }
473
- },
474
-
475
- clearSort() {
476
- const states = this.states;
477
- if (!states.sortingColumn) return;
478
-
479
- this.updateSort(null, null, null);
480
- this.commit('changeSortCondition', {
481
- silent: true
482
- });
483
- },
484
-
485
- // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用
486
- setExpandRowKeysAdapter(val) {
487
- // 这里会触发额外的计算,但为了兼容性,暂时这么做
488
- this.setExpandRowKeys(val);
489
- this.updateTreeExpandKeys(val);
490
- },
491
-
492
- // 展开行与 TreeTable 都要使用
493
- toggleRowExpansionAdapter(row, expanded) {
494
- const hasExpandColumn = this.states.columns.some(({ type }) => type === 'expand');
495
- if (hasExpandColumn) {
496
- this.toggleRowExpansion(row, expanded);
497
- } else {
498
- this.toggleTreeExpansion(row, expanded);
499
- }
500
- }
501
- }
502
- });
1
+ import Vue from 'vue';
2
+ import merge from 'iov-design/src/utils/merge';
3
+ import { getKeysMap, getRowIdentity, getColumnById, getColumnByKey, orderBy, toggleRowStatus } from '../util';
4
+ import expand from './expand';
5
+ import current from './current';
6
+ import tree from './tree';
7
+
8
+ const sortData = (data, states) => {
9
+ const sortingColumn = states.sortingColumn;
10
+ if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
11
+ return data;
12
+ }
13
+ return orderBy(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod, sortingColumn.sortBy);
14
+ };
15
+
16
+ const doFlattenColumns = (columns) => {
17
+ const result = [];
18
+ columns.forEach((column) => {
19
+ if (column.children) {
20
+ result.push.apply(result, doFlattenColumns(column.children));
21
+ } else {
22
+ result.push(column);
23
+ }
24
+ });
25
+ return result;
26
+ };
27
+
28
+ export default Vue.extend({
29
+ data() {
30
+ return {
31
+ states: {
32
+ // 3.0 版本后要求必须设置该属性
33
+ rowKey: null,
34
+
35
+ // 渲染的数据来源,是对 table 中的 data 过滤排序后的结果
36
+ data: [],
37
+
38
+ // 是否包含固定列
39
+ isComplex: false,
40
+
41
+ // 列
42
+ _columns: [], // 不可响应的
43
+ originColumns: [],
44
+ columns: [],
45
+ fixedColumns: [],
46
+ rightFixedColumns: [],
47
+ leafColumns: [],
48
+ fixedLeafColumns: [],
49
+ rightFixedLeafColumns: [],
50
+ leafColumnsLength: 0,
51
+ fixedLeafColumnsLength: 0,
52
+ rightFixedLeafColumnsLength: 0,
53
+
54
+ // 选择
55
+ isAllSelected: false,
56
+ selection: [],
57
+ reserveSelection: false,
58
+ selectOnIndeterminate: false,
59
+ selectable: null,
60
+
61
+ // 跨页全选标记
62
+ isCrossPageSelection: false,
63
+ // 全选下拉出现/隐藏事件
64
+ showSelectionDropdown: false,
65
+ // 已取消勾选的数据
66
+ unSelectionData: [],
67
+
68
+ // 过滤
69
+ filters: {}, // 不可响应的
70
+ filteredData: null,
71
+
72
+ // 排序
73
+ sortingColumn: null,
74
+ sortProp: null,
75
+ sortOrder: null,
76
+
77
+ hoverRow: null
78
+ }
79
+ };
80
+ },
81
+
82
+ mixins: [expand, current, tree],
83
+
84
+ methods: {
85
+ // 检查 rowKey 是否存在
86
+ assertRowKey() {
87
+ const rowKey = this.states.rowKey;
88
+ if (!rowKey) throw new Error('[ElTable] prop row-key is required');
89
+ },
90
+
91
+ // 更新列
92
+ updateColumns() {
93
+ const states = this.states;
94
+ const _columns = states._columns || [];
95
+ states.fixedColumns = _columns.filter((column) => column.fixed === true || column.fixed === 'left');
96
+ states.rightFixedColumns = _columns.filter((column) => column.fixed === 'right');
97
+
98
+ if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
99
+ _columns[0].fixed = true;
100
+ states.fixedColumns.unshift(_columns[0]);
101
+ }
102
+
103
+ const notFixedColumns = _columns.filter(column => !column.fixed);
104
+ states.originColumns = [].concat(states.fixedColumns).concat(notFixedColumns).concat(states.rightFixedColumns);
105
+
106
+ const leafColumns = doFlattenColumns(notFixedColumns);
107
+ const fixedLeafColumns = doFlattenColumns(states.fixedColumns);
108
+ const rightFixedLeafColumns = doFlattenColumns(states.rightFixedColumns);
109
+
110
+ states.leafColumnsLength = leafColumns.length;
111
+ states.fixedLeafColumnsLength = fixedLeafColumns.length;
112
+ states.rightFixedLeafColumnsLength = rightFixedLeafColumns.length;
113
+
114
+ states.columns = [].concat(fixedLeafColumns).concat(leafColumns).concat(rightFixedLeafColumns);
115
+ states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
116
+ },
117
+
118
+ // 更新 DOM
119
+ scheduleLayout(needUpdateColumns) {
120
+ if (needUpdateColumns) {
121
+ this.updateColumns();
122
+ }
123
+ this.table.debouncedUpdateLayout();
124
+ },
125
+
126
+ // 选择
127
+ isSelected(row) {
128
+ const { selection = [] } = this.states;
129
+ return selection.indexOf(row) > -1;
130
+ },
131
+
132
+ clearSelection(emitChange = true) {
133
+ const states = this.states;
134
+ states.isAllSelected = false;
135
+ const oldSelection = states.selection;
136
+
137
+ // 表格中有选中的数据项是disabled状态时,清空时保留该数据
138
+ const isDisabledSelection = states.data.filter((row, index) => {
139
+ // 判断selectable是不可选中状态, 且当前数据项已被选中
140
+ if (states.selectable && !states.selectable.call(null, row, index) && oldSelection.some(item => item[states.rowKey] === row[states.rowKey])) {
141
+ return row;
142
+ }
143
+ });
144
+ if (oldSelection.length) {
145
+ states.selection = isDisabledSelection;
146
+ emitChange && this.table.$emit('selection-change', states.selection, states.isCrossPageSelection);
147
+ }
148
+ },
149
+
150
+ cleanSelection() {
151
+ const states = this.states;
152
+ const { data, rowKey, selection } = states;
153
+ let deleted;
154
+ if (rowKey) {
155
+ deleted = [];
156
+ const selectedMap = getKeysMap(selection, rowKey);
157
+ const dataMap = getKeysMap(data, rowKey);
158
+ for (let key in selectedMap) {
159
+ if (selectedMap.hasOwnProperty(key) && !dataMap[key]) {
160
+ deleted.push(selectedMap[key].row);
161
+ }
162
+ }
163
+ } else {
164
+ deleted = selection.filter(item => data.indexOf(item) === -1);
165
+ }
166
+ if (deleted.length) {
167
+ const newSelection = selection.filter(item => deleted.indexOf(item) === -1);
168
+ states.selection = newSelection;
169
+ this.table.$emit('selection-change', newSelection.slice(), false);
170
+ }
171
+ },
172
+
173
+ toggleRowSelection(row, selected, emitChange = true) {
174
+ const changed = toggleRowStatus(this.states.selection, row, selected);
175
+ if (changed) {
176
+ const newSelection = (this.states.selection || []).slice();
177
+ // 调用 API 修改选中值,不触发 select 事件
178
+ if (emitChange) {
179
+ this.getUnSelectedRow(newSelection);
180
+ this.table.$emit('select', newSelection, row);
181
+ }
182
+ if (this.states.isCrossPageSelection) {
183
+ this.table.$emit('selection-change', this.states.unSelectionData, true);
184
+ } else {
185
+ this.table.$emit('selection-change', newSelection, false);
186
+ }
187
+ }
188
+ },
189
+
190
+ /**
191
+ * 选择数据事件
192
+ * @param {num} command 选择事件类型 1-全选当前页 2-清空当前页 3-全选所有页 4-清空所有页
193
+ */
194
+ onSelectionChange(command) {
195
+ switch (command) {
196
+ // 全选当前页
197
+ case 1:
198
+ this.onChangeCurrentPage(true, command);
199
+ break;
200
+ // 清空当前页
201
+ case 2:
202
+ this.onChangeCurrentPage(false, command);
203
+ break;
204
+ // 全选所有页
205
+ case 3:
206
+ this.states.isCrossPageSelection = true;
207
+ this.states.unSelectionData = [];
208
+ this.onChangeCurrentPage(true, command);
209
+ break;
210
+ // 清空所有页
211
+ case 4:
212
+ this.onChangeCurrentPage(false, command);
213
+ break;
214
+ default:
215
+ break;
216
+ }
217
+ },
218
+
219
+ onChangeCurrentPage(selected, command) {
220
+ const states = this.states;
221
+ const { data = [], selection } = states;
222
+ data.forEach((row, index) => {
223
+ if (states.selectable) {
224
+ if (states.selectable.call(null, row, index)) {
225
+ toggleRowStatus(selection, row, selected);
226
+ }
227
+ } else {
228
+ toggleRowStatus(selection, row, selected);
229
+ }
230
+ });
231
+ this.updateAllSelected();
232
+
233
+ // 先点击跨页全选,再点击清空当前页/取消几条勾选数据, 最后点击全选当前页
234
+ if (states.isCrossPageSelection) {
235
+ // 重新计算未选中数据
236
+ this.getUnSelectedRow(states.selection);
237
+ }
238
+
239
+ if (command === 4) {
240
+ states.isCrossPageSelection = false;
241
+ this.clearSelection(false);
242
+ states.unSelectionData = [];
243
+ }
244
+
245
+ // 触发el-table的'selection-change'事件
246
+ if (states.isCrossPageSelection) {
247
+ this.table.$listeners['selection-change'](states.unSelectionData, states.isCrossPageSelection);
248
+ } else {
249
+ this.table.$listeners['selection-change'](states.selection, states.isCrossPageSelection);
250
+ }
251
+ },
252
+
253
+ /**
254
+ * 获取取消勾选数据项
255
+ * @param {arr} selection 当前已选择所有数据项
256
+ */
257
+ getUnSelectedRow(selection) {
258
+ if (!this.states.isCrossPageSelection) return;
259
+
260
+ const { rowKey } = this.states;
261
+
262
+ // 从全部勾选数据中过滤出当前页勾选的数据
263
+ const selected = this.states.data.filter(item => selection.some(row => row[rowKey] === item[rowKey]));
264
+ // 通过当前页数据与当前页已勾选的数据, 过滤出当前页未勾选的数据
265
+ const unselected = this.states.data.filter((item) => !selected.some((row) => row[rowKey] === item[rowKey]));
266
+
267
+ // 取消勾选数据中是否存在当页面已勾选的数据项, 如有则删除
268
+ const index = [];
269
+ this.states.unSelectionData.forEach((item, i) => {
270
+ if (selected.some(s => s[rowKey] === item[rowKey])) {
271
+ index.push(i);
272
+ }
273
+ });
274
+ this.states.unSelectionData = this.states.unSelectionData.filter((item, i) => !index.includes(i));
275
+
276
+ // 取消勾选数据中如果不存在当前页未勾选的数据, 则将当前未勾选的数据添push到取消勾选数据中
277
+ unselected.forEach(item => {
278
+ if (!this.states.unSelectionData.some(s => s[rowKey] === item[rowKey])) {
279
+ this.states.unSelectionData.push(item);
280
+ }
281
+ });
282
+ },
283
+
284
+ _toggleAllSelection() {
285
+ const states = this.states;
286
+ const { data = [], selection } = states;
287
+ // when only some rows are selected (but not all), select or deselect all of them
288
+ // depending on the value of selectOnIndeterminate
289
+ const value = states.selectOnIndeterminate
290
+ ? !states.isAllSelected
291
+ : !(states.isAllSelected || selection.length);
292
+ states.isAllSelected = value;
293
+
294
+ let selectionChanged = false;
295
+ data.forEach((row, index) => {
296
+ if (states.selectable) {
297
+ if (states.selectable.call(null, row, index) && toggleRowStatus(selection, row, value)) {
298
+ selectionChanged = true;
299
+ }
300
+ } else {
301
+ if (toggleRowStatus(selection, row, value)) {
302
+ selectionChanged = true;
303
+ }
304
+ }
305
+ });
306
+
307
+ const newSelection = (this.states.selection || []).slice();
308
+
309
+ if (selectionChanged) {
310
+ if (states.isCrossPageSelection) {
311
+ this.getUnSelectedRow(newSelection);
312
+ this.table.$emit('selection-change', states.unSelectionData || [], true);
313
+ } else {
314
+ this.table.$emit('selection-change', selection ? selection.slice() : [], false);
315
+ }
316
+ }
317
+ this.table.$emit('select-all', selection);
318
+ },
319
+
320
+ updateSelectionByRowKey() {
321
+ const states = this.states;
322
+ const { selection, rowKey, data } = states;
323
+ const selectedMap = getKeysMap(selection, rowKey);
324
+ data.forEach(row => {
325
+ const rowId = getRowIdentity(row, rowKey);
326
+ const rowInfo = selectedMap[rowId];
327
+ if (rowInfo) {
328
+ selection[rowInfo.index] = row;
329
+ }
330
+ });
331
+ },
332
+
333
+ updateAllSelected() {
334
+ const states = this.states;
335
+ const { selection, rowKey, selectable } = states;
336
+ // data 为 null 时,解构时的默认值会被忽略
337
+ const data = states.data || [];
338
+ if (data.length === 0) {
339
+ states.isAllSelected = false;
340
+ return;
341
+ }
342
+
343
+ let selectedMap;
344
+ if (rowKey) {
345
+ selectedMap = getKeysMap(selection, rowKey);
346
+ }
347
+ const isSelected = function(row) {
348
+ if (selectedMap) {
349
+ return !!selectedMap[getRowIdentity(row, rowKey)];
350
+ } else {
351
+ return selection.indexOf(row) !== -1;
352
+ }
353
+ };
354
+ let isAllSelected = true;
355
+ let selectedCount = 0;
356
+ for (let i = 0, j = data.length; i < j; i++) {
357
+ const item = data[i];
358
+ const isRowSelectable = selectable && selectable.call(null, item, i);
359
+ if (!isSelected(item)) {
360
+ if (!selectable || isRowSelectable) {
361
+ isAllSelected = false;
362
+ break;
363
+ }
364
+ } else {
365
+ selectedCount++;
366
+ }
367
+ }
368
+
369
+ if (selectedCount === 0) isAllSelected = false;
370
+ states.isAllSelected = isAllSelected;
371
+ },
372
+
373
+ // 过滤与排序
374
+ updateFilters(columns, values) {
375
+ if (!Array.isArray(columns)) {
376
+ columns = [columns];
377
+ }
378
+ const states = this.states;
379
+ const filters = {};
380
+ columns.forEach(col => {
381
+ states.filters[col.id] = values;
382
+ filters[col.columnKey || col.id] = values;
383
+ });
384
+
385
+ return filters;
386
+ },
387
+
388
+ updateSort(column, prop, order) {
389
+ if (this.states.sortingColumn && this.states.sortingColumn !== column) {
390
+ this.states.sortingColumn.order = null;
391
+ }
392
+ this.states.sortingColumn = column;
393
+ this.states.sortProp = prop;
394
+ this.states.sortOrder = order;
395
+ },
396
+
397
+ execFilter() {
398
+ const states = this.states;
399
+ const { _data, filters } = states;
400
+ let data = _data;
401
+
402
+ Object.keys(filters).forEach((columnId) => {
403
+ const values = states.filters[columnId];
404
+ if (!values || values.length === 0) return;
405
+ const column = getColumnById(this.states, columnId);
406
+ if (column && column.filterMethod) {
407
+ data = data.filter((row) => {
408
+ return values.some(value => column.filterMethod.call(null, value, row, column));
409
+ });
410
+ }
411
+ });
412
+
413
+ states.filteredData = data;
414
+ },
415
+
416
+ execSort() {
417
+ const states = this.states;
418
+ states.data = sortData(states.filteredData, states);
419
+ },
420
+
421
+ // 根据 filters 与 sort 去过滤 data
422
+ execQuery(ignore) {
423
+ if (!(ignore && ignore.filter)) {
424
+ this.execFilter();
425
+ }
426
+ this.execSort();
427
+ },
428
+
429
+ clearFilter(columnKeys) {
430
+ const states = this.states;
431
+ const { tableHeader, fixedTableHeader, rightFixedTableHeader } = this.table.$refs;
432
+
433
+ let panels = {};
434
+ if (tableHeader) panels = merge(panels, tableHeader.filterPanels);
435
+ if (fixedTableHeader) panels = merge(panels, fixedTableHeader.filterPanels);
436
+ if (rightFixedTableHeader) panels = merge(panels, rightFixedTableHeader.filterPanels);
437
+
438
+ const keys = Object.keys(panels);
439
+ if (!keys.length) return;
440
+
441
+ if (typeof columnKeys === 'string') {
442
+ columnKeys = [columnKeys];
443
+ }
444
+
445
+ if (Array.isArray(columnKeys)) {
446
+ const columns = columnKeys.map(key => getColumnByKey(states, key));
447
+ keys.forEach(key => {
448
+ const column = columns.find(col => col.id === key);
449
+ if (column) {
450
+ // TODO: 优化这里的代码
451
+ panels[key].filteredValue = [];
452
+ }
453
+ });
454
+ this.commit('filterChange', {
455
+ column: columns,
456
+ values: [],
457
+ silent: true,
458
+ multi: true
459
+ });
460
+ } else {
461
+ keys.forEach(key => {
462
+ // TODO: 优化这里的代码
463
+ panels[key].filteredValue = [];
464
+ });
465
+
466
+ states.filters = {};
467
+ this.commit('filterChange', {
468
+ column: {},
469
+ values: [],
470
+ silent: true
471
+ });
472
+ }
473
+ },
474
+
475
+ clearSort() {
476
+ const states = this.states;
477
+ if (!states.sortingColumn) return;
478
+
479
+ this.updateSort(null, null, null);
480
+ this.commit('changeSortCondition', {
481
+ silent: true
482
+ });
483
+ },
484
+
485
+ // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用
486
+ setExpandRowKeysAdapter(val) {
487
+ // 这里会触发额外的计算,但为了兼容性,暂时这么做
488
+ this.setExpandRowKeys(val);
489
+ this.updateTreeExpandKeys(val);
490
+ },
491
+
492
+ // 展开行与 TreeTable 都要使用
493
+ toggleRowExpansionAdapter(row, expanded) {
494
+ const hasExpandColumn = this.states.columns.some(({ type }) => type === 'expand');
495
+ if (hasExpandColumn) {
496
+ this.toggleRowExpansion(row, expanded);
497
+ } else {
498
+ this.toggleTreeExpansion(row, expanded);
499
+ }
500
+ }
501
+ }
502
+ });