@king-design/react 2.0.0-beta.1 → 2.0.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 (136) hide show
  1. package/__tests__/__snapshots__/React Demos.md +317 -291
  2. package/__tests__/index.ts +5 -2
  3. package/__tests__/karma.conf.js +1 -1
  4. package/components/breadcrumb/item.d.ts +1 -1
  5. package/components/breadcrumb/item.js +3 -14
  6. package/components/breadcrumb/styles.js +1 -1
  7. package/components/button/index.vdt.js +26 -17
  8. package/components/button/styles.d.ts +82 -1
  9. package/components/button/styles.js +16 -2
  10. package/components/card/styles.js +1 -1
  11. package/components/carousel/styles.js +4 -1
  12. package/components/carousel/useSlide.js +10 -9
  13. package/components/cascader/index.spec.js +1 -1
  14. package/components/checkbox/index.vdt.js +15 -10
  15. package/components/checkbox/styles.js +2 -2
  16. package/components/collapse/item.vdt.js +2 -1
  17. package/components/collapse/styles.js +5 -1
  18. package/components/colorpicker/index.d.ts +2 -0
  19. package/components/colorpicker/index.js +2 -1
  20. package/components/colorpicker/index.spec.js +1 -1
  21. package/components/colorpicker/index.vdt.js +3 -1
  22. package/components/context.d.ts +5 -2
  23. package/components/context.js +7 -4
  24. package/components/datepicker/helpers.d.ts +2 -1
  25. package/components/datepicker/helpers.js +8 -2
  26. package/components/datepicker/index.spec.js +1 -1
  27. package/components/datepicker/styles.d.ts +46 -1
  28. package/components/diagram/shapes/generateShapes.js +3 -3
  29. package/components/diagram/shapes/line.d.ts +2 -2
  30. package/components/diagram/shapes/line.js +0 -1
  31. package/components/dialog/base.d.ts +2 -0
  32. package/components/dialog/base.js +2 -1
  33. package/components/dialog/index.spec.js +59 -94
  34. package/components/dialog/styles.js +5 -1
  35. package/components/dialog/useFixBody.d.ts +6 -0
  36. package/components/dialog/useFixBody.js +12 -0
  37. package/components/drawer/index.spec.js +5 -5
  38. package/components/drawer/styles.js +1 -1
  39. package/components/dropdown/index.js +1 -2
  40. package/components/dropdown/index.spec.js +3 -3
  41. package/components/dropdown/styles.js +1 -1
  42. package/components/editable/index.vdt.js +2 -1
  43. package/components/editable/styles.d.ts +8 -1
  44. package/components/form/index.spec.js +8 -8
  45. package/components/form/item.vdt.js +13 -9
  46. package/components/form/useError.d.ts +5 -1
  47. package/components/form/useError.js +3 -1
  48. package/components/form/useValidate.js +2 -2
  49. package/components/grid/col.vdt.js +4 -2
  50. package/components/grid/styles.js +1 -1
  51. package/components/grid/useGutter.d.ts +1 -1
  52. package/components/icon/index.vdt.js +3 -2
  53. package/components/icon/styles.js +8 -4
  54. package/components/input/index.d.ts +1 -0
  55. package/components/input/index.js +2 -1
  56. package/components/input/index.vdt.js +47 -32
  57. package/components/input/search.vdt.js +4 -2
  58. package/components/input/styles.js +8 -3
  59. package/components/layout/styles.d.ts +1 -1
  60. package/components/layout/styles.js +7 -3
  61. package/components/menu/index.spec.js +2 -2
  62. package/components/menu/item.d.ts +1 -1
  63. package/components/menu/item.js +4 -13
  64. package/components/menu/styles.d.ts +62 -1
  65. package/components/menu/styles.js +6 -2
  66. package/components/message/index.spec.js +1 -1
  67. package/components/message/styles.js +6 -2
  68. package/components/pagination/styles.js +1 -1
  69. package/components/radio/index.vdt.js +14 -9
  70. package/components/radio/styles.js +9 -1
  71. package/components/rate/styles.js +5 -1
  72. package/components/scrollSelect/styles.d.ts +14 -1
  73. package/components/scrollSelect/styles.js +9 -1
  74. package/components/select/base.vdt.js +135 -121
  75. package/components/select/index.spec.js +1 -1
  76. package/components/select/menu.vdt.js +1 -0
  77. package/components/select/styles.js +9 -4
  78. package/components/select/useSearchable.d.ts +1 -1
  79. package/components/slider/styles.js +5 -1
  80. package/components/spinner/index.d.ts +1 -1
  81. package/components/spinner/index.js +1 -1
  82. package/components/split/style.js +1 -1
  83. package/components/steps/context.d.ts +1 -1
  84. package/components/steps/styles.js +5 -1
  85. package/components/switch/styles.js +5 -1
  86. package/components/table/index.d.ts +1 -0
  87. package/components/table/index.spec.js +2 -1
  88. package/components/table/row.vdt.js +12 -4
  89. package/components/table/styles.js +6 -1
  90. package/components/table/table.d.ts +1 -0
  91. package/components/table/table.js +2 -1
  92. package/components/table/table.vdt.js +30 -27
  93. package/components/table/useColumns.d.ts +1 -1
  94. package/components/table/useFixedColumns.d.ts +1 -1
  95. package/components/table/useFixedColumns.js +5 -2
  96. package/components/table/useGroup.d.ts +1 -1
  97. package/components/table/useResizable.d.ts +1 -1
  98. package/components/table/useSortable.d.ts +1 -1
  99. package/components/table/useWidth.js +7 -1
  100. package/components/tabs/index.spec.js +1 -1
  101. package/components/tabs/styles.js +9 -2
  102. package/components/tabs/tab.vdt.js +2 -1
  103. package/components/tabs/useActiveBar.js +6 -3
  104. package/components/tag/base.js +1 -0
  105. package/components/tag/styles.js +8 -2
  106. package/components/timepicker/constants.d.ts +2 -1
  107. package/components/timepicker/constants.js +3 -2
  108. package/components/timepicker/index.spec.js +36 -35
  109. package/components/timepicker/useStep.js +3 -3
  110. package/components/timepicker/useValue.js +2 -2
  111. package/components/tooltip/index.spec.js +28 -24
  112. package/components/transfer/index.spec.js +20 -19
  113. package/components/tree/index.d.ts +1 -1
  114. package/components/tree/index.js +1 -1
  115. package/components/tree/index.spec.js +20 -19
  116. package/components/tree/index.vdt.js +1 -0
  117. package/components/tree/styles.js +5 -1
  118. package/components/treeSelect/index.spec.js +5 -5
  119. package/components/treeSelect/styles.js +5 -1
  120. package/components/upload/index.d.ts +1 -1
  121. package/components/upload/index.spec.js +1 -1
  122. package/components/upload/index.vdt.js +10 -11
  123. package/components/upload/styles.js +5 -1
  124. package/components/utils.d.ts +1 -1
  125. package/components/wave/index.d.ts +19 -0
  126. package/components/wave/index.js +120 -0
  127. package/components/wave/styles.d.ts +2 -0
  128. package/components/wave/styles.js +17 -0
  129. package/hooks/useRouter.d.ts +1 -0
  130. package/hooks/useRouter.js +10 -0
  131. package/index.d.ts +3 -2
  132. package/index.js +3 -2
  133. package/package.json +2 -2
  134. package/styles/global.js +4 -3
  135. package/styles/theme.d.ts +16 -7
  136. package/styles/theme.js +15 -7
