@spothero/ui 22.3.2 → 22.3.9-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/index.cjs.js +54151 -0
- package/dist/index.cjs.js.map +1 -0
- package/dist/index.esm.js +53999 -0
- package/dist/index.esm.js.map +1 -0
- package/package.json +39 -40
- package/dist/components/Accordion/Accordion.stories.js +0 -91
- package/dist/components/Accordion/AccordionActionButton.js +0 -29
- package/dist/components/Accordion/index.js +0 -44
- package/dist/components/Accordion/styles/index.js +0 -76
- package/dist/components/Alert/Alert.js +0 -83
- package/dist/components/Alert/Alert.stories.js +0 -49
- package/dist/components/Alert/index.js +0 -13
- package/dist/components/AutoSuggestSelect/AutoSuggestSelect.js +0 -148
- package/dist/components/AutoSuggestSelect/AutoSuggestSelect.stories.js +0 -19
- package/dist/components/AutoSuggestSelect/index.js +0 -13
- package/dist/components/Badge/Badge.js +0 -12
- package/dist/components/Badge/Badge.stories.js +0 -28
- package/dist/components/Badge/styles/index.js +0 -32
- package/dist/components/Button/Button.js +0 -36
- package/dist/components/Button/Button.spec.js +0 -25
- package/dist/components/Button/Button.styles.js +0 -164
- package/dist/components/Button/button-props.js +0 -71
- package/dist/components/Button/index.js +0 -20
- package/dist/components/Button/stories/button.js +0 -45
- package/dist/components/Button/stories/index.stories.js +0 -94
- package/dist/components/Button/stories/overview.js +0 -63
- package/dist/components/Card/Card.js +0 -22
- package/dist/components/Card/Card.stories.js +0 -29
- package/dist/components/Checkbox/Checkbox.js +0 -38
- package/dist/components/Checkbox/Checkbox.stories.js +0 -65
- package/dist/components/Checkbox/index.js +0 -13
- package/dist/components/Checkbox/styles/index.js +0 -89
- package/dist/components/Container/Container.js +0 -17
- package/dist/components/Container/Container.stories.js +0 -43
- package/dist/components/Container/Container.styles.js +0 -16
- package/dist/components/CreatableSelect/CreatableSelect.js +0 -124
- package/dist/components/CreatableSelect/CreatableSelect.stories.js +0 -55
- package/dist/components/CreatableSelect/index.js +0 -13
- package/dist/components/Divider/Divider.js +0 -29
- package/dist/components/Divider/Divider.stories.js +0 -35
- package/dist/components/Divider/Divider.styles.js +0 -20
- package/dist/components/Drawer/Drawer.js +0 -24
- package/dist/components/Drawer/Drawer.stories.js +0 -39
- package/dist/components/Drawer/index.js +0 -56
- package/dist/components/Drawer/styles/index.js +0 -104
- package/dist/components/FormControl/FormControl.js +0 -67
- package/dist/components/Grid/Grid.js +0 -28
- package/dist/components/Grid/Grid.stories.js +0 -100
- package/dist/components/Grid/Grid.styles.js +0 -17
- package/dist/components/Grid/GridItem.js +0 -17
- package/dist/components/Grid/GridItem.styles.js +0 -13
- package/dist/components/Grid/index.js +0 -20
- package/dist/components/Heading/Heading.js +0 -27
- package/dist/components/Heading/Heading.stories.js +0 -41
- package/dist/components/Heading/Heading.styles.js +0 -63
- package/dist/components/Icon/Icon.js +0 -12
- package/dist/components/Icon/Icon.stories.js +0 -36
- package/dist/components/Image/Image.js +0 -73
- package/dist/components/Image/Image.spec.js +0 -77
- package/dist/components/Image/Image.stories.js +0 -74
- package/dist/components/Input/Input.js +0 -44
- package/dist/components/Input/Input.stories.js +0 -59
- package/dist/components/Input/index.js +0 -13
- package/dist/components/Input/styles/index.js +0 -64
- package/dist/components/Link/Link.js +0 -12
- package/dist/components/Link/Link.stories.js +0 -49
- package/dist/components/Link/Link.styles.js +0 -44
- package/dist/components/List/List.js +0 -61
- package/dist/components/List/List.stories.js +0 -75
- package/dist/components/List/index.js +0 -20
- package/dist/components/List/styles/index.js +0 -16
- package/dist/components/List/styles/item.styles.js +0 -10
- package/dist/components/Loader/Loader.js +0 -44
- package/dist/components/Loader/Loader.stories.js +0 -116
- package/dist/components/Menu/Menu.js +0 -16
- package/dist/components/Menu/Menu.stories.js +0 -159
- package/dist/components/Menu/Menu.styles.js +0 -173
- package/dist/components/Menu/index.js +0 -56
- package/dist/components/Modal/Modal.js +0 -42
- package/dist/components/Modal/Modal.stories.js +0 -184
- package/dist/components/Modal/index.js +0 -32
- package/dist/components/Modal/styles/body.js +0 -30
- package/dist/components/Modal/styles/closeButton.js +0 -24
- package/dist/components/Modal/styles/dialog.js +0 -22
- package/dist/components/Modal/styles/dialogContainer.js +0 -19
- package/dist/components/Modal/styles/footer.js +0 -11
- package/dist/components/Modal/styles/header.js +0 -17
- package/dist/components/Modal/styles/index.js +0 -53
- package/dist/components/Modal/styles/overlay.js +0 -10
- package/dist/components/Popover/Popover.js +0 -26
- package/dist/components/Popover/Popover.stories.js +0 -80
- package/dist/components/Popover/PopoverArrow.js +0 -19
- package/dist/components/Popover/PopoverCloseButton.js +0 -19
- package/dist/components/Popover/PopoverContent.js +0 -38
- package/dist/components/Popover/index.js +0 -40
- package/dist/components/Popover/styles/index.js +0 -24
- package/dist/components/Popover/styles/popover-arrow.js +0 -12
- package/dist/components/Popover/styles/popover-body.js +0 -10
- package/dist/components/Popover/styles/popover-close-button.js +0 -26
- package/dist/components/Popover/styles/popover-content.js +0 -26
- package/dist/components/Popover/styles/popover-header.js +0 -11
- package/dist/components/Popover/styles/popper.js +0 -10
- package/dist/components/Progress/Progress.js +0 -37
- package/dist/components/Progress/Progress.stories.js +0 -79
- package/dist/components/Progress/Progress.styles.js +0 -122
- package/dist/components/Radio/Radio.js +0 -37
- package/dist/components/Radio/Radio.stories.js +0 -138
- package/dist/components/Radio/RadioGroup.js +0 -47
- package/dist/components/Radio/index.js +0 -20
- package/dist/components/Radio/styles/index.js +0 -118
- package/dist/components/RefreshedInput/Button/Button.js +0 -67
- package/dist/components/RefreshedInput/Button/Button.stories.js +0 -79
- package/dist/components/RefreshedInput/Button/index.js +0 -13
- package/dist/components/RefreshedInput/Button/styles/index.js +0 -25
- package/dist/components/RefreshedInput/FormControl/index.js +0 -167
- package/dist/components/RefreshedInput/Input/Input.js +0 -61
- package/dist/components/RefreshedInput/Input/Input.stories.js +0 -74
- package/dist/components/RefreshedInput/Input/index.js +0 -13
- package/dist/components/RefreshedInput/Input/styles/index.js +0 -23
- package/dist/components/RefreshedInput/Select/Select.js +0 -65
- package/dist/components/RefreshedInput/Select/Select.stories.js +0 -80
- package/dist/components/RefreshedInput/Select/index.js +0 -13
- package/dist/components/RefreshedInput/Select/styles/index.js +0 -26
- package/dist/components/RefreshedInput/index.js +0 -34
- package/dist/components/RefreshedInput/storyAid/index.js +0 -19
- package/dist/components/Select/Select.js +0 -50
- package/dist/components/Select/Select.stories.js +0 -63
- package/dist/components/Select/index.js +0 -13
- package/dist/components/Select/styles/index.js +0 -46
- package/dist/components/SelectionCard/SelectionCard.js +0 -61
- package/dist/components/SelectionCard/SelectionCard.stories.js +0 -90
- package/dist/components/SelectionCard/index.js +0 -13
- package/dist/components/Skeleton/Skeleton.stories.js +0 -23
- package/dist/components/Skeleton/Skeleton.styles.js +0 -9
- package/dist/components/Skeleton/index.js +0 -24
- package/dist/components/Spinner/Spinner.js +0 -29
- package/dist/components/Spinner/Spinner.stories.js +0 -98
- package/dist/components/Spinner/Spinner.styles.js +0 -85
- package/dist/components/Switch/Switch.js +0 -40
- package/dist/components/Switch/Switch.stories.js +0 -76
- package/dist/components/Switch/index.js +0 -13
- package/dist/components/Switch/styles/index.js +0 -32
- package/dist/components/Table/Table.js +0 -12
- package/dist/components/Table/Table.stories.js +0 -69
- package/dist/components/Table/Table.styles.js +0 -66
- package/dist/components/Table/index.js +0 -62
- package/dist/components/Tabs/Tabs.js +0 -35
- package/dist/components/Tabs/Tabs.stories.js +0 -39
- package/dist/components/Tabs/combineSizeWithVariant.js +0 -36
- package/dist/components/Tabs/index.js +0 -38
- package/dist/components/Tabs/styles/index.js +0 -70
- package/dist/components/Text/Text.js +0 -33
- package/dist/components/Text/Text.stories.js +0 -42
- package/dist/components/Text/Text.styles.js +0 -45
- package/dist/components/Text/combineAsWithVariant.js +0 -100
- package/dist/components/Text/options.js +0 -8
- package/dist/components/Textarea/Textarea.js +0 -44
- package/dist/components/Textarea/Textarea.stories.js +0 -59
- package/dist/components/Textarea/index.js +0 -13
- package/dist/components/Textarea/styles/index.js +0 -64
- package/dist/components/ThemeProvider/ThemeProvider.js +0 -39
- package/dist/components/ThemeProvider/ThemeProvider.stories.js +0 -51
- package/dist/components/Toast/Toast.stories.js +0 -77
- package/dist/components/ToggleButtonGroup/ToggleButtonGroup.js +0 -59
- package/dist/components/ToggleButtonGroup/ToggleButtonGroup.stories.js +0 -53
- package/dist/components/ToggleButtonGroup/index.js +0 -13
- package/dist/components/ToggleButtonGroup/styles/index.js +0 -47
- package/dist/components/index.js +0 -785
- package/dist/components/styles.js +0 -188
- package/dist/theme/base/breakpoints.js +0 -23
- package/dist/theme/base/colors.js +0 -138
- package/dist/theme/base/index.js +0 -79
- package/dist/theme/base/notifications.js +0 -198
- package/dist/theme/base/shadows.js +0 -15
- package/dist/theme/base/sizes.js +0 -88
- package/dist/theme/base/typography.js +0 -38
- package/dist/theme/base/zindices.js +0 -33
- package/dist/theme/global.js +0 -110
- package/dist/theme/index.js +0 -33
- package/dist/utils/Spaces.js +0 -16
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.variants = exports.default = void 0;
|
|
7
|
-
var _typography = require("../../theme/base/typography");
|
|
8
|
-
const baseStyle = {
|
|
9
|
-
lineHeight: 1.5,
|
|
10
|
-
fontWeight: _typography.fontWeights.semibold
|
|
11
|
-
};
|
|
12
|
-
const variants = exports.variants = {
|
|
13
|
-
h1: {
|
|
14
|
-
...baseStyle,
|
|
15
|
-
fontSize: {
|
|
16
|
-
base: _typography.fontSizes['2xl'],
|
|
17
|
-
desktop: _typography.fontSizes['3xl']
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
h2: {
|
|
21
|
-
...baseStyle,
|
|
22
|
-
fontSize: {
|
|
23
|
-
base: _typography.fontSizes.xl,
|
|
24
|
-
desktop: _typography.fontSizes['2xl']
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
|
-
h3: {
|
|
28
|
-
...baseStyle,
|
|
29
|
-
fontSize: {
|
|
30
|
-
base: _typography.fontSizes.lg,
|
|
31
|
-
desktop: _typography.fontSizes.xl
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
h4: {
|
|
35
|
-
...baseStyle,
|
|
36
|
-
fontSize: {
|
|
37
|
-
base: _typography.fontSizes.base,
|
|
38
|
-
desktop: _typography.fontSizes.lg
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
h5: {
|
|
42
|
-
...baseStyle,
|
|
43
|
-
fontSize: {
|
|
44
|
-
base: _typography.fontSizes.base,
|
|
45
|
-
desktop: _typography.fontSizes.base
|
|
46
|
-
}
|
|
47
|
-
},
|
|
48
|
-
h6: {
|
|
49
|
-
...baseStyle,
|
|
50
|
-
fontSize: {
|
|
51
|
-
base: _typography.fontSizes.sm,
|
|
52
|
-
desktop: _typography.fontSizes.sm
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
};
|
|
56
|
-
const defaultProps = {
|
|
57
|
-
variant: variants.h2
|
|
58
|
-
};
|
|
59
|
-
var _default = exports.default = {
|
|
60
|
-
variants,
|
|
61
|
-
baseStyle,
|
|
62
|
-
defaultProps
|
|
63
|
-
};
|
|
@@ -1,36 +0,0 @@
|
|
|
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.Icon = void 0;
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _icons = require("@spothero/icons");
|
|
10
|
-
var _Icon = _interopRequireDefault(require("./Icon"));
|
|
11
|
-
var _default = exports.default = {
|
|
12
|
-
title: 'v2/Icon',
|
|
13
|
-
component: _Icon.default,
|
|
14
|
-
parameters: {
|
|
15
|
-
removeBaseHtmlClass: true
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
const Template = props => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Icon.default, {
|
|
19
|
-
as: _icons.HeroCar,
|
|
20
|
-
color: "primary.default",
|
|
21
|
-
height: "24",
|
|
22
|
-
width: "24"
|
|
23
|
-
}), /*#__PURE__*/_react.default.createElement(_Icon.default, {
|
|
24
|
-
as: _icons.S4BLogo,
|
|
25
|
-
color: "gray.dark",
|
|
26
|
-
height: "24",
|
|
27
|
-
width: "24",
|
|
28
|
-
paddingLeft: "16"
|
|
29
|
-
}), /*#__PURE__*/_react.default.createElement(_Icon.default, {
|
|
30
|
-
as: _icons.CheckmarkShieldFilled,
|
|
31
|
-
color: "green.default",
|
|
32
|
-
height: "24",
|
|
33
|
-
width: "24",
|
|
34
|
-
paddingLeft: "16"
|
|
35
|
-
}));
|
|
36
|
-
const Icon = exports.Icon = Template.bind({});
|
|
@@ -1,73 +0,0 @@
|
|
|
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 _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _react2 = require("@chakra-ui/react");
|
|
10
|
-
var _template = _interopRequireDefault(require("lodash/template"));
|
|
11
|
-
var _environment = _interopRequireDefault(require("@spothero/utils/environment"));
|
|
12
|
-
const buildCloudinarySrc = ({
|
|
13
|
-
cloudinaryImageId,
|
|
14
|
-
cloudinaryTemplate,
|
|
15
|
-
cloudinaryCloudName,
|
|
16
|
-
htmlWidth,
|
|
17
|
-
htmlHeight,
|
|
18
|
-
quality
|
|
19
|
-
}) => {
|
|
20
|
-
const defaultTemplate = `https://res.cloudinary.com/${cloudinaryCloudName}/image/upload/$w_{{WIDTH}},$h_{{HEIGHT}},$q_{{QUALITY}}/c_fill,f_auto,fl_progressive,dpr_${_environment.default.isHighDensityDisplay() ? 2 : 1},h_$h,q_$q,w_$w/${cloudinaryImageId}`;
|
|
21
|
-
const tmpl = cloudinaryTemplate ? cloudinaryTemplate : defaultTemplate;
|
|
22
|
-
return (0, _template.default)(tmpl, {
|
|
23
|
-
interpolate: /{{([\s\S]+?)}}/g // matches template vars in the format '{{ var }}' or '{{var}}'
|
|
24
|
-
})({
|
|
25
|
-
WIDTH: htmlWidth,
|
|
26
|
-
HEIGHT: htmlHeight,
|
|
27
|
-
QUALITY: quality
|
|
28
|
-
});
|
|
29
|
-
};
|
|
30
|
-
const Image = ({
|
|
31
|
-
isSSR,
|
|
32
|
-
cloudinaryImageId,
|
|
33
|
-
cloudinaryTemplate,
|
|
34
|
-
cloudinaryCloudName,
|
|
35
|
-
htmlWidth,
|
|
36
|
-
htmlHeight,
|
|
37
|
-
quality,
|
|
38
|
-
lazyLoad,
|
|
39
|
-
...otherProps
|
|
40
|
-
}) => {
|
|
41
|
-
const hasValidCloudinarySrc = (cloudinaryImageId || cloudinaryTemplate) && Boolean(htmlWidth) && Boolean(htmlHeight);
|
|
42
|
-
let cloudinarySrc;
|
|
43
|
-
if (hasValidCloudinarySrc) {
|
|
44
|
-
cloudinarySrc = buildCloudinarySrc({
|
|
45
|
-
cloudinaryImageId,
|
|
46
|
-
cloudinaryTemplate,
|
|
47
|
-
cloudinaryCloudName,
|
|
48
|
-
htmlWidth,
|
|
49
|
-
htmlHeight,
|
|
50
|
-
quality
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
const imageProps = {
|
|
54
|
-
...otherProps,
|
|
55
|
-
src: cloudinarySrc || otherProps.src,
|
|
56
|
-
htmlWidth,
|
|
57
|
-
htmlHeight,
|
|
58
|
-
...(lazyLoad && {
|
|
59
|
-
loading: 'lazy'
|
|
60
|
-
})
|
|
61
|
-
};
|
|
62
|
-
if (isSSR) {
|
|
63
|
-
return /*#__PURE__*/_react.default.createElement(_react2.Img, imageProps);
|
|
64
|
-
} else {
|
|
65
|
-
return /*#__PURE__*/_react.default.createElement(_react2.Image, imageProps);
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
Image.defaultProps = {
|
|
69
|
-
isSSR: false,
|
|
70
|
-
quality: 50,
|
|
71
|
-
cloudinaryCloudName: 'spothero'
|
|
72
|
-
};
|
|
73
|
-
var _default = exports.default = Image;
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
-
var _react = _interopRequireDefault(require("react"));
|
|
5
|
-
var _react2 = require("@testing-library/react");
|
|
6
|
-
var _Image = _interopRequireDefault(require("./Image"));
|
|
7
|
-
const defaultSrc = 'http://placehold.it/350x200';
|
|
8
|
-
const render = props => {
|
|
9
|
-
(0, _react2.render)( /*#__PURE__*/_react.default.createElement(_Image.default, props));
|
|
10
|
-
};
|
|
11
|
-
describe('Image', () => {
|
|
12
|
-
describe('basic behavior', () => {
|
|
13
|
-
it('displays an image', () => {
|
|
14
|
-
render({
|
|
15
|
-
src: defaultSrc,
|
|
16
|
-
alt: 'An image'
|
|
17
|
-
});
|
|
18
|
-
(0, _react2.waitFor)(() => {
|
|
19
|
-
expect(_react2.screen.getByRole('img')).toHaveAttribute('src', defaultSrc);
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
it('displays an image (SSR)', () => {
|
|
23
|
-
render({
|
|
24
|
-
src: defaultSrc,
|
|
25
|
-
alt: 'An image',
|
|
26
|
-
isSSR: true
|
|
27
|
-
});
|
|
28
|
-
expect(_react2.screen.getByRole('img')).toHaveAttribute('src', defaultSrc);
|
|
29
|
-
});
|
|
30
|
-
});
|
|
31
|
-
describe('Cloudinary properties', () => {
|
|
32
|
-
it('correctly sets image src when a Cloudinary image template is passed in', () => {
|
|
33
|
-
render({
|
|
34
|
-
cloudinaryTemplate: 'https://res.cloudinary.com/spothero/image/upload/$w_{{WIDTH}},$h_{{HEIGHT}},$q_{{QUALITY}}/c_fill,f_auto,h_$h,q_$q,w_$w/html-emails/google',
|
|
35
|
-
htmlWidth: 250,
|
|
36
|
-
htmlHeight: 500,
|
|
37
|
-
quality: 75,
|
|
38
|
-
alt: 'An image'
|
|
39
|
-
});
|
|
40
|
-
(0, _react2.waitFor)(() => {
|
|
41
|
-
expect(_react2.screen.getByRole('img')).toHaveAttribute('src', 'https://res.cloudinary.com/spothero/image/upload/$w_250,$h_500,$q_75/c_fill,f_auto,h_$h,q_$q,w_$w/html-emails/google');
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
it('correctly sets image src when a Cloudinary image id is passed in', () => {
|
|
45
|
-
render({
|
|
46
|
-
cloudinaryImageId: 'html-emails/partner-hertz',
|
|
47
|
-
htmlWidth: 250,
|
|
48
|
-
htmlHeight: 500,
|
|
49
|
-
alt: 'An image',
|
|
50
|
-
isSSR: true
|
|
51
|
-
});
|
|
52
|
-
expect(_react2.screen.getByRole('img')).toHaveAttribute('src', 'https://res.cloudinary.com/spothero/image/upload/$w_250,$h_500,$q_50/c_fill,f_auto,fl_progressive,dpr_1,h_$h,q_$q,w_$w/html-emails/partner-hertz');
|
|
53
|
-
});
|
|
54
|
-
it('does not set in image src when invalid set of Cloudinary props is passed in', () => {
|
|
55
|
-
render({
|
|
56
|
-
cloudinaryImageId: 'html-emails/partner-hertz',
|
|
57
|
-
alt: 'An image',
|
|
58
|
-
isSSR: true
|
|
59
|
-
});
|
|
60
|
-
(0, _react2.waitFor)(() => {
|
|
61
|
-
expect(_react2.screen.getByRole('img')).not.toHaveAttribute('src');
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
});
|
|
65
|
-
describe('Lazy loading', () => {
|
|
66
|
-
it('correctly sets image loading attribute to lazy when lazyLoad prop is true', () => {
|
|
67
|
-
render({
|
|
68
|
-
src: defaultSrc,
|
|
69
|
-
alt: 'An image',
|
|
70
|
-
lazyLoad: true
|
|
71
|
-
});
|
|
72
|
-
(0, _react2.waitFor)(() => {
|
|
73
|
-
expect(_react2.screen.getByRole('img')).toHaveAttribute('loading', 'lazy');
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
});
|
|
@@ -1,74 +0,0 @@
|
|
|
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.StyledImage = exports.SSRImg = exports.LazyLoadImage = exports.DefaultImage = exports.CloudinaryImageTemplate = exports.CloudinaryImageId = void 0;
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _Image = _interopRequireDefault(require("./Image"));
|
|
10
|
-
var _default = exports.default = {
|
|
11
|
-
title: 'v2/Image',
|
|
12
|
-
component: _Image.default,
|
|
13
|
-
parameters: {
|
|
14
|
-
removeBaseHtmlClass: true,
|
|
15
|
-
importBy: 'Image'
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
const Template = props => /*#__PURE__*/_react.default.createElement(_Image.default, props);
|
|
19
|
-
const LazyLoadTemplate = props => /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", null, "Scroll down to see lazy loaded image in action..."), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement(_Image.default, props));
|
|
20
|
-
const DefaultImage = exports.DefaultImage = Template.bind({});
|
|
21
|
-
DefaultImage.args = {
|
|
22
|
-
src: 'http://placehold.it/350x200',
|
|
23
|
-
width: 350,
|
|
24
|
-
height: 200,
|
|
25
|
-
alt: 'Placeholder image'
|
|
26
|
-
};
|
|
27
|
-
const StyledImage = exports.StyledImage = Template.bind({});
|
|
28
|
-
StyledImage.args = {
|
|
29
|
-
src: 'http://placehold.it/350x200',
|
|
30
|
-
alt: 'Placeholder image',
|
|
31
|
-
padding: 4,
|
|
32
|
-
borderColor: 'green.default',
|
|
33
|
-
borderWidth: '1px',
|
|
34
|
-
borderStyle: 'solid',
|
|
35
|
-
height: {
|
|
36
|
-
base: 'auto',
|
|
37
|
-
tablet: 52
|
|
38
|
-
},
|
|
39
|
-
width: {
|
|
40
|
-
base: 'auto',
|
|
41
|
-
tablet: 52
|
|
42
|
-
}
|
|
43
|
-
};
|
|
44
|
-
const SSRImg = exports.SSRImg = Template.bind({});
|
|
45
|
-
SSRImg.args = {
|
|
46
|
-
src: 'http://placehold.it/350x200',
|
|
47
|
-
width: 350,
|
|
48
|
-
height: 200,
|
|
49
|
-
alt: 'SSR image'
|
|
50
|
-
};
|
|
51
|
-
const CloudinaryImageId = exports.CloudinaryImageId = Template.bind({});
|
|
52
|
-
CloudinaryImageId.args = {
|
|
53
|
-
cloudinaryImageId: 'html-emails/partner-hertz',
|
|
54
|
-
htmlWidth: 186,
|
|
55
|
-
htmlHeight: 76,
|
|
56
|
-
quality: 50,
|
|
57
|
-
alt: 'Cloudinary image ID'
|
|
58
|
-
};
|
|
59
|
-
const CloudinaryImageTemplate = exports.CloudinaryImageTemplate = Template.bind({});
|
|
60
|
-
CloudinaryImageTemplate.args = {
|
|
61
|
-
cloudinaryTemplate: 'https://res.cloudinary.com/spothero/image/upload/$w_{{WIDTH}},$h_{{HEIGHT}},$q_{{QUALITY}}/c_fill,f_auto,h_$h,q_$q,w_$w/html-emails/google',
|
|
62
|
-
htmlWidth: 132,
|
|
63
|
-
htmlHeight: 111,
|
|
64
|
-
quality: 80,
|
|
65
|
-
alt: 'Cloudinary image template'
|
|
66
|
-
};
|
|
67
|
-
const LazyLoadImage = exports.LazyLoadImage = LazyLoadTemplate.bind({});
|
|
68
|
-
LazyLoadImage.args = {
|
|
69
|
-
src: 'https://res.cloudinary.com/spothero/image/upload/$w_1024,$h_704,$q_50/c_fill,f_auto,h_$h,q_$q,w_$w,x_375,y_250/v1577978927/rzm2xqhtgqxfv3isxmyy.jpg',
|
|
70
|
-
width: 350,
|
|
71
|
-
height: 200,
|
|
72
|
-
alt: 'Placeholder image',
|
|
73
|
-
lazyLoad: true
|
|
74
|
-
};
|
|
@@ -1,44 +0,0 @@
|
|
|
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 = _interopRequireWildcard(require("react"));
|
|
10
|
-
var _classnames = _interopRequireDefault(require("classnames"));
|
|
11
|
-
var _react2 = require("@chakra-ui/react");
|
|
12
|
-
var _FormControl = _interopRequireDefault(require("../FormControl/FormControl"));
|
|
13
|
-
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
14
|
-
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
15
|
-
const Input = /*#__PURE__*/(0, _react.forwardRef)(({
|
|
16
|
-
label,
|
|
17
|
-
helperText,
|
|
18
|
-
errorMessage,
|
|
19
|
-
isInvalid,
|
|
20
|
-
isDisabled,
|
|
21
|
-
isRequired,
|
|
22
|
-
isOptional,
|
|
23
|
-
customRequiredText,
|
|
24
|
-
...props
|
|
25
|
-
}, ref) => {
|
|
26
|
-
const classes = (0, _classnames.default)({
|
|
27
|
-
'FormElement-contains-error': isInvalid
|
|
28
|
-
});
|
|
29
|
-
return /*#__PURE__*/_react.default.createElement(_FormControl.default, {
|
|
30
|
-
isInvalid: isInvalid,
|
|
31
|
-
isDisabled: isDisabled,
|
|
32
|
-
isRequired: isRequired,
|
|
33
|
-
isOptional: isOptional,
|
|
34
|
-
errorMessage: errorMessage,
|
|
35
|
-
helperText: helperText,
|
|
36
|
-
label: label,
|
|
37
|
-
inputId: props.id,
|
|
38
|
-
customRequiredText: customRequiredText
|
|
39
|
-
}, /*#__PURE__*/_react.default.createElement(_react2.Input, (0, _extends2.default)({
|
|
40
|
-
ref: ref,
|
|
41
|
-
className: classes
|
|
42
|
-
}, props)));
|
|
43
|
-
});
|
|
44
|
-
var _default = exports.default = Input;
|
|
@@ -1,59 +0,0 @@
|
|
|
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.Input = void 0;
|
|
8
|
-
var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
|
|
9
|
-
var _react = _interopRequireDefault(require("react"));
|
|
10
|
-
var _Input = _interopRequireDefault(require("./Input"));
|
|
11
|
-
var _react2 = require("@chakra-ui/react");
|
|
12
|
-
var _default = exports.default = {
|
|
13
|
-
title: 'v2/Input',
|
|
14
|
-
component: _Input.default,
|
|
15
|
-
parameters: {
|
|
16
|
-
importBy: 'Input',
|
|
17
|
-
removeBaseHtmlClass: true,
|
|
18
|
-
chakraLink: 'https://chakra-ui.com/docs/components/input'
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
const InputTemplate = props => /*#__PURE__*/_react.default.createElement(_Input.default, (0, _extends2.default)({
|
|
22
|
-
variant: "outline",
|
|
23
|
-
maxWidth: "200px"
|
|
24
|
-
}, props));
|
|
25
|
-
const Input = exports.Input = InputTemplate.bind({});
|
|
26
|
-
Input.argTypes = {
|
|
27
|
-
placeholder: {
|
|
28
|
-
control: {
|
|
29
|
-
type: 'text'
|
|
30
|
-
}
|
|
31
|
-
},
|
|
32
|
-
label: {
|
|
33
|
-
control: {
|
|
34
|
-
type: 'text'
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
helperText: {
|
|
38
|
-
control: {
|
|
39
|
-
type: 'text'
|
|
40
|
-
}
|
|
41
|
-
},
|
|
42
|
-
errorMessage: {
|
|
43
|
-
control: {
|
|
44
|
-
type: 'text'
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
};
|
|
48
|
-
Input.args = {
|
|
49
|
-
id: 'input_id',
|
|
50
|
-
placeholder: 'Placeholder text',
|
|
51
|
-
label: 'Label',
|
|
52
|
-
helperText: 'Helper text',
|
|
53
|
-
errorMessage: 'Error message',
|
|
54
|
-
isInvalid: false,
|
|
55
|
-
isDisabled: false,
|
|
56
|
-
isReadOnly: false,
|
|
57
|
-
isRequired: false,
|
|
58
|
-
isOptional: false
|
|
59
|
-
};
|
|
@@ -1,13 +0,0 @@
|
|
|
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, "default", {
|
|
8
|
-
enumerable: true,
|
|
9
|
-
get: function () {
|
|
10
|
-
return _Input.default;
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
var _Input = _interopRequireDefault(require("./Input"));
|
|
@@ -1,64 +0,0 @@
|
|
|
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 _merge = _interopRequireDefault(require("lodash/merge"));
|
|
9
|
-
var _theme = _interopRequireDefault(require("@chakra-ui/theme"));
|
|
10
|
-
const baseStyle = {
|
|
11
|
-
field: {
|
|
12
|
-
_placeholder: {
|
|
13
|
-
color: 'text.secondary.light',
|
|
14
|
-
fontWeight: 'normal',
|
|
15
|
-
_disabled: {
|
|
16
|
-
color: 'text.secondary.light',
|
|
17
|
-
opacity: 1
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
const variants = {
|
|
23
|
-
outline: {
|
|
24
|
-
field: {
|
|
25
|
-
border: '1px solid',
|
|
26
|
-
borderColor: 'gray.200',
|
|
27
|
-
fontSize: 'base',
|
|
28
|
-
paddingLeft: 3,
|
|
29
|
-
paddingRight: 3,
|
|
30
|
-
bg: 'inherit',
|
|
31
|
-
fontWeight: 'normal',
|
|
32
|
-
boxShadow: 'none !important',
|
|
33
|
-
_placeholder: {
|
|
34
|
-
color: 'text.secondary.light',
|
|
35
|
-
fontWeight: 'normal'
|
|
36
|
-
},
|
|
37
|
-
_focus: {
|
|
38
|
-
borderColor: 'primary.default'
|
|
39
|
-
},
|
|
40
|
-
_hover: {
|
|
41
|
-
borderColor: 'gray.300'
|
|
42
|
-
},
|
|
43
|
-
_readOnly: {
|
|
44
|
-
boxShadow: 'none !important',
|
|
45
|
-
userSelect: 'all'
|
|
46
|
-
},
|
|
47
|
-
_disabled: {
|
|
48
|
-
backgroundColor: 'gray.50',
|
|
49
|
-
opacity: 1,
|
|
50
|
-
cursor: 'not-allowed'
|
|
51
|
-
},
|
|
52
|
-
_invalid: {
|
|
53
|
-
borderColor: 'error',
|
|
54
|
-
_focus: {
|
|
55
|
-
borderColor: 'error'
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
var _default = exports.default = (0, _merge.default)(_theme.default.components.Input, {
|
|
62
|
-
baseStyle,
|
|
63
|
-
variants
|
|
64
|
-
});
|
|
@@ -1,49 +0,0 @@
|
|
|
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.Overview = void 0;
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _react2 = require("@chakra-ui/react");
|
|
10
|
-
var _share = _interopRequireDefault(require("@spothero/icons/share"));
|
|
11
|
-
var _Text = _interopRequireDefault(require("../Text/Text"));
|
|
12
|
-
var _Link = _interopRequireDefault(require("./Link"));
|
|
13
|
-
var _default = exports.default = {
|
|
14
|
-
title: 'v2/Link',
|
|
15
|
-
component: _Link.default,
|
|
16
|
-
parameters: {
|
|
17
|
-
removeBaseHtmlClass: true
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
const OverviewTemplate = (props, {
|
|
21
|
-
hasDarkBackground
|
|
22
|
-
}) => /*#__PURE__*/_react.default.createElement(_react2.Box, null, /*#__PURE__*/_react.default.createElement(_Text.default, {
|
|
23
|
-
color: hasDarkBackground ? 'text.primary.dark' : 'text.primary.light'
|
|
24
|
-
}, "A link with", ' ', /*#__PURE__*/_react.default.createElement(_Link.default, {
|
|
25
|
-
variant: hasDarkBackground ? 'onDark' : 'standard'
|
|
26
|
-
}, "no href"), ' ', "is only styled."), /*#__PURE__*/_react.default.createElement(_Text.default, {
|
|
27
|
-
color: hasDarkBackground ? 'text.primary.dark' : 'text.primary.light'
|
|
28
|
-
}, "Links can be linked to", ' ', /*#__PURE__*/_react.default.createElement(_Link.default, {
|
|
29
|
-
href: "#",
|
|
30
|
-
isExternal: true,
|
|
31
|
-
variant: hasDarkBackground ? 'onDark' : 'standard'
|
|
32
|
-
}, "External Pages"), ' ', "and will have ", /*#__PURE__*/_react.default.createElement("code", null, "target=\"_blank\""), " and", ' ', /*#__PURE__*/_react.default.createElement("code", null, "rel=\"noopener noreferrer\""), " appended to them."), /*#__PURE__*/_react.default.createElement(_Text.default, {
|
|
33
|
-
color: hasDarkBackground ? 'text.primary.dark' : 'text.primary.light'
|
|
34
|
-
}, "Links can have", ' ', /*#__PURE__*/_react.default.createElement(_Link.default, {
|
|
35
|
-
href: "#",
|
|
36
|
-
variant: hasDarkBackground ? 'onDark' : 'standard'
|
|
37
|
-
}, "icons inline ", /*#__PURE__*/_react.default.createElement(_share.default, {
|
|
38
|
-
width: "1rem"
|
|
39
|
-
}))), /*#__PURE__*/_react.default.createElement(_Text.default, {
|
|
40
|
-
color: hasDarkBackground ? 'text.primary.dark' : 'text.primary.light'
|
|
41
|
-
}, "Using the ", /*#__PURE__*/_react.default.createElement("code", null, "as"), " prop, you can utilize a routing library, like", ' ', /*#__PURE__*/_react.default.createElement(_Link.default, {
|
|
42
|
-
href: "https://chakra-ui.com/docs/navigation/link#usage-with-routing-library",
|
|
43
|
-
isExternal: true,
|
|
44
|
-
variant: hasDarkBackground ? 'onDark' : 'standard'
|
|
45
|
-
}, "React Router"), ' ', "and it will replace the ", /*#__PURE__*/_react.default.createElement("code", null, "a"), " tag with it's", ' ', /*#__PURE__*/_react.default.createElement("code", null, "Link"), "."));
|
|
46
|
-
const Overview = exports.Overview = OverviewTemplate.bind({});
|
|
47
|
-
Overview.parameters = {
|
|
48
|
-
importBy: 'Link'
|
|
49
|
-
};
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
|
|
4
|
-
Object.defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.variants = exports.default = void 0;
|
|
8
|
-
var _merge = _interopRequireDefault(require("lodash/merge"));
|
|
9
|
-
var _theme = _interopRequireDefault(require("@chakra-ui/theme"));
|
|
10
|
-
const baseStyle = {
|
|
11
|
-
transition: `all 0.15s ease`,
|
|
12
|
-
color: 'text.link.light',
|
|
13
|
-
fontWeight: 'semibold',
|
|
14
|
-
_hover: {
|
|
15
|
-
color: 'primary.600',
|
|
16
|
-
textDecoration: 'none'
|
|
17
|
-
},
|
|
18
|
-
_focus: {
|
|
19
|
-
boxShadow: 'outline'
|
|
20
|
-
},
|
|
21
|
-
'& svg': {
|
|
22
|
-
d: 'inline-block',
|
|
23
|
-
verticalAlign: 'initial'
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
const linkOnDark = {
|
|
27
|
-
color: 'text.link.dark',
|
|
28
|
-
_hover: {
|
|
29
|
-
color: 'text.link.dark',
|
|
30
|
-
opacity: '.8'
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
const variants = exports.variants = {
|
|
34
|
-
standard: baseStyle,
|
|
35
|
-
onDark: linkOnDark
|
|
36
|
-
};
|
|
37
|
-
const defaultProps = {
|
|
38
|
-
variant: 'standard'
|
|
39
|
-
};
|
|
40
|
-
var _default = exports.default = (0, _merge.default)(_theme.default.components.Link, {
|
|
41
|
-
baseStyle,
|
|
42
|
-
variants,
|
|
43
|
-
defaultProps
|
|
44
|
-
});
|