@kdcloudjs/kdesign 1.5.2 → 1.5.5

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 (107) hide show
  1. package/CHANGELOG.md +64 -0
  2. package/dist/default-theme.js +4 -4
  3. package/dist/kdesign-complete.less +169 -88
  4. package/dist/kdesign.css +165 -86
  5. package/dist/kdesign.css.map +1 -1
  6. package/dist/kdesign.js +335 -220
  7. package/dist/kdesign.js.map +1 -1
  8. package/dist/kdesign.min.css +4 -4
  9. package/dist/kdesign.min.js +6 -6
  10. package/dist/kdesign.min.js.map +1 -1
  11. package/es/_utils/usePopper.js +17 -8
  12. package/es/alert/alert.js +2 -2
  13. package/es/alert/style/index.css +27 -11
  14. package/es/alert/style/index.less +24 -10
  15. package/es/alert/style/mixin.less +8 -2
  16. package/es/alert/style/token.less +16 -8
  17. package/es/config-provider/compDefaultProps.d.ts +1 -0
  18. package/es/config-provider/compDefaultProps.js +2 -1
  19. package/es/drawer/drawer.js +1 -0
  20. package/es/dropdown/dropdown.js +16 -6
  21. package/es/dropdown/style/index.css +13 -14
  22. package/es/dropdown/style/index.less +4 -5
  23. package/es/dropdown/style/token.less +6 -5
  24. package/es/input/ClearableLabeledInput.js +5 -5
  25. package/es/input/style/index.css +5 -0
  26. package/es/input/style/index.less +5 -0
  27. package/es/radio/style/index.css +7 -1
  28. package/es/radio/style/index.less +9 -1
  29. package/es/search/style/index.css +3 -3
  30. package/es/select/select.js +1 -1
  31. package/es/spin/style/index.css +25 -26
  32. package/es/spin/style/index.less +18 -19
  33. package/es/spin/style/token.less +9 -3
  34. package/es/stepper/stepper.js +9 -4
  35. package/es/stepper/style/index.css +2 -0
  36. package/es/stepper/style/index.less +2 -0
  37. package/es/stepper/style/token.less +1 -2
  38. package/es/style/icon/kdicon.css +2 -1
  39. package/es/style/icon/kdicon.woff +0 -0
  40. package/es/style/themes/default.less +3 -4
  41. package/es/tabs/style/index.css +1 -0
  42. package/es/tabs/style/index.less +1 -0
  43. package/es/timeline/style/index.css +22 -21
  44. package/es/timeline/style/index.less +2 -2
  45. package/es/timeline/style/token.less +4 -7
  46. package/es/tooltip/tooltip.js +1 -1
  47. package/es/tree/style/index.css +56 -7
  48. package/es/tree/style/index.less +26 -18
  49. package/es/tree/style/mixin.less +25 -1
  50. package/es/tree/style/token.less +6 -4
  51. package/es/tree/tree.d.ts +2 -0
  52. package/es/tree/tree.js +77 -20
  53. package/es/tree/treeHooks.d.ts +1 -1
  54. package/es/tree/treeHooks.js +3 -4
  55. package/es/tree/treeNode.d.ts +1 -0
  56. package/es/tree/treeNode.js +45 -49
  57. package/es/tree/utils/treeUtils.d.ts +6 -3
  58. package/es/tree/utils/treeUtils.js +66 -42
  59. package/lib/_utils/usePopper.js +17 -8
  60. package/lib/alert/alert.js +2 -2
  61. package/lib/alert/style/index.css +27 -11
  62. package/lib/alert/style/index.less +24 -10
  63. package/lib/alert/style/mixin.less +8 -2
  64. package/lib/alert/style/token.less +16 -8
  65. package/lib/config-provider/compDefaultProps.d.ts +1 -0
  66. package/lib/config-provider/compDefaultProps.js +2 -1
  67. package/lib/drawer/drawer.js +1 -0
  68. package/lib/dropdown/dropdown.js +15 -6
  69. package/lib/dropdown/style/index.css +13 -14
  70. package/lib/dropdown/style/index.less +4 -5
  71. package/lib/dropdown/style/token.less +6 -5
  72. package/lib/input/ClearableLabeledInput.js +5 -5
  73. package/lib/input/style/index.css +5 -0
  74. package/lib/input/style/index.less +5 -0
  75. package/lib/radio/style/index.css +7 -1
  76. package/lib/radio/style/index.less +9 -1
  77. package/lib/search/style/index.css +3 -3
  78. package/lib/select/select.js +1 -1
  79. package/lib/spin/style/index.css +25 -26
  80. package/lib/spin/style/index.less +18 -19
  81. package/lib/spin/style/token.less +9 -3
  82. package/lib/stepper/stepper.js +9 -4
  83. package/lib/stepper/style/index.css +2 -0
  84. package/lib/stepper/style/index.less +2 -0
  85. package/lib/stepper/style/token.less +1 -2
  86. package/lib/style/icon/kdicon.css +2 -1
  87. package/lib/style/icon/kdicon.woff +0 -0
  88. package/lib/style/themes/default.less +3 -4
  89. package/lib/tabs/style/index.css +1 -0
  90. package/lib/tabs/style/index.less +1 -0
  91. package/lib/timeline/style/index.css +22 -21
  92. package/lib/timeline/style/index.less +2 -2
  93. package/lib/timeline/style/token.less +4 -7
  94. package/lib/tooltip/tooltip.js +1 -1
  95. package/lib/tree/style/index.css +56 -7
  96. package/lib/tree/style/index.less +26 -18
  97. package/lib/tree/style/mixin.less +25 -1
  98. package/lib/tree/style/token.less +6 -4
  99. package/lib/tree/tree.d.ts +2 -0
  100. package/lib/tree/tree.js +78 -20
  101. package/lib/tree/treeHooks.d.ts +1 -1
  102. package/lib/tree/treeHooks.js +3 -4
  103. package/lib/tree/treeNode.d.ts +1 -0
  104. package/lib/tree/treeNode.js +46 -48
  105. package/lib/tree/utils/treeUtils.d.ts +6 -3
  106. package/lib/tree/utils/treeUtils.js +64 -42
  107. package/package.json +1 -1
