@spothero/ui 21.1.0 → 21.1.1-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/ToggleButtonGroup/ToggleButtonGroup.js +61 -0
- package/dist/components/ToggleButtonGroup/ToggleButtonGroup.stories.js +49 -0
- package/dist/components/ToggleButtonGroup/index.js +13 -0
- package/dist/components/ToggleButtonGroup/styles/index.js +51 -0
- package/dist/components/index.js +8 -0
- package/package.json +4 -4
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
9
|
+
var _react = require("@chakra-ui/react");
|
|
10
|
+
var _react2 = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _styles = require("./styles");
|
|
12
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
|
+
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; }
|
|
14
|
+
/**
|
|
15
|
+
* @example (
|
|
16
|
+
* <ToggleButton onChange={handleChangeValue} value={value}>
|
|
17
|
+
* <Button value={value1}>label1</Button>
|
|
18
|
+
* <Button value={value2}>label2</Button>
|
|
19
|
+
* </ToggleButton>
|
|
20
|
+
* )
|
|
21
|
+
* @note
|
|
22
|
+
* must have multiple child elements
|
|
23
|
+
*/
|
|
24
|
+
// const ToggleButtonGroup = forwardRef(({onChange, value, children, groupProps}, ref) => {
|
|
25
|
+
const ToggleButtonGroup = /*#__PURE__*/(0, _react2.forwardRef)((props, ref) => {
|
|
26
|
+
const {
|
|
27
|
+
onChange,
|
|
28
|
+
value,
|
|
29
|
+
children,
|
|
30
|
+
groupProps
|
|
31
|
+
} = props;
|
|
32
|
+
if (!children) throw new Error('Children required');
|
|
33
|
+
|
|
34
|
+
// iterate over array of child nodes to apply extended props
|
|
35
|
+
return /*#__PURE__*/_react2.default.createElement(_react.ButtonGroup, (0, _extends2.default)({
|
|
36
|
+
ref: ref,
|
|
37
|
+
sx: {
|
|
38
|
+
..._styles.buttonGroupStyles
|
|
39
|
+
}
|
|
40
|
+
}, groupProps), _react2.default.Children.map(children, CHILD => {
|
|
41
|
+
return /*#__PURE__*/_react2.default.cloneElement(CHILD, {
|
|
42
|
+
onClick: () => {
|
|
43
|
+
if (value === CHILD?.props?.value) return;
|
|
44
|
+
onChange(CHILD?.props?.value);
|
|
45
|
+
},
|
|
46
|
+
...(value !== CHILD?.props?.value ? {
|
|
47
|
+
sx: {
|
|
48
|
+
..._styles.defaultStyles,
|
|
49
|
+
..._styles.inactiveStyles
|
|
50
|
+
}
|
|
51
|
+
} : {
|
|
52
|
+
sx: {
|
|
53
|
+
..._styles.defaultStyles,
|
|
54
|
+
..._styles.activeStyles
|
|
55
|
+
}
|
|
56
|
+
})
|
|
57
|
+
});
|
|
58
|
+
}));
|
|
59
|
+
});
|
|
60
|
+
var _default = ToggleButtonGroup;
|
|
61
|
+
exports.default = _default;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.default = exports.ToggleButtonGroup = void 0;
|
|
8
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
9
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
10
|
+
var _react2 = require("@chakra-ui/react");
|
|
11
|
+
var _Button = require("../Button");
|
|
12
|
+
var _ToggleButtonGroup = _interopRequireDefault(require("./ToggleButtonGroup"));
|
|
13
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
14
|
+
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; }
|
|
15
|
+
var _default = {
|
|
16
|
+
title: 'v2/ToggleButtonGroup',
|
|
17
|
+
displayName: 'ToggleButtonGroup',
|
|
18
|
+
component: _ToggleButtonGroup.default,
|
|
19
|
+
parameters: {
|
|
20
|
+
removeBaseHtmlClass: true
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
/*
|
|
24
|
+
Storybook's background is white so the ToggleButtonGroup is hard to see.
|
|
25
|
+
The ToggleButtonGroup is typically displayed against a light green background.
|
|
26
|
+
*/
|
|
27
|
+
exports.default = _default;
|
|
28
|
+
const Template = props => {
|
|
29
|
+
const [toggleValue, setToggleValue] = (0, _react.useState)("multiple");
|
|
30
|
+
const onChange = value => {
|
|
31
|
+
setToggleValue(value);
|
|
32
|
+
};
|
|
33
|
+
return /*#__PURE__*/_react.default.createElement(_react2.Box, {
|
|
34
|
+
backgroundColor: "green.50",
|
|
35
|
+
padding: 8
|
|
36
|
+
}, /*#__PURE__*/_react.default.createElement(_ToggleButtonGroup.default, (0, _extends2.default)({}, props, {
|
|
37
|
+
value: toggleValue,
|
|
38
|
+
onChange: onChange
|
|
39
|
+
}), /*#__PURE__*/_react.default.createElement(_Button.Button, {
|
|
40
|
+
key: "single",
|
|
41
|
+
value: "single"
|
|
42
|
+
}, "Single Bookings"), /*#__PURE__*/_react.default.createElement(_Button.Button, {
|
|
43
|
+
key: "multiple",
|
|
44
|
+
value: "multiple"
|
|
45
|
+
}, "Multiple Bookings")));
|
|
46
|
+
};
|
|
47
|
+
const ToggleButtonGroup = Template.bind({});
|
|
48
|
+
exports.ToggleButtonGroup = ToggleButtonGroup;
|
|
49
|
+
ToggleButtonGroup.args = {};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
Object.defineProperty(exports, "ToggleButtonGroup", {
|
|
8
|
+
enumerable: true,
|
|
9
|
+
get: function () {
|
|
10
|
+
return _ToggleButtonGroup.default;
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
var _ToggleButtonGroup = _interopRequireDefault(require("./ToggleButtonGroup"));
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.inactiveStyles = exports.defaultStyles = exports.buttonGroupStyles = exports.activeStyles = void 0;
|
|
7
|
+
const defaultStyles = {
|
|
8
|
+
border: 0,
|
|
9
|
+
borderRadius: '4px',
|
|
10
|
+
fontSize: 'xs',
|
|
11
|
+
fontWeight: 'normal',
|
|
12
|
+
paddingX: 4,
|
|
13
|
+
paddingY: 1,
|
|
14
|
+
_hover: {
|
|
15
|
+
boxShadow: '0 0 0 2px rgba(158, 202, 237, 1)'
|
|
16
|
+
},
|
|
17
|
+
_focus: {
|
|
18
|
+
boxShadow: '0 0 0 2px rgba(158, 202, 237, 1)'
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
exports.defaultStyles = defaultStyles;
|
|
22
|
+
const inactiveStyles = {
|
|
23
|
+
color: 'gray.700',
|
|
24
|
+
borderColor: 'gray.100',
|
|
25
|
+
bg: 'gray.100',
|
|
26
|
+
_hover: {
|
|
27
|
+
bg: 'gray.100'
|
|
28
|
+
},
|
|
29
|
+
_active: {
|
|
30
|
+
bg: 'gray.100'
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
exports.inactiveStyles = inactiveStyles;
|
|
34
|
+
const activeStyles = {
|
|
35
|
+
color: 'black',
|
|
36
|
+
fontWeight: 'semibold',
|
|
37
|
+
bg: 'white',
|
|
38
|
+
_hover: {
|
|
39
|
+
bg: 'white'
|
|
40
|
+
},
|
|
41
|
+
_active: {
|
|
42
|
+
bg: 'white'
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
exports.activeStyles = activeStyles;
|
|
46
|
+
const buttonGroupStyles = {
|
|
47
|
+
borderRadius: '4px',
|
|
48
|
+
backgroundColor: 'gray.100',
|
|
49
|
+
padding: 1
|
|
50
|
+
};
|
|
51
|
+
exports.buttonGroupStyles = buttonGroupStyles;
|
package/dist/components/index.js
CHANGED
|
@@ -40,6 +40,7 @@ var _exportNames = {
|
|
|
40
40
|
RadioGroup: true,
|
|
41
41
|
AutoSuggestSelect: true,
|
|
42
42
|
Badge: true,
|
|
43
|
+
ToggleButtonGroup: true,
|
|
43
44
|
Box: true,
|
|
44
45
|
Kbd: true,
|
|
45
46
|
Code: true,
|
|
@@ -453,6 +454,12 @@ Object.defineProperty(exports, "ThemeProvider", {
|
|
|
453
454
|
return _ThemeProvider.default;
|
|
454
455
|
}
|
|
455
456
|
});
|
|
457
|
+
Object.defineProperty(exports, "ToggleButtonGroup", {
|
|
458
|
+
enumerable: true,
|
|
459
|
+
get: function () {
|
|
460
|
+
return _ToggleButtonGroup.default;
|
|
461
|
+
}
|
|
462
|
+
});
|
|
456
463
|
Object.defineProperty(exports, "VStack", {
|
|
457
464
|
enumerable: true,
|
|
458
465
|
get: function () {
|
|
@@ -628,6 +635,7 @@ var _Popover = require("./Popover");
|
|
|
628
635
|
var _Radio = require("./Radio");
|
|
629
636
|
var _AutoSuggestSelect = require("./AutoSuggestSelect");
|
|
630
637
|
var _Badge = _interopRequireDefault(require("./Badge/Badge"));
|
|
638
|
+
var _ToggleButtonGroup = _interopRequireDefault(require("./ToggleButtonGroup/ToggleButtonGroup"));
|
|
631
639
|
var _react = require("@chakra-ui/react");
|
|
632
640
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
633
641
|
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; }
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spothero/ui",
|
|
3
|
-
"version": "21.1.0",
|
|
3
|
+
"version": "21.1.1-beta.0",
|
|
4
4
|
"description": "SpotHero's React component UI library.",
|
|
5
5
|
"main": "./dist/components/index.js",
|
|
6
6
|
"exports": "./dist/components/index.js",
|
|
@@ -96,13 +96,13 @@
|
|
|
96
96
|
"css-loader": "5.1.3",
|
|
97
97
|
"sass-loader": "10.2.1",
|
|
98
98
|
"@spothero/babel-preset-spothero": "5.0.0",
|
|
99
|
-
"@spothero/core": "7.0.0",
|
|
100
99
|
"@spothero/browserslist-config": "4.0.0",
|
|
101
100
|
"@spothero/eslint-config": "6.0.0",
|
|
101
|
+
"@spothero/core": "7.0.0",
|
|
102
102
|
"@spothero/icons": "8.0.0",
|
|
103
103
|
"@spothero/npm-publisher": "7.0.0",
|
|
104
|
-
"@spothero/
|
|
105
|
-
"@spothero/
|
|
104
|
+
"@spothero/prettier-config": "4.0.0",
|
|
105
|
+
"@spothero/stylelint-config": "6.0.0"
|
|
106
106
|
},
|
|
107
107
|
"dependencies": {
|
|
108
108
|
"@chakra-ui/react": "1.8.8",
|