@kdcloudjs/kdesign 1.1.1 → 1.2.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 (128) hide show
  1. package/CHANGELOG.md +60 -0
  2. package/dist/kdesign-complete.less +662 -572
  3. package/dist/kdesign.css +400 -316
  4. package/dist/kdesign.css.map +1 -1
  5. package/dist/kdesign.js +287 -40
  6. package/dist/kdesign.js.map +1 -1
  7. package/dist/kdesign.min.css +4 -4
  8. package/dist/kdesign.min.js +8 -8
  9. package/dist/kdesign.min.js.map +1 -1
  10. package/es/_utils/usePopper.js +4 -5
  11. package/es/anchor/anchor.js +0 -6
  12. package/es/anchor/style/index.css +5 -2
  13. package/es/anchor/style/index.less +6 -2
  14. package/es/anchor/style/token.less +2 -1
  15. package/es/button/button.d.ts +1 -1
  16. package/es/button/button.js +2 -2
  17. package/es/button/group.d.ts +21 -0
  18. package/es/button/group.js +130 -0
  19. package/es/button/index.d.ts +5 -1
  20. package/es/button/index.js +4 -1
  21. package/es/button/style/index.css +117 -21
  22. package/es/button/style/index.less +332 -192
  23. package/es/button/style/token.less +41 -25
  24. package/es/carousel/carousel.js +4 -0
  25. package/es/checkbox/checkbox.js +3 -4
  26. package/es/checkbox/style/index.css +36 -33
  27. package/es/checkbox/style/index.less +25 -18
  28. package/es/checkbox/style/token.less +34 -35
  29. package/es/config-provider/compDefaultProps.d.ts +4 -0
  30. package/es/config-provider/compDefaultProps.js +4 -0
  31. package/es/date-picker/style/index.css +8 -8
  32. package/es/date-picker/style/index.less +8 -8
  33. package/es/date-picker/style/token.less +3 -21
  34. package/es/empty/defaultEmptyImg.js +5 -3
  35. package/es/empty/illustrationEmptyImg.js +6 -4
  36. package/es/icon/interface.js +1 -1
  37. package/es/image/preview.js +1 -1
  38. package/es/image/style/index.css +8 -8
  39. package/es/image/style/index.less +5 -5
  40. package/es/image/style/token.less +12 -25
  41. package/es/input/style/index.css +53 -50
  42. package/es/input/style/index.less +5 -4
  43. package/es/input/style/mixin.less +1 -0
  44. package/es/input/style/token.less +23 -20
  45. package/es/layout/style/index.css +1 -1
  46. package/es/layout/style/index.less +1 -1
  47. package/es/layout/style/token.less +5 -5
  48. package/es/menu/style/index.css +76 -114
  49. package/es/menu/style/index.less +66 -140
  50. package/es/menu/style/mixin.less +10 -1
  51. package/es/menu/style/token.less +9 -12
  52. package/es/menu/subMenu.js +2 -1
  53. package/es/pagination/pagination.js +4 -4
  54. package/es/pagination/style/index.css +70 -55
  55. package/es/pagination/style/index.less +61 -43
  56. package/es/pagination/style/token.less +4 -4
  57. package/es/radio/radio.js +21 -8
  58. package/es/rate/style/index.css +9 -9
  59. package/es/rate/style/token.less +6 -6
  60. package/es/select/style/index.css +1 -1
  61. package/es/select/style/token.less +1 -1
  62. package/es/stepper/style/index.css +1 -1
  63. package/es/stepper/style/token.less +1 -1
  64. package/es/style/icon/kdicon.css +225 -0
  65. package/es/style/icon/kdicon.woff +0 -0
  66. package/es/switch/style/index.css +11 -11
  67. package/es/switch/style/index.less +2 -2
  68. package/es/switch/style/token.less +7 -10
  69. package/lib/_utils/usePopper.js +4 -5
  70. package/lib/anchor/anchor.js +0 -6
  71. package/lib/anchor/style/index.css +5 -2
  72. package/lib/anchor/style/index.less +6 -2
  73. package/lib/anchor/style/token.less +2 -1
  74. package/lib/button/button.d.ts +1 -1
  75. package/lib/button/button.js +2 -2
  76. package/lib/button/group.d.ts +21 -0
  77. package/lib/button/group.js +166 -0
  78. package/lib/button/index.d.ts +5 -1
  79. package/lib/button/index.js +5 -1
  80. package/lib/button/style/index.css +117 -21
  81. package/lib/button/style/index.less +332 -192
  82. package/lib/button/style/token.less +41 -25
  83. package/lib/carousel/carousel.js +4 -0
  84. package/lib/checkbox/checkbox.js +3 -4
  85. package/lib/checkbox/style/index.css +36 -33
  86. package/lib/checkbox/style/index.less +25 -18
  87. package/lib/checkbox/style/token.less +34 -35
  88. package/lib/config-provider/compDefaultProps.d.ts +4 -0
  89. package/lib/config-provider/compDefaultProps.js +4 -0
  90. package/lib/date-picker/style/index.css +8 -8
  91. package/lib/date-picker/style/index.less +8 -8
  92. package/lib/date-picker/style/token.less +3 -21
  93. package/lib/empty/defaultEmptyImg.js +6 -3
  94. package/lib/empty/illustrationEmptyImg.js +7 -4
  95. package/lib/icon/interface.js +1 -1
  96. package/lib/image/preview.js +1 -1
  97. package/lib/image/style/index.css +8 -8
  98. package/lib/image/style/index.less +5 -5
  99. package/lib/image/style/token.less +12 -25
  100. package/lib/input/style/index.css +53 -50
  101. package/lib/input/style/index.less +5 -4
  102. package/lib/input/style/mixin.less +1 -0
  103. package/lib/input/style/token.less +23 -20
  104. package/lib/layout/style/index.css +1 -1
  105. package/lib/layout/style/index.less +1 -1
  106. package/lib/layout/style/token.less +5 -5
  107. package/lib/menu/style/index.css +76 -114
  108. package/lib/menu/style/index.less +66 -140
  109. package/lib/menu/style/mixin.less +10 -1
  110. package/lib/menu/style/token.less +9 -12
  111. package/lib/menu/subMenu.js +2 -1
  112. package/lib/pagination/pagination.js +4 -3
  113. package/lib/pagination/style/index.css +70 -55
  114. package/lib/pagination/style/index.less +61 -43
  115. package/lib/pagination/style/token.less +4 -4
  116. package/lib/radio/radio.js +21 -8
  117. package/lib/rate/style/index.css +9 -9
  118. package/lib/rate/style/token.less +6 -6
  119. package/lib/select/style/index.css +1 -1
  120. package/lib/select/style/token.less +1 -1
  121. package/lib/stepper/style/index.css +1 -1
  122. package/lib/stepper/style/token.less +1 -1
  123. package/lib/style/icon/kdicon.css +225 -0
  124. package/lib/style/icon/kdicon.woff +0 -0
  125. package/lib/switch/style/index.css +11 -11
  126. package/lib/switch/style/index.less +2 -2
  127. package/lib/switch/style/token.less +7 -10
  128. package/package.json +1 -1