@@ -18,7 +18,7 @@ describe('Timepicker', function () {
18
18
  case 0:
19
19
  unmount();
20
20
  _context.next = 3;
21
- return wait(400);
21
+ return wait(500);
22
22
 
23
23
  case 3:
24
24
  case "end":
@@ -34,106 +34,107 @@ describe('Timepicker', function () {
34
34
  while (1) {
35
35
  switch (_context2.prev = _context2.next) {
36
36
  case 0:
37
+ this.timeout(0);
37
38
  _mount = mount(BasicDemo), instance = _mount[0], element = _mount[1];
38
39
  _element$querySelecto = element.querySelectorAll('.k-select'), picker1 = _element$querySelecto[0], picker2 = _element$querySelecto[1];
39
40
  picker1.click();
40
- _context2.next = 5;
41
- return wait(300);
41
+ _context2.next = 6;
42
+ return wait(500);
42
43
 
43
- case 5:
44
+ case 6:
44
45
  dropdown = getElement('.k-time-content');
45
46
  expect(dropdown.innerHTML).to.matchSnapshot();
46
47
  next = dropdown.querySelector('.k-scroll-select-item:nth-child(11)');
47
48
  next.click();
48
- _context2.next = 11;
49
+ _context2.next = 12;
49
50
  return wait();
50
51
 
51
- case 11:
52
+ case 12:
52
53
  expect(dropdown.innerHTML).to.matchSnapshot();
53
54
  expect(instance.get('time')).to.be.null;
54
55
  next.click();
55
- _context2.next = 16;
56
+ _context2.next = 17;
56
57
  return wait();
57
58
 
58
- case 16:
59
+ case 17:
59
60
  expect(instance.get('time')).to.be.null;
60
61
  expect(dropdown.innerHTML).to.matchSnapshot();
61
62
  ok = dropdown.querySelector('.k-btn');
62
63
  ok.click();
63
- _context2.next = 22;
64
- return wait(300);
64
+ _context2.next = 23;
65
+ return wait(500);
65
66
 
66
- case 22:
67
+ case 23:
67
68
  expect(instance.get('time')).to.eql('02:00:00');
68
69
  expect(dropdown.style.display).to.eql('none'); // set time
69
70
 
70
71
  instance.set('time', '03:03:03');
71
72
  picker1.click();
72
- _context2.next = 28;
73
- return wait(300);
73
+ _context2.next = 29;
74
+ return wait(500);
74
75
 
75
- case 28:
76
+ case 29:
76
77
  expect(dropdown.innerHTML).to.matchSnapshot(); // multiple
77
78
 
78
79
  picker2.click();
79
- _context2.next = 32;
80
- return wait(300);
80
+ _context2.next = 33;
81
+ return wait(500);
81
82
 
82
- case 32:
83
+ case 33:
83
84
  dropdown = getElement('.k-time-content');
84
85
  dropdown.querySelector('.k-scroll-select-item:nth-child(11)').click();
85
86
  ok2 = dropdown.querySelector('.k-btn');
86
87
  ok2.click();
87
88
  dropdown.querySelector('.k-scroll-select-item:nth-child(12)').click();
88
89
  ok2.click();
89
- _context2.next = 40;
90
+ _context2.next = 41;
90
91
  return wait();
91
92
 
92
- case 40:
93
+ case 41:
93
94
  expect(instance.get('timeArray')).to.eql(['01:00:00', '02:00:00']); // click the same time will do nothing
94
95
 
95
96
  ok2.click();
96
- _context2.next = 44;
97
+ _context2.next = 45;
97
98
  return wait();
98
99
 
99
- case 44:
100
+ case 45:
100
101
  expect(instance.get('timeArray')).to.eql(['01:00:00', '02:00:00']); // remove one value
101
102
 
102
103
  _picker2$querySelecto = picker2.querySelectorAll('.k-select-close'), close = _picker2$querySelecto[1];
103
104
  close.click();
104
- _context2.next = 49;
105
+ _context2.next = 50;
105
106
  return wait();
106
107
 
107
- case 49:
108
+ case 50:
108
109
  expect(instance.get('timeArray')).to.eql(['01:00:00']);
109
110
  expect(dropdown.innerHTML).to.matchSnapshot(); // clear
110
111
 
111
112
  picker2.querySelector('.k-select-clear').click();
112
- _context2.next = 54;
113
+ _context2.next = 55;
113
114
  return wait();
114
115
 
115
- case 54:
116
+ case 55:
116
117
  expect(instance.get('timeArray')).to.eql([]);
117
118
  ok2.click();
118
- _context2.next = 58;
119
+ _context2.next = 59;
119
120
  return wait();
120
121
 
121
- case 58:
122
+ case 59:
122
123
  expect(instance.get('timeArray')).to.eql(['00:00:00']); // set value
123
124
 
124
125
  instance.set('timeArray', ['03:03:03', '03:03:04']);
125
- _context2.next = 62;
126
+ _context2.next = 63;
126
127
  return wait();
127
128
 
128
- case 62:
129
+ case 63:
129
130
  expect(dropdown.innerHTML).to.matchSnapshot();
130
131
 
131
- case 63:
132
+ case 64:
132
133
  case "end":
133
134
  return _context2.stop();
134
135
  }
135
136
  }
136
- }, _callee2);
137
+ }, _callee2, this);
137
138
  })));
