@atlaskit/button 16.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +1485 -0
- package/LICENSE +13 -0
- package/README.md +13 -0
- package/__perf__/button.tsx +19 -0
- package/__perf__/custom.tsx +19 -0
- package/__perf__/customised.tsx +11 -0
- package/__perf__/default.tsx +5 -0
- package/__perf__/loading.tsx +5 -0
- package/__perf__/utils/example-runner.tsx +48 -0
- package/__perf__/utils/interaction-tasks.tsx +98 -0
- package/button-group/package.json +7 -0
- package/codemods/15.0.0-lite-mode.ts +49 -0
- package/codemods/15.1.1-data-testid.ts +173 -0
- package/codemods/__tests__/15.0.0-lite-mode/optimistic.ts +646 -0
- package/codemods/__tests__/15.0.0-lite-mode/safe.ts +223 -0
- package/codemods/__tests__/15.0.0-lite-mode/shared.ts +257 -0
- package/codemods/__tests__/15.1.1-data-testid/rename-data-testid.ts +186 -0
- package/codemods/__tests__/_framework.ts +47 -0
- package/codemods/helpers/15.0.0-runner.ts +169 -0
- package/codemods/helpers/helpers-generic.ts +662 -0
- package/codemods/optimistic-15.0.0-lite-mode.ts +279 -0
- package/codemods/readme.md +1 -0
- package/custom-theme-button/package.json +7 -0
- package/dist/cjs/button-group.js +50 -0
- package/dist/cjs/button.js +104 -0
- package/dist/cjs/custom-theme-button/custom-theme-button-types.js +5 -0
- package/dist/cjs/custom-theme-button/custom-theme-button.js +229 -0
- package/dist/cjs/custom-theme-button/index.js +23 -0
- package/dist/cjs/custom-theme-button/theme.js +108 -0
- package/dist/cjs/entry-points/button-group.js +15 -0
- package/dist/cjs/entry-points/custom-theme-button.js +25 -0
- package/dist/cjs/entry-points/loading-button.js +15 -0
- package/dist/cjs/entry-points/standard-button.js +15 -0
- package/dist/cjs/entry-points/types.js +5 -0
- package/dist/cjs/index.js +51 -0
- package/dist/cjs/loading-button.js +34 -0
- package/dist/cjs/shared/block-events.js +44 -0
- package/dist/cjs/shared/button-base.js +158 -0
- package/dist/cjs/shared/colors.js +409 -0
- package/dist/cjs/shared/css.js +265 -0
- package/dist/cjs/shared/get-is-only-single-icon.js +26 -0
- package/dist/cjs/shared/loading-spinner.js +45 -0
- package/dist/cjs/types.js +5 -0
- package/dist/cjs/version.json +5 -0
- package/dist/es2019/button-group.js +36 -0
- package/dist/es2019/button.js +69 -0
- package/dist/es2019/custom-theme-button/custom-theme-button-types.js +1 -0
- package/dist/es2019/custom-theme-button/custom-theme-button.js +164 -0
- package/dist/es2019/custom-theme-button/index.js +2 -0
- package/dist/es2019/custom-theme-button/theme.js +81 -0
- package/dist/es2019/entry-points/button-group.js +1 -0
- package/dist/es2019/entry-points/custom-theme-button.js +1 -0
- package/dist/es2019/entry-points/loading-button.js +1 -0
- package/dist/es2019/entry-points/standard-button.js +1 -0
- package/dist/es2019/entry-points/types.js +1 -0
- package/dist/es2019/index.js +6 -0
- package/dist/es2019/loading-button.js +17 -0
- package/dist/es2019/shared/block-events.js +37 -0
- package/dist/es2019/shared/button-base.js +127 -0
- package/dist/es2019/shared/colors.js +393 -0
- package/dist/es2019/shared/css.js +249 -0
- package/dist/es2019/shared/get-is-only-single-icon.js +19 -0
- package/dist/es2019/shared/loading-spinner.js +33 -0
- package/dist/es2019/types.js +1 -0
- package/dist/es2019/version.json +5 -0
- package/dist/esm/button-group.js +35 -0
- package/dist/esm/button.js +79 -0
- package/dist/esm/custom-theme-button/custom-theme-button-types.js +1 -0
- package/dist/esm/custom-theme-button/custom-theme-button.js +203 -0
- package/dist/esm/custom-theme-button/index.js +2 -0
- package/dist/esm/custom-theme-button/theme.js +90 -0
- package/dist/esm/entry-points/button-group.js +1 -0
- package/dist/esm/entry-points/custom-theme-button.js +1 -0
- package/dist/esm/entry-points/loading-button.js +1 -0
- package/dist/esm/entry-points/standard-button.js +1 -0
- package/dist/esm/entry-points/types.js +1 -0
- package/dist/esm/index.js +6 -0
- package/dist/esm/loading-button.js +19 -0
- package/dist/esm/shared/block-events.js +36 -0
- package/dist/esm/shared/button-base.js +135 -0
- package/dist/esm/shared/colors.js +393 -0
- package/dist/esm/shared/css.js +245 -0
- package/dist/esm/shared/get-is-only-single-icon.js +19 -0
- package/dist/esm/shared/loading-spinner.js +35 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/version.json +5 -0
- package/dist/types/button-group.d.ts +18 -0
- package/dist/types/button.d.ts +8 -0
- package/dist/types/custom-theme-button/custom-theme-button-types.d.ts +21 -0
- package/dist/types/custom-theme-button/custom-theme-button.d.ts +6 -0
- package/dist/types/custom-theme-button/index.d.ts +2 -0
- package/dist/types/custom-theme-button/theme.d.ts +21 -0
- package/dist/types/entry-points/button-group.d.ts +1 -0
- package/dist/types/entry-points/custom-theme-button.d.ts +2 -0
- package/dist/types/entry-points/loading-button.d.ts +2 -0
- package/dist/types/entry-points/standard-button.d.ts +2 -0
- package/dist/types/entry-points/types.d.ts +4 -0
- package/dist/types/index.d.ts +8 -0
- package/dist/types/loading-button.d.ts +11 -0
- package/dist/types/shared/block-events.d.ts +3 -0
- package/dist/types/shared/button-base.d.ts +10 -0
- package/dist/types/shared/colors.d.ts +31 -0
- package/dist/types/shared/css.d.ts +22 -0
- package/dist/types/shared/get-is-only-single-icon.d.ts +2 -0
- package/dist/types/shared/loading-spinner.d.ts +4 -0
- package/dist/types/types.d.ts +51 -0
- package/extract-react-types/custom-theme-button-props.tsx +7 -0
- package/extract-react-types/loading-button-props.tsx +5 -0
- package/extract-react-types/shared-props.tsx +5 -0
- package/loading-button/package.json +7 -0
- package/package.json +83 -0
- package/standard-button/package.json +7 -0
- package/types/package.json +7 -0
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.default = void 0;
|
|
11
|
+
|
|
12
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
13
|
+
|
|
14
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
15
|
+
|
|
16
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
17
|
+
|
|
18
|
+
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
19
|
+
|
|
20
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
21
|
+
|
|
22
|
+
var _components = _interopRequireDefault(require("@atlaskit/theme/components"));
|
|
23
|
+
|
|
24
|
+
var _buttonBase = _interopRequireDefault(require("../shared/button-base"));
|
|
25
|
+
|
|
26
|
+
var _getIsOnlySingleIcon = _interopRequireDefault(require("../shared/get-is-only-single-icon"));
|
|
27
|
+
|
|
28
|
+
var _loadingSpinner = _interopRequireDefault(require("../shared/loading-spinner"));
|
|
29
|
+
|
|
30
|
+
var _theme = _interopRequireWildcard(require("./theme"));
|
|
31
|
+
|
|
32
|
+
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); }
|
|
33
|
+
|
|
34
|
+
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; }
|
|
35
|
+
|
|
36
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
37
|
+
|
|
38
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
39
|
+
|
|
40
|
+
function getInteractionState(_ref) {
|
|
41
|
+
var _ref$isDisabled = _ref.isDisabled,
|
|
42
|
+
isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
|
|
43
|
+
_ref$isActive = _ref.isActive,
|
|
44
|
+
isActive = _ref$isActive === void 0 ? false : _ref$isActive,
|
|
45
|
+
_ref$isFocus = _ref.isFocus,
|
|
46
|
+
isFocus = _ref$isFocus === void 0 ? false : _ref$isFocus,
|
|
47
|
+
_ref$isHover = _ref.isHover,
|
|
48
|
+
isHover = _ref$isHover === void 0 ? false : _ref$isHover,
|
|
49
|
+
_ref$isSelected = _ref.isSelected,
|
|
50
|
+
isSelected = _ref$isSelected === void 0 ? false : _ref$isSelected,
|
|
51
|
+
_ref$isLoading = _ref.isLoading,
|
|
52
|
+
isLoading = _ref$isLoading === void 0 ? false : _ref$isLoading;
|
|
53
|
+
|
|
54
|
+
if (isDisabled) {
|
|
55
|
+
return 'disabled';
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
if (isSelected && isFocus) {
|
|
59
|
+
return 'focusSelected';
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
if (isSelected) {
|
|
63
|
+
return 'selected';
|
|
64
|
+
} // not allowing active or focus style changes while loading
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
if (!isLoading && isActive) {
|
|
68
|
+
return 'active';
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (!isLoading && isHover) {
|
|
72
|
+
return 'hover';
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (isFocus) {
|
|
76
|
+
return 'focus';
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return 'default';
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
var initial = {
|
|
83
|
+
isHover: false,
|
|
84
|
+
isActive: false,
|
|
85
|
+
isFocus: false
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
var CustomThemeButton = /*#__PURE__*/_react.default.memo( /*#__PURE__*/_react.default.forwardRef(function CustomThemeButton(_ref2, ref) {
|
|
89
|
+
var _ref2$appearance = _ref2.appearance,
|
|
90
|
+
appearance = _ref2$appearance === void 0 ? 'default' : _ref2$appearance,
|
|
91
|
+
_ref2$autoFocus = _ref2.autoFocus,
|
|
92
|
+
autoFocus = _ref2$autoFocus === void 0 ? false : _ref2$autoFocus,
|
|
93
|
+
_ref2$isDisabled = _ref2.isDisabled,
|
|
94
|
+
isDisabled = _ref2$isDisabled === void 0 ? false : _ref2$isDisabled,
|
|
95
|
+
_ref2$isSelected = _ref2.isSelected,
|
|
96
|
+
isSelected = _ref2$isSelected === void 0 ? false : _ref2$isSelected,
|
|
97
|
+
_ref2$shouldFitContai = _ref2.shouldFitContainer,
|
|
98
|
+
shouldFitContainer = _ref2$shouldFitContai === void 0 ? false : _ref2$shouldFitContai,
|
|
99
|
+
_ref2$spacing = _ref2.spacing,
|
|
100
|
+
spacing = _ref2$spacing === void 0 ? 'default' : _ref2$spacing,
|
|
101
|
+
_ref2$isLoading = _ref2.isLoading,
|
|
102
|
+
isLoading = _ref2$isLoading === void 0 ? false : _ref2$isLoading,
|
|
103
|
+
providedOnMouseEnter = _ref2.onMouseEnter,
|
|
104
|
+
providedOnMouseLeave = _ref2.onMouseLeave,
|
|
105
|
+
providedOnMouseDown = _ref2.onMouseDown,
|
|
106
|
+
providedOnMouseUp = _ref2.onMouseUp,
|
|
107
|
+
providedOnFocus = _ref2.onFocus,
|
|
108
|
+
providedOnBlur = _ref2.onBlur,
|
|
109
|
+
_ref2$theme = _ref2.theme,
|
|
110
|
+
theme = _ref2$theme === void 0 ? _theme.defaultThemeFn : _ref2$theme,
|
|
111
|
+
rest = (0, _objectWithoutProperties2.default)(_ref2, ["appearance", "autoFocus", "isDisabled", "isSelected", "shouldFitContainer", "spacing", "isLoading", "onMouseEnter", "onMouseLeave", "onMouseDown", "onMouseUp", "onFocus", "onBlur", "theme"]);
|
|
112
|
+
|
|
113
|
+
// TODO is there a nicer way to do this?
|
|
114
|
+
// Add default props back into object for spreading
|
|
115
|
+
var restProps = _objectSpread({
|
|
116
|
+
appearance: appearance,
|
|
117
|
+
autoFocus: autoFocus,
|
|
118
|
+
isDisabled: isDisabled,
|
|
119
|
+
isSelected: isSelected,
|
|
120
|
+
shouldFitContainer: shouldFitContainer,
|
|
121
|
+
spacing: spacing
|
|
122
|
+
}, rest);
|
|
123
|
+
|
|
124
|
+
var _useState = (0, _react.useState)(initial),
|
|
125
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
126
|
+
state = _useState2[0],
|
|
127
|
+
setState = _useState2[1];
|
|
128
|
+
|
|
129
|
+
var onMouseEnter = (0, _react.useCallback)(function (event) {
|
|
130
|
+
setState(function (current) {
|
|
131
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
132
|
+
isHover: true
|
|
133
|
+
});
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
if (providedOnMouseEnter) {
|
|
137
|
+
providedOnMouseEnter(event);
|
|
138
|
+
}
|
|
139
|
+
}, [providedOnMouseEnter]);
|
|
140
|
+
var onMouseLeave = (0, _react.useCallback)(function (event) {
|
|
141
|
+
setState(function (current) {
|
|
142
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
143
|
+
isHover: false,
|
|
144
|
+
isActive: false
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
if (providedOnMouseLeave) {
|
|
149
|
+
providedOnMouseLeave(event);
|
|
150
|
+
}
|
|
151
|
+
}, [providedOnMouseLeave]);
|
|
152
|
+
var onMouseDown = (0, _react.useCallback)(function (event) {
|
|
153
|
+
setState(function (current) {
|
|
154
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
155
|
+
isActive: true
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
|
|
159
|
+
if (providedOnMouseDown) {
|
|
160
|
+
providedOnMouseDown(event);
|
|
161
|
+
}
|
|
162
|
+
}, [providedOnMouseDown]);
|
|
163
|
+
var onMouseUp = (0, _react.useCallback)(function (event) {
|
|
164
|
+
setState(function (current) {
|
|
165
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
166
|
+
isActive: false
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
if (providedOnMouseUp) {
|
|
171
|
+
providedOnMouseUp(event);
|
|
172
|
+
}
|
|
173
|
+
}, [providedOnMouseUp]);
|
|
174
|
+
var onFocus = (0, _react.useCallback)(function (event) {
|
|
175
|
+
setState(function (current) {
|
|
176
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
177
|
+
isFocus: true
|
|
178
|
+
});
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
if (providedOnFocus) {
|
|
182
|
+
providedOnFocus(event);
|
|
183
|
+
}
|
|
184
|
+
}, [providedOnFocus]);
|
|
185
|
+
var onBlur = (0, _react.useCallback)(function (event) {
|
|
186
|
+
setState(function (current) {
|
|
187
|
+
return _objectSpread(_objectSpread({}, current), {}, {
|
|
188
|
+
isFocus: false
|
|
189
|
+
});
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
if (providedOnBlur) {
|
|
193
|
+
providedOnBlur(event);
|
|
194
|
+
}
|
|
195
|
+
}, [providedOnBlur]);
|
|
196
|
+
return /*#__PURE__*/_react.default.createElement(_theme.default.Provider, {
|
|
197
|
+
value: theme
|
|
198
|
+
}, /*#__PURE__*/_react.default.createElement(_components.default.Consumer, null, function (_ref3) {
|
|
199
|
+
var mode = _ref3.mode;
|
|
200
|
+
return /*#__PURE__*/_react.default.createElement(_theme.default.Consumer, (0, _extends2.default)({
|
|
201
|
+
mode: mode,
|
|
202
|
+
state: getInteractionState(_objectSpread(_objectSpread({}, state), {}, {
|
|
203
|
+
isLoading: isLoading,
|
|
204
|
+
isSelected: restProps.isSelected,
|
|
205
|
+
isDisabled: restProps.isDisabled
|
|
206
|
+
})),
|
|
207
|
+
iconIsOnlyChild: (0, _getIsOnlySingleIcon.default)(restProps),
|
|
208
|
+
isLoading: isLoading
|
|
209
|
+
}, restProps), function (_ref4) {
|
|
210
|
+
var buttonStyles = _ref4.buttonStyles;
|
|
211
|
+
return /*#__PURE__*/_react.default.createElement(_buttonBase.default, (0, _extends2.default)({}, restProps, {
|
|
212
|
+
ref: ref,
|
|
213
|
+
overlay: isLoading ? /*#__PURE__*/_react.default.createElement(_loadingSpinner.default, restProps) : null,
|
|
214
|
+
onMouseEnter: onMouseEnter,
|
|
215
|
+
onMouseLeave: onMouseLeave,
|
|
216
|
+
onMouseDown: onMouseDown,
|
|
217
|
+
onMouseUp: onMouseUp,
|
|
218
|
+
onFocus: onFocus,
|
|
219
|
+
onBlur: onBlur,
|
|
220
|
+
buttonCss: (0, _theme.getSpecifiers)(buttonStyles)
|
|
221
|
+
}));
|
|
222
|
+
});
|
|
223
|
+
}));
|
|
224
|
+
})); // Tools including enzyme rely on components having a display name
|
|
225
|
+
|
|
226
|
+
|
|
227
|
+
CustomThemeButton.displayName = 'CustomThemeButton';
|
|
228
|
+
var _default = CustomThemeButton;
|
|
229
|
+
exports.default = _default;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
Object.defineProperty(exports, "default", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function get() {
|
|
11
|
+
return _customThemeButton.default;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(exports, "Theme", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function get() {
|
|
17
|
+
return _theme.default;
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
var _customThemeButton = _interopRequireDefault(require("./custom-theme-button"));
|
|
22
|
+
|
|
23
|
+
var _theme = _interopRequireDefault(require("./theme"));
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.getCustomCss = getCustomCss;
|
|
9
|
+
exports.getSpecifiers = getSpecifiers;
|
|
10
|
+
exports.defaultThemeFn = defaultThemeFn;
|
|
11
|
+
exports.default = void 0;
|
|
12
|
+
|
|
13
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
14
|
+
|
|
15
|
+
var _components = require("@atlaskit/theme/components");
|
|
16
|
+
|
|
17
|
+
var _css = require("../shared/css");
|
|
18
|
+
|
|
19
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
20
|
+
|
|
21
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
22
|
+
|
|
23
|
+
var stateToSelectorMap = {
|
|
24
|
+
focus: '&:focus',
|
|
25
|
+
focusSelected: '&:focus',
|
|
26
|
+
hover: '&:hover',
|
|
27
|
+
active: '&:active',
|
|
28
|
+
disabled: '&[disabled]'
|
|
29
|
+
}; // Mapping the new clean css back to the legacy theme format.
|
|
30
|
+
// The legacy theme format has all styles at the top level (no nested selectors)
|
|
31
|
+
// and uses `getSpecifiers()` to apply the style to all pseudo states
|
|
32
|
+
|
|
33
|
+
function getCustomCss(_ref) {
|
|
34
|
+
var _ref$appearance = _ref.appearance,
|
|
35
|
+
appearance = _ref$appearance === void 0 ? 'default' : _ref$appearance,
|
|
36
|
+
_ref$spacing = _ref.spacing,
|
|
37
|
+
spacing = _ref$spacing === void 0 ? 'default' : _ref$spacing,
|
|
38
|
+
_ref$mode = _ref.mode,
|
|
39
|
+
mode = _ref$mode === void 0 ? 'light' : _ref$mode,
|
|
40
|
+
_ref$isSelected = _ref.isSelected,
|
|
41
|
+
isSelected = _ref$isSelected === void 0 ? false : _ref$isSelected,
|
|
42
|
+
_ref$shouldFitContain = _ref.shouldFitContainer,
|
|
43
|
+
shouldFitContainer = _ref$shouldFitContain === void 0 ? false : _ref$shouldFitContain,
|
|
44
|
+
_ref$iconIsOnlyChild = _ref.iconIsOnlyChild,
|
|
45
|
+
iconIsOnlyChild = _ref$iconIsOnlyChild === void 0 ? false : _ref$iconIsOnlyChild,
|
|
46
|
+
_ref$isLoading = _ref.isLoading,
|
|
47
|
+
isLoading = _ref$isLoading === void 0 ? false : _ref$isLoading,
|
|
48
|
+
state = _ref.state;
|
|
49
|
+
var result = (0, _css.getCss)({
|
|
50
|
+
appearance: appearance,
|
|
51
|
+
spacing: spacing,
|
|
52
|
+
mode: mode,
|
|
53
|
+
isSelected: isSelected,
|
|
54
|
+
shouldFitContainer: shouldFitContainer,
|
|
55
|
+
isOnlySingleIcon: iconIsOnlyChild
|
|
56
|
+
}); // we need to disable the default browser focus styles always
|
|
57
|
+
// this is because we are not expressing that we can have two pseudo states at a time
|
|
58
|
+
|
|
59
|
+
result.outline = 'none'; // Pulling relevant styles up to the top level
|
|
60
|
+
|
|
61
|
+
var selector = stateToSelectorMap[state];
|
|
62
|
+
|
|
63
|
+
if (selector) {
|
|
64
|
+
result = _objectSpread(_objectSpread({}, result), result[selector]);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if (isLoading) {
|
|
68
|
+
result = _objectSpread(_objectSpread({}, result), result['&[data-has-overlay="true"]']);
|
|
69
|
+
} // Delete all selectors and just keep root styles
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
Object.keys(result).forEach(function (key) {
|
|
73
|
+
// want to keep this one
|
|
74
|
+
if (key === '&::-moz-focus-inner') {
|
|
75
|
+
return;
|
|
76
|
+
} // Not using .startsWith for ie11
|
|
77
|
+
|
|
78
|
+
|
|
79
|
+
if (key.indexOf('&') === 0) {
|
|
80
|
+
delete result[key];
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
return result;
|
|
84
|
+
} // This styling approach works by generating a 'style' and applying with maximum specificity
|
|
85
|
+
// To do this we are overwriting all pseudo selectors
|
|
86
|
+
|
|
87
|
+
|
|
88
|
+
function getSpecifiers(styles) {
|
|
89
|
+
return {
|
|
90
|
+
'&, &:hover, &:active, &:focus, &:visited, &:disabled, &[disabled]': styles
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function defaultThemeFn(current, values) {
|
|
95
|
+
return current(values);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
var Theme = (0, _components.createTheme)(function (themeProps) {
|
|
99
|
+
return {
|
|
100
|
+
buttonStyles: getCustomCss(themeProps),
|
|
101
|
+
// No styles being applied directly to spinner by default
|
|
102
|
+
// Keeping this for legacy compat. We could remove it, but given
|
|
103
|
+
// that we are changing theme soon there is no point
|
|
104
|
+
spinnerStyles: {}
|
|
105
|
+
};
|
|
106
|
+
});
|
|
107
|
+
var _default = Theme;
|
|
108
|
+
exports.default = _default;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
Object.defineProperty(exports, "default", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function get() {
|
|
11
|
+
return _buttonGroup.default;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
var _buttonGroup = _interopRequireDefault(require("../button-group"));
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
Object.defineProperty(exports, "default", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function get() {
|
|
11
|
+
return _customThemeButton.default;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
Object.defineProperty(exports, "Theme", {
|
|
15
|
+
enumerable: true,
|
|
16
|
+
get: function get() {
|
|
17
|
+
return _customThemeButton.Theme;
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
var _customThemeButton = _interopRequireWildcard(require("../custom-theme-button"));
|
|
22
|
+
|
|
23
|
+
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); }
|
|
24
|
+
|
|
25
|
+
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; }
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
Object.defineProperty(exports, "default", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function get() {
|
|
11
|
+
return _loadingButton.default;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
var _loadingButton = _interopRequireDefault(require("../loading-button"));
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
Object.defineProperty(exports, "default", {
|
|
9
|
+
enumerable: true,
|
|
10
|
+
get: function get() {
|
|
11
|
+
return _button.default;
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
var _button = _interopRequireDefault(require("../button"));
|