@@ -56,7 +56,7 @@ var ButtonTypes = (0, _type.tuple)('second', 'primary', 'ghost', 'text');
56
56
  exports.ButtonTypes = ButtonTypes;
57
57
  var ButtonSizes = (0, _type.tuple)('large', 'middle', 'small');
58
58
  exports.ButtonSizes = ButtonSizes;
59
- var ButtonShapes = (0, _type.tuple)('circle', 'round');
59
+ var ButtonShapes = (0, _type.tuple)('circle', 'round', 'none');
60
60
  exports.ButtonShapes = ButtonShapes;
61
61
  var ButtonIconPlaces = (0, _type.tuple)('left', 'right');
62
62
  exports.ButtonIconPlaces = ButtonIconPlaces;
@@ -142,7 +142,7 @@ var InternalButton = function InternalButton(props, ref) {
142
142
 
143
143
  var isTextBtn = type === 'text'; // 判断按钮是否文本类型。这些类型下有部分样式不适用
144
144
 
145
- var btnClasses = (0, _classnames.default)(btnPrefixCls, className, (_classNames = {}, (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context = "".concat(btnPrefixCls, "-")).call(_context, type), type), (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context2 = "".concat(btnPrefixCls, "-size-")).call(_context2, size), size), (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context3 = "".concat(btnPrefixCls, "-shape-")).call(_context3, shape), shape && !isTextBtn), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-no-border"), !bordered), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-background-ghost"), ghost && !disabled), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-loading"), loading && !isTextBtn), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-block"), block && !shape), _classNames));
145
+ var btnClasses = (0, _classnames.default)(btnPrefixCls, className, (_classNames = {}, (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context = "".concat(btnPrefixCls, "-")).call(_context, type), type), (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context2 = "".concat(btnPrefixCls, "-size-")).call(_context2, size), size), (0, _defineProperty2.default)(_classNames, (0, _concat.default)(_context3 = "".concat(btnPrefixCls, "-shape-")).call(_context3, shape), shape && !isTextBtn), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-no-border"), !bordered), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-background-ghost"), ghost && !disabled), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-loading"), loading && !isTextBtn), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-block"), block && !shape), (0, _defineProperty2.default)(_classNames, "".concat(btnPrefixCls, "-icon-only"), !children && children !== 0 && icon), _classNames));
146
146
  var iconWrapperClassName = (0, _concat.default)(_context4 = "".concat(btnPrefixCls, "-iconWrapper-")).call(_context4, iconPlace === 'left' ? 'left' : 'right');