138
139
  it('range', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3() {
139
140
  var _mount2, instance, element, picker, dropdown, _dropdown$querySelect, start, end;
@@ -146,7 +147,7 @@ describe('Timepicker', function () {
146
147
  picker = element.querySelector('.k-select');
147
148
  picker.click();
148
149
  _context3.next = 5;
149
- return wait(300);
150
+ return wait(500);
150
151
 
151
152
  case 5:
152
153
  dropdown = getElement('.k-time-content');
@@ -169,7 +170,7 @@ describe('Timepicker', function () {
169
170
  return wait();
170
171
 
171
172
  case 19:
172
- expect(instance.get('time')).to.eql(['01:00:00', '02:00:00']);
173
+ expect(instance.get('time')).to.eql(['01:00:00', '01:59:59']);
173
174
 
174
175
  case 20:
175
176
  case "end":
@@ -227,7 +228,7 @@ describe('Timepicker', function () {
227
228
 
228
229
  case 11:
229
230
  expect(dropdown.innerHTML).to.matchSnapshot();
230
- end.querySelector('.k-active').nextElementSibling.click();
231
+ end.querySelector('.k-disabled').nextElementSibling.click();
231
232
  _context5.next = 15;
232
233
  return wait();
233
234
 
@@ -306,7 +307,7 @@ describe('Timepicker', function () {
306
307
  return wait();
307
308
 
308
309
  case 39:
309
- expect(instance.get('time3')).eql(['00:30:00.000', '01:00:00.000']);
310
+ expect(instance.get('time3')).eql(['00:30:00.000', '00:30:00.000']);
310
311
  expect(input3.innerHTML).to.matchSnapshot();
311
312
 
312
313
  case 41:
@@ -1,7 +1,7 @@
1
1
  import _mapInstanceProperty from "@babel/runtime-corejs3/core-js/instance/map";
2
2
  import { useInstance } from 'intact-react';
3
3
  import { useState } from '../../hooks/useState';
4
- import { NOW } from './constants';
4
+ import { NOW_START, NOW_END } from './constants';
5
5
  import { useReceive } from '../../hooks/useReceive';
6
6
  export function useStep(_ref, _ref2) {
7
7
  var maxDate = _ref.maxDate,
@@ -18,9 +18,9 @@ export function useStep(_ref, _ref2) {
18
18
 
19
19
  if (step) {
20
20
  var data = [];
21
- var maxValue = maxDate.value || NOW.hour(23).minute(59).second(59);
21
+ var maxValue = maxDate.value || NOW_END;
22
22
  var stepValue = parseTime(step);
23
- var value = minDate.value || NOW;
23
+ var value = minDate.value || NOW_START;
24
24
 
25
25
  var push = function push(value) {
26
26
  data.push({
@@ -5,7 +5,7 @@ import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js/instance/slic
5
5
  import { useInstance } from 'intact-react';
6
6
  import { last } from '../utils';
7
7
  import { useValue as useValueBase } from '../datepicker/basepicker';
8
- import { NOW } from './constants';
8
+ import { NOW_START, NOW_END } from './constants';
9
9
  export function useValue(formats, disabled, panel) {
10
10
  var instance = useInstance();
11
11
 
@@ -34,7 +34,7 @@ export function useValue(formats, disabled, panel) {
34
34
  });
35
35
 
36
36
  function getPlaceholderDates() {
37
- return instance.get('range') ? [NOW, NOW] : NOW;
37
+ return instance.get('range') ? [NOW_START, NOW_END] : NOW_START;
38
38
  }
39
39
 
40
40
  function onChangeTimeByStep(v, flag) {
@@ -3,6 +3,7 @@ import _asyncToGenerator from "@babel/runtime-corejs3/helpers/asyncToGenerator";
3
3
  import _regeneratorRuntime from "@babel/runtime-corejs3/regenerator";
4
4
  import _Array$from2 from "@babel/runtime-corejs3/core-js/array/from";
5
5
  import _concatInstanceProperty from "@babel/runtime-corejs3/core-js/instance/concat";
6
+ import _JSON$stringify from "@babel/runtime-corejs3/core-js/json/stringify";
6
7
  import { findDomFromVNode, Component } from 'intact-react';
7
8
  import BasicDemo from '~/components/tooltip/demos/basic';
8
9
  import PositionDemo from '~/components/tooltip/demos/position';
@@ -52,7 +53,7 @@ describe('Tooltip', function () {
52
53
 
53
54
  dispatchEvent(first, 'mouseleave');
54
55
  _context.next = 20;
55
- return wait(400);
56
+ return wait(600);
56
57
 
57
58
  case 20:
58
59
  expect(content.style.display).to.eql('none');
@@ -208,7 +209,7 @@ describe('Tooltip', function () {
208
209
 
209
210
  document.body.click();
210
211
  _context3.next = 15;
211
- return wait(300);
212
+ return wait(500);
212
213
 
213
214
  case 15:
214
215
  expect(content.style.display).to.eql('none');
@@ -227,40 +228,41 @@ describe('Tooltip', function () {
227
228
  while (1) {
228
229
  switch (_context4.prev = _context4.next) {
229
230
  case 0:
231
+ this.timeout(0);
230
232
  _mount4 = mount(TriggerDemo), element = _mount4[1];
231
233
  _Array$from3 = _Array$from2(element.querySelectorAll('.k-btn')), canHover = _Array$from3[2];
232
234
  dispatchEvent(canHover, 'mouseenter');
233
- _context4.next = 5;
235
+ _context4.next = 6;
234
236
  return wait();
235
237
 
236
- case 5:
238
+ case 6:
237
239
  dispatchEvent(canHover, 'mouseleave');
238
- _context4.next = 8;
239
- return wait(300);
240
+ _context4.next = 9;
241
+ return wait(500);
240
242
 
241
- case 8:
243
+ case 9:
242
244
  content = getElement('.k-tooltip-content');
243
245
  dispatchEvent(content, 'mouseenter');
244
- _context4.next = 12;
245
- return wait(300);
246
+ _context4.next = 13;
247
+ return wait(500);
246
248
 
247
- case 12:
248
- content1 = getElement('.k-tooltip-content'); // should not hide when hover from button to tooltip content
249
+ case 13:
250
+ content1 = getElement('.k-tooltip-content'); // should not hide when move mouse from button to tooltip content
249
251
 
250
252
  expect(content1).eql(content);
251
253
  dispatchEvent(canHover, 'mouseleave');
252
- _context4.next = 17;
253
- return wait(500);
254
+ _context4.next = 18;
255
+ return wait(800);
254
256
 
255
- case 17:
257
+ case 18:
256
258
  expect(content.style.display).to.eql('none');
257
259
 
258
- case 18:
260
+ case 19:
259
261
  case "end":
260
262
  return _context4.stop();
261
263
  }
262
264
  }
263
- }, _callee4);
265
+ }, _callee4, this);
264
266
  })));
265
267
  it('should custom content correctly', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee5() {
266
268
  var _mount5, element, _Array$from4, btn, content;
@@ -273,7 +275,7 @@ describe('Tooltip', function () {
273
275
  _Array$from4 = _Array$from2(element.querySelectorAll('.k-btn')), btn = _Array$from4[0];
274
276
  btn.click();
275
277
  _context5.next = 5;
276
- return wait(300);
278
+ return wait(500);
277
279
 
278
280
  case 5:
279
281
  content = getElement('.k-tooltip-content'); // ignore the arrow, because it may change className to adapt to the direction
@@ -311,7 +313,7 @@ describe('Tooltip', function () {
311
313
  expect(content.querySelector('.k-tooltip-buttons').outerHTML).to.matchSnapshot();
312
314
  content.querySelector('.k-btn').click();
313
315
  _context6.next = 13;
314
- return wait(300);
316
+ return wait(500);
315
317
 
316
318
  case 13:
317
319
  expect(content.style.display).eql('none');
@@ -324,7 +326,7 @@ describe('Tooltip', function () {
324
326
  _Array$from5 = _Array$from2(content.querySelectorAll('.k-btn')), btn = _Array$from5[1];
325
327
  btn.click();
326
328
  _context6.next = 22;
327
- return wait(300);
329
+ return wait(500);
328
330
 
329
331
  case 22:
330
332
  expect(content.style.display).eql('none');
@@ -350,19 +352,19 @@ describe('Tooltip', function () {
350
352
  expect(content.textContent).eql('hello');
351
353
  document.body.click();
352
354
  _context7.next = 6;
353
- return wait(300);
355
+ return wait(500);
354
356
 
355
357
  case 6:
356
358
  expect(getElement('.k-tooltip-content')).eql(content);
357
359
  element.querySelector('span').click();
358
360
  _context7.next = 10;
359
- return wait(300);
361
+ return wait(500);
360
362
 
361
363
  case 10:
362
364
  expect(getElement('.k-tooltip-content')).eql(content);
363
365
  dispatchEvent(content, 'mouseleave');
364
366
  _context7.next = 14;
365
- return wait(500);
367
+ return wait(600);
366
368
 
367
369
  case 14:
368
370
  expect(getElement('.k-tooltip-content')).eql(content);
@@ -487,7 +489,7 @@ describe('Tooltip', function () {
487
489
  expect(content.textContent).eql('hello');
488
490
  i.set('disabled', true);
489
491
  _context9.next = 12;
490
- return wait(300);
492
+ return wait(500);
491
493
 
492
494
  case 12:
493
495
  content = getElement('.k-tooltip-content');
@@ -562,9 +564,11 @@ describe('Tooltip', function () {
562
564
 
563
565
  case 10:
564
566
  content = getElement('.k-tooltip-content');
567
+ console.log(content.outerHTML);
568
+ console.log(_JSON$stringify(content.getBoundingClientRect()));
565
569
  expect(content.getBoundingClientRect().top < 0).to.be.true;
566
570
 
567
- case 12:
571
+ case 14:
568
572
  case "end":
569
573
  return _context11.stop();
570
574
  }
@@ -89,7 +89,7 @@ describe('Transfer', function () {
89
89
  _element$querySelecto = element.querySelectorAll('.k-btn'), remove = _element$querySelecto[0], add = _element$querySelecto[1];
90
90
  add.click();
91
91
  _context2.next = 10;
92
- return wait(300);
92
+ return wait(500);
93
93
 
94
94
  case 10:
95
95
  expect(element.outerHTML).to.matchSnapshot();
@@ -102,7 +102,7 @@ describe('Transfer', function () {
102
102
  expect(element.outerHTML).to.matchSnapshot();
103
103
  remove.click();
104
104
  _context2.next = 19;
105
- return wait(300);
105
+ return wait(500);
106
106
 
107
107
  case 19:
108
108
  expect(element.outerHTML).to.matchSnapshot();
@@ -191,50 +191,51 @@ describe('Transfer', function () {
191
191
  while (1) {
192
192
  switch (_context4.prev = _context4.next) {
193
193
  case 0:
194
+ this.timeout(0);
194
195
  _mount5 = mount(LabelDemo), instance = _mount5[0], element = _mount5[1];
195
196
  transfer = instance.refs.__test;
196
197
  transfer.set('leftKeywords', '0');
197
- _context4.next = 5;
198
- return wait(300);
198
+ _context4.next = 6;
199
+ return wait(500);
199
200
 
200
- case 5:
201
+ case 6:
201
202
  expect(element.innerHTML).to.matchSnapshot();
202
203
  checkAll = element.querySelector('.k-transfer-title .k-checkbox');
203
204
  checkAll.click();
204
- _context4.next = 10;
205
+ _context4.next = 11;
205
206
  return wait();
206
207
 
207
- case 10:
208
+ case 11:
208
209
  expect(element.innerHTML).to.matchSnapshot();
209
210
  transfer.set('leftKeywords', '');
210
- _context4.next = 14;
211
- return wait(300);
211
+ _context4.next = 15;
212
+ return wait(500);
212
213
 
213
- case 14:
214
+ case 15:
214
215
  expect(element.innerHTML).to.matchSnapshot();
215
216
  checkAll.click();
216
- _context4.next = 18;
217
+ _context4.next = 19;
217
218
  return wait();
218
219
 
219
- case 18:
220
+ case 19:
220
221
  expect(element.innerHTML).to.matchSnapshot();
221
222
  transfer.set('leftKeywords', '0');
222
- _context4.next = 22;
223
+ _context4.next = 23;
223
224
  return wait();
224
225
 
225
- case 22:
226
+ case 23:
226
227
  transfer.set('leftKeywords', '');
227
- _context4.next = 25;
228
- return wait(300);
228
+ _context4.next = 26;
229
+ return wait(500);
229
230
 
230
- case 25:
231
+ case 26:
231
232
  expect(element.innerHTML).to.matchSnapshot();
232
233
 
233
- case 26:
234
+ case 27:
234
235
  case "end":
235
236
  return _context4.stop();
236
237
  }
237
238
  }
238
- }, _callee4);
239
+ }, _callee4, this);
239
240
  })));
240
241
  });
@@ -2,7 +2,7 @@ import { Component, Key, TypeDefs } from 'intact-react';
2
2
  import { DataItem, Node } from './useNodes';
3
3
  import { Mode } from './useDraggable';
4
4
  import type { Events } from '../types';
5
- export type { Node as TreeNode, DataItem as TreeDataItem, };
5
+ export type { Node as TreeNode, DataItem as TreeDataItem, Mode as TreeMode, };
6
6
  export interface TreeProps<K extends Key = Key> {
7
7
  data?: DataItem<K>[];
8
8
  filter?: Filter<K>;
@@ -10,7 +10,7 @@ import { useChecked } from './useChecked';
10
10
  import { useExpanded } from './useExpanded';
11
11
  import { useSelected } from './useSelected';
12
12
  import { useFilter } from './useFilter';
13
- import { useDraggable } from './useDraggable';
13
+ import { useDraggable, Mode } from './useDraggable';
14
14
  import { useTransitionEvent } from './useTransitionEvent';
15
15
  var typeDefs = {
16
16
  data: Array,
@@ -21,33 +21,34 @@ describe('Tree', function () {
21
21
  while (1) {
22
22
  switch (_context.prev = _context.next) {
23
23
  case 0:
24
+ this.timeout(0);
24
25
  _mount = mount(BasicDemo), instance = _mount[0], element = _mount[1];
25
26
  _element$querySelecto = element.querySelectorAll('.k-icon'), icon1 = _element$querySelecto[1], icon2 = _element$querySelecto[2];
26
27
  icon2.click();
27
- _context.next = 5;
28
- return wait(300);
28
+ _context.next = 6;
29
+ return wait(500);
29
30
 
30
- case 5:
31
+ case 6:
31
32
  expect(element.outerHTML).to.matchSnapshot();
32
33
  icon1.click();
33
- _context.next = 9;
34
- return wait(300);
34
+ _context.next = 10;
35
+ return wait(500);
35
36
 
36
- case 9:
37
+ case 10:
37
38
  expect(element.outerHTML).to.matchSnapshot();
38
39
  icon1.click();
39
- _context.next = 13;
40
- return wait(300);
40
+ _context.next = 14;
41
+ return wait(500);
41
42
 
42
- case 13:
43
+ case 14:
43
44
  expect(element.outerHTML).to.matchSnapshot();
44
45
 
45
- case 14:
46
+ case 15:
46
47
  case "end":
47
48
  return _context.stop();
48
49
  }
49
50
  }
50
- }, _callee);
51
+ }, _callee, this);
51
52
  })));
52
53
  it('checkbox', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
53
54
  var _mount2, instance, element, tree, _element$querySelecto2, checkbox1, checkbox2, data1, _element$querySelecto3, firstIcon, icon, _element$querySelecto4, icon1, data2, _element$querySelecto5, checkbox3, checkbox4;
@@ -80,7 +81,7 @@ describe('Tree', function () {
80
81
 
81
82
  icon1.click();
82
83
  _context2.next = 19;
83
- return wait(300);
84
+ return wait(500);
84
85
 
85
86
  case 19:
86
87
  expect(element.outerHTML).to.matchSnapshot();
@@ -182,7 +183,7 @@ describe('Tree', function () {
182
183
  _element$querySelecto8 = element.querySelectorAll('.k-btn'), btn1 = _element$querySelecto8[0], btn2 = _element$querySelecto8[1];
183
184
  btn1.click();
184
185
  _context4.next = 6;
185
- return wait(300);
186
+ return wait(500);
186
187
 
187
188
  case 6:
188
189
  expect(element.outerHTML).to.matchSnapshot();
@@ -190,7 +191,7 @@ describe('Tree', function () {
190
191
  expect(instance.get('data')).to.matchSnapshot();
191
192
  btn2.click();
192
193
  _context4.next = 12;
193
- return wait(300);
194
+ return wait(500);
194
195
 
195
196
  case 12:
196
197
  expect(element.outerHTML).to.matchSnapshot();
@@ -203,7 +204,7 @@ describe('Tree', function () {
203
204
  _element$querySelecto10 = element.querySelectorAll('.k-btn'), btn3 = _element$querySelecto10[3];
204
205
  btn3.click();
205
206
  _context4.next = 21;
206
- return wait(300);
207
+ return wait(500);
207
208
 
208
209
  case 21:
209
210
  expect(element.outerHTML).to.matchSnapshot(); // uncheck and remove
@@ -216,7 +217,7 @@ describe('Tree', function () {
216
217
  case 26:
217
218
  checkbox1.parentNode.querySelector('.k-btn:nth-child(2)').click();
218
219
  _context4.next = 29;
219
- return wait(300);
220
+ return wait(500);
220
221
 
221
222
  case 29:
222
223
  expect(element.outerHTML).to.matchSnapshot();
@@ -291,7 +292,7 @@ describe('Tree', function () {
291
292
  tree.set('selectable', false);
292
293
  text1.click();
293
294
  _context6.next = 21;
294
- return wait(300);
295
+ return wait(500);
295
296
 
296
297
  case 21:
297
298
  expect(tree.getSelectedData().length).to.eql(0);
@@ -321,7 +322,7 @@ describe('Tree', function () {
321
322
  _mount7 = mount(DraggableDemo), instance = _mount7[0], element = _mount7[1];
322
323
  instance.set('expandedKeys', ['2', '2-1', '1', '1-1']);
323
324
  _context7.next = 11;
324
- return wait(300);
325
+ return wait(500);
325
326
 
326
327
  case 11:
327
328
  // can not drag disabled item
@@ -413,7 +414,7 @@ function _dragInsert() {
413
414
  case 6:
414
415
  dispatchEvent(toElement, 'dragend');
415
416
  _context8.next = 9;
416
- return wait(300);
417
+ return wait(500);
417
418
 
418
419
  case 9:
419
420
  case "end":
@@ -80,6 +80,7 @@ export default function ($props, $blocks, $__proto__) {
80
80
 
81
81
  return _$ce(2, 'div', [_$ce(2, 'div', [node.children && node.loaded !== false ? _$cc(Icon, {
82
82
  'className': 'k-tree-icon ion-android-arrow-dropdown',
83
+ 'hoverable': true,
83
84
  'ev-click': function evClick(e) {
84
85
  // it may be in dropdownMenu, e.g. TreeSelect
85
86
  e._ignore = true;
@@ -3,6 +3,10 @@ import { theme, setDefault } from '../../styles/theme';
3
3
  import { deepDefaults, palette } from '../../styles/utils';
4
4
  import '../../styles/global';
5
5
  var defaults = {
6
+ get transition() {
7
+ return theme.transition.middle;
8
+ },
9
+
6
10
  fontSize: '12px',
7
11
  lineHeight: '24px',
8
12
 
@@ -65,5 +69,5 @@ setDefault(function () {
65
69
  }).tree;
66
70
  });
67
71
  export function makeStyles() {
68
- return /*#__PURE__*/css("font-size:", tree.fontSize, ";line-height:", tree.lineHeight, ";position:relative;.k-tree-label{position:relative;display:flex;align-items:center;&.k-before,&.k-after{&:before{position:absolute;content:'';display:block;border-top:", tree.dragging.border, ";width:100%;left:0;}}&.k-before:before{top:0;}&.k-after:before{bottom:0;}&.k-inner{background:", tree.selected.bgColor, ";}}.k-tree-icon,.k-tree-text{cursor:pointer;}.k-tree-text{padding:", tree.textPadding, ";border-radius:", tree.borderRadius, ";flex:1;}.k-tree-leaf{padding-left:", tree.leafIndent, ";}.k-tree-icon{width:", tree.iconWidth, ";text-align:center;color:", tree.iconColor, ";transform:rotate(-90deg);transition:transform ", theme.transition, ";}.k-tree-checkbox{margin-right:", tree.checkboxGap, ";}&.k-selectable{.k-tree-node{&.k-selected{>.k-tree-label .k-tree-text{background:", tree.selected.bgColor, "!important;}}}}.k-tree-node{background:#fff;&:not(.k-disabled){>.k-tree-label .k-tree-text:hover{background:", theme.color.bg, ";}}&.k-expanded{>.k-tree-label .k-tree-icon{transform:rotate(0);}}&.k-disabled{>.k-tree-label{color:", tree.disabledColor, ";.k-tree-text{cursor:not-allowed;}}}&.k-dragging{background:", tree.dragging.bgColor, ";.k-tree-node{background:", tree.dragging.bgColor, ";}}}.k-tree{margin-left:", tree.marginLeft, ";padding-left:", tree.paddingLeft, ";}&.k-line .k-tree{border-left:", tree.line, ";}");
72
+ return /*#__PURE__*/css("font-size:", tree.fontSize, ";line-height:", tree.lineHeight, ";position:relative;.k-tree-label{position:relative;display:flex;align-items:center;&.k-before,&.k-after{&:before{position:absolute;content:'';display:block;border-top:", tree.dragging.border, ";width:100%;left:0;}}&.k-before:before{top:0;}&.k-after:before{bottom:0;}&.k-inner{background:", tree.selected.bgColor, ";}}.k-tree-icon,.k-tree-text{cursor:pointer;}.k-tree-text{padding:", tree.textPadding, ";border-radius:", tree.borderRadius, ";flex:1;}.k-tree-leaf{padding-left:", tree.leafIndent, ";}.k-tree-icon{width:", tree.iconWidth, ";text-align:center;color:", tree.iconColor, ";&:before{transform:rotate(-90deg);transition:transform ", tree.transition, ";}}.k-tree-checkbox{margin-right:", tree.checkboxGap, ";}&.k-selectable{.k-tree-node{&.k-selected{>.k-tree-label .k-tree-text{background:", tree.selected.bgColor, "!important;}}}}.k-tree-node{background:#fff;&:not(.k-disabled){>.k-tree-label .k-tree-text:hover{background:", theme.color.bg, ";}}&.k-expanded{>.k-tree-label .k-tree-icon:before{transform:rotate(0);}}&.k-disabled{>.k-tree-label{color:", tree.disabledColor, ";.k-tree-text{cursor:not-allowed;}}}&.k-dragging{background:", tree.dragging.bgColor, ";.k-tree-node{background:", tree.dragging.bgColor, ";}}}.k-tree{margin-left:", tree.marginLeft, ";padding-left:", tree.paddingLeft, ";}&.k-line .k-tree{border-left:", tree.line, ";}");
69
73
  }
@@ -32,7 +32,7 @@ describe('TreeSelect', function () {
32
32
  dropdown.querySelector('.k-tree-text').click();
33
33
  expect(instance.get('value')).to.eql('1');
34
34
  _context.next = 10;
35
- return wait(300);
35
+ return wait(500);
36
36
 
37
37
  case 10:
38
38
  expect(getElement('.k-tree-select-menu')).to.be.undefined;
@@ -66,7 +66,7 @@ describe('TreeSelect', function () {
66
66
  expect(instance.get('values')).to.eql(['1.1']);
67
67
  instance.set('values', ['1']);
68
68
  _context2.next = 14;
69
- return wait(300);
69
+ return wait(500);
70
70
 
71
71
  case 14:
72
72
  expect(dropdown.innerHTML).to.matchSnapshot();
@@ -133,7 +133,7 @@ describe('TreeSelect', function () {
133
133
  input.value = 'first';
134
134
  dispatchEvent(input, 'input');
135
135
  _context4.next = 10;
136
- return wait(300);
136
+ return wait(500);
137
137
 
138
138
  case 10:
139
139
  expect(dropdown.innerHTML).to.matchSnapshot();
@@ -187,13 +187,13 @@ describe('TreeSelect', function () {
187
187
  case 7:
188
188
  dispatchEvent(select, 'focusout');
189
189
  _context6.next = 10;
190
- return wait(300);
190
+ return wait(500);
191
191
 
192
192
  case 10:
193
193
  expect(element.querySelector('.k-form-error')).to.be.null;
194
194
  dispatchEvent(select, 'click');
195
195
  _context6.next = 14;
196
- return wait(300);
196
+ return wait(500);
197
197
 
198
198
  case 14:
199
199
  expect(element.querySelector('.k-form-error')).not.to.be.null;