@king-design/intact 2.0.16 → 2.1.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.
- package/components/cascader/index.md +18 -0
- package/components/cascader/index.spec.ts +56 -0
- package/components/cascader/index.ts +35 -12
- package/components/cascader/index.vdt +9 -8
- package/components/cascader/styles.ts +2 -1
- package/components/cascader/useFields.ts +22 -0
- package/components/cascader/useFilterable.ts +23 -8
- package/components/cascader/useLabel.ts +7 -4
- package/components/cascader/useLoad.ts +4 -2
- package/components/code/demos/basic.md +1 -1
- package/components/colorpicker/index.md +16 -0
- package/components/colorpicker/index.ts +4 -0
- package/components/colorpicker/index.vdt +3 -2
- package/components/datepicker/index.md +11 -0
- package/components/dialog/index.spec.ts +2 -2
- package/components/dropdown/dropdown.ts +18 -10
- package/components/dropdown/item.ts +3 -2
- package/components/dropdown/menu.ts +1 -1
- package/components/dropdown/usePosition.ts +9 -1
- package/components/editable/index.ts +17 -3
- package/components/editable/index.vdt +1 -0
- package/components/input/demos/autoRows.md +44 -0
- package/components/input/demos/password.md +12 -0
- package/components/input/demos/textarea.md +2 -2
- package/components/input/index.md +1 -0
- package/components/input/index.spec.ts +97 -1
- package/components/input/index.ts +17 -3
- package/components/input/index.vdt +29 -6
- package/components/input/styles.ts +18 -1
- package/components/input/useAutoRows.ts +65 -0
- package/components/input/useAutoWidth.ts +12 -3
- package/components/input/useShowPassword.ts +27 -0
- package/components/pagination/index.spec.ts +1 -1
- package/components/pagination/index.ts +1 -2
- package/components/portal.ts +4 -4
- package/components/position.ts +5 -1
- package/components/select/base.ts +3 -1
- package/components/select/base.vdt +2 -0
- package/components/select/index.md +11 -1
- package/components/table/cell.ts +4 -5
- package/components/table/demos/hideHeader.md +33 -0
- package/components/table/demos/pagination.md +53 -0
- package/components/table/index.md +22 -0
- package/components/table/index.spec.ts +73 -1
- package/components/table/row.ts +3 -3
- package/components/table/styles.ts +5 -0
- package/components/table/table.ts +29 -4
- package/components/table/table.vdt +21 -3
- package/components/table/useChecked.ts +21 -6
- package/components/table/useDisableRow.ts +3 -2
- package/components/table/useDraggable.ts +11 -8
- package/components/table/useGroup.ts +2 -0
- package/components/table/useMerge.ts +6 -3
- package/components/table/usePagination.ts +71 -0
- package/components/table/useRestRowStatus.ts +4 -1
- package/components/table/useTree.ts +4 -3
- package/components/timepicker/index.md +11 -0
- package/components/tooltip/demos/trigger.md +1 -1
- package/components/tooltip/index.md +1 -1
- package/components/tooltip/index.spec.ts +8 -5
- package/components/tooltip/tooltip.ts +0 -2
- package/components/treeSelect/index.md +9 -0
- package/es/components/cascader/index.d.ts +22 -11
- package/es/components/cascader/index.js +9 -12
- package/es/components/cascader/index.spec.js +81 -0
- package/es/components/cascader/index.vdt.js +10 -8
- package/es/components/cascader/styles.js +1 -1
- package/es/components/cascader/useFields.d.ts +2 -0
- package/es/components/cascader/useFields.js +18 -0
- package/es/components/cascader/useFilterable.d.ts +2 -1
- package/es/components/cascader/useFilterable.js +17 -6
- package/es/components/cascader/useLabel.d.ts +2 -1
- package/es/components/cascader/useLabel.js +4 -4
- package/es/components/cascader/useLoad.d.ts +2 -1
- package/es/components/cascader/useLoad.js +9 -7
- package/es/components/colorpicker/index.d.ts +2 -0
- package/es/components/colorpicker/index.js +7 -2
- package/es/components/colorpicker/index.vdt.js +3 -6
- package/es/components/dialog/index.spec.js +2 -2
- package/es/components/dropdown/dropdown.d.ts +0 -1
- package/es/components/dropdown/dropdown.js +19 -8
- package/es/components/dropdown/item.js +3 -3
- package/es/components/dropdown/menu.js +1 -1
- package/es/components/dropdown/usePosition.js +8 -1
- package/es/components/editable/index.d.ts +1 -0
- package/es/components/editable/index.js +20 -6
- package/es/components/editable/index.vdt.js +2 -1
- package/es/components/input/index.d.ts +10 -2
- package/es/components/input/index.js +10 -3
- package/es/components/input/index.spec.js +169 -1
- package/es/components/input/index.vdt.js +26 -7
- package/es/components/input/styles.js +8 -3
- package/es/components/input/useAutoRows.d.ts +2 -0
- package/es/components/input/useAutoRows.js +79 -0
- package/es/components/input/useAutoWidth.js +13 -3
- package/es/components/input/useShowPassword.d.ts +7 -0
- package/es/components/input/useShowPassword.js +31 -0
- package/es/components/pagination/index.js +1 -3
- package/es/components/pagination/index.spec.js +2 -4
- package/es/components/portal.d.ts +6 -2
- package/es/components/portal.js +4 -3
- package/es/components/position.js +2 -1
- package/es/components/select/base.d.ts +2 -1
- package/es/components/select/base.js +3 -1
- package/es/components/select/base.vdt.js +3 -1
- package/es/components/table/cell.js +1 -6
- package/es/components/table/index.spec.js +130 -19
- package/es/components/table/row.d.ts +1 -1
- package/es/components/table/row.js +2 -1
- package/es/components/table/styles.js +1 -1
- package/es/components/table/table.d.ts +15 -0
- package/es/components/table/table.js +16 -7
- package/es/components/table/table.vdt.js +20 -6
- package/es/components/table/useChecked.d.ts +3 -2
- package/es/components/table/useChecked.js +23 -12
- package/es/components/table/useDisableRow.d.ts +2 -1
- package/es/components/table/useDisableRow.js +4 -4
- package/es/components/table/useDraggable.d.ts +3 -2
- package/es/components/table/useDraggable.js +11 -8
- package/es/components/table/useGroup.js +3 -0
- package/es/components/table/useMerge.d.ts +2 -1
- package/es/components/table/useMerge.js +5 -4
- package/es/components/table/usePagination.d.ts +8 -0
- package/es/components/table/usePagination.js +81 -0
- package/es/components/table/useTree.d.ts +2 -1
- package/es/components/table/useTree.js +3 -4
- package/es/components/tooltip/index.spec.js +9 -10
- package/es/components/tooltip/tooltip.d.ts +0 -1
- package/es/components/tooltip/tooltip.js +1 -12
- package/es/index.d.ts +3 -3
- package/es/index.js +3 -3
- package/es/packages/kpc-react/__tests__/components/cascader.spec.d.ts +1 -0
- package/es/packages/kpc-react/__tests__/components/cascader.spec.js +79 -0
- package/es/site/data/components/dialog/demos/basic/react.js +4 -1
- package/es/site/data/components/input/demos/autoRows/index.d.ts +9 -0
- package/es/site/data/components/input/demos/autoRows/index.js +24 -0
- package/es/site/data/components/input/demos/autoRows/react.d.ts +8 -0
- package/es/site/data/components/input/demos/autoRows/react.js +62 -0
- package/es/site/data/components/input/demos/password/index.d.ts +5 -0
- package/es/site/data/components/input/demos/password/index.js +17 -0
- package/es/site/data/components/input/demos/password/react.d.ts +5 -0
- package/es/site/data/components/input/demos/password/react.js +41 -0
- package/es/site/data/components/input/demos/textarea/react.js +4 -2
- package/es/site/data/components/table/demos/hideHeader/index.d.ts +12 -0
- package/es/site/data/components/table/demos/hideHeader/index.js +30 -0
- package/es/site/data/components/table/demos/hideHeader/react.d.ts +11 -0
- package/es/site/data/components/table/demos/hideHeader/react.js +60 -0
- package/es/site/data/components/table/demos/pagination/index.d.ts +12 -0
- package/es/site/data/components/table/demos/pagination/index.js +35 -0
- package/es/site/data/components/table/demos/pagination/react.d.ts +16 -0
- package/es/site/data/components/table/demos/pagination/react.js +65 -0
- package/es/styles/fonts/ionicons.js +1 -1
- package/index.ts +3 -3
- package/package.json +4 -4
- package/styles/fonts/ionicons.ts +0 -1
|
@@ -23,13 +23,14 @@ import { Table, TableColumn } from './';
|
|
|
23
23
|
import DraggableTable from '~/components/table/demos/draggable';
|
|
24
24
|
import MergeCellDemo from '~/components/table/demos/mergeCell';
|
|
25
25
|
import { AllCheckedStatus } from './useChecked';
|
|
26
|
+
import PaginationDemo from '~/components/table/demos/pagination';
|
|
26
27
|
describe('Table', function () {
|
|
27
28
|
afterEach(function () {
|
|
28
29
|
unmount();
|
|
29
30
|
localStorage.removeItem('resizableTable');
|
|
30
31
|
});
|
|
31
32
|
it('check & uncheck', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
|
|
32
|
-
var _mount, instance, element, table, checked, spy, _element$querySelecto, tr1, tr2, all;
|
|
33
|
+
var _mount, instance, element, table, checked, spy, spyCheckRow, spyUncheckRow, spyCheckAll, spyUncheckAll, _element$querySelecto, tr1, tr2, all;
|
|
33
34
|
|
|
34
35
|
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
35
36
|
while (1) {
|
|
@@ -42,54 +43,76 @@ describe('Table', function () {
|
|
|
42
43
|
spy = sinon.spy(function (v) {
|
|
43
44
|
return console.log(v);
|
|
44
45
|
});
|
|
45
|
-
table.on('$change:checkedKeys', spy);
|
|
46
|
+
table.on('$change:checkedKeys', spy);
|
|
47
|
+
spyCheckRow = sinon.spy(function (data, index, key) {
|
|
48
|
+
return console.log('checkRow', data, index, key);
|
|
49
|
+
});
|
|
50
|
+
table.on('checkRow', spyCheckRow);
|
|
51
|
+
spyUncheckRow = sinon.spy(function (data, index, key) {
|
|
52
|
+
return console.log('uncheckRow', data, index, key);
|
|
53
|
+
});
|
|
54
|
+
table.on('uncheckRow', spyUncheckRow);
|
|
55
|
+
spyCheckAll = sinon.spy(function () {
|
|
56
|
+
return console.log('checkAll');
|
|
57
|
+
});
|
|
58
|
+
table.on('checkAll', spyCheckAll);
|
|
59
|
+
spyUncheckAll = sinon.spy(function () {
|
|
60
|
+
return console.log('uncheckAll');
|
|
61
|
+
});
|
|
62
|
+
table.on('uncheckAll', spyUncheckAll); // click row
|
|
46
63
|
|
|
47
64
|
_element$querySelecto = element.querySelectorAll('tbody tr'), tr1 = _element$querySelecto[0], tr2 = _element$querySelecto[1];
|
|
48
65
|
tr1.click();
|
|
49
|
-
_context.next =
|
|
66
|
+
_context.next = 17;
|
|
50
67
|
return wait();
|
|
51
68
|
|
|
52
|
-
case
|
|
69
|
+
case 17:
|
|
53
70
|
expect(table.get('checkedKeys')).to.eql([0]);
|
|
71
|
+
expect(spyCheckRow.callCount).to.eql(1);
|
|
54
72
|
tr2.click();
|
|
55
|
-
_context.next =
|
|
73
|
+
_context.next = 22;
|
|
56
74
|
return wait();
|
|
57
75
|
|
|
58
|
-
case
|
|
76
|
+
case 22:
|
|
59
77
|
expect(table.get('checkedKeys')).to.eql([0, 1]);
|
|
60
78
|
expect(checked.getAllCheckedStatus()).eql(AllCheckedStatus.All);
|
|
79
|
+
expect(spyCheckRow.callCount).to.eql(2);
|
|
80
|
+
expect(spyCheckAll.callCount).to.eq(0);
|
|
61
81
|
tr1.click();
|
|
62
|
-
_context.next =
|
|
82
|
+
_context.next = 29;
|
|
63
83
|
return wait();
|
|
64
84
|
|
|
65
|
-
case
|
|
85
|
+
case 29:
|
|
66
86
|
expect(table.get('checkedKeys')).to.eql([1]);
|
|
67
87
|
expect(checked.getAllCheckedStatus()).eql(AllCheckedStatus.Indeterminate);
|
|
88
|
+
expect(spyUncheckRow.callCount).to.eql(1);
|
|
68
89
|
all = element.querySelector('.k-checkbox');
|
|
69
90
|
all.click();
|
|
70
|
-
_context.next =
|
|
91
|
+
_context.next = 36;
|
|
71
92
|
return wait();
|
|
72
93
|
|
|
73
|
-
case
|
|
94
|
+
case 36:
|
|
74
95
|
expect(checked.getAllCheckedStatus()).eql(AllCheckedStatus.All);
|
|
96
|
+
expect(spyCheckAll.callCount).to.eql(1);
|
|
75
97
|
all.click();
|
|
76
|
-
_context.next =
|
|
98
|
+
_context.next = 41;
|
|
77
99
|
return wait();
|
|
78
100
|
|
|
79
|
-
case
|
|
101
|
+
case 41:
|
|
80
102
|
expect(checked.getAllCheckedStatus()).eql(AllCheckedStatus.None);
|
|
81
103
|
expect(table.get('checkedKeys')).to.eql([]);
|
|
104
|
+
expect(spyUncheckAll.callCount).to.eql(1);
|
|
82
105
|
expect(spy.callCount).to.eql(5); // clear data of table should only trigger $change:checked event once, #407
|
|
83
106
|
|
|
84
107
|
all.click();
|
|
85
|
-
|
|
86
|
-
_context.next =
|
|
108
|
+
instance.set('data', []);
|
|
109
|
+
_context.next = 49;
|
|
87
110
|
return wait();
|
|
88
111
|
|
|
89
|
-
case
|
|
112
|
+
case 49:
|
|
90
113
|
expect(spy.callCount).to.eql(7);
|
|
91
114
|
|
|
92
|
-
case
|
|
115
|
+
case 50:
|
|
93
116
|
case "end":
|
|
94
117
|
return _context.stop();
|
|
95
118
|
}
|
|
@@ -342,7 +365,7 @@ describe('Table', function () {
|
|
|
342
365
|
}, _callee6);
|
|
343
366
|
})));
|
|
344
367
|
it('group', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee7() {
|
|
345
|
-
var _mount7, instance, element, _instance$refs4, __test1, __test2, _element$querySelecto8, table1, table2, icon, dropdown, item, icon2, dropdown2, _dropdown2$querySelec, item1, item2;
|
|
368
|
+
var _mount7, instance, element, _instance$refs4, __test1, __test2, _element$querySelecto8, table1, table2, icon, dropdown, item, icon2, dropdown2, _dropdown2$querySelec, item1, item2, newDropdown;
|
|
346
369
|
|
|
347
370
|
return _regeneratorRuntime.wrap(function _callee7$(_context7) {
|
|
348
371
|
while (1) {
|
|
@@ -395,9 +418,21 @@ describe('Table', function () {
|
|
|
395
418
|
expect(instance.get('multipleGroup')).to.eql({
|
|
396
419
|
status: ['active', 'stopped']
|
|
397
420
|
});
|
|
398
|
-
expect(table2.innerHTML).to.matchSnapshot();
|
|
421
|
+
expect(table2.innerHTML).to.matchSnapshot(); // update group
|
|
399
422
|
|
|
400
|
-
|
|
423
|
+
instance.set('statusGroup', [{
|
|
424
|
+
label: 'label',
|
|
425
|
+
value: 'value'
|
|
426
|
+
}]);
|
|
427
|
+
dispatchEvent(icon, 'click');
|
|
428
|
+
_context7.next = 36;
|
|
429
|
+
return wait(500);
|
|
430
|
+
|
|
431
|
+
case 36:
|
|
432
|
+
newDropdown = getElement('.k-table-group-dropdown');
|
|
433
|
+
expect(newDropdown.innerHTML).to.matchSnapshot();
|
|
434
|
+
|
|
435
|
+
case 38:
|
|
401
436
|
case "end":
|
|
402
437
|
return _context7.stop();
|
|
403
438
|
}
|
|
@@ -1064,4 +1099,80 @@ describe('Table', function () {
|
|
|
1064
1099
|
}
|
|
1065
1100
|
}, _callee22);
|
|
1066
1101
|
})));
|
|
1102
|
+
it('pagination', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee23() {
|
|
1103
|
+
var _mount25, instance, element, table, pagination, spy;
|
|
1104
|
+
|
|
1105
|
+
return _regeneratorRuntime.wrap(function _callee23$(_context26) {
|
|
1106
|
+
while (1) {
|
|
1107
|
+
switch (_context26.prev = _context26.next) {
|
|
1108
|
+
case 0:
|
|
1109
|
+
_mount25 = mount(PaginationDemo), instance = _mount25[0], element = _mount25[1];
|
|
1110
|
+
table = instance.refs.table;
|
|
1111
|
+
pagination = table.pagination.paginationRef;
|
|
1112
|
+
spy = sinon.spy();
|
|
1113
|
+
table.on('changePage', spy); // check all
|
|
1114
|
+
|
|
1115
|
+
table.checkAll();
|
|
1116
|
+
expect(table.getCheckedData()).to.have.length(10); // next page
|
|
1117
|
+
|
|
1118
|
+
table.set('pagination', {
|
|
1119
|
+
value: 2
|
|
1120
|
+
});
|
|
1121
|
+
table.trigger('$receive:pagination');
|
|
1122
|
+
_context26.next = 11;
|
|
1123
|
+
return wait();
|
|
1124
|
+
|
|
1125
|
+
case 11:
|
|
1126
|
+
expect(table.getCheckedData()).to.have.length(0); // check all again
|
|
1127
|
+
|
|
1128
|
+
table.checkAll();
|
|
1129
|
+
expect(table.getCheckedData()).to.have.length(10); // change limit
|
|
1130
|
+
|
|
1131
|
+
table.set('pagination', {
|
|
1132
|
+
value: 1,
|
|
1133
|
+
limit: 20
|
|
1134
|
+
});
|
|
1135
|
+
table.trigger('$receive:pagination');
|
|
1136
|
+
_context26.next = 18;
|
|
1137
|
+
return wait();
|
|
1138
|
+
|
|
1139
|
+
case 18:
|
|
1140
|
+
expect(table.getCheckedData()).to.have.length(10); // check all again
|
|
1141
|
+
|
|
1142
|
+
table.checkAll();
|
|
1143
|
+
expect(table.getCheckedData()).to.have.length(20); // change limit from pagination
|
|
1144
|
+
|
|
1145
|
+
pagination.value.set('limit', 10);
|
|
1146
|
+
_context26.next = 24;
|
|
1147
|
+
return wait();
|
|
1148
|
+
|
|
1149
|
+
case 24:
|
|
1150
|
+
expect(table.getCheckedData()).to.have.length(10); // FIXME: Pagination component should no trigger change event multiple times
|
|
1151
|
+
// when we set value and limit at the same time
|
|
1152
|
+
|
|
1153
|
+
expect(spy.callCount).to.eql(4);
|
|
1154
|
+
expect(spy.lastCall.lastArg).to.eql({
|
|
1155
|
+
value: 1,
|
|
1156
|
+
limit: 10
|
|
1157
|
+
}); // change page from pagination
|
|
1158
|
+
|
|
1159
|
+
_context26.next = 29;
|
|
1160
|
+
return wait();
|
|
1161
|
+
|
|
1162
|
+
case 29:
|
|
1163
|
+
pagination.value.changePage(2);
|
|
1164
|
+
expect(table.getCheckedData()).to.have.length(0);
|
|
1165
|
+
expect(spy.callCount).to.eql(5);
|
|
1166
|
+
expect(spy.lastCall.lastArg).to.eql({
|
|
1167
|
+
value: 2,
|
|
1168
|
+
limit: 10
|
|
1169
|
+
});
|
|
1170
|
+
|
|
1171
|
+
case 33:
|
|
1172
|
+
case "end":
|
|
1173
|
+
return _context26.stop();
|
|
1174
|
+
}
|
|
1175
|
+
}
|
|
1176
|
+
}, _callee23);
|
|
1177
|
+
})));
|
|
1067
1178
|
});
|
|
@@ -14,7 +14,7 @@ export interface TableRowProps {
|
|
|
14
14
|
index: number;
|
|
15
15
|
disabled: boolean;
|
|
16
16
|
allDisabled: boolean;
|
|
17
|
-
onChangeChecked: (index: number, checked: boolean) => void;
|
|
17
|
+
onChangeChecked: (index: number, checked: boolean, key: TableRowKey) => void;
|
|
18
18
|
grid: TableGrid;
|
|
19
19
|
selected: boolean;
|
|
20
20
|
spreaded: boolean;
|
|
@@ -56,9 +56,10 @@ export var TableRow = /*#__PURE__*/function (_Component) {
|
|
|
56
56
|
_proto.onChangeChecked = function onChangeChecked(v) {
|
|
57
57
|
var _this$get2 = this.get(),
|
|
58
58
|
index = _this$get2.index,
|
|
59
|
+
key = _this$get2.key,
|
|
59
60
|
onChangeChecked = _this$get2.onChangeChecked;
|
|
60
61
|
|
|
61
|
-
onChangeChecked(index, v);
|
|
62
|
+
onChangeChecked(index, v, key);
|
|
62
63
|
};
|
|
63
64
|
|
|
64
65
|
_proto.onClickArrow = function onClickArrow(e) {
|
|
@@ -92,7 +92,7 @@ setDefault(function () {
|
|
|
92
92
|
export function makeStyles() {
|
|
93
93
|
return /*#__PURE__*/css("font-size:", table.fontSize, ";color:", table.color, ";border-top:", table.border, ";position:relative;z-index:0;.k-table-wrapper{border-bottom:", table.border, ";overflow:auto;}table{width:100%;border-spacing:0;table-layout:fixed;td,th{transition:all ", table.transition, ";}}thead{text-align:", table.thead.textAlign, ";font-size:", table.thead.fontSize, ";font-weight:", table.thead.fontWeight, ";position:sticky;top:0;z-index:2;tr{height:", table.thead.height, ";}}th{padding:", table.thead.padding, ";position:relative;background:", table.thead.bgColor, ";border-bottom:", table.border, ";&:before{content:'';height:", table.thead.delimiterHeight, ";position:absolute;background-color:", table.thead.delimiterColor, ";width:1px;left:1px;top:50%;transform:translateY(-50%);}&:first-of-type:before{display:none;}}.k-table-title{display:inline-flex;align-items:center;max-width:100%;}.k-table-title-text{flex:1;}tbody{tr{&:hover td{background:", table.tbody.hoverBgcolor, ";}&:last-of-type td{border-bottom-color:transparent;}}}td{padding:", table.tbody.padding, ";border-bottom:", table.border, ";background:", table.bgColor, ";word-wrap:break-word;}.k-fixed-left,.k-fixed-right{position:sticky;z-index:1;&:after{content:'';display:block;transition:box-shadow ", table.transition, ";position:absolute;top:0;bottom:0px;width:10px;pointer-events:none;}}.k-fixed-left:after{right:-11px;}.k-fixed-right:after{left:-11px;}&.k-scroll-left .k-fixed-right:after{box-shadow:", table.fixRightShadow, ";}&.k-scroll-right .k-fixed-left:after{box-shadow:", table.fixLeftShadow, ";}&.k-scroll-middle{.k-fixed-left:after{box-shadow:", table.fixLeftShadow, ";}.k-fixed-right:after{box-shadow:", table.fixRightShadow, ";}}.k-fixed-right+.k-fixed-right:after{display:none;}.k-table-affix-header{position:sticky;top:0;left:0;.k-affix-wrapper{overflow:hidden;}&.k-fixed{position:relative;}}&.k-border,&.k-grid{.k-table-wrapper{border-left:", table.border, ";border-right:", table.border, ";}}&.k-grid{td:not(:last-of-type),th:not(:last-of-type){border-right:", table.border, ";}th:before{display:none;}}&.k-stripe{tr:nth-child(even):not(:hover) td{background:", table.stripeBgColor, ";}}.k-table-group{width:", table.group.width, "!important;height:", table.group.width, "!important;margin-left:", table.group.gap, ";position:relative;color:", table.group.color, ";&:hover{color:", theme.color.primary, ";}.k-icon{transition:transform ", table.transition, ";}&.k-dropdown-open .k-icon{transform:rotate(180deg);}}.k-table-check{.k-checkbox,.k-radio{position:relative;top:-1px;}}.k-column-sortable{cursor:pointer;}.k-column-sort{.k-icon{display:block;height:", _sortInstanceProperty(table).iconHeight, ";line-height:", _sortInstanceProperty(table).iconHeight, ";margin-left:", _sortInstanceProperty(table).gap, ";color:", _sortInstanceProperty(table).color, ";}&.k-asc .k-icon.k-desc,&.k-desc .k-icon.k-asc{color:", _sortInstanceProperty(table).disabledColor, ";}}.k-table-spin.k-overlay{z-index:2;}.k-table-empty{text-align:center;}tr.k-expand{td{padding:0;background:#fdfcff;}}&.k-with-expand{tr:not(.k-expand){td{border-bottom:none;}}}.k-table-expand{border-top:", table.border, ";box-sizing:content-box;}tbody tr.k-selected td{background:", table.selectedBgColor, ";}.k-table-arrow{margin-right:", table.arrow.gap, ";transition:transform ", table.transition, ";position:relative;top:-1px;}tr.k-spreaded{.k-table-arrow{transform:rotate(90deg);}}.k-table-resize{height:100%;width:", table.resizeWidth, ";position:absolute;top:0;left:-1px;cursor:ew-resize;}tr.k-dragging{opacity:", table.draggingOpacity, ";}.k-table-scrollbar{overflow-x:auto;overflow-y:hidden;}.k-table-scrollbar-inner{height:1px;}", _mapInstanceProperty(aligns).call(aligns, function (type) {
|
|
94
94
|
return /*#__PURE__*/css(".k-align-", type, "{text-align:", type, ";}");
|
|
95
|
-
}), ";");
|
|
95
|
+
}), ">.k-pagination{margin:16px 0;}");
|
|
96
96
|
}
|
|
97
97
|
export function makeGroupMenuStyles() {
|
|
98
98
|
return /*#__PURE__*/css("max-height:", table.group.menuMaxHeight, ";overflow:auto;.k-dropdown-item.k-active{color:", table.group.activeColor, ";}.k-table-group-header{padding:", table.group.headerPadding, ";border-bottom:", table.group.headerBorder, ";}");
|
|
@@ -2,6 +2,7 @@ import { Component, TypeDefs } from 'intact';
|
|
|
2
2
|
import { TableMerge } from './useMerge';
|
|
3
3
|
import { TooltipProps } from '../tooltip/tooltip';
|
|
4
4
|
import type { Events } from '../types';
|
|
5
|
+
import type { PaginationProps, PaginationChangeData } from '../pagination';
|
|
5
6
|
export interface TableProps<T = any, K extends TableRowKey = TableRowKey, C extends CheckType = CheckType, S extends string = string, G extends TableGroupValue = TableGroupValue> {
|
|
6
7
|
data?: T[];
|
|
7
8
|
fixHeader?: boolean | string | number;
|
|
@@ -35,6 +36,8 @@ export interface TableProps<T = any, K extends TableRowKey = TableRowKey, C exte
|
|
|
35
36
|
widthStoreKey?: string;
|
|
36
37
|
draggable?: boolean;
|
|
37
38
|
animation?: boolean | [boolean, boolean];
|
|
39
|
+
hideHeader?: boolean;
|
|
40
|
+
pagination?: boolean | PaginationProps;
|
|
38
41
|
}
|
|
39
42
|
export interface TableEvents<T = any, K extends TableRowKey = number> {
|
|
40
43
|
clickRow: [T, number, K];
|
|
@@ -47,6 +50,11 @@ export interface TableEvents<T = any, K extends TableRowKey = number> {
|
|
|
47
50
|
from: number;
|
|
48
51
|
to: number;
|
|
49
52
|
}];
|
|
53
|
+
checkRow: [T, number, K];
|
|
54
|
+
uncheckRow: [T, number, K];
|
|
55
|
+
checkAll: [];
|
|
56
|
+
uncheckAll: [];
|
|
57
|
+
changePage: [PaginationChangeData];
|
|
50
58
|
}
|
|
51
59
|
export interface TableBlocks<T = unknown> {
|
|
52
60
|
empty: null;
|
|
@@ -66,6 +74,13 @@ export declare class Table<T = any, RowKey extends TableRowKey = TableRowKey, Ch
|
|
|
66
74
|
static typeDefs: Required<TypeDefs<TableProps<unknown, TableRowKey, CheckType, string, TableGroupValue<string | number | symbol>>>>;
|
|
67
75
|
static defaults: () => Partial<TableProps<any, TableRowKey, CheckType, string, TableGroupValue<string | number | symbol>>>;
|
|
68
76
|
static events: Events<TableEvents<any, number>>;
|
|
77
|
+
pagination: {
|
|
78
|
+
data: import("../../hooks/useState").State<any[] | undefined>;
|
|
79
|
+
value: import("../../hooks/useState").State<number>;
|
|
80
|
+
limit: import("../../hooks/useState").State<number>;
|
|
81
|
+
onChange: (data: PaginationChangeData) => void;
|
|
82
|
+
paginationRef: import("intact").RefObject<import("../pagination").Pagination>;
|
|
83
|
+
};
|
|
69
84
|
private tree;
|
|
70
85
|
private columns;
|
|
71
86
|
private scroll;
|
|
@@ -25,6 +25,7 @@ import { useDraggable } from './useDraggable';
|
|
|
25
25
|
import { useStickyScrollbar } from './useStickyScrollbar';
|
|
26
26
|
import { useWidth } from './useWidth';
|
|
27
27
|
import { useScroll } from './useScroll';
|
|
28
|
+
import { usePagination } from './usePagination';
|
|
28
29
|
var typeDefs = {
|
|
29
30
|
data: Array,
|
|
30
31
|
fixHeader: [Boolean, String, Number],
|
|
@@ -57,7 +58,9 @@ var typeDefs = {
|
|
|
57
58
|
minColWidth: Number,
|
|
58
59
|
widthStoreKey: String,
|
|
59
60
|
draggable: Boolean,
|
|
60
|
-
animation: [Boolean, Array]
|
|
61
|
+
animation: [Boolean, Array],
|
|
62
|
+
hideHeader: Boolean,
|
|
63
|
+
pagination: [Boolean, Object]
|
|
61
64
|
};
|
|
62
65
|
|
|
63
66
|
var defaults = function defaults() {
|
|
@@ -78,7 +81,12 @@ var defaults = function defaults() {
|
|
|
78
81
|
var events = {
|
|
79
82
|
clickRow: true,
|
|
80
83
|
dragstart: true,
|
|
81
|
-
dragend: true
|
|
84
|
+
dragend: true,
|
|
85
|
+
checkRow: true,
|
|
86
|
+
uncheckRow: true,
|
|
87
|
+
checkAll: true,
|
|
88
|
+
uncheckAll: true,
|
|
89
|
+
changePage: true
|
|
82
90
|
};
|
|
83
91
|
export var Table = /*#__PURE__*/function (_Component) {
|
|
84
92
|
_inheritsLoose(Table, _Component);
|
|
@@ -93,21 +101,22 @@ export var Table = /*#__PURE__*/function (_Component) {
|
|
|
93
101
|
}
|
|
94
102
|
|
|
95
103
|
_this = _Component.call.apply(_Component, _concatInstanceProperty(_context = [this]).call(_context, args)) || this;
|
|
96
|
-
_this.
|
|
104
|
+
_this.pagination = usePagination();
|
|
105
|
+
_this.tree = useTree(_this.pagination.data);
|
|
97
106
|
_this.columns = useColumns();
|
|
98
107
|
_this.scroll = useScroll();
|
|
99
108
|
_this.stickyHeader = useStickyHeader(_this.scroll.callbacks);
|
|
100
109
|
_this.width = useWidth(_this.scroll.scrollRef, _this.columns.getColumns);
|
|
101
110
|
_this.resizable = useResizable(_this.scroll.scrollRef, _this.width.tableRef, _this.width.tableWidth, _this.width.widthMap, _this.width.storeWidth);
|
|
102
111
|
_this.fixedColumns = useFixedColumns(_this.columns.getColumns, _this.scroll, _this.width.widthMap);
|
|
103
|
-
_this.disableRow = useDisableRow(_this.tree.loopData);
|
|
104
|
-
_this.merge = useMerge(_this.columns.getCols);
|
|
105
|
-
_this.checked = useChecked(_this.disableRow.getEnableKeys, _this.disableRow.getAllKeys, _this.disableRow.isDisabledKey, _this.merge.getGrid, _this.tree.loopData);
|
|
112
|
+
_this.disableRow = useDisableRow(_this.tree.loopData, _this.pagination.data);
|
|
113
|
+
_this.merge = useMerge(_this.columns.getCols, _this.pagination.data);
|
|
114
|
+
_this.checked = useChecked(_this.disableRow.getEnableKeys, _this.disableRow.getAllKeys, _this.disableRow.isDisabledKey, _this.merge.getGrid, _this.tree.loopData, _this.pagination.data);
|
|
106
115
|
_this.sortable = useSortable();
|
|
107
116
|
_this.expandable = useExpandable();
|
|
108
117
|
_this.selected = useSelected();
|
|
109
118
|
_this.resetRowStatus = useRestRowStatus(_this.disableRow.getAllKeys);
|
|
110
|
-
_this.draggable = useDraggable();
|
|
119
|
+
_this.draggable = useDraggable(_this.pagination.data);
|
|
111
120
|
_this.stickyScrollbar = useStickyScrollbar(_this.stickyHeader.elementRef, _this.scroll, _this.width.tableRef, _this.fixedColumns.setScrollPosition);
|
|
112
121
|
return _this;
|
|
113
122
|
}
|
|
@@ -3,7 +3,7 @@ import _sortInstanceProperty from "@babel/runtime-corejs3/core-js/instance/sort"
|
|
|
3
3
|
import { createElementVNode as _$ce, map as _$ma, className as _$cn, createUnknownComponentVNode as _$cc, createVNode as _$cv, noop as _$no, extend as _$ex, EMPTY_OBJ as _$em } from 'intact';
|
|
4
4
|
import { eachChildren } from '../utils';
|
|
5
5
|
import { makeStyles } from './styles';
|
|
6
|
-
import { isStringOrNumber, isNull } from 'intact-shared';
|
|
6
|
+
import { isStringOrNumber, isNull, isObject, EMPTY_OBJ } from 'intact-shared';
|
|
7
7
|
import { getClassAndStyleForFixed } from './useFixedColumns';
|
|
8
8
|
import { Affix } from '../affix';
|
|
9
9
|
import { TableRow } from './row';
|
|
@@ -19,6 +19,7 @@ import { Tooltip } from '../tooltip';
|
|
|
19
19
|
import { AllCheckedStatus } from './useChecked';
|
|
20
20
|
import { context as ResizableContext } from './useResizable';
|
|
21
21
|
import { context as FixedColumnsContext } from './useFixedColumns';
|
|
22
|
+
import { Pagination } from '../pagination';
|
|
22
23
|
var _$tmp0 = {
|
|
23
24
|
'width': '40'
|
|
24
25
|
};
|
|
@@ -58,7 +59,9 @@ export default function ($props, $blocks, $__proto__) {
|
|
|
58
59
|
showIndeterminate = _this$get.showIndeterminate,
|
|
59
60
|
resizable = _this$get.resizable,
|
|
60
61
|
draggable = _this$get.draggable,
|
|
61
|
-
_animation = _this$get.animation
|
|
62
|
+
_animation = _this$get.animation,
|
|
63
|
+
hideHeader = _this$get.hideHeader,
|
|
64
|
+
pagination = _this$get.pagination;
|
|
62
65
|
|
|
63
66
|
var animation = !Array.isArray(_animation) ? [_animation, _animation] : _animation;
|
|
64
67
|
|
|
@@ -112,8 +115,7 @@ export default function ($props, $blocks, $__proto__) {
|
|
|
112
115
|
onChangeChecked = _this$checked.onChangeChecked;
|
|
113
116
|
var allCheckedStatus = getAllCheckedStatus();
|
|
114
117
|
var offsetMap = getOffsetMap();
|
|
115
|
-
|
|
116
|
-
var thead = _$cc(TableContext.Provider, {
|
|
118
|
+
var thead = hideHeader ? null : _$cc(TableContext.Provider, {
|
|
117
119
|
'value': checkType,
|
|
118
120
|
'children': _$cc(GroupContext.Provider, {
|
|
119
121
|
'value': {
|
|
@@ -157,7 +159,6 @@ export default function ($props, $blocks, $__proto__) {
|
|
|
157
159
|
})
|
|
158
160
|
})
|
|
159
161
|
});
|
|
160
|
-
|
|
161
162
|
var getAllKeys = this.disableRow.getAllKeys;
|
|
162
163
|
var getGrid = this.merge.getGrid;
|
|
163
164
|
var allStatus = getAllStatus();
|
|
@@ -306,6 +307,11 @@ export default function ($props, $blocks, $__proto__) {
|
|
|
306
307
|
scrollbarRef = _this$stickyScrollbar.scrollbarRef,
|
|
307
308
|
onScrollbarScroll = _this$stickyScrollbar.onScroll,
|
|
308
309
|
tableActualWidth = _this$stickyScrollbar.tableActualWidth;
|
|
310
|
+
var _this$pagination = this.pagination,
|
|
311
|
+
pageValue = _this$pagination.value,
|
|
312
|
+
pageLimit = _this$pagination.limit,
|
|
313
|
+
onPageChange = _this$pagination.onChange,
|
|
314
|
+
paginationRef = _this$pagination.paginationRef;
|
|
309
315
|
return _$ce(2, 'div', [_$ce(2, 'div', [!isNull(stickHeader.value) ? _$cc(Affix, {
|
|
310
316
|
'top': stickHeader.value,
|
|
311
317
|
'exclude': excludeStickHeader,
|
|
@@ -321,7 +327,15 @@ export default function ($props, $blocks, $__proto__) {
|
|
|
321
327
|
}
|
|
322
328
|
}, null, tableRef)], 0, 'k-table-wrapper', {
|
|
323
329
|
'style': style
|
|
324
|
-
}, null, scrollRef), _$cc(
|
|
330
|
+
}, null, scrollRef), pagination ? _$cc(Pagination, _extends({
|
|
331
|
+
'ref': paginationRef,
|
|
332
|
+
'total': data ? data.length : 0,
|
|
333
|
+
'size': 'small'
|
|
334
|
+
}, isObject(pagination) ? pagination : EMPTY_OBJ, {
|
|
335
|
+
'value': pageValue.value,
|
|
336
|
+
'limit': pageLimit.value,
|
|
337
|
+
'ev-change': onPageChange
|
|
338
|
+
}), null, paginationRef) : undefined, _$cc(Transition, {
|
|
325
339
|
'name': 'k-fade',
|
|
326
340
|
'children': loading ? _$cc(Spin, _$tmp1) : undefined
|
|
327
341
|
}), !isNull(stickScrollbar.value) ? _$cc(Affix, {
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { State } from '../../hooks/useState';
|
|
1
2
|
import type { TableRowKey } from './';
|
|
2
3
|
import type { TableGrid } from './useMerge';
|
|
3
4
|
import type { useTree } from './useTree';
|
|
@@ -12,12 +13,12 @@ export declare enum AllCheckedStatus {
|
|
|
12
13
|
Indeterminate = 1,
|
|
13
14
|
None = 2
|
|
14
15
|
}
|
|
15
|
-
export declare function useChecked(getEnableKeys: () => TableRowKey[], getAllKeys: () => TableRowKey[], isDisabledKey: (key: TableRowKey) => boolean, getGrid: () => TableGrid, loopData: ReturnType<typeof useTree>['loopData']): {
|
|
16
|
+
export declare function useChecked(getEnableKeys: () => TableRowKey[], getAllKeys: () => TableRowKey[], isDisabledKey: (key: TableRowKey) => boolean, getGrid: () => TableGrid, loopData: ReturnType<typeof useTree>['loopData'], data: State<any[] | undefined>): {
|
|
16
17
|
isChecked: (key: TableRowKey) => boolean;
|
|
17
18
|
getAllCheckedStatus: () => AllCheckedStatus;
|
|
18
19
|
toggleCheckedAll: (v: boolean) => void;
|
|
19
20
|
getAllStatus: () => RowStatus[];
|
|
20
|
-
onChangeChecked: (rowIndex: number, v: boolean) => void;
|
|
21
|
+
onChangeChecked: (rowIndex: number, v: boolean, key: TableRowKey) => void;
|
|
21
22
|
};
|
|
22
23
|
export declare function inArray<T>(arr: T[] | undefined, v: T): boolean;
|
|
23
24
|
export declare function addOrRemove(keys: TableRowKey[], key: TableRowKey, isAdd: boolean): void;
|
|
@@ -2,6 +2,7 @@ import _includesInstanceProperty from "@babel/runtime-corejs3/core-js/instance/i
|
|
|
2
2
|
import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js/instance/slice";
|
|
3
3
|
import _spliceInstanceProperty from "@babel/runtime-corejs3/core-js/instance/splice";
|
|
4
4
|
import { useInstance } from 'intact';
|
|
5
|
+
import { watchState } from '../../hooks/useState';
|
|
5
6
|
import { toggleArray } from '../utils';
|
|
6
7
|
export var AllCheckedStatus;
|
|
7
8
|
|
|
@@ -11,7 +12,7 @@ export var AllCheckedStatus;
|
|
|
11
12
|
AllCheckedStatus[AllCheckedStatus["None"] = 2] = "None";
|
|
12
13
|
})(AllCheckedStatus || (AllCheckedStatus = {}));
|
|
13
14
|
|
|
14
|
-
export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, loopData) {
|
|
15
|
+
export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, loopData, data) {
|
|
15
16
|
var instance = useInstance();
|
|
16
17
|
var allStatus = [];
|
|
17
18
|
|
|
@@ -21,7 +22,10 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
21
22
|
|
|
22
23
|
function toggleChecked(key, rowIndex) {
|
|
23
24
|
if (instance.get('checkType') === 'checkbox') {
|
|
24
|
-
instance.set('checkedKeys', toggleArray(instance.get('checkedKeys'), key));
|
|
25
|
+
instance.set('checkedKeys', toggleArray(instance.get('checkedKeys'), key)); // trigger check event for checkbox,
|
|
26
|
+
// radio check event trigger in onChangeChecked function
|
|
27
|
+
|
|
28
|
+
triggerEvent(isChecked(key), key, rowIndex);
|
|
25
29
|
} else {
|
|
26
30
|
if (isChecked(key)) return;
|
|
27
31
|
var grid = getGrid();
|
|
@@ -34,7 +38,7 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
34
38
|
}
|
|
35
39
|
}
|
|
36
40
|
|
|
37
|
-
onChangeChecked(rowIndex, true);
|
|
41
|
+
onChangeChecked(rowIndex, true, key);
|
|
38
42
|
}
|
|
39
43
|
}
|
|
40
44
|
|
|
@@ -61,6 +65,7 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
61
65
|
|
|
62
66
|
function toggleCheckedAll(v) {
|
|
63
67
|
instance.set('checkedKeys', getCheckedAllOrUncheckedAllKeys(v));
|
|
68
|
+
instance.trigger(v ? 'checkAll' : 'uncheckAll');
|
|
64
69
|
}
|
|
65
70
|
/**
|
|
66
71
|
* keep the original keys which don't exist in the enableKeys,
|
|
@@ -92,12 +97,11 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
92
97
|
allStatus = [];
|
|
93
98
|
|
|
94
99
|
var _instance$get2 = instance.get(),
|
|
95
|
-
data = _instance$get2.data,
|
|
96
100
|
rowKey = _instance$get2.rowKey,
|
|
97
101
|
checkType = _instance$get2.checkType,
|
|
98
102
|
merge = _instance$get2.merge;
|
|
99
103
|
|
|
100
|
-
if (!data || !data.length) return;
|
|
104
|
+
if (!data.value || !data.value.length) return;
|
|
101
105
|
var allKeys = getAllKeys();
|
|
102
106
|
allKeys.forEach(function (key) {
|
|
103
107
|
var disabled = isDisabledKey(key);
|
|
@@ -161,7 +165,7 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
161
165
|
}
|
|
162
166
|
}
|
|
163
167
|
|
|
164
|
-
function onChangeChecked(rowIndex, v) {
|
|
168
|
+
function onChangeChecked(rowIndex, v, key) {
|
|
165
169
|
var _context;
|
|
166
170
|
|
|
167
171
|
// should check or uncheck all grouped rows
|
|
@@ -172,9 +176,9 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
172
176
|
|
|
173
177
|
if (checkType === 'radio') {
|
|
174
178
|
for (var i = 0; i < checkedKeys.length; i++) {
|
|
175
|
-
var
|
|
179
|
+
var _key = checkedKeys[i]; // FIXME: should ignore the disabled status, if we remove the radio keys
|
|
176
180
|
|
|
177
|
-
if (isDisabledKey(
|
|
181
|
+
if (isDisabledKey(_key)) continue;
|
|
178
182
|
|
|
179
183
|
_spliceInstanceProperty(checkedKeys).call(checkedKeys, i, 1);
|
|
180
184
|
|
|
@@ -189,27 +193,34 @@ export function useChecked(getEnableKeys, getAllKeys, isDisabledKey, getGrid, lo
|
|
|
189
193
|
if ((rowspan = grid[rowIndex]) && (rowspan = rowspan[0]) && (rowspan = rowspan.spans) && (rowspan = rowspan.rowspan) && rowspan > 1) {
|
|
190
194
|
for (var _i = rowIndex; _i < rowspan + rowIndex; _i++) {
|
|
191
195
|
var status = allStatus[_i];
|
|
192
|
-
var
|
|
196
|
+
var _key2 = allKeys[_i];
|
|
193
197
|
|
|
194
198
|
if (!status.disabled) {
|
|
195
|
-
addOrRemove(checkedKeys,
|
|
199
|
+
addOrRemove(checkedKeys, _key2, v);
|
|
196
200
|
}
|
|
197
201
|
}
|
|
198
202
|
} else {
|
|
199
203
|
addOrRemove(checkedKeys, allKeys[rowIndex], v);
|
|
200
204
|
}
|
|
201
205
|
|
|
202
|
-
instance.set('checkedKeys', checkedKeys);
|
|
206
|
+
instance.set('checkedKeys', checkedKeys); // onChangeChecked will be called in clickRow and check in Row component
|
|
207
|
+
|
|
208
|
+
triggerEvent(v, key, rowIndex);
|
|
203
209
|
}
|
|
204
210
|
|
|
205
211
|
function getAllStatus() {
|
|
206
212
|
return allStatus;
|
|
207
213
|
}
|
|
208
214
|
|
|
215
|
+
function triggerEvent(isChecked, key, rowIndex) {
|
|
216
|
+
instance.trigger(isChecked ? 'checkRow' : 'uncheckRow', data.value[rowIndex], rowIndex, key);
|
|
217
|
+
}
|
|
218
|
+
|
|
209
219
|
instance.on('$receive:children', updateAllCheckedStatus);
|
|
210
220
|
instance.on('$change:checkedKeys', updateAllCheckedStatus); // for draggable
|
|
211
221
|
|
|
212
|
-
instance.on('$change:data', updateAllCheckedStatus);
|
|
222
|
+
watchState(data, updateAllCheckedStatus); // instance.on('$change:data', updateAllCheckedStatus);
|
|
223
|
+
|
|
213
224
|
instance.on('clickRow', function (data, index, key) {
|
|
214
225
|
if (instance.get('rowCheckable') && instance.get('checkType') !== 'none') {
|
|
215
226
|
toggleChecked(key, index);
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { TableRowKey } from './table';
|
|
2
2
|
import type { useTree } from './useTree';
|
|
3
|
-
|
|
3
|
+
import { State } from '../../hooks/useState';
|
|
4
|
+
export declare function useDisableRow(loopData: ReturnType<typeof useTree>['loopData'], data: State<any[] | undefined>): {
|
|
4
5
|
isDisabled: (data: any, index: number, key: TableRowKey) => boolean;
|
|
5
6
|
getEnableKeys: () => TableRowKey[];
|
|
6
7
|
isDisabledKey: (key: TableRowKey) => boolean;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { useInstance } from 'intact';
|
|
2
|
-
|
|
2
|
+
import { watchState } from '../../hooks/useState';
|
|
3
|
+
export function useDisableRow(loopData, data) {
|
|
3
4
|
var instance = useInstance();
|
|
4
5
|
var enabledKeys = [];
|
|
5
6
|
var disabledKeys = [];
|
|
@@ -45,9 +46,8 @@ export function useDisableRow(loopData) {
|
|
|
45
46
|
return allKeys;
|
|
46
47
|
}
|
|
47
48
|
|
|
48
|
-
instance.on('$receive:children', setDisabledKeys);
|
|
49
|
-
|
|
50
|
-
instance.on('$change:data', setDisabledKeys);
|
|
49
|
+
instance.on('$receive:children', setDisabledKeys);
|
|
50
|
+
watchState(data, setDisabledKeys);
|
|
51
51
|
return {
|
|
52
52
|
isDisabled: isDisabled,
|
|
53
53
|
getEnableKeys: getEnableKeys,
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import type { TableRowKey } from './table';
|
|
2
|
+
import { State } from '../../hooks/useState';
|
|
2
3
|
import type { TableRow } from './row';
|
|
3
|
-
export declare function useDraggable(): {
|
|
4
|
+
export declare function useDraggable(data: State<unknown[] | undefined>): {
|
|
4
5
|
onRowDragStart: (e: MouseEvent, tableRow: TableRow) => void;
|
|
5
6
|
onRowDragOver: (e: MouseEvent, tableRow: TableRow) => void;
|
|
6
7
|
onRowDragEnd: (e: MouseEvent, tableRow: TableRow) => void;
|
|
7
|
-
draggingKey:
|
|
8
|
+
draggingKey: State<TableRowKey | null>;
|
|
8
9
|
};
|