147
147
  var iconNode = icon && !loading ? /*#__PURE__*/_react.default.createElement("span", {
148
148
  className: iconWrapperClassName
@@ -0,0 +1,21 @@
1
+ import React, { CSSProperties, ReactNode } from 'react';
2
+ import { ButtonType } from './button';
3
+ export declare const ButtonGroupTypes: ["basic", "similar"];
4
+ export declare type ButtonGroupType = typeof ButtonGroupTypes[number];
5
+ export interface OverlayType {
6
+ value?: string;
7
+ label?: React.ReactNode;
8
+ }
9
+ export interface ButtonGroupProps {
10
+ style?: CSSProperties;
11
+ className?: string;
12
+ children?: ReactNode;
13
+ onClick?: () => void;
14
+ overlay?: Array<OverlayType>;
15
+ icon?: [ReactNode, ReactNode];
16
+ type?: ButtonGroupType;
17
+ buttonType?: ButtonType;
18
+ disabled?: boolean;
19
+ }
20
+ declare const ButtonGroup: React.ForwardRefExoticComponent<ButtonGroupProps & React.RefAttributes<HTMLDivElement>>;
21
+ export default ButtonGroup;
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+
3
+ var _typeof = require("@babel/runtime-corejs3/helpers/typeof");
4
+
5
+ var _WeakMap = require("@babel/runtime-corejs3/core-js-stable/weak-map");
6
+
7
+ var _Object$getOwnPropertyDescriptor = require("@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor");
8
+
9
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
10
+
11
+ Object.defineProperty(exports, "__esModule", {
12
+ value: true
13
+ });
14
+ exports.default = exports.ButtonGroupTypes = void 0;
15
+
16
+ var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
17
+
18
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
19
+
20
+ var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
21
+
22
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
23
+
24
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
25
+
26
+ var _react = _interopRequireWildcard(require("react"));
27
+
28
+ var _classnames = _interopRequireDefault(require("classnames"));
29
+
30
+ var _ConfigContext = _interopRequireDefault(require("../config-provider/ConfigContext"));
31
+
32
+ var _utils = require("../_utils");
33
+
34
+ var _index = require("../index");
35
+
36
+ var _usePopper = _interopRequireDefault(require("../_utils/usePopper"));
37
+
38
+ var _reactChildren = require("../_utils/react-children");
39
+
40
+ var _type = require("../_utils/type");
41
+
42
+ function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
43
+
44
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
45
+
46
+ var ButtonGroupTypes = (0, _type.tuple)('basic', 'similar');
47
+ exports.ButtonGroupTypes = ButtonGroupTypes;
48
+
49
+ var InternalButtonGroup = function InternalButtonGroup(props, ref) {
50
+ var _context;
51
+
52
+ var _useContext = (0, _react.useContext)(_ConfigContext.default),
53
+ getPrefixCls = _useContext.getPrefixCls,
54
+ prefixCls = _useContext.prefixCls,
55
+ userDefaultProps = _useContext.compDefaultProps;
56
+
57
+ var buttonGoupProps = (0, _utils.getCompProps)('ButtonGroup', userDefaultProps, props);
58
+ var style = buttonGoupProps.style,
59
+ className = buttonGoupProps.className,
60
+ children = buttonGoupProps.children,
61
+ customPrefixcls = buttonGoupProps.prefixCls,
62
+ onClick = buttonGoupProps.onClick,
63
+ onItemClick = buttonGoupProps.onItemClick,
64
+ overlay = buttonGoupProps.overlay,
65
+ icon = buttonGoupProps.icon,
66
+ type = buttonGoupProps.type,
67
+ buttonType = buttonGoupProps.buttonType,
68
+ disabled = buttonGoupProps.disabled,
69
+ onVisibleChange = buttonGoupProps.onVisibleChange;
70
+
71
+ var _useState = (0, _react.useState)(false),
72
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
73
+ optionShow = _useState2[0],
74
+ setOptionShow = _useState2[1]; // 下拉列表是否展示
75
+
76
+
77
+ var refBtnGroup = _react.default.useRef(null) || ref;
78
+
79
+ var triggerRef = _react.default.useRef(null);
80
+
81
+ var isBsicType = type === 'basic';
82
+ var btnGroupPrefixCls = getPrefixCls(prefixCls, 'btn-group', customPrefixcls);
83
+ var btnGroupClasses = (0, _classnames.default)("".concat(btnGroupPrefixCls), className, (0, _defineProperty2.default)({}, (0, _concat.default)(_context = "".concat(btnGroupPrefixCls, "-")).call(_context, type), type));
84
+ var renderTriggerButton = (0, _react.useCallback)(function () {
85
+ var _toArray = (0, _reactChildren.toArray)(icon),
86
+ _toArray2 = (0, _slicedToArray2.default)(_toArray, 2),
87
+ _toArray2$ = _toArray2[0],
88
+ iconUp = _toArray2$ === void 0 ? /*#__PURE__*/_react.default.createElement(_index.Icon, {
89
+ type: "arrow-up"
90
+ }) : _toArray2$,
91
+ _toArray2$2 = _toArray2[1],
92
+ iconDown = _toArray2$2 === void 0 ? /*#__PURE__*/_react.default.createElement(_index.Icon, {
93
+ type: "arrow-down"
94
+ }) : _toArray2$2;
95
+
96
+ return /*#__PURE__*/_react.default.createElement("div", {
97
+ style: style,
98
+ className: btnGroupClasses,
99
+ ref: refBtnGroup
100
+ }, isBsicType && /*#__PURE__*/_react.default.createElement(_index.Button, {
101
+ type: buttonType,
102
+ disabled: disabled
103
+ }, children, /*#__PURE__*/_react.default.createElement("span", {
104
+ className: "".concat(btnGroupPrefixCls, "-basic-icon")
105
+ }, optionShow ? iconUp : iconDown)), !isBsicType && /*#__PURE__*/_react.default.createElement(_index.Button, {
106
+ type: buttonType,
107
+ disabled: disabled,
108
+ onClick: onClick
109
+ }, children), !isBsicType && /*#__PURE__*/_react.default.createElement("span", {
110
+ className: "".concat(btnGroupPrefixCls, "-trigger"),
111
+ ref: triggerRef
112
+ }, optionShow ? /*#__PURE__*/_react.default.createElement(_index.Button, {
113
+ icon: iconUp,
114
+ type: buttonType,
115
+ disabled: disabled
116
+ }) : /*#__PURE__*/_react.default.createElement(_index.Button, {
117
+ icon: iconDown,
118
+ type: buttonType,
119
+ disabled: disabled
120
+ })));
121
+ }, [icon, btnGroupPrefixCls, style, btnGroupClasses, refBtnGroup, isBsicType, buttonType, disabled, children, optionShow, onClick]);
122
+ var handleItemClick = (0, _react.useCallback)(function (data) {
123
+ onItemClick === null || onItemClick === void 0 ? void 0 : onItemClick(data);
124
+ setOptionShow(false);
125
+ }, [onItemClick]);
126
+ var renderContent = (0, _react.useCallback)(function () {
127
+ var _context2;
128
+
129
+ return /*#__PURE__*/_react.default.createElement("div", {
130
+ className: "".concat(btnGroupPrefixCls, "-dropdown")
131
+ }, (0, _map.default)(_context2 = overlay || []).call(_context2, function (item) {
132
+ return /*#__PURE__*/_react.default.createElement("div", {
133
+ key: item.value,
134
+ className: "".concat(btnGroupPrefixCls, "-dropdown-item"),
135
+ onClick: function onClick() {
136
+ return handleItemClick === null || handleItemClick === void 0 ? void 0 : handleItemClick(item);
137
+ }
138
+ }, item.label);
139
+ }));
140
+ }, [btnGroupPrefixCls, overlay, handleItemClick]);
141
+
142
+ var handleVisibleChange = function handleVisibleChange(visible) {
143
+ setOptionShow(visible);
144
+ onVisibleChange === null || onVisibleChange === void 0 ? void 0 : onVisibleChange(visible);
145
+ };
146
+
147
+ var popperProps = (0, _extends2.default)((0, _extends2.default)({
148
+ placement: 'bottomLeft',
149
+ trigger: 'click'
150
+ }, buttonGoupProps), {
151
+ prefixCls: btnGroupPrefixCls,
152
+ defaultVisible: optionShow,
153
+ visible: optionShow,
154
+ onVisibleChange: handleVisibleChange,
155
+ getTriggerElement: function getTriggerElement(locatorNode) {
156
+ return isBsicType ? locatorNode : triggerRef.current;
157
+ }
158
+ });
159
+ return (0, _usePopper.default)(renderTriggerButton(), renderContent(), popperProps);
160
+ };
161
+
162
+ var ButtonGroup = /*#__PURE__*/_react.default.forwardRef(InternalButtonGroup);
163
+
164
+ ButtonGroup.displayName = 'ButtonGroup';
165
+ var _default = ButtonGroup;
166
+ exports.default = _default;
@@ -1,3 +1,7 @@
1
- import Button from './button';
1
+ /// <reference types="react" />
2
+ import Dropdown from './group';
3
+ declare const Button: import("react").ForwardRefExoticComponent<import("./button").IButtonProps & import("react").RefAttributes<unknown>> & {
4
+ Dropdown: typeof Dropdown;
5
+ };
2
6
  export { ButtonType, IButtonProps } from './button';
3
7
  export default Button;
@@ -9,5 +9,9 @@ exports.default = void 0;
9
9
 
10
10
  var _button = _interopRequireDefault(require("./button"));
11
11
 
12
- var _default = _button.default;
12
+ var _group = _interopRequireDefault(require("./group"));
13
+
14
+ var Button = _button.default;
15
+ Button.Dropdown = _group.default;
16
+ var _default = Button;
13
17
  exports.default = _default;
@@ -145,24 +145,24 @@
145
145
  animation: fadeEffect var(--kd-c-button-motion-duration-fade, var(--kd-g-duration-slowly, 0.4s)) cubic-bezier(0, 0.4, 0.4, 1) forwards, waveEffect var(--kd-c-button-motion-duration-wave, var(--kd-g-duration-quickly, 0.2s)) cubic-bezier(0, 0.4, 0.4, 1) forwards;
146
146
  }
147
147
  .kd-btn-second {
148
- border-color: var(--kd-c-button-second-color-border, var(--kd-g-color-border-strong-3, rgba(217, 217, 217, 0.65)));
149
- background-color: var(--kd-c-button-second-color-background, var(--kd-g-color-background-3, rgba(255, 255, 255, 0.65)));
150
- color: var(--kd-c-button-second-color-text, var(--kd-g-color-text-secondary-3, rgba(102, 102, 102, 0.65)));
148
+ border-color: var(--kd-c-button-second-color-border, #D9D9D9);
149
+ background-color: var(--kd-c-button-second-color-background, transparent);
150
+ color: var(--kd-c-button-second-color-text, #212121);
151
151
  }
152
152
  .kd-btn-second:hover:not(.kd-btn-loading) {
153
153
  background-color: var(--kd-c-button-second-color-background-hover, var(--kd-g-color-white, #fff));
154
- border-color: var(--kd-c-button-second-color-border-hover, var(--kd-g-color-border-strong, #d9d9d9));
155
- color: var(--kd-c-button-second-color-text-hover, var(--kd-g-color-text-secondary, #666));
154
+ border-color: var(--kd-c-button-second-color-border-hover, var(--kd-g-color-theme, #5582f3));
155
+ color: var(--kd-c-button-second-color-text-hover, var(--kd-g-color-theme, #5582f3));
156
156
  }
157
157
  .kd-btn-second:active:not(.kd-btn-loading) {
158
158
  background-color: var(--kd-c-button-second-color-background-active, var(--kd-g-color-white, #fff));
159
- border-color: var(--kd-c-button-second-color-border-active, var(--kd-g-color-border-strong, #d9d9d9));
160
- color: var(--kd-c-button-second-color-text-active, var(--kd-g-color-text-secondary, #666));
159
+ border-color: var(--kd-c-button-second-color-border-active, var(--kd-g-color-theme-7, #375cca));
160
+ color: var(--kd-c-button-second-color-text-active, var(--kd-g-color-theme-7, #375cca));
161
161
  }
162
162
  .kd-btn-second:disabled {
163
- border-color: var(--kd-c-button-second-color-border-disabled, var(--kd-g-color-text-secondary-3, rgba(102, 102, 102, 0.65))) !important;
164
- background-color: var(--kd-c-button-second-color-background-disabled, var(--kd-g-color-background-3, rgba(255, 255, 255, 0.65))) !important;
165
- color: var(--kd-c-button-second-color-text-disabled, var(--kd-g-color-text-secondary-3, rgba(102, 102, 102, 0.65))) !important;
163
+ border-color: var(--kd-c-button-second-color-border-disabled, #D9D9D9) !important;
164
+ background-color: var(--kd-c-button-second-color-background-disabled, var(--kd-g-color-background-contain-disabled, #f5f5f5)) !important;
165
+ color: var(--kd-c-button-second-color-text-disabled, #B2B2B2) !important;
166
166
  }
167
167
  .kd-btn-primary {
168
168
  border-color: var(--kd-c-button-primary-color-border, var(--kd-g-color-theme, #5582f3));
@@ -182,22 +182,24 @@
182
182
  border-color: var(--kd-c-button-primary-color-border-disabled, var(--kd-g-color-theme-3, #e3eeff)) !important;
183
183
  }
184
184
  .kd-btn-ghost {
185
- border-color: var(--kd-c-button-ghost-color-border, var(--kd-g-color-border-strong, #d9d9d9));
185
+ border-color: var(--kd-c-button-ghost-color-border, var(--kd-g-color-theme-6, #5582f3));
186
186
  background-color: var(--kd-c-button-ghost-color-background, transparent);
187
- color: var(--kd-c-button-ghost-color-text, var(--kd-g-color-text-secondary, #666));
187
+ color: var(--kd-c-button-ghost-color-text, #5582F3);
188
188
  }
189
189
  .kd-btn-ghost:hover:not(.kd-btn-loading) {
190
- border-color: var(--kd-c-button-ghost-color-border-hover, var(--kd-g-color-theme, #5582f3));
191
- color: var(--kd-c-button-ghost-color-text-hover, var(--kd-g-color-theme, #5582f3));
190
+ background-color: var(--kd-c-button-ghost-color-background-hover, var(--kd-g-color-theme-5, #87adff));
191
+ border-color: var(--kd-c-button-ghost-color-border-hover, transparent);
192
+ color: var(--kd-c-button-ghost-color-text-hover, #ffffff);
192
193
  }
193
194
  .kd-btn-ghost:active:not(.kd-btn-loading) {
194
- border-color: var(--kd-c-button-ghost-color-border-hover, var(--kd-g-color-theme, #5582f3));
195
- color: var(--kd-c-button-ghost-color-text-active, var(--kd-g-color-theme-7, #375cca));
195
+ background-color: var(--kd-c-button-ghost-color-background-active, var(--kd-g-color-theme-7, #375cca));
196
+ border-color: var(--kd-c-button-ghost-color-border-hover, transparent);
197
+ color: var(--kd-c-button-ghost-color-text-active, #ffffff);
196
198
  }
197
199
  .kd-btn-ghost:disabled {
198
200
  background-color: var(--kd-c-button-ghost-color-background-disabled, var(--kd-g-color-background-contain-disabled, #f5f5f5)) !important;
199
- border-color: var(--kd-c-button-ghost-color-border-disabled, var(--kd-g-color-disabled, #b2b2b2)) !important;
200
- color: var(--kd-c-button-ghost-color-border-disabled, var(--kd-g-color-disabled, #b2b2b2)) !important;
201
+ border-color: var(--kd-c-button-ghost-color-border-disabled, #D9D9D9) !important;
202
+ color: var(--kd-c-button-ghost-color-text-disabled, #B2B2B2) !important;
201
203
  }
202
204
  .kd-btn-iconWrapper-left {
203
205
  display: -webkit-box;
@@ -236,6 +238,13 @@
236
238
  font-size: var(--kd-c-button-font-size-small, var(--kd-g-font-size-small, 12px));
237
239
  padding: var(--kd-c-button-spacing-padding-vertical-small, 3px) var(--kd-c-button-spacing-padding-horizontal-small, 8px);
238
240
  }
241
+ .kd-btn-size-small.kd-btn-icon-only {
242
+ font-size: var(--kd-c-button-icon-font-size-small, 14px);
243
+ padding: 0 var(--kd-c-button-icon-spacing-padding-horizontal, 4px);
244
+ }
245
+ .kd-btn-size-small .kd-btn-group-basic-icon {
246
+ font-size: var(--kd-c-button-icon-font-size-small, 14px);
247
+ }
239
248
  .kd-btn-size-middle {
240
249
  height: var(--kd-c-button-sizing-height-middle, 28px);
241
250
  min-width: var(--kd-c-button-sizing-min-width-middle, 60px);
@@ -243,6 +252,13 @@
243
252
  font-size: var(--kd-c-button-font-size-middle, var(--kd-g-font-size-small, 12px));
244
253
  padding: var(--kd-c-button-spacing-padding-vertical-middle, 5px) var(--kd-c-button-spacing-padding-horizontal-middle, 8px);
245
254
  }
255
+ .kd-btn-size-middle.kd-btn-icon-only {
256
+ font-size: var(--kd-c-button-icon-font-size-middle, 16px);
257
+ padding: 0 var(--kd-c-button-icon-spacing-padding-horizontal, 4px);
258
+ }
259
+ .kd-btn-size-middle .kd-btn-group-basic-icon {
260
+ font-size: var(--kd-c-button-icon-font-size-middle, 16px);
261
+ }
246
262
  .kd-btn-size-large {
247
263
  height: var(--kd-c-button-sizing-height-large, 32px);
248
264
  min-width: var(--kd-c-button-sizing-min-width-large, 80px);
@@ -250,6 +266,13 @@
250
266
  font-size: var(--kd-c-button-font-size-large, var(--kd-g-font-size-large, 16px));
251
267
  padding: var(--kd-c-button-spacing-padding-vertical-large, 6px) var(--kd-c-button-spacing-padding-horizontal-large, 8px);
252
268
  }
269
+ .kd-btn-size-large.kd-btn-icon-only {
270
+ font-size: var(--kd-c-button-icon-font-size-large, 18px);
271
+ padding: 0 var(--kd-c-button-icon-spacing-padding-horizontal, 4px);
272
+ }
273
+ .kd-btn-size-large .kd-btn-group-basic-icon {
274
+ font-size: var(--kd-c-button-icon-font-size-large, 18px);
275
+ }
253
276
  .kd-btn-shape-circle {
254
277
  border-radius: 50%;
255
278
  min-width: auto;
@@ -275,10 +298,13 @@
275
298
  .kd-btn-shape-round.kd-btn-size-large {
276
299
  border-radius: var(--kd-c-button-sizing-height-large, 32px);
277
300
  }
301
+ .kd-btn-shape-none {
302
+ border-radius: 0;
303
+ }
278
304
  .kd-btn-text {
279
305
  height: auto;
280
306
  width: auto;
281
- color: var(--kd-c-button-text-color-text, var(--kd-g-color-theme, #5582f3));
307
+ color: var(--kd-c-button-text-color-text, var(--kd-g-color-theme-6, #5582f3));
282
308
  padding: 0;
283
309
  min-width: auto;
284
310
  }
@@ -289,7 +315,7 @@
289
315
  color: var(--kd-c-button-text-color-text-active, var(--kd-g-color-theme-7, #375cca));
290
316
  }
291
317
  .kd-btn-text[disabled] {
292
- color: var(--kd-c-button-text-color-text-disabled, var(--kd-g-color-disabled, #b2b2b2)) !important;
318
+ color: var(--kd-c-button-text-color-text-disabled, var(--kd-g-color-theme-4, #b5cfff)) !important;
293
319
  }
294
320
  .kd-btn-no-border {
295
321
  border: none;
@@ -316,5 +342,75 @@
316
342
  width: 100%;
317
343
  }
318
344
  .kd-btn .btn-space {
319
- margin-left: 5px;
345
+ margin-left: 4px;
346
+ }
347
+ .kd-btn-group {
348
+ display: inline-block;
349
+ }
350
+ .kd-btn-group-basic .kd-btn {
351
+ padding-top: 0;
352
+ padding-bottom: 0;
353
+ }
354
+ .kd-btn-group-basic-icon {
355
+ margin-left: 4px;
356
+ }
357
+ .kd-btn-group-trigger .kd-btn-primary {
358
+ background: var(--kd-c-button-group-trigger-color-background, #4367c1);
359
+ }
360
+ .kd-btn-group-trigger .kd-btn-primary:hover {
361
+ background: var(--kd-c-button-group-trigger-color-background-hover, #4c74da);
362
+ border-color: var(--kd-c-button-group-trigger-color-background-hover, #4c74da);
363
+ }
364
+ .kd-btn-group-trigger .kd-btn-primary:active {
365
+ background: var(--kd-c-button-group-trigger-color-background-active, #3B5AA9);
366
+ }
367
+ .kd-btn-group-trigger .kd-btn-primary:disabled {
368
+ background: var(--kd-c-button-group-trigger-color-background-disabled, #95a4c8) !important;
369
+ }
370
+ .kd-btn-group-trigger .kd-btn {
371
+ margin-left: -1px;
372
+ }
373
+ .kd-btn-group .kd-btn-size-small,
374
+ .kd-btn-group .kd-btn-size-middle,
375
+ .kd-btn-group .kd-btn-size-large {
376
+ min-width: unset;
377
+ }
378
+ .kd-btn-group .kd-btn:first-child {
379
+ border-top-right-radius: 0;
380
+ border-bottom-right-radius: 0;
381
+ }
382
+ .kd-btn-group .kd-btn:last-child {
383
+ border-top-left-radius: 0;
384
+ border-bottom-left-radius: 0;
385
+ }
386
+ .kd-btn-group .kd-dropdown-menu {
387
+ padding: 0;
388
+ }
389
+ .kd-btn-group-dropdown {
390
+ -webkit-box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.2);
391
+ box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.2);
392
+ background: var(--kd-c-button-group-dropdown-color-background, #fff);
393
+ color: #333333;
394
+ min-width: var(--kd-c-button-group-dropdown-min-width, 80px);
395
+ }
396
+ .kd-btn-group-dropdown-item {
397
+ height: var(--kd-c-button--group-dropdown-item-height, 30px);
398
+ line-height: var(--kd-c-button--group-dropdown-item-height, 30px);
399
+ cursor: pointer;
400
+ padding: 0 var(--kd-c-button-group-dropdown-item-horizonta, 12px);
401
+ }
402
+ .kd-btn-group-dropdown-item:hover {
403
+ background: var(--kd-c-button-group-dropdown-item-color-background-hover, #F5F5F5);
404
+ }
405
+ .kd-btn-group-dropdown-item:not(:last-child) {
406
+ border-bottom: 1px solid var(--kd-c-button-group-dropdown-item-border-color, #E5E5E5);
407
+ }
408
+ .kd-btn-group.topLeft.hidden,
409
+ .kd-btn-group.bottomLeft.hidden,
410
+ .kd-btn-group.topRight.hidden,
411
+ .kd-btn-group.bottomRight.hidden {
412
+ opacity: 0;
413
+ visibility: hidden;
414
+ -webkit-transition: all calc(0.3s - 0.1s) cubic-bezier(0.4, 0, 0.6, 1);
415
+ transition: all calc(0.3s - 0.1s) cubic-bezier(0.4, 0, 0.6, 1);
320
416
  }