@@ -486,6 +486,11 @@ function usePopper(locatorElement, popperElement, props) {
486
486
  props.visible === undefined && setVisible(false);
487
487
  onVisibleChange && onVisibleChange(false);
488
488
  }, [onVisibleChange, props.visible]);
489
+
490
+ var matchTrigger = function matchTrigger(words) {
491
+ return Array.isArray(trigger) ? _includesInstanceProperty(trigger).call(trigger, words) : trigger === words;
492
+ };
493
+
489
494
  useEffect(function () {
490
495
  if (exist && visible) {
491
496
  var mouseleaveTimer;
@@ -502,13 +507,13 @@ function usePopper(locatorElement, popperElement, props) {
502
507
  Y = e.clientY;
503
508
  var inTriggerRect = X > left - 2 && X < right + 2 && Y > top - 2 && Y < bottom + 2;
504
509
  var inPopperRect = X > popperRect.left && X < popperRect.right && Y > popperRect.top && Y < popperRect.bottom;
505
- var ableArea = evType === 'contextmenu' ? inPopperRect : inTriggerRect || inPopperRect;
510
+ var ableArea = matchTrigger('contextMenu') ? inPopperRect : inTriggerRect || inPopperRect;
506
511
 
507
512
  if (ableArea) {
508
513
  mouseleaveTimer && clearTimeout(mouseleaveTimer);
509
- evType === 'focus' && triggerNode.focus();
514
+ matchTrigger('focus') && triggerNode.focus();
510
515
  } else {
511
- evType === 'mouseenter' ? mouseleaveTimer = window.setTimeout(hidePopper, mouseLeaveDelay * 1000) : hidePopper();
516
+ matchTrigger('hover') ? mouseleaveTimer = window.setTimeout(hidePopper, mouseLeaveDelay * 1000) : hidePopper();
512
517
  }
513
518
  };
514
519
 
@@ -516,14 +521,18 @@ function usePopper(locatorElement, popperElement, props) {
516
521
  leading: true
517
522
  });
518
523
  var mapEvent = {
519
- mouseenter: 'mousemove',
520
- mouseup: 'mousedown',
524
+ hover: 'mousemove',
525
+ click: 'mousedown',
521
526
  focus: 'mousedown',
522
- contextmenu: 'mousedown'
527
+ contextMenu: 'mousedown'
523
528
  };
524
- document.addEventListener(mapEvent[evType], debounceHidePopper);
529
+ Array.isArray(trigger) ? trigger.forEach(function (action) {
530
+ return document.addEventListener(mapEvent[action], debounceHidePopper);
531
+ }) : document.addEventListener(mapEvent[trigger], debounceHidePopper);
525
532
  return function () {
526
- document.removeEventListener(mapEvent[evType], debounceHidePopper);
533
+ Array.isArray(trigger) ? trigger.forEach(function (action) {
534
+ return document.removeEventListener(mapEvent[action], debounceHidePopper);
535
+ }) : document.removeEventListener(mapEvent[trigger], debounceHidePopper);
527
536
  };
528
537
  }
529
538
  }, [currentPlacement, evType, exist, getTriggerElement, hidePopper, locatorRef, mouseLeaveDelay, popperRef, visible]);
package/es/alert/alert.js CHANGED
@@ -180,12 +180,12 @@ var Alert = function Alert(props) {
180
180
  };
181
181
 
182
182
  var iconNode = /*#__PURE__*/React.createElement("div", {
183
- className: "".concat(alertPrefixCls, "-icon")
183
+ className: classNames("".concat(alertPrefixCls, "-icon"), getAlertColorType('icon'))
184
184
  }, icon || /*#__PURE__*/React.createElement(Icon, {
185
185
  type: alertIconType
186
186
  }));
187
187
  var AlertComp = /*#__PURE__*/React.createElement("div", _extends({
188
- className: classNames(alertClasses, getAlertColorType('bg'), getAlertColorType('font'))
188
+ className: classNames(alertClasses, getAlertColorType('bg'), getAlertColorType('border'))
189
189
  }, events, {
190
190
  ref: alertRef
191
191
  }), showIcon && iconNode, /*#__PURE__*/React.createElement("div", {
@@ -109,12 +109,14 @@
109
109
  z-index: var(--kd-g-z-index-apex, 9999);
110
110
  display: none;
111
111
  width: 100%;
112
- padding: var(--kd-c-alert-sizing-padding-top, 8px) var(--kd-c-alert-sizing-padding-horizontal, 12px) var(--kd-c-alert-sizing-padding-bottom, 12px);
112
+ padding: var(--kd-c-alert-sizing-padding-vertical, 12px) var(--kd-c-alert-sizing-padding-horizontal, 20px);
113
113
  -webkit-box-align: center;
114
114
  -ms-flex-align: center;
115
115
  align-items: center;
116
116
  -webkit-transition: display 3s;
117
117
  transition: display 3s;
118
+ border-radius: var(--kd-c-alert-radius-border, 4px);
119
+ border: 1px solid;
118
120
  }
119
121
  .kd-alert-banner-container {
120
122
  display: -webkit-box;
@@ -140,23 +142,24 @@
140
142
  .kd-alert.alert-info-bg-color {
141
143
  background-color: var(--kd-c-alert-color-background-info, var(--kd-g-color-background-ongoing, #f2f9ff));
142
144
  }
143
- .kd-alert.alert-success-font-color {
144
- color: var(--kd-c-alert-color-text-success, var(--kd-g-color-success, #1ba854));
145
+ .kd-alert.alert-success-border-color {
146
+ border-color: var(--kd-c-alert-color-border-success, #DCFAE4);
145
147
  }
146
- .kd-alert.alert-warning-font-color {
147
- color: var(--kd-c-alert-color-text-warning, var(--kd-g-color-warning, #ff991c));
148
+ .kd-alert.alert-warning-border-color {
149
+ border-color: var(--kd-c-alert-color-border-warning, #FFF1D4);
148
150
  }
149
- .kd-alert.alert-error-font-color {
150
- color: var(--kd-c-alert-color-text-error, var(--kd-g-color-error, #fb2323));
151
+ .kd-alert.alert-error-border-color {
152
+ border-color: var(--kd-c-alert-color-border-error, #FFDBE0);
151
153
  }
152
- .kd-alert.alert-info-font-color {
153
- color: var(--kd-c-alert-color-text-info, var(--kd-g-color-ongoing, #276ff5));
154
+ .kd-alert.alert-info-border-color {
155
+ border-color: var(--kd-c-alert-color-border-info, #E0EFFF);
154
156
  }
155
157
  .kd-alert-icon {
156
158
  display: -webkit-box;
157
159
  display: -ms-flexbox;
158
160
  display: flex;
159
161
  cursor: default;
162
+ height: var(--kd-c-alert-message-icon-font-size, var(--kd-g-font-size-middle, 14px));
160
163
  margin-right: var(--kd-c-alert-message-icon-sizing-margin-right, 8px);
161
164
  font-size: var(--kd-c-alert-message-icon-font-size, var(--kd-g-font-size-middle, 14px));
162
165
  }
@@ -164,9 +167,22 @@
164
167
  -ms-flex-item-align: center;
165
168
  align-self: center;
166
169
  }
170
+ .kd-alert-icon.alert-success-icon-color {
171
+ color: var(--kd-c-alert-color-icon-success, var(--kd-g-color-success, #1ba854));
172
+ }
173
+ .kd-alert-icon.alert-warning-icon-color {
174
+ color: var(--kd-c-alert-color-icon-warning, var(--kd-g-color-warning, #ff991c));
175
+ }
176
+ .kd-alert-icon.alert-error-icon-color {
177
+ color: var(--kd-c-alert-color-icon-error, var(--kd-g-color-error, #fb2323));
178
+ }
179
+ .kd-alert-icon.alert-info-icon-color {
180
+ color: var(--kd-c-alert-color-icon-info, var(--kd-g-color-ongoing, #276ff5));
181
+ }
167
182
  .kd-alert-message {
183
+ color: var(--kd-c-alert-color-text, var(--kd-g-color-text-primary, #212121));
168
184
  font-size: var(--kd-c-alert-message-font-size, var(--kd-g-font-size-small, 12px));
169
- line-height: 18px;
185
+ line-height: 16px;
170
186
  display: -webkit-box;
171
187
  display: -ms-flexbox;
172
188
  display: flex;
@@ -196,10 +212,10 @@
196
212
  display: -webkit-box;
197
213
  display: -ms-flexbox;
198
214
  display: flex;
215
+ height: var(--kd-c-alert-message-icon-font-size, var(--kd-g-font-size-middle, 14px));
199
216
  margin-left: var(--kd-c-alert-close-icon-sizing-margin-left, 8px);
200
217
  color: var(--kd-c-alert-close-icon-color-text, var(--kd-g-color-text-secondary, #666));
201
218
  font-size: var(--kd-c-alert-close-icon-font-size, var(--kd-g-font-size-middle, 14px));
202
- justify-self: flex-end;
203
219
  cursor: pointer;
204
220
  }
205
221
  .kd-alert-close-icon:hover {
@@ -16,11 +16,18 @@
16
16
  @info: @alert-info-bg-color;
17
17
  }
18
18
 
19
- .alert-font-type-set() {
20
- @success: @alert-success-font-color;
21
- @warning: @alert-warning-font-color;
22
- @error: @alert-error-font-color;
23
- @info: @alert-info-font-color;
19
+ .alert-icon-type-set() {
20
+ @success: @alert-success-icon-color;
21
+ @warning: @alert-warning-icon-color;
22
+ @error: @alert-error-icon-color;
23
+ @info: @alert-info-icon-color;
24
+ }
25
+
26
+ .alert-border-type-set() {
27
+ @success: @alert-success-border-color;
28
+ @warning: @alert-warning-border-color;
29
+ @error: @alert-error-border-color;
30
+ @info: @alert-info-border-color;
24
31
  }
25
32
 
26
33
  @alert-transition-fn: cubic-bezier(0.32, 0.94, 0.6, 1);
@@ -36,9 +43,11 @@
36
43
  z-index: @z-index-apex;
37
44
  display: none;
38
45
  width: 100%;
39
- padding: @alert-padding-top @alert-padding-horizontal @alert-padding-bottom;
46
+ padding: @alert-padding-vertical @alert-padding-horizontal;
40
47
  align-items: center;
41
48
  transition: display 3s;
49
+ border-radius: @alert-radius-border;
50
+ border: 1px solid;
42
51
  }
43
52
  &-banner-container {
44
53
  display: flex;
@@ -50,19 +59,24 @@
50
59
  each(.alert-bg-type-set(), {
51
60
  .alert-bg-type(@key, @value);
52
61
  });
53
- each(.alert-font-type-set(), {
54
- .alert-font-type(@key, @value);
62
+ each(.alert-border-type-set(), {
63
+ .alert-border-type(@key, @value);
55
64
  });
56
65
  &-icon {
57
66
  display: flex;
58
67
  cursor: default;
59
68
  .icon-center();
69
+ height: @alert-message-icon-font-size;
60
70
  margin-right: @alert-message-icon-margin-right;
61
71
  font-size: @alert-message-icon-font-size;
72
+ each(.alert-icon-type-set(), {
73
+ .alert-icon-type(@key, @value);
74
+ });
62
75
  }
63
76
  &-message {
77
+ color: @alert-message-color-text;
64
78
  font-size: @alert-message-font-size;
65
- line-height: 18px;
79
+ line-height: 16px;
66
80
  display: flex;
67
81
  flex-grow: 1;
68
82
  cursor: default;
@@ -86,10 +100,10 @@
86
100
  }
87
101
  &-close-icon {
88
102
  display: flex;
103
+ height: @alert-message-icon-font-size;
89
104
  margin-left: @alert-close-icon-margin-left;
90
105
  color: @alert-close-icon-color;
91
106
  font-size: @alert-close-icon-font-size;
92
- justify-self: flex-end;
93
107
  cursor: pointer;
94
108
  &:hover {
95
109
  color: @alert-close-icon-color-hover;
@@ -4,12 +4,18 @@
4
4
  }
5
5
  }
6
6
 
7
- .alert-font-type(@type, @color) {
8
- &.alert-@{type}-font-color {
7
+ .alert-icon-type(@type, @color) {
8
+ &.alert-@{type}-icon-color {
9
9
  color: @color
10
10
  }
11
11
  }
12
12
 
13
+ .alert-border-type(@type, @color) {
14
+ &.alert-@{type}-border-color {
15
+ border-color: @color
16
+ }
17
+ }
18
+
13
19
  .square(@side-length) {
14
20
  width: @side-length;
15
21
  height: @side-length;
@@ -8,10 +8,16 @@
8
8
  @alert-error-bg-color: var(~'@{alert-custom-prefix}-color-background-error', @color-background-error); // 反馈浮层错误提示的背景色
9
9
  @alert-info-bg-color: var(~'@{alert-custom-prefix}-color-background-info', @color-background-ongoing); // 反馈浮层一般提示的背景色
10
10
 
11
- @alert-success-font-color: var(~'@{alert-custom-prefix}-color-text-success', @color-success); // 反馈浮层成功提示的文字色
12
- @alert-warning-font-color: var(~'@{alert-custom-prefix}-color-text-warning', @color-warning); // 反馈浮层警告提示的文字色
13
- @alert-error-font-color: var(~'@{alert-custom-prefix}-color-text-error', @color-error); // 反馈浮层错误提示的文字色
14
- @alert-info-font-color: var(~'@{alert-custom-prefix}-color-text-info', @color-ongoing); // 反馈浮层一般提示的文字色
11
+ @alert-message-color-text: var(~'@{alert-custom-prefix}-color-text', @color-text-primary); // 反馈浮层提示的文字色
12
+ @alert-success-icon-color: var(~'@{alert-custom-prefix}-color-icon-success', @color-success); // 反馈浮层成功提示的图标颜色
13
+ @alert-warning-icon-color: var(~'@{alert-custom-prefix}-color-icon-warning', @color-warning); // 反馈浮层警告提示的图标颜色
14
+ @alert-error-icon-color: var(~'@{alert-custom-prefix}-color-icon-error', @color-error); // 反馈浮层错误提示的图标颜色
15
+ @alert-info-icon-color: var(~'@{alert-custom-prefix}-color-icon-info', @color-ongoing); // 反馈浮层一般提示的图标颜色
16
+
17
+ @alert-success-border-color: var(~'@{alert-custom-prefix}-color-border-success', #DCFAE4); // 反馈浮层成功提示的边框色
18
+ @alert-warning-border-color: var(~'@{alert-custom-prefix}-color-border-warning', #FFF1D4); // 反馈浮层警告提示的边框色
19
+ @alert-error-border-color: var(~'@{alert-custom-prefix}-color-border-error', #FFDBE0); // 反馈浮层错误提示的边框色
20
+ @alert-info-border-color: var(~'@{alert-custom-prefix}-color-border-info', #E0EFFF); // 反馈浮层一般提示的边框色
15
21
 
16
22
  @alert-close-icon-color: var(~'@{alert-custom-prefix}-close-icon-color-text', @color-text-secondary);
17
23
  @alert-close-icon-color-hover: var(~'@{alert-custom-prefix}-close-icon-color-text-hover', @color-theme-hover);
@@ -22,8 +28,10 @@
22
28
  @alert-close-icon-font-size: var(~'@{alert-custom-prefix}-close-icon-font-size', @font-size-middle);
23
29
 
24
30
  // spacing
25
- @alert-padding-top: var(~'@{alert-custom-prefix}-sizing-padding-top', 8px);
26
- @alert-padding-bottom: var(~'@{alert-custom-prefix}-sizing-padding-bottom', 12px);
27
- @alert-padding-horizontal: var(~'@{alert-custom-prefix}-sizing-padding-horizontal', 12px);
31
+ @alert-padding-vertical: var(~'@{alert-custom-prefix}-sizing-padding-vertical', 12px);
32
+ @alert-padding-horizontal: var(~'@{alert-custom-prefix}-sizing-padding-horizontal', 20px);
28
33
  @alert-message-icon-margin-right: var(~'@{alert-custom-prefix}-message-icon-sizing-margin-right', 8px);
29
- @alert-close-icon-margin-left: var(~'@{alert-custom-prefix}-close-icon-sizing-margin-left', 8px);
34
+ @alert-close-icon-margin-left: var(~'@{alert-custom-prefix}-close-icon-sizing-margin-left', 8px);
35
+
36
+ // radius
37
+ @alert-radius-border: var(~'@{alert-custom-prefix}-radius-border', 4px);
@@ -305,6 +305,7 @@ declare const compDefaultProps: {
305
305
  virtual: boolean;
306
306
  switcherIcon: () => JSX.Element;
307
307
  estimatedItemSize: number;
308
+ expandOnClickNode: boolean;
308
309
  };
309
310
  TreeNode: {};
310
311
  ToolTip: {
@@ -319,7 +319,8 @@ var compDefaultProps = {
319
319
  type: "arrow-right-solid"
320
320
  });
321
321
  },
322
- estimatedItemSize: 32
322
+ estimatedItemSize: 32,
323
+ expandOnClickNode: true
323
324
  },
324
325
  TreeNode: {},
325
326
  ToolTip: {
@@ -206,6 +206,7 @@ var InternalDrawer = function InternalDrawer(props, ref) {
206
206
  width: width,
207
207
  transform: transform
208
208
  } : {
209
+ height: height,
209
210
  transform: transform
210
211
  });
211
212
 
@@ -7,6 +7,17 @@ import ConfigContext from '../config-provider/ConfigContext';
7
7
  import { getCompProps } from '../_utils';
8
8
  import { Menu, Item } from './menu';
9
9
  import usePopper from '../_utils/usePopper';
10
+
11
+ var findItem = function findItem(element) {
12
+ var isItem = element.className === 'kd-dropdown-menu-item';
13
+
14
+ if (isItem) {
15
+ return element;
16
+ } else {
17
+ return element.parentNode ? findItem(element.parentNode) : null;
18
+ }
19
+ };
20
+
10
21
  var Dropdown = /*#__PURE__*/React.forwardRef(function (props, ref) {
11
22
  var _a, _b, _c;
12
23
 
@@ -37,7 +48,7 @@ var Dropdown = /*#__PURE__*/React.forwardRef(function (props, ref) {
37
48
  setVisible(!!props.visible);
38
49
  }, [props.visible]);
39
50
  var child = /*#__PURE__*/React.cloneElement(React.Children.only(children), {
40
- ref: ref,
51
+ ref: children.ref || ref,
41
52
  className: classNames("".concat(prefixCls, "-trigger"), children.props.className, {
42
53
  disabled: disabled
43
54
  })
@@ -55,13 +66,12 @@ var Dropdown = /*#__PURE__*/React.forwardRef(function (props, ref) {
55
66
  var menuSelectable = ((_b = menu.props) === null || _b === void 0 ? void 0 : _b.selectable) === undefined ? selectable : (_c = menu.props) === null || _c === void 0 ? void 0 : _c.selectable;
56
67
 
57
68
  var handleItemClick = function handleItemClick(e) {
58
- var _a, _b;
69
+ var _a;
59
70
 
60
- var currentTarget = e.target;
61
- var parentTarget = currentTarget.parentNode;
62
- var key = ((_a = currentTarget.dataset) === null || _a === void 0 ? void 0 : _a.key) || ((_b = currentTarget.parentNode.dataset) === null || _b === void 0 ? void 0 : _b.key);
71
+ var item = findItem(e.target);
72
+ var key = (_a = item === null || item === void 0 ? void 0 : item.dataset) === null || _a === void 0 ? void 0 : _a.key;
63
73
 
64
- if (currentTarget.className.indexOf('disabled') === -1 && parentTarget.className.indexOf('disabled') === -1 && key) {
74
+ if ((item === null || item === void 0 ? void 0 : item.className.indexOf('disabled')) === -1 && key) {
65
75
  if (isMenu && menu.props.onClick) {
66
76
  menu.props.onClick(key);
67
77
  } else if (onItemClick) {
@@ -137,10 +137,10 @@
137
137
  opacity: 1;
138
138
  visibility: visible;
139
139
  z-index: var(--kd-g-z-index-popper, 1050);
140
- background-color: var(--kd-g-color-background, #fff);
140
+ background-color: var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff));
141
141
  border-radius: var(--kd-g-radius-border, 2px);
142
- min-width: var(--kd-c-dropdown-menu-sizing-min-width, 136px);
143
- max-width: var(--kd-c-dropdown-menu-sizing-max-width, 320px);
142
+ min-width: var(--kd-c-dropdown-menu-sizing-min-width, 64px);
143
+ max-width: var(--kd-c-dropdown-menu-sizing-max-width, 600px);
144
144
  -webkit-box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.2);
145
145
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.2);
146
146
  }
@@ -151,7 +151,7 @@
151
151
  .kd-dropdown.arrow::before {
152
152
  position: absolute;
153
153
  z-index: -2;
154
- background: var(--kd-g-color-background, #fff);
154
+ background: var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff));
155
155
  border-style: solid;
156
156
  border-width: var(--arrowSize);
157
157
  -webkit-transform: rotate(45deg);
@@ -166,7 +166,7 @@
166
166
  bottom: 0;
167
167
  left: 0;
168
168
  content: '';
169
- background: var(--kd-g-color-background, #fff);
169
+ background: var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff));
170
170
  border-radius: var(--kd-g-radius-border, 2px);
171
171
  }
172
172
  .kd-dropdown.arrow.bottomLeft::before,
@@ -176,7 +176,7 @@
176
176
  top: var(--arrowSpill);
177
177
  -webkit-box-shadow: -2px -2px calc(10px - 1px) rgba(0, 0, 0, 0.1);
178
178
  box-shadow: -2px -2px calc(10px - 1px) rgba(0, 0, 0, 0.1);
179
- border-color: var(--kd-g-color-background, #fff) transparent transparent var(--kd-g-color-background, #fff);
179
+ border-color: var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) transparent transparent var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff));
180
180
  }
181
181
  .kd-dropdown.arrow.topLeft::before,
182
182
  .kd-dropdown.arrow.top::before,
@@ -185,7 +185,7 @@
185
185
  bottom: var(--arrowSpill);
186
186
  -webkit-box-shadow: 3px 3px calc(10px + 1px) rgba(0, 0, 0, 0.15);
187
187
  box-shadow: 3px 3px calc(10px + 1px) rgba(0, 0, 0, 0.15);
188
- border-color: transparent var(--kd-g-color-background, #fff) var(--kd-g-color-background, #fff) transparent;
188
+ border-color: transparent var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) transparent;
189
189
  }
190
190
  .kd-dropdown.arrow.leftTop::before,
191
191
  .kd-dropdown.arrow.left::before,
@@ -194,7 +194,7 @@
194
194
  right: var(--arrowSpill);
195
195
  -webkit-box-shadow: 3px 0 10px rgba(0, 0, 0, 0.12), 0 -2px 10px rgba(204, 149, 149, 0.12);
196
196
  box-shadow: 3px 0 10px rgba(0, 0, 0, 0.12), 0 -2px 10px rgba(204, 149, 149, 0.12);
197
- border-color: var(--kd-g-color-background, #fff) var(--kd-g-color-background, #fff) transparent transparent;
197
+ border-color: var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) transparent transparent;
198
198
  }
199
199
  .kd-dropdown.arrow.rightTop::before,
200
200
  .kd-dropdown.arrow.right::before,
@@ -203,11 +203,11 @@
203
203
  left: var(--arrowSpill);
204
204
  -webkit-box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1), -2px 0 10px rgba(0, 0, 0, 0.1);
205
205
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.1), -2px 0 10px rgba(0, 0, 0, 0.1);
206
- border-color: transparent transparent var(--kd-g-color-background, #fff) var(--kd-g-color-background, #fff);
206
+ border-color: transparent transparent var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff)) var(--kd-c-dropdown-menu-color-background, var(--kd-g-color-background, #fff));
207
207
  }
208
208
  .kd-dropdown-menu {
209
- max-height: var(--kd-c-dropdown-menu-sizing-max-height, 336px);
210
- padding: var(--kd-c-dropdown-menu-spacing-padding-vertical, 8px) 0;
209
+ max-height: var(--kd-c-dropdown-menu-sizing-max-height, 328px);
210
+ padding: var(--kd-c-dropdown-menu-spacing-padding-vertical, 4px) 0;
211
211
  overflow-y: auto;
212
212
  }
213
213
  .kd-dropdown-menu-item {
@@ -234,12 +234,11 @@
234
234
  }
235
235
  .kd-dropdown-menu-item:not(.disabled):active,
236
236
  .kd-dropdown-menu-item:not(.disabled).selected {
237
- color: var(--kd-g-color-theme, #5582f3);
238
- background-color: var(--kd-c-dropdown-item-color-background-active, var(--kd-g-color-theme-1, #f2f8ff));
237
+ color: var(--kd-c-dropdown-item-color-text-active, var(--kd-g-color-theme, #5582f3));
239
238
  }
240
239
  .kd-dropdown-menu-item:not(.disabled):active > a,
241
240
  .kd-dropdown-menu-item:not(.disabled).selected > a {
242
- color: var(--kd-g-color-theme, #5582f3);
241
+ color: var(--kd-c-dropdown-item-color-text-active, var(--kd-g-color-theme, #5582f3));
243
242
  }
244
243
  .kd-dropdown-menu-item.divided::before {
245
244
  content: '';
@@ -37,7 +37,7 @@
37
37
  opacity: 1;
38
38
  visibility: visible;
39
39
  z-index: @z-index-popper;
40
- background-color: @color-background;
40
+ background-color: @dropdown-color-background;
41
41
  border-radius: @radius-border;
42
42
  min-width: @dropdown-menu-min-width;
43
43
  max-width: @dropdown-menu-max-width;
@@ -49,7 +49,7 @@
49
49
  }
50
50
 
51
51
  // 箭头样式
52
- .popperArrow(@color-background, @dropdown-item-horizontal-gap, @dropdown-box-shadow-blur);
52
+ .popperArrow(@dropdown-color-background, @dropdown-item-horizontal-gap, @dropdown-box-shadow-blur);
53
53
 
54
54
  &-menu {
55
55
  max-height: @dropdown-menu-max-height;
@@ -80,11 +80,10 @@
80
80
 
81
81
  &:not(.disabled):active,
82
82
  &:not(.disabled).selected {
83
- color: @color-theme;
84
- background-color: @dropdown-item-active-bg-color;
83
+ color: @dropdown-item-active-color;
85
84
 
86
85
  > a {
87
- color: @color-theme;
86
+ color: @dropdown-item-active-color;
88
87
  }
89
88
  }
90
89
 
@@ -4,22 +4,23 @@
4
4
 
5
5
  // color
6
6
  @dropdown-item-hover-bg-color: var(~'@{dropdown-custom-prefix}-item-color-background-hover', @color-hover);
7
- @dropdown-item-active-bg-color: var(~'@{dropdown-custom-prefix}-item-color-background-active', @color-theme-light-active);
7
+ @dropdown-item-active-color: var(~'@{dropdown-custom-prefix}-item-color-text-active', @color-theme);
8
8
  @dropdown-item-color-disabled: var(~'@{dropdown-custom-prefix}-item-color-text-disabled', @color-disabled);
9
9
  @dropdown-item-color-text-danger: var(~'@{dropdown-custom-prefix}-item-color-text-danger', @color-error);
10
10
  @dropdown-item-color-background-danger-hover: var(~'@{dropdown-custom-prefix}-item-color-background-danger-hover', @color-error);
11
11
  @dropdown-item-hover-color-text: var(~'@{dropdown-custom-prefix}-item-color-text-hover', @color-text-primary);
12
12
  @dropdown-divided-color-bg: var(~'@{dropdown-custom-prefix}-divided-color-background', @color-border-weak);
13
13
  @dropdown-color: var(~'@{dropdown-custom-prefix}-menu-item-color-text', @color-text-primary);
14
+ @dropdown-color-background: var(~'@{dropdown-custom-prefix}-menu-color-background', @color-background);
14
15
 
15
16
  // sizing
16
- @dropdown-menu-min-width: var(~'@{dropdown-custom-prefix}-menu-sizing-min-width', 136px);
17
- @dropdown-menu-max-width: var(~'@{dropdown-custom-prefix}-menu-sizing-max-width', 320px);
18
- @dropdown-menu-max-height: var(~'@{dropdown-custom-prefix}-menu-sizing-max-height', 336px);
17
+ @dropdown-menu-min-width: var(~'@{dropdown-custom-prefix}-menu-sizing-min-width', 64px);
18
+ @dropdown-menu-max-width: var(~'@{dropdown-custom-prefix}-menu-sizing-max-width', 600px);
19
+ @dropdown-menu-max-height: var(~'@{dropdown-custom-prefix}-menu-sizing-max-height', 328px);
19
20
  @dropdown-divided-height: var(~'@{dropdown-custom-prefix}-divided-sizing-height', 1px);
20
21
 
21
22
  // spacing
22
- @dropdown-menu-padding-vertical: var(~'@{dropdown-custom-prefix}-menu-spacing-padding-vertical', 8px);
23
+ @dropdown-menu-padding-vertical: var(~'@{dropdown-custom-prefix}-menu-spacing-padding-vertical', 4px);
23
24
  @dropdown-item-vertical-gap: var(~'@{dropdown-custom-prefix}-item-spacing-padding-vertical', 7px);
24
25
  @dropdown-item-horizontal-gap: var(~'@{dropdown-custom-prefix}-item-spacing-padding-horizontal', 12px);
25
26
 
@@ -46,13 +46,13 @@ var ClearableInput = function ClearableInput(props) {
46
46
  };
47
47
 
48
48
  var renderSuffix = function renderSuffix() {
49
- if (!suffix && !allowClear) {
50
- return null;
49
+ if (suffix || !disabled && allowClear) {
50
+ return /*#__PURE__*/React.createElement("span", {
51
+ className: "".concat(prefixCls, "-suffix")
52
+ }, renderClearIcon(), suffix);
51
53
  }
52
54
 
53
- return /*#__PURE__*/React.createElement("span", {
54
- className: "".concat(prefixCls, "-suffix")
55
- }, !disabled && renderClearIcon(), suffix);
55
+ return null;
56
56
  };
57
57
 
58
58
  var renderInputWithFixNode = function renderInputWithFixNode(originElement) {
@@ -365,6 +365,10 @@ textarea {
365
365
  border-color: var(--kd-c-input-color-border-disabled, var(--kd-g-color-border-strong, #d9d9d9));
366
366
  cursor: not-allowed;
367
367
  }
368
+ .kd-input-wrapper-disabled .kd-input-suffix,
369
+ .kd-input-wrapper-disabled .kd-input-prefix {
370
+ color: var(--kd-c-input-color-disabled, var(--kd-g-color-disabled, #b2b2b2));
371
+ }
368
372
  .kd-input-wrapper-textarea {
369
373
  width: 100%;
370
374
  min-width: 0;
@@ -508,6 +512,7 @@ textarea {
508
512
  .kd-input-group-wrapper .kd-input-group .kd-input-group-addon-disabled {
509
513
  background-color: var(--kd-c-input-color-background-disabled, var(--kd-g-color-background-contain-disabled, #f5f5f5));
510
514
  border-color: var(--kd-c-input-color-border-disabled, var(--kd-g-color-border-strong, #d9d9d9));
515
+ color: var(--kd-c-input-color-disabled, var(--kd-g-color-disabled, #b2b2b2));
511
516
  cursor: not-allowed;
512
517
  }
513
518
  .kd-input-group-wrapper .kd-input-group-size-small .kd-input-group-addon {
@@ -131,6 +131,10 @@ textarea {
131
131
  background-color: @input-background-color-disabled-inner;
132
132
  border-color: @input-border-color-disabled-inner;
133
133
  cursor: not-allowed;
134
+
135
+ .@{input-prefix-cls}-suffix, .@{input-prefix-cls}-prefix {
136
+ color: @input-color-disabled-inner;
137
+ }
134
138
  }
135
139
  }
136
140
  &-wrapper-textarea {
@@ -225,6 +229,7 @@ textarea {
225
229
  &-disabled {
226
230
  background-color: @input-background-color-disabled-inner;
227
231
  border-color: @input-border-color-disabled-inner;
232
+ color: @input-color-disabled-inner;
228
233
  cursor: not-allowed;
229
234
  }
230
235
  }
@@ -284,6 +284,9 @@
284
284
  width: 100%;
285
285
  height: 100%;
286
286
  }
287
+ .kd-radio-square-input[disabled] {
288
+ cursor: not-allowed;
289
+ }
287
290
  .kd-radio-square:hover {
288
291
  color: var(--kd-c-radio-color-theme, var(--kd-g-color-theme, #5582f3));
289
292
  border-color: var(--kd-c-radio-color-theme, var(--kd-g-color-theme, #5582f3));
@@ -391,6 +394,9 @@
391
394
  cursor: pointer;
392
395
  opacity: 0;
393
396
  }
397
+ .kd-radio-button-input[disabled] {
398
+ cursor: not-allowed;
399
+ }
394
400
  .kd-radio-button:hover {
395
401
  color: var(--kd-c-radio-color-theme, var(--kd-g-color-theme, #5582f3));
396
402
  }
@@ -407,7 +413,7 @@
407
413
  .kd-radio-button-checked:hover {
408
414
  color: var(--kd-c-radio-color-background, var(--kd-g-color-white, #fff));
409
415
  }
410
- .kd-radio-button-checked::before {
416
+ .kd-radio-button-checked:not(.kd-radio-button-disabled)::before {
411
417
  background-color: var(--kd-c-radio-color-theme, var(--kd-g-color-theme, #5582f3));
412
418
  }
413
419
  .kd-radio-button-checked:first-child {
@@ -179,6 +179,10 @@
179
179
  opacity: 0;
180
180
  width: 100%;
181
181
  height: 100%;
182
+
183
+ &[disabled] {
184
+ cursor: not-allowed;
185
+ }
182
186
  }
183
187
 
184
188
  // 悬停状态
@@ -289,6 +293,10 @@
289
293
  z-index: 1;
290
294
  cursor: pointer;
291
295
  opacity: 0;
296
+
297
+ &[disabled]{
298
+ cursor: not-allowed;
299
+ }
292
300
  }
293
301
 
294
302
  // 悬停状态
@@ -312,7 +320,7 @@
312
320
  color: @radio-color-background;
313
321
  }
314
322
 
315
- &::before {
323
+ &:not(.@{radio-button-prefix-cls}-disabled)::before {
316
324
  background-color: @radio-color-theme;
317
325
  }
318
326
 
@@ -483,13 +483,13 @@
483
483
  animation: animate_loading 1s infinite;
484
484
  }
485
485
  .kd-quick-search-npl-loading-item:nth-child(1) {
486
- background-color: var(--kd-c-search-dot-color-first, var(--kd-g-color-logo-1, #2386ee));
486
+ background-color: var(--kd-c-search-dot-color-first, var(--kd-g-color-logo-1, #2486ee));
487
487
  }
488
488
  .kd-quick-search-npl-loading-item:nth-child(2) {
489
- background-color: #00ccfe;
489
+ background-color: #02ccfe;
490
490
  }
491
491
  .kd-quick-search-npl-loading-item:nth-child(3) {
492
- background-color: #05c8c8;
492
+ background-color: #05c8c7;
493
493
  }
494
494
  .kd-quick-search-npl-loading-item:nth-child(4) {
495
495
  background-color: #a06eff;