@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.
@@ -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;
@@ -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/stylelint-config": "6.0.0",
105
- "@spothero/prettier-config": "4.0.0"
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",