@preply/ds-web-lib 0.89.0 → 0.91.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/Avatar/Avatar.d.ts.map +1 -1
- package/dist/components/Avatar/Avatar.js +5 -5
- package/dist/components/AvatarWithStatus/AvatarWithStatus.d.ts.map +1 -1
- package/dist/components/AvatarWithStatus/AvatarWithStatus.js +10 -6
- package/dist/components/Badge/Badge.d.ts.map +1 -1
- package/dist/components/Badge/Badge.js +4 -4
- package/dist/components/Box/Box.d.ts.map +1 -1
- package/dist/components/Box/Box.js +4 -4
- package/dist/components/Button/Button.d.ts.map +1 -1
- package/dist/components/Button/Button.js +5 -5
- package/dist/components/Chips/Chips.d.ts +80 -0
- package/dist/components/Chips/Chips.d.ts.map +1 -0
- package/dist/components/Chips/Chips.js +36 -0
- package/dist/components/Chips/Chips.stories.d.ts +10 -0
- package/dist/components/Chips/Chips.stories.d.ts.map +1 -0
- package/dist/components/Chips/Chips.stories.js +76 -0
- package/dist/components/Chips/style/index.module.less +94 -0
- package/dist/components/Chips/style/index.module.less.js +9 -0
- package/dist/components/FieldAdditionalText/FieldAdditionalText.d.ts.map +1 -1
- package/dist/components/FieldAdditionalText/FieldAdditionalText.js +4 -3
- package/dist/components/FieldButton/FieldButton.d.ts.map +1 -1
- package/dist/components/FieldButton/FieldButton.js +4 -4
- package/dist/components/FieldLayout/FieldLayout.d.ts.map +1 -1
- package/dist/components/FieldLayout/FieldLayout.js +7 -6
- package/dist/components/Heading/Heading.d.ts.map +1 -1
- package/dist/components/Heading/Heading.js +5 -5
- package/dist/components/Icon/Icon.d.ts.map +1 -1
- package/dist/components/Icon/Icon.js +4 -4
- package/dist/components/IconButton/IconButton.d.ts.map +1 -1
- package/dist/components/IconButton/IconButton.js +4 -4
- package/dist/components/LayoutFlex/LayoutFlex.d.ts.map +1 -1
- package/dist/components/LayoutFlex/LayoutFlex.js +4 -4
- package/dist/components/LayoutFlexItem/LayoutFlexItem.d.ts.map +1 -1
- package/dist/components/LayoutFlexItem/LayoutFlexItem.js +4 -4
- package/dist/components/LayoutGrid/LayoutGrid.d.ts.map +1 -1
- package/dist/components/LayoutGrid/LayoutGrid.js +3 -2
- package/dist/components/LayoutGridItem/LayoutGridItem.d.ts.map +1 -1
- package/dist/components/LayoutGridItem/LayoutGridItem.js +4 -4
- package/dist/components/Link/Link.d.ts.map +1 -1
- package/dist/components/Link/Link.js +5 -5
- package/dist/components/Loader/Loader.d.ts.map +1 -1
- package/dist/components/Loader/Loader.js +4 -4
- package/dist/components/NumberField/NumberField.d.ts.map +1 -1
- package/dist/components/NumberField/NumberField.js +4 -4
- package/dist/components/ObserveIntersection/ObserveIntersection.d.ts.map +1 -1
- package/dist/components/ObserveIntersection/ObserveIntersection.js +3 -2
- package/dist/components/Panel/Panel.d.ts.map +1 -1
- package/dist/components/Panel/Panel.js +7 -5
- package/dist/components/Panel/private/PanelBody.d.ts.map +1 -1
- package/dist/components/Panel/private/PanelBody.js +4 -4
- package/dist/components/Panel/private/PanelFooter.d.ts.map +1 -1
- package/dist/components/Panel/private/PanelFooter.js +4 -4
- package/dist/components/Panel/private/PanelHeader.d.ts.map +1 -1
- package/dist/components/Panel/private/PanelHeader.js +4 -4
- package/dist/components/Panel/private/PanelSection.d.ts.map +1 -1
- package/dist/components/Panel/private/PanelSection.js +4 -4
- package/dist/components/PasswordField/PasswordField.d.ts.map +1 -1
- package/dist/components/PasswordField/PasswordField.js +4 -4
- package/dist/components/PreplyLogo/PreplyLogo.d.ts.map +1 -1
- package/dist/components/PreplyLogo/PreplyLogo.js +4 -4
- package/dist/components/SelectField/SelectField.d.ts.map +1 -1
- package/dist/components/SelectField/SelectField.js +4 -4
- package/dist/components/Text/Text.d.ts.map +1 -1
- package/dist/components/Text/Text.js +5 -5
- package/dist/components/TextField/TextField.d.ts.map +1 -1
- package/dist/components/TextField/TextField.js +4 -4
- package/dist/components/TextHighlighted/TextHighlighted.d.ts.map +1 -1
- package/dist/components/TextHighlighted/TextHighlighted.js +4 -4
- package/dist/components/TextInline/TextInline.d.ts.map +1 -1
- package/dist/components/TextInline/TextInline.js +4 -4
- package/dist/components/TextareaField/TextareaField.d.ts.map +1 -1
- package/dist/components/TextareaField/TextareaField.js +4 -4
- package/dist/components/private/Input/Checkbox.d.ts.map +1 -1
- package/dist/components/private/Input/Checkbox.js +4 -4
- package/dist/components/private/Input/InputDate.d.ts.map +1 -1
- package/dist/components/private/Input/InputDate.js +4 -4
- package/dist/components/private/Input/InputNumber.d.ts.map +1 -1
- package/dist/components/private/Input/InputNumber.js +4 -4
- package/dist/components/private/Input/InputPassword.d.ts.map +1 -1
- package/dist/components/private/Input/InputPassword.js +4 -4
- package/dist/components/private/Input/InputText.d.ts +1 -0
- package/dist/components/private/Input/InputText.d.ts.map +1 -1
- package/dist/components/private/Input/InputText.js +5 -4
- package/dist/components/private/Input/InputTime.d.ts.map +1 -1
- package/dist/components/private/Input/InputTime.js +4 -4
- package/dist/components/private/Input/Radio.d.ts.map +1 -1
- package/dist/components/private/Input/Radio.js +4 -4
- package/dist/components/private/Input/Select.d.ts.map +1 -1
- package/dist/components/private/Input/Select.js +4 -4
- package/dist/components/private/Input/Textarea.d.ts.map +1 -1
- package/dist/components/private/Input/Textarea.js +6 -4
- package/dist/components/private/SelectFieldLayout/SelectFieldLayout.d.ts.map +1 -1
- package/dist/components/private/SelectFieldLayout/SelectFieldLayout.js +8 -9
- package/package.json +14 -12
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Avatar.d.ts","sourceRoot":"","sources":["../../../src/components/Avatar/Avatar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"Avatar.d.ts","sourceRoot":"","sources":["../../../src/components/Avatar/Avatar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAiBvE,OAAc,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAIlC,MAAM,WAAW,KAAK;IAClB,IAAI,CAAC,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;IAC9B,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,eAAO,MAAM,MAAM,EAAE,EAAE,CAAC,KAAK,CAmC5B,CAAC"}
|
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
import { AVATAR_SIZE_DEFAULT, AVATAR_SRC_DEFAULT_TOKYO_UI, AVATAR_SRC_DEFAULT } from '@preply/ds-core';
|
|
2
|
+
import { webComponentNames } from '@preply/ds-visual-coverage-component-names';
|
|
2
3
|
import { useInstrument, useStyleExtract, moduleClassNames, stringClassNames, booleanClassNames, useVisualModeClassNames, getDatasetProps, useTheme } from '@preply/ds-web-core';
|
|
3
4
|
import React__default from 'react';
|
|
4
5
|
import styles from './style/index.module.less.js';
|
|
5
6
|
|
|
6
|
-
const AVATAR = 'Avatar';
|
|
7
7
|
const Avatar = ({ size = AVATAR_SIZE_DEFAULT, round, src, alt = '', dataset, }) => {
|
|
8
8
|
useInstrument('render', {
|
|
9
|
-
component: AVATAR,
|
|
9
|
+
component: webComponentNames.AVATAR,
|
|
10
10
|
props: { size, round },
|
|
11
11
|
});
|
|
12
12
|
useStyleExtract(styles);
|
|
13
13
|
const actualRound = round !== null && round !== void 0 ? round : true;
|
|
14
|
-
const classNames = moduleClassNames(styles, AVATAR, [
|
|
14
|
+
const classNames = moduleClassNames(styles, webComponentNames.AVATAR, [
|
|
15
15
|
stringClassNames('size', size),
|
|
16
16
|
booleanClassNames('round', undefined, actualRound),
|
|
17
17
|
]);
|
|
18
18
|
const props = {
|
|
19
19
|
className: useVisualModeClassNames(classNames).join(' '),
|
|
20
|
-
...getDatasetProps(dataset, { preplyDsComponent: AVATAR }),
|
|
20
|
+
...getDatasetProps(dataset, { preplyDsComponent: webComponentNames.AVATAR }),
|
|
21
21
|
};
|
|
22
22
|
const { theme } = useTheme();
|
|
23
23
|
const fallbackSrc = theme.name === 'tokyo-ui' ? AVATAR_SRC_DEFAULT_TOKYO_UI : AVATAR_SRC_DEFAULT;
|
|
@@ -26,4 +26,4 @@ const Avatar = ({ size = AVATAR_SIZE_DEFAULT, round, src, alt = '', dataset, })
|
|
|
26
26
|
};
|
|
27
27
|
|
|
28
28
|
export { Avatar };
|
|
29
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXZhdGFyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9BdmF0YXIvQXZhdGFyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEF2YXRhclNpemUsIERhdGFzZXQsIFJlc3BvbnNpdmUgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHtcbiAgICBBVkFUQVJfU0laRV9ERUZBVUxULFxuICAgIEFWQVRBUl9TUkNfREVGQVVMVCxcbiAgICBBVkFUQVJfU1JDX0RFRkFVTFRfVE9LWU9fVUksXG59IGZyb20gJ0BwcmVwbHkvZHMtY29yZSc7XG5pbXBvcnQgeyB3ZWJDb21wb25lbnROYW1lcyB9IGZyb20gJ0BwcmVwbHkvZHMtdmlzdWFsLWNvdmVyYWdlLWNvbXBvbmVudC1uYW1lcyc7XG5pbXBvcnQge1xuICAgIGJvb2xlYW5DbGFzc05hbWVzLFxuICAgIGdldERhdGFzZXRQcm9wcyxcbiAgICBtb2R1bGVDbGFzc05hbWVzLFxuICAgIHN0cmluZ0NsYXNzTmFtZXMsXG4gICAgdXNlSW5zdHJ1bWVudCxcbiAgICB1c2VTdHlsZUV4dHJhY3QsXG4gICAgdXNlVGhlbWUsXG4gICAgdXNlVmlzdWFsTW9kZUNsYXNzTmFtZXMsXG59IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IFJlYWN0LCB7IEZDIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByb3BzIHtcbiAgICBzaXplPzogUmVzcG9uc2l2ZTxBdmF0YXJTaXplPjtcbiAgICByb3VuZD86IGJvb2xlYW47XG4gICAgc3JjPzogc3RyaW5nO1xuICAgIGFsdD86IHN0cmluZztcbiAgICBkYXRhc2V0PzogRGF0YXNldDtcbn1cblxuZXhwb3J0IGNvbnN0IEF2YXRhcjogRkM8UHJvcHM+ID0gKHtcbiAgICBzaXplID0gQVZBVEFSX1NJWkVfREVGQVVMVCxcbiAgICByb3VuZCxcbiAgICBzcmMsXG4gICAgYWx0ID0gJycsXG4gICAgZGF0YXNldCxcbn06IFByb3BzKSA9PiB7XG4gICAgdXNlSW5zdHJ1bWVudCgncmVuZGVyJywge1xuICAgICAgICBjb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkFWQVRBUixcbiAgICAgICAgcHJvcHM6IHsgc2l6ZSwgcm91bmQgfSxcbiAgICB9KTtcblxuICAgIHVzZVN0eWxlRXh0cmFjdChzdHlsZXMpO1xuXG4gICAgY29uc3QgYWN0dWFsUm91bmQgPSByb3VuZCA/PyB0cnVlO1xuXG4gICAgY29uc3QgY2xhc3NOYW1lcyA9IG1vZHVsZUNsYXNzTmFtZXMoc3R5bGVzLCB3ZWJDb21wb25lbnROYW1lcy5BVkFUQVIsIFtcbiAgICAgICAgc3RyaW5nQ2xhc3NOYW1lcygnc2l6ZScsIHNpemUpLFxuICAgICAgICBib29sZWFuQ2xhc3NOYW1lcygncm91bmQnLCB1bmRlZmluZWQsIGFjdHVhbFJvdW5kKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICBjbGFzc05hbWU6IHVzZVZpc3VhbE1vZGVDbGFzc05hbWVzKGNsYXNzTmFtZXMpLmpvaW4oJyAnKSxcbiAgICAgICAgLi4uZ2V0RGF0YXNldFByb3BzKGRhdGFzZXQsIHsgcHJlcGx5RHNDb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkFWQVRBUiB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgeyB0aGVtZSB9ID0gdXNlVGhlbWUoKTtcbiAgICBjb25zdCBmYWxsYmFja1NyYyA9XG4gICAgICAgIHRoZW1lLm5hbWUgPT09ICd0b2t5by11aScgPyBBVkFUQVJfU1JDX0RFRkFVTFRfVE9LWU9fVUkgOiBBVkFUQVJfU1JDX0RFRkFVTFQ7XG5cbiAgICByZXR1cm4gKFxuICAgICAgICA8cGljdHVyZSB7Li4ucHJvcHN9PlxuICAgICAgICAgICAgPGltZyBzcmM9e3NyYyB8fCBmYWxsYmFja1NyY30gYWx0PXthbHR9IC8+XG4gICAgICAgIDwvcGljdHVyZT5cbiAgICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O01BNkJhLE1BQU0sR0FBYyxDQUFDLEVBQzlCLElBQUksR0FBRyxtQkFBbUIsRUFDMUIsS0FBSyxFQUNMLEdBQUcsRUFDSCxHQUFHLEdBQUcsRUFBRSxFQUNSLE9BQU8sR0FDSDtJQUNKLGFBQWEsQ0FBQyxRQUFRLEVBQUU7UUFDcEIsU0FBUyxFQUFFLGlCQUFpQixDQUFDLE1BQU07UUFDbkMsS0FBSyxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRTtLQUN6QixDQUFDLENBQUM7SUFFSCxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxXQUFXLEdBQUcsS0FBSyxhQUFMLEtBQUssY0FBTCxLQUFLLEdBQUksSUFBSSxDQUFDO0lBRWxDLE1BQU0sVUFBVSxHQUFHLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLEVBQUU7UUFDbEUsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQztRQUM5QixpQkFBaUIsQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsQ0FBQztLQUNyRCxDQUFDLENBQUM7SUFFSCxNQUFNLEtBQUssR0FBRztRQUNWLFNBQVMsRUFBRSx1QkFBdUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBQ3hELEdBQUcsZUFBZSxDQUFDLE9BQU8sRUFBRSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixDQUFDLE1BQU0sRUFBRSxDQUFDO0tBQy9FLENBQUM7SUFFRixNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUM7SUFDN0IsTUFBTSxXQUFXLEdBQ2IsS0FBSyxDQUFDLElBQUksS0FBSyxVQUFVLEdBQUcsMkJBQTJCLEdBQUcsa0JBQWtCLENBQUM7SUFFakYsUUFDSUEsNkNBQWEsS0FBSztRQUNkQSxzQ0FBSyxHQUFHLEVBQUUsR0FBRyxJQUFJLFdBQVcsRUFBRSxHQUFHLEVBQUUsR0FBRyxHQUFJLENBQ3BDLEVBQ1o7QUFDTjs7OzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AvatarWithStatus.d.ts","sourceRoot":"","sources":["../../../src/components/AvatarWithStatus/AvatarWithStatus.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AvatarWithStatus.d.ts","sourceRoot":"","sources":["../../../src/components/AvatarWithStatus/AvatarWithStatus.tsx"],"names":[],"mappings":"AAYA,OAAc,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAElC,OAAO,EAAU,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAIjD,aAAK,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC,CAAC;AAEjD,aAAK,qBAAqB,GAAG,KAAK,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC;AAEvD,oBAAY,qBAAqB,GAAG,WAAW,GAAG;IAC9C,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,qBAAqB,CAAC;CAChC,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CAqCtD,CAAC"}
|
|
@@ -1,22 +1,26 @@
|
|
|
1
1
|
import { AVATAR_SIZE_DEFAULT } from '@preply/ds-core';
|
|
2
|
+
import { webComponentNames } from '@preply/ds-visual-coverage-component-names';
|
|
2
3
|
import { useStyleExtract, useTheme, moduleClassNames, booleanClassNames, stringClassNames, moduleLocals, useVisualModeClassNames, getDatasetProps } from '@preply/ds-web-core';
|
|
3
4
|
import React__default from 'react';
|
|
4
5
|
import { Avatar } from '../Avatar/Avatar.js';
|
|
5
6
|
import styles from './style/index.module.less.js';
|
|
6
7
|
|
|
7
|
-
const AVATAR_WITH_STATUS = 'AvatarWithStatus';
|
|
8
8
|
const AvatarWithStatus = ({ online = false, size = AVATAR_SIZE_DEFAULT, dataset, ...avatarProps }) => {
|
|
9
9
|
useStyleExtract(styles);
|
|
10
10
|
const { theme } = useTheme();
|
|
11
|
-
const classNames = moduleClassNames(styles, AVATAR_WITH_STATUS, [
|
|
11
|
+
const classNames = moduleClassNames(styles, webComponentNames.AVATAR_WITH_STATUS, [
|
|
12
12
|
booleanClassNames('online', undefined, online),
|
|
13
13
|
stringClassNames('size', size),
|
|
14
14
|
]);
|
|
15
|
-
const indicatorClassName = [
|
|
16
|
-
|
|
15
|
+
const indicatorClassName = [
|
|
16
|
+
...moduleLocals(styles, webComponentNames.AVATAR_WITH_STATUS, ['indicator']),
|
|
17
|
+
];
|
|
18
|
+
const clipClassName = theme.name === 'tokyo-ui'
|
|
19
|
+
? []
|
|
20
|
+
: [...moduleLocals(styles, webComponentNames.AVATAR_WITH_STATUS, ['clip'])];
|
|
17
21
|
const props = {
|
|
18
22
|
className: useVisualModeClassNames(classNames).join(' '),
|
|
19
|
-
...getDatasetProps(dataset, { preplyDsComponent: AVATAR_WITH_STATUS }),
|
|
23
|
+
...getDatasetProps(dataset, { preplyDsComponent: webComponentNames.AVATAR_WITH_STATUS }),
|
|
20
24
|
};
|
|
21
25
|
return (React__default.createElement("div", { ...props },
|
|
22
26
|
React__default.createElement("span", { className: indicatorClassName.join(' ') }),
|
|
@@ -25,4 +29,4 @@ const AvatarWithStatus = ({ online = false, size = AVATAR_SIZE_DEFAULT, dataset,
|
|
|
25
29
|
};
|
|
26
30
|
|
|
27
31
|
export { AvatarWithStatus };
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXZhdGFyV2l0aFN0YXR1cy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQXZhdGFyV2l0aFN0YXR1cy9BdmF0YXJXaXRoU3RhdHVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBVkFUQVJfU0laRV9ERUZBVUxUIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7IHdlYkNvbXBvbmVudE5hbWVzIH0gZnJvbSAnQHByZXBseS9kcy12aXN1YWwtY292ZXJhZ2UtY29tcG9uZW50LW5hbWVzJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkNsYXNzTmFtZXMsXG4gICAgZ2V0RGF0YXNldFByb3BzLFxuICAgIG1vZHVsZUNsYXNzTmFtZXMsXG4gICAgbW9kdWxlTG9jYWxzLFxuICAgIHN0cmluZ0NsYXNzTmFtZXMsXG4gICAgdXNlU3R5bGVFeHRyYWN0LFxuICAgIHVzZVRoZW1lLFxuICAgIHVzZVZpc3VhbE1vZGVDbGFzc05hbWVzLFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQyB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgQXZhdGFyLCBQcm9wcyB9IGZyb20gJy4uL0F2YXRhci9BdmF0YXInO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG50eXBlIEF2YXRhclByb3BzID0gT21pdDxQcm9wcywgJ3JvdW5kJyB8ICdzaXplJz47XG5cbnR5cGUgQXZhdGFyV2l0aFN0YXR1c1NpemVzID0gJzJ4cycgfCAneHMnIHwgJ20nIHwgJ3hsJztcblxuZXhwb3J0IHR5cGUgQXZhdGFyV2l0aFN0YXR1c1Byb3BzID0gQXZhdGFyUHJvcHMgJiB7XG4gICAgb25saW5lOiBib29sZWFuO1xuICAgIHNpemU/OiBBdmF0YXJXaXRoU3RhdHVzU2l6ZXM7XG59O1xuXG5leHBvcnQgY29uc3QgQXZhdGFyV2l0aFN0YXR1czogRkM8QXZhdGFyV2l0aFN0YXR1c1Byb3BzPiA9ICh7XG4gICAgb25saW5lID0gZmFsc2UsXG4gICAgc2l6ZSA9IEFWQVRBUl9TSVpFX0RFRkFVTFQsXG4gICAgZGF0YXNldCxcbiAgICAuLi5hdmF0YXJQcm9wc1xufSkgPT4ge1xuICAgIHVzZVN0eWxlRXh0cmFjdChzdHlsZXMpO1xuXG4gICAgY29uc3QgeyB0aGVtZSB9ID0gdXNlVGhlbWUoKTtcblxuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgd2ViQ29tcG9uZW50TmFtZXMuQVZBVEFSX1dJVEhfU1RBVFVTLCBbXG4gICAgICAgIGJvb2xlYW5DbGFzc05hbWVzKCdvbmxpbmUnLCB1bmRlZmluZWQsIG9ubGluZSksXG4gICAgICAgIHN0cmluZ0NsYXNzTmFtZXMoJ3NpemUnLCBzaXplKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IGluZGljYXRvckNsYXNzTmFtZSA9IFtcbiAgICAgICAgLi4ubW9kdWxlTG9jYWxzKHN0eWxlcywgd2ViQ29tcG9uZW50TmFtZXMuQVZBVEFSX1dJVEhfU1RBVFVTLCBbJ2luZGljYXRvciddKSxcbiAgICBdO1xuXG4gICAgY29uc3QgY2xpcENsYXNzTmFtZSA9XG4gICAgICAgIHRoZW1lLm5hbWUgPT09ICd0b2t5by11aSdcbiAgICAgICAgICAgID8gW11cbiAgICAgICAgICAgIDogWy4uLm1vZHVsZUxvY2FscyhzdHlsZXMsIHdlYkNvbXBvbmVudE5hbWVzLkFWQVRBUl9XSVRIX1NUQVRVUywgWydjbGlwJ10pXTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICBjbGFzc05hbWU6IHVzZVZpc3VhbE1vZGVDbGFzc05hbWVzKGNsYXNzTmFtZXMpLmpvaW4oJyAnKSxcbiAgICAgICAgLi4uZ2V0RGF0YXNldFByb3BzKGRhdGFzZXQsIHsgcHJlcGx5RHNDb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkFWQVRBUl9XSVRIX1NUQVRVUyB9KSxcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgICAgPGRpdiB7Li4ucHJvcHN9PlxuICAgICAgICAgICAgPHNwYW4gY2xhc3NOYW1lPXtpbmRpY2F0b3JDbGFzc05hbWUuam9pbignICcpfSAvPlxuICAgICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2NsaXBDbGFzc05hbWUuam9pbignICcpfT5cbiAgICAgICAgICAgICAgICA8QXZhdGFyIHsuLi5hdmF0YXJQcm9wc30gc2l6ZT17c2l6ZX0gLz5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztNQTJCYSxnQkFBZ0IsR0FBOEIsQ0FBQyxFQUN4RCxNQUFNLEdBQUcsS0FBSyxFQUNkLElBQUksR0FBRyxtQkFBbUIsRUFDMUIsT0FBTyxFQUNQLEdBQUcsV0FBVyxFQUNqQjtJQUNHLGVBQWUsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUV4QixNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUM7SUFFN0IsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLGlCQUFpQixDQUFDLGtCQUFrQixFQUFFO1FBQzlFLGlCQUFpQixDQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDO1FBQzlDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUM7S0FDakMsQ0FBQyxDQUFDO0lBRUgsTUFBTSxrQkFBa0IsR0FBRztRQUN2QixHQUFHLFlBQVksQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUMvRSxDQUFDO0lBRUYsTUFBTSxhQUFhLEdBQ2YsS0FBSyxDQUFDLElBQUksS0FBSyxVQUFVO1VBQ25CLEVBQUU7VUFDRixDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUVwRixNQUFNLEtBQUssR0FBRztRQUNWLFNBQVMsRUFBRSx1QkFBdUIsQ0FBQyxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBQ3hELEdBQUcsZUFBZSxDQUFDLE9BQU8sRUFBRSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixDQUFDLGtCQUFrQixFQUFFLENBQUM7S0FDM0YsQ0FBQztJQUVGLFFBQ0lBLHlDQUFTLEtBQUs7UUFDVkEsdUNBQU0sU0FBUyxFQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBSTtRQUNqREEsc0NBQUssU0FBUyxFQUFFLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1lBQ25DQSw2QkFBQyxNQUFNLE9BQUssV0FBVyxFQUFFLElBQUksRUFBRSxJQUFJLEdBQUksQ0FDckMsQ0FDSixFQUNSO0FBQ047Ozs7In0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Badge.d.ts","sourceRoot":"","sources":["../../../src/components/Badge/Badge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"Badge.d.ts","sourceRoot":"","sources":["../../../src/components/Badge/Badge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAWnF,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAI7C,MAAM,WAAW,KAAK;IAClB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB;;OAEG;IACH,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACxB;AAED,eAAO,MAAM,KAAK,EAAE,EAAE,CAAC,KAAK,CA4B3B,CAAC"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { BADGE_COLOR_DEFAULT, BADGE_SIZE_DEFAULT } from '@preply/ds-core';
|
|
2
|
+
import { webComponentNames } from '@preply/ds-visual-coverage-component-names';
|
|
2
3
|
import { useStyleExtract, stringClassNames, moduleClassNames, booleanClassNames, useVisualModeClassNames, getDatasetProps } from '@preply/ds-web-core';
|
|
3
4
|
import React__default from 'react';
|
|
4
5
|
import styles from './style/index.module.less.js';
|
|
5
6
|
|
|
6
|
-
const BADGE = 'Badge';
|
|
7
7
|
const Badge = ({ color = BADGE_COLOR_DEFAULT, inverted = false, size = BADGE_SIZE_DEFAULT, assistiveText, dataset, children, accent, }) => {
|
|
8
8
|
useStyleExtract(styles);
|
|
9
9
|
const actualColorClassnames = accent
|
|
10
10
|
? stringClassNames('accent', accent)
|
|
11
11
|
: stringClassNames('color', color);
|
|
12
|
-
const classNames = moduleClassNames(styles, BADGE, [
|
|
12
|
+
const classNames = moduleClassNames(styles, webComponentNames.BADGE, [
|
|
13
13
|
actualColorClassnames,
|
|
14
14
|
booleanClassNames('inverted', 'normal', inverted),
|
|
15
15
|
stringClassNames('size', size),
|
|
@@ -17,10 +17,10 @@ const Badge = ({ color = BADGE_COLOR_DEFAULT, inverted = false, size = BADGE_SIZ
|
|
|
17
17
|
const props = {
|
|
18
18
|
'aria-label': assistiveText,
|
|
19
19
|
className: useVisualModeClassNames(classNames).join(' '),
|
|
20
|
-
...getDatasetProps(dataset, { preplyDsComponent: BADGE }),
|
|
20
|
+
...getDatasetProps(dataset, { preplyDsComponent: webComponentNames.BADGE }),
|
|
21
21
|
};
|
|
22
22
|
return React__default.createElement("span", { ...props }, children);
|
|
23
23
|
};
|
|
24
24
|
|
|
25
25
|
export { Badge };
|
|
26
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQmFkZ2UuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0JhZGdlL0JhZGdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJhZGdlQWNjZW50LCBCYWRnZUNvbG9yLCBCYWRnZVNpemUsIERhdGFzZXQgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHsgQkFER0VfQ09MT1JfREVGQVVMVCwgQkFER0VfU0laRV9ERUZBVUxUIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7IHdlYkNvbXBvbmVudE5hbWVzIH0gZnJvbSAnQHByZXBseS9kcy12aXN1YWwtY292ZXJhZ2UtY29tcG9uZW50LW5hbWVzJztcbmltcG9ydCB7XG4gICAgYm9vbGVhbkNsYXNzTmFtZXMsXG4gICAgZ2V0RGF0YXNldFByb3BzLFxuICAgIG1vZHVsZUNsYXNzTmFtZXMsXG4gICAgc3RyaW5nQ2xhc3NOYW1lcyxcbiAgICB1c2VTdHlsZUV4dHJhY3QsXG4gICAgdXNlVmlzdWFsTW9kZUNsYXNzTmFtZXMsXG59IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS9pbmRleC5tb2R1bGUubGVzcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvcHMge1xuICAgIGFjY2VudD86IEJhZGdlQWNjZW50O1xuICAgIC8qKlxuICAgICAqIEBkZXByZWNhdGVkIFVzZSBhY2NlbnQgaW5zdGVhZC5cbiAgICAgKi9cbiAgICBjb2xvcj86IEJhZGdlQ29sb3I7XG4gICAgaW52ZXJ0ZWQ/OiBib29sZWFuO1xuICAgIHNpemU/OiBCYWRnZVNpemU7XG4gICAgYXNzaXN0aXZlVGV4dD86IHN0cmluZztcbiAgICBkYXRhc2V0PzogRGF0YXNldDtcbiAgICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IGNvbnN0IEJhZGdlOiBGQzxQcm9wcz4gPSAoe1xuICAgIGNvbG9yID0gQkFER0VfQ09MT1JfREVGQVVMVCxcbiAgICBpbnZlcnRlZCA9IGZhbHNlLFxuICAgIHNpemUgPSBCQURHRV9TSVpFX0RFRkFVTFQsXG4gICAgYXNzaXN0aXZlVGV4dCxcbiAgICBkYXRhc2V0LFxuICAgIGNoaWxkcmVuLFxuICAgIGFjY2VudCxcbn0pID0+IHtcbiAgICB1c2VTdHlsZUV4dHJhY3Qoc3R5bGVzKTtcblxuICAgIGNvbnN0IGFjdHVhbENvbG9yQ2xhc3NuYW1lcyA9IGFjY2VudFxuICAgICAgICA/IHN0cmluZ0NsYXNzTmFtZXMoJ2FjY2VudCcsIGFjY2VudClcbiAgICAgICAgOiBzdHJpbmdDbGFzc05hbWVzKCdjb2xvcicsIGNvbG9yKTtcblxuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgd2ViQ29tcG9uZW50TmFtZXMuQkFER0UsIFtcbiAgICAgICAgYWN0dWFsQ29sb3JDbGFzc25hbWVzLFxuICAgICAgICBib29sZWFuQ2xhc3NOYW1lcygnaW52ZXJ0ZWQnLCAnbm9ybWFsJywgaW52ZXJ0ZWQpLFxuICAgICAgICBzdHJpbmdDbGFzc05hbWVzKCdzaXplJywgc2l6ZSksXG4gICAgXSk7XG5cbiAgICBjb25zdCBwcm9wcyA9IHtcbiAgICAgICAgJ2FyaWEtbGFiZWwnOiBhc3Npc3RpdmVUZXh0LFxuICAgICAgICBjbGFzc05hbWU6IHVzZVZpc3VhbE1vZGVDbGFzc05hbWVzKGNsYXNzTmFtZXMpLmpvaW4oJyAnKSxcbiAgICAgICAgLi4uZ2V0RGF0YXNldFByb3BzKGRhdGFzZXQsIHsgcHJlcGx5RHNDb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkJBREdFIH0pLFxuICAgIH07XG5cbiAgICByZXR1cm4gPHNwYW4gey4uLnByb3BzfT57Y2hpbGRyZW59PC9zcGFuPjtcbn07XG4iXSwibmFtZXMiOlsiUmVhY3QiXSwibWFwcGluZ3MiOiI7Ozs7OztNQTRCYSxLQUFLLEdBQWMsQ0FBQyxFQUM3QixLQUFLLEdBQUcsbUJBQW1CLEVBQzNCLFFBQVEsR0FBRyxLQUFLLEVBQ2hCLElBQUksR0FBRyxrQkFBa0IsRUFDekIsYUFBYSxFQUNiLE9BQU8sRUFDUCxRQUFRLEVBQ1IsTUFBTSxHQUNUO0lBQ0csZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRXhCLE1BQU0scUJBQXFCLEdBQUcsTUFBTTtVQUM5QixnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDO1VBQ2xDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FBQztJQUV2QyxNQUFNLFVBQVUsR0FBRyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsaUJBQWlCLENBQUMsS0FBSyxFQUFFO1FBQ2pFLHFCQUFxQjtRQUNyQixpQkFBaUIsQ0FBQyxVQUFVLEVBQUUsUUFBUSxFQUFFLFFBQVEsQ0FBQztRQUNqRCxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDO0tBQ2pDLENBQUMsQ0FBQztJQUVILE1BQU0sS0FBSyxHQUFHO1FBQ1YsWUFBWSxFQUFFLGFBQWE7UUFDM0IsU0FBUyxFQUFFLHVCQUF1QixDQUFDLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDeEQsR0FBRyxlQUFlLENBQUMsT0FBTyxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUMsS0FBSyxFQUFFLENBQUM7S0FDOUUsQ0FBQztJQUVGLE9BQU9BLDBDQUFVLEtBQUssSUFBRyxRQUFRLENBQVEsQ0FBQztBQUM5Qzs7OzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Box.d.ts","sourceRoot":"","sources":["../../../src/components/Box/Box.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,UAAU,EACV,SAAS,EACT,eAAe,EACf,SAAS,EACT,OAAO,EACP,SAAS,EACT,UAAU,EACV,SAAS,EACT,OAAO,EACV,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"Box.d.ts","sourceRoot":"","sources":["../../../src/components/Box/Box.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,UAAU,EACV,SAAS,EACT,eAAe,EACf,SAAS,EACT,OAAO,EACP,SAAS,EACT,UAAU,EACV,SAAS,EACT,OAAO,EACV,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EACH,gBAAgB,EAUnB,MAAM,qBAAqB,CAAC;AAC7B,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAI7C,MAAM,WAAW,QAAQ;IACrB,UAAU,CAAC,EAAE,SAAS,GAAG,eAAe,CAAC;IACzC,MAAM,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;IAC/B,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,OAAO,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;IACjE,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACxB;AAED,oBAAY,KAAK,GAAG,QAAQ,GAAG,gBAAgB,CAAC;AAgChD,eAAO,MAAM,GAAG,EAAE,EAAE,CAAC,KAAK,CAA4B,CAAC"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { BOX_RADIUS_DEFAULT, BOX_PADDING_DEFAULT, LAYOUT_TAG_DEFAULT } from '@preply/ds-core';
|
|
2
|
+
import { webComponentNames } from '@preply/ds-visual-coverage-component-names';
|
|
2
3
|
import { withColorScheme, useStyleExtract, globalClassNames, moduleClassNames, stringClassNames, useLayoutPaddingClassnames, useVisualModeClassNames, getDatasetProps } from '@preply/ds-web-core';
|
|
3
4
|
import React__default from 'react';
|
|
4
5
|
import styles from './style/index.module.less.js';
|
|
5
6
|
|
|
6
|
-
const BOX = 'Box';
|
|
7
7
|
const BoxBase = ({ children, colorSchemeClassName, background, radius = BOX_RADIUS_DEFAULT, padding = BOX_PADDING_DEFAULT, tag, dataset, }) => {
|
|
8
8
|
useStyleExtract(styles);
|
|
9
9
|
const globalClasses = globalClassNames([colorSchemeClassName]);
|
|
10
|
-
const classNames = moduleClassNames(styles, BOX, [
|
|
10
|
+
const classNames = moduleClassNames(styles, webComponentNames.BOX, [
|
|
11
11
|
stringClassNames('box-radius', radius),
|
|
12
12
|
stringClassNames('background', background),
|
|
13
13
|
]);
|
|
@@ -16,11 +16,11 @@ const BoxBase = ({ children, colorSchemeClassName, background, radius = BOX_RADI
|
|
|
16
16
|
const allClassNames = [...globalClasses, ...classNames, ...paddingClassNames];
|
|
17
17
|
const props = {
|
|
18
18
|
className: useVisualModeClassNames(allClassNames).join(' '),
|
|
19
|
-
...getDatasetProps(dataset, { preplyDsComponent: BOX }),
|
|
19
|
+
...getDatasetProps(dataset, { preplyDsComponent: webComponentNames.BOX }),
|
|
20
20
|
};
|
|
21
21
|
return React__default.createElement(Tag, { ...props }, children);
|
|
22
22
|
};
|
|
23
23
|
const Box = withColorScheme(BoxBase);
|
|
24
24
|
|
|
25
25
|
export { Box };
|
|
26
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQm94LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Cb3gvQm94LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gICAgQm94UGFkZGluZyxcbiAgICBCb3hSYWRpdXMsXG4gICAgQ29sb3JCYWNrZ3JvdW5kLFxuICAgIENvbG9yTmFtZSxcbiAgICBEYXRhc2V0LFxuICAgIExheW91dFRhZyxcbiAgICBSZXNwb25zaXZlLFxuICAgIFNob3J0SGFuZCxcbiAgICBTcGFjaW5nLFxufSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHsgQk9YX1BBRERJTkdfREVGQVVMVCwgQk9YX1JBRElVU19ERUZBVUxULCBMQVlPVVRfVEFHX0RFRkFVTFQgfSBmcm9tICdAcHJlcGx5L2RzLWNvcmUnO1xuaW1wb3J0IHsgd2ViQ29tcG9uZW50TmFtZXMgfSBmcm9tICdAcHJlcGx5L2RzLXZpc3VhbC1jb3ZlcmFnZS1jb21wb25lbnQtbmFtZXMnO1xuaW1wb3J0IHtcbiAgICBDb2xvclNjaGVtZVByb3BzLFxuICAgIFdpdGhDb2xvclNjaGVtZVByb3BzLFxuICAgIGdldERhdGFzZXRQcm9wcyxcbiAgICBnbG9iYWxDbGFzc05hbWVzLFxuICAgIG1vZHVsZUNsYXNzTmFtZXMsXG4gICAgc3RyaW5nQ2xhc3NOYW1lcyxcbiAgICB1c2VMYXlvdXRQYWRkaW5nQ2xhc3NuYW1lcyxcbiAgICB1c2VTdHlsZUV4dHJhY3QsXG4gICAgdXNlVmlzdWFsTW9kZUNsYXNzTmFtZXMsXG4gICAgd2l0aENvbG9yU2NoZW1lLFxufSBmcm9tICdAcHJlcGx5L2RzLXdlYi1jb3JlJztcbmltcG9ydCBSZWFjdCwgeyBGQywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJveFByb3BzIHtcbiAgICBiYWNrZ3JvdW5kPzogQ29sb3JOYW1lIHwgQ29sb3JCYWNrZ3JvdW5kO1xuICAgIHJhZGl1cz86IFJlc3BvbnNpdmU8Qm94UmFkaXVzPjtcbiAgICB0YWc/OiBMYXlvdXRUYWc7XG4gICAgcGFkZGluZz86IFJlc3BvbnNpdmU8U2hvcnRIYW5kPEJveFBhZGRpbmc+IHwgU2hvcnRIYW5kPFNwYWNpbmc+PjtcbiAgICBkYXRhc2V0PzogRGF0YXNldDtcbiAgICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn1cblxuZXhwb3J0IHR5cGUgUHJvcHMgPSBCb3hQcm9wcyAmIENvbG9yU2NoZW1lUHJvcHM7XG5cbmNvbnN0IEJveEJhc2U6IEZDPEJveFByb3BzICYgV2l0aENvbG9yU2NoZW1lUHJvcHM+ID0gKHtcbiAgICBjaGlsZHJlbixcbiAgICBjb2xvclNjaGVtZUNsYXNzTmFtZSxcbiAgICBiYWNrZ3JvdW5kLFxuICAgIHJhZGl1cyA9IEJPWF9SQURJVVNfREVGQVVMVCxcbiAgICBwYWRkaW5nID0gQk9YX1BBRERJTkdfREVGQVVMVCxcbiAgICB0YWcsXG4gICAgZGF0YXNldCxcbn0pID0+IHtcbiAgICB1c2VTdHlsZUV4dHJhY3Qoc3R5bGVzKTtcblxuICAgIGNvbnN0IGdsb2JhbENsYXNzZXMgPSBnbG9iYWxDbGFzc05hbWVzKFtjb2xvclNjaGVtZUNsYXNzTmFtZV0pO1xuICAgIGNvbnN0IGNsYXNzTmFtZXMgPSBtb2R1bGVDbGFzc05hbWVzKHN0eWxlcywgd2ViQ29tcG9uZW50TmFtZXMuQk9YLCBbXG4gICAgICAgIHN0cmluZ0NsYXNzTmFtZXMoJ2JveC1yYWRpdXMnLCByYWRpdXMpLFxuICAgICAgICBzdHJpbmdDbGFzc05hbWVzKCdiYWNrZ3JvdW5kJywgYmFja2dyb3VuZCksXG4gICAgXSk7XG4gICAgY29uc3QgcGFkZGluZ0NsYXNzTmFtZXMgPSB1c2VMYXlvdXRQYWRkaW5nQ2xhc3NuYW1lcyhwYWRkaW5nKTtcblxuICAgIGNvbnN0IFRhZyA9IHRhZyA/PyBMQVlPVVRfVEFHX0RFRkFVTFQ7XG5cbiAgICBjb25zdCBhbGxDbGFzc05hbWVzID0gWy4uLmdsb2JhbENsYXNzZXMsIC4uLmNsYXNzTmFtZXMsIC4uLnBhZGRpbmdDbGFzc05hbWVzXTtcblxuICAgIGNvbnN0IHByb3BzID0ge1xuICAgICAgICBjbGFzc05hbWU6IHVzZVZpc3VhbE1vZGVDbGFzc05hbWVzKGFsbENsYXNzTmFtZXMpLmpvaW4oJyAnKSxcbiAgICAgICAgLi4uZ2V0RGF0YXNldFByb3BzKGRhdGFzZXQsIHsgcHJlcGx5RHNDb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkJPWCB9KSxcbiAgICB9O1xuXG4gICAgcmV0dXJuIDxUYWcgey4uLnByb3BzfT57Y2hpbGRyZW59PC9UYWc+O1xufTtcblxuZXhwb3J0IGNvbnN0IEJveDogRkM8UHJvcHM+ID0gd2l0aENvbG9yU2NoZW1lKEJveEJhc2UpO1xuIl0sIm5hbWVzIjpbIlJlYWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUF3Q0EsTUFBTSxPQUFPLEdBQXdDLENBQUMsRUFDbEQsUUFBUSxFQUNSLG9CQUFvQixFQUNwQixVQUFVLEVBQ1YsTUFBTSxHQUFHLGtCQUFrQixFQUMzQixPQUFPLEdBQUcsbUJBQW1CLEVBQzdCLEdBQUcsRUFDSCxPQUFPLEdBQ1Y7SUFDRyxlQUFlLENBQUMsTUFBTSxDQUFDLENBQUM7SUFFeEIsTUFBTSxhQUFhLEdBQUcsZ0JBQWdCLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDLENBQUM7SUFDL0QsTUFBTSxVQUFVLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLGlCQUFpQixDQUFDLEdBQUcsRUFBRTtRQUMvRCxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDO1FBQ3RDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxVQUFVLENBQUM7S0FDN0MsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxpQkFBaUIsR0FBRywwQkFBMEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUU5RCxNQUFNLEdBQUcsR0FBRyxHQUFHLGFBQUgsR0FBRyxjQUFILEdBQUcsR0FBSSxrQkFBa0IsQ0FBQztJQUV0QyxNQUFNLGFBQWEsR0FBRyxDQUFDLEdBQUcsYUFBYSxFQUFFLEdBQUcsVUFBVSxFQUFFLEdBQUcsaUJBQWlCLENBQUMsQ0FBQztJQUU5RSxNQUFNLEtBQUssR0FBRztRQUNWLFNBQVMsRUFBRSx1QkFBdUIsQ0FBQyxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO1FBQzNELEdBQUcsZUFBZSxDQUFDLE9BQU8sRUFBRSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixDQUFDLEdBQUcsRUFBRSxDQUFDO0tBQzVFLENBQUM7SUFFRixPQUFPQSw2QkFBQyxHQUFHLE9BQUssS0FBSyxJQUFHLFFBQVEsQ0FBTyxDQUFDO0FBQzVDLENBQUMsQ0FBQztNQUVXLEdBQUcsR0FBYyxlQUFlLENBQUMsT0FBTzs7OzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../src/components/Button/Button.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Button.d.ts","sourceRoot":"","sources":["../../../src/components/Button/Button.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAA+B,MAAM,qBAAqB,CAAC;AACzF,OAAc,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAElC,OAAO,EAAc,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAI/E,aAAK,wBAAwB,GACvB;IACI,cAAc,CAAC,EAAE,qBAAqB,CAAC;IACvC,eAAe,CAAC,EAAE,KAAK,CAAC;CAC3B,GACD;IACI,eAAe,CAAC,EAAE,qBAAqB,CAAC;IACxC,cAAc,CAAC,EAAE,KAAK,CAAC;CAC1B,CAAC;AAER,oBAAY,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,cAAc,GAAG,mBAAmB,CAAC,GAC3E,wBAAwB,CAAC;AAE7B,eAAO,MAAM,MAAM,EAAE,EAAE,CAAC,KAAK,CAwC5B,CAAC"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { BUTTON_VARIANT_DEFAULT, BUTTON_SIZE_DEFAULT } from '@preply/ds-core';
|
|
2
|
+
import { webComponentNames } from '@preply/ds-visual-coverage-component-names';
|
|
2
3
|
import { useInstrument, moduleLocals } from '@preply/ds-web-core';
|
|
3
4
|
import React__default from 'react';
|
|
4
5
|
import { ButtonBase } from '../private/ButtonBase/ButtonBase.js';
|
|
5
6
|
import styles from './style/index.module.less.js';
|
|
6
7
|
|
|
7
|
-
const BUTTON = 'Button';
|
|
8
8
|
const Button = ({ variant = BUTTON_VARIANT_DEFAULT, size = BUTTON_SIZE_DEFAULT, url, a11yLabel, leadingSvgIcon: LeadingSvgIcon, trailingSvgIcon: TrailingSvgIcon, children, ...props }) => {
|
|
9
9
|
useInstrument('render', {
|
|
10
|
-
component: BUTTON,
|
|
10
|
+
component: webComponentNames.BUTTON,
|
|
11
11
|
props: { variant, size, url, a11yLabel },
|
|
12
12
|
});
|
|
13
|
-
const iconClassNames = [...moduleLocals(styles, BUTTON, ['icon'])];
|
|
14
|
-
return (React__default.createElement(ButtonBase, { ...props, isIconButton: false, variant: variant, size: size, url: url, a11yLabel: a11yLabel, preplyDsComponent: BUTTON },
|
|
13
|
+
const iconClassNames = [...moduleLocals(styles, webComponentNames.BUTTON, ['icon'])];
|
|
14
|
+
return (React__default.createElement(ButtonBase, { ...props, isIconButton: false, variant: variant, size: size, url: url, a11yLabel: a11yLabel, preplyDsComponent: webComponentNames.BUTTON },
|
|
15
15
|
!!LeadingSvgIcon && (React__default.createElement("span", { className: iconClassNames.join(' ') },
|
|
16
16
|
React__default.createElement(LeadingSvgIcon, { "aria-hidden": "true", focusable: "false" }))),
|
|
17
17
|
children,
|
|
@@ -20,4 +20,4 @@ const Button = ({ variant = BUTTON_VARIANT_DEFAULT, size = BUTTON_SIZE_DEFAULT,
|
|
|
20
20
|
};
|
|
21
21
|
|
|
22
22
|
export { Button };
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQnV0dG9uLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9CdXR0b24vQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCVVRUT05fU0laRV9ERUZBVUxULCBCVVRUT05fVkFSSUFOVF9ERUZBVUxUIH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCB7IHdlYkNvbXBvbmVudE5hbWVzIH0gZnJvbSAnQHByZXBseS9kcy12aXN1YWwtY292ZXJhZ2UtY29tcG9uZW50LW5hbWVzJztcbmltcG9ydCB7IFJlYWN0U1ZHQ29tcG9uZW50VHlwZSwgbW9kdWxlTG9jYWxzLCB1c2VJbnN0cnVtZW50IH0gZnJvbSAnQHByZXBseS9kcy13ZWItY29yZSc7XG5pbXBvcnQgUmVhY3QsIHsgRkMgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IEJ1dHRvbkJhc2UsIEJ1dHRvbkJhc2VQcm9wcyB9IGZyb20gJy4uL3ByaXZhdGUvQnV0dG9uQmFzZS9CdXR0b25CYXNlJztcblxuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3N0eWxlL2luZGV4Lm1vZHVsZS5sZXNzJztcblxudHlwZSBMZWFkaW5nT3JUcmFpbGluZ1N2Z0ljb24gPVxuICAgIHwge1xuICAgICAgICAgIGxlYWRpbmdTdmdJY29uPzogUmVhY3RTVkdDb21wb25lbnRUeXBlO1xuICAgICAgICAgIHRyYWlsaW5nU3ZnSWNvbj86IG5ldmVyO1xuICAgICAgfVxuICAgIHwge1xuICAgICAgICAgIHRyYWlsaW5nU3ZnSWNvbj86IFJlYWN0U1ZHQ29tcG9uZW50VHlwZTtcbiAgICAgICAgICBsZWFkaW5nU3ZnSWNvbj86IG5ldmVyO1xuICAgICAgfTtcblxuZXhwb3J0IHR5cGUgUHJvcHMgPSBPbWl0PEJ1dHRvbkJhc2VQcm9wcywgJ2lzSWNvbkJ1dHRvbicgfCAncHJlcGx5RHNDb21wb25lbnQnPiAmXG4gICAgTGVhZGluZ09yVHJhaWxpbmdTdmdJY29uO1xuXG5leHBvcnQgY29uc3QgQnV0dG9uOiBGQzxQcm9wcz4gPSAoe1xuICAgIHZhcmlhbnQgPSBCVVRUT05fVkFSSUFOVF9ERUZBVUxULFxuICAgIHNpemUgPSBCVVRUT05fU0laRV9ERUZBVUxULFxuICAgIHVybCxcbiAgICBhMTF5TGFiZWwsXG4gICAgbGVhZGluZ1N2Z0ljb246IExlYWRpbmdTdmdJY29uLFxuICAgIHRyYWlsaW5nU3ZnSWNvbjogVHJhaWxpbmdTdmdJY29uLFxuICAgIGNoaWxkcmVuLFxuICAgIC4uLnByb3BzXG59KSA9PiB7XG4gICAgdXNlSW5zdHJ1bWVudCgncmVuZGVyJywge1xuICAgICAgICBjb21wb25lbnQ6IHdlYkNvbXBvbmVudE5hbWVzLkJVVFRPTixcbiAgICAgICAgcHJvcHM6IHsgdmFyaWFudCwgc2l6ZSwgdXJsLCBhMTF5TGFiZWwgfSxcbiAgICB9KTtcblxuICAgIGNvbnN0IGljb25DbGFzc05hbWVzID0gWy4uLm1vZHVsZUxvY2FscyhzdHlsZXMsIHdlYkNvbXBvbmVudE5hbWVzLkJVVFRPTiwgWydpY29uJ10pXTtcblxuICAgIHJldHVybiAoXG4gICAgICAgIDxCdXR0b25CYXNlXG4gICAgICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgICAgICBpc0ljb25CdXR0b249e2ZhbHNlfVxuICAgICAgICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICB1cmw9e3VybH1cbiAgICAgICAgICAgIGExMXlMYWJlbD17YTExeUxhYmVsfVxuICAgICAgICAgICAgcHJlcGx5RHNDb21wb25lbnQ9e3dlYkNvbXBvbmVudE5hbWVzLkJVVFRPTn1cbiAgICAgICAgPlxuICAgICAgICAgICAgeyEhTGVhZGluZ1N2Z0ljb24gJiYgKFxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT17aWNvbkNsYXNzTmFtZXMuam9pbignICcpfT5cbiAgICAgICAgICAgICAgICAgICAgPExlYWRpbmdTdmdJY29uIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIGZvY3VzYWJsZT1cImZhbHNlXCIgLz5cbiAgICAgICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICApfVxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgeyEhVHJhaWxpbmdTdmdJY29uICYmIChcbiAgICAgICAgICAgICAgICA8c3BhbiBjbGFzc05hbWU9e2ljb25DbGFzc05hbWVzLmpvaW4oJyAnKX0+XG4gICAgICAgICAgICAgICAgICAgIDxUcmFpbGluZ1N2Z0ljb24gYXJpYS1oaWRkZW49XCJ0cnVlXCIgZm9jdXNhYmxlPVwiZmFsc2VcIiAvPlxuICAgICAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICAgICl9XG4gICAgICAgIDwvQnV0dG9uQmFzZT5cbiAgICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztNQXNCYSxNQUFNLEdBQWMsQ0FBQyxFQUM5QixPQUFPLEdBQUcsc0JBQXNCLEVBQ2hDLElBQUksR0FBRyxtQkFBbUIsRUFDMUIsR0FBRyxFQUNILFNBQVMsRUFDVCxjQUFjLEVBQUUsY0FBYyxFQUM5QixlQUFlLEVBQUUsZUFBZSxFQUNoQyxRQUFRLEVBQ1IsR0FBRyxLQUFLLEVBQ1g7SUFDRyxhQUFhLENBQUMsUUFBUSxFQUFFO1FBQ3BCLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxNQUFNO1FBQ25DLEtBQUssRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRTtLQUMzQyxDQUFDLENBQUM7SUFFSCxNQUFNLGNBQWMsR0FBRyxDQUFDLEdBQUcsWUFBWSxDQUFDLE1BQU0sRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFckYsUUFDSUEsNkJBQUMsVUFBVSxPQUNILEtBQUssRUFDVCxZQUFZLEVBQUUsS0FBSyxFQUNuQixPQUFPLEVBQUUsT0FBTyxFQUNoQixJQUFJLEVBQUUsSUFBSSxFQUNWLEdBQUcsRUFBRSxHQUFHLEVBQ1IsU0FBUyxFQUFFLFNBQVMsRUFDcEIsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUMsTUFBTTtRQUUxQyxDQUFDLENBQUMsY0FBYyxLQUNiQSx1Q0FBTSxTQUFTLEVBQUUsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDckNBLDZCQUFDLGNBQWMsbUJBQWEsTUFBTSxFQUFDLFNBQVMsRUFBQyxPQUFPLEdBQUcsQ0FDcEQsQ0FDVjtRQUNBLFFBQVE7UUFDUixDQUFDLENBQUMsZUFBZSxLQUNkQSx1Q0FBTSxTQUFTLEVBQUUsY0FBYyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7WUFDckNBLDZCQUFDLGVBQWUsbUJBQWEsTUFBTSxFQUFDLFNBQVMsRUFBQyxPQUFPLEdBQUcsQ0FDckQsQ0FDVixDQUNRLEVBQ2Y7QUFDTjs7OzsifQ==
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { Dataset } from '@preply/ds-core';
|
|
2
|
+
import { ReactSVGComponentType } from '@preply/ds-web-core';
|
|
3
|
+
import { FC, ReactNode } from 'react';
|
|
4
|
+
interface ChipsProps {
|
|
5
|
+
/**
|
|
6
|
+
* The Chip list variant;
|
|
7
|
+
* - For simple checkbox-like behaviour, use `choice`.
|
|
8
|
+
* - For more complex filtering controls, use `filter`.
|
|
9
|
+
*
|
|
10
|
+
* @default choice
|
|
11
|
+
*/
|
|
12
|
+
variant?: 'choice' | 'filter';
|
|
13
|
+
/**
|
|
14
|
+
* Allows assistive technologies to correctly identify and announce
|
|
15
|
+
* the Chip list.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* <Chips aria-label="tutor filter">
|
|
19
|
+
* // When the Chip below is in focus, screen readers may announce it as:
|
|
20
|
+
* // "tutor filter list, option 1, Availability, press to toggle"
|
|
21
|
+
* <Chips.Item label="Availability" />
|
|
22
|
+
* </Chips>
|
|
23
|
+
*/
|
|
24
|
+
'aria-label': string;
|
|
25
|
+
/**
|
|
26
|
+
* These should be {@link Chips.Item}s.
|
|
27
|
+
*/
|
|
28
|
+
children: ReactNode;
|
|
29
|
+
dataset?: Dataset;
|
|
30
|
+
}
|
|
31
|
+
interface ChipsSubcomponents {
|
|
32
|
+
/**
|
|
33
|
+
* A single {@link Chips} list item.
|
|
34
|
+
*/
|
|
35
|
+
Item: FC<ChipsItemProps>;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* A Chips container; add {@link Chips.Item} children to render a list of Chips.
|
|
39
|
+
*/
|
|
40
|
+
export declare const Chips: FC<ChipsProps> & ChipsSubcomponents;
|
|
41
|
+
interface ChipsItemProps {
|
|
42
|
+
label: ReactNode;
|
|
43
|
+
leadingSvgIcon?: ReactSVGComponentType;
|
|
44
|
+
/**
|
|
45
|
+
* The current state of the Chip; this needs to be controlled manually,
|
|
46
|
+
* to cater for cases in which a Chip also controls a seperate filter menu.
|
|
47
|
+
*/
|
|
48
|
+
pressed: boolean;
|
|
49
|
+
/**
|
|
50
|
+
* Called when the Chip is pressed, and returns the resulting state udpate.
|
|
51
|
+
*
|
|
52
|
+
* @see {@link ChipItemProps.pressed} for controlling the Chip state.
|
|
53
|
+
* @see {@link ChipItemProps.onRemove} for when the user removes the Chip.
|
|
54
|
+
*/
|
|
55
|
+
onToggle?: (newState: boolean) => void;
|
|
56
|
+
/**
|
|
57
|
+
* Called when the Chip's remove (`X`) button is clicked.
|
|
58
|
+
* This is only available for `filter` Chips.
|
|
59
|
+
*/
|
|
60
|
+
onRemove?: () => void;
|
|
61
|
+
/**
|
|
62
|
+
* If the Chip toggles the presence or content of another element, set this
|
|
63
|
+
* prop to the ID of that element.
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* <Chips variant="filter">
|
|
67
|
+
* <Chips.Item
|
|
68
|
+
* label="Availability"
|
|
69
|
+
* pressed={filterByAvailability}
|
|
70
|
+
* aria-controls="tutor-search-list"
|
|
71
|
+
* />
|
|
72
|
+
* </Chips>
|
|
73
|
+
* ...
|
|
74
|
+
* <TutorSearchList id="tutor-search-list" />
|
|
75
|
+
*/
|
|
76
|
+
'aria-controls'?: string;
|
|
77
|
+
dataset?: Dataset;
|
|
78
|
+
}
|
|
79
|
+
export {};
|
|
80
|
+
//# sourceMappingURL=Chips.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Chips.d.ts","sourceRoot":"","sources":["../../../src/components/Chips/Chips.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAE1C,OAAO,EAAE,qBAAqB,EAAmB,MAAM,qBAAqB,CAAC;AAC7E,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAM7C,UAAU,UAAU;IAChB;;;;;;OAMG;IACH,OAAO,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;IAC9B;;;;;;;;;;OAUG;IACH,YAAY,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,QAAQ,EAAE,SAAS,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,UAAU,kBAAkB;IACxB;;OAEG;IACH,IAAI,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC;CAC5B;AAED;;GAEG;AACH,eAAO,MAAM,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,kBAYpC,CAAC;AAEF,UAAU,cAAc;IACpB,KAAK,EAAE,SAAS,CAAC;IACjB,cAAc,CAAC,EAAE,qBAAqB,CAAC;IACvC;;;OAGG;IACH,OAAO,EAAE,OAAO,CAAC;IACjB;;;;;OAKG;IACH,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;IACtB;;;;;;;;;;;;;;OAcG;IACH,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,OAAO,CAAC,EAAE,OAAO,CAAC;CACrB"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import CloseIcon from '@preply/ds-media-icons/dist/24/Close.svg';
|
|
2
|
+
import { getDatasetProps } from '@preply/ds-web-core';
|
|
3
|
+
import React__default from 'react';
|
|
4
|
+
import { Icon } from '../Icon/Icon.js';
|
|
5
|
+
import styles from './style/index.module.less.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* A Chips container; add {@link Chips.Item} children to render a list of Chips.
|
|
9
|
+
*/
|
|
10
|
+
const Chips = ({ variant = 'choice', children, 'aria-label': ariaLabel, dataset, }) => {
|
|
11
|
+
const dataAttributes = { ...dataset, variant };
|
|
12
|
+
return (React__default.createElement("ul", { "aria-label": ariaLabel, className: styles.chips, ...getDatasetProps(dataAttributes) }, children));
|
|
13
|
+
};
|
|
14
|
+
Chips.Item = function ChipsItem({ label, leadingSvgIcon, pressed, onToggle, onRemove, 'aria-controls': ariaControls, dataset, }) {
|
|
15
|
+
const toggle = () => onToggle === null || onToggle === void 0 ? void 0 : onToggle(!pressed);
|
|
16
|
+
const remove = onRemove !== null && onRemove !== void 0 ? onRemove : toggle;
|
|
17
|
+
return (React__default.createElement("li", { role: "group", className: styles.chip, ...getDatasetProps(dataset, { preplyDsComponent: 'Chip' }) },
|
|
18
|
+
React__default.createElement("button", { type: "button", className: styles['chip-toggle'], "aria-pressed": pressed, "aria-controls": ariaControls, onClick: toggle, onKeyUp: e => {
|
|
19
|
+
switch (e.key) {
|
|
20
|
+
case 'Backspace':
|
|
21
|
+
case 'Delete':
|
|
22
|
+
if (!pressed) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
toggle();
|
|
26
|
+
break;
|
|
27
|
+
}
|
|
28
|
+
} },
|
|
29
|
+
leadingSvgIcon && React__default.createElement(Icon, { size: "24", svg: leadingSvgIcon }),
|
|
30
|
+
label),
|
|
31
|
+
React__default.createElement("button", { type: "button", className: styles['chip-remove'], onClick: remove, "aria-label": "Remove", "aria-controls": ariaControls },
|
|
32
|
+
React__default.createElement(Icon, { size: "24", svg: CloseIcon }))));
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export { Chips };
|
|
36
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ2hpcHMuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NoaXBzL0NoaXBzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXRhc2V0IH0gZnJvbSAnQHByZXBseS9kcy1jb3JlJztcbmltcG9ydCBDbG9zZUljb24gZnJvbSAnQHByZXBseS9kcy1tZWRpYS1pY29ucy9kaXN0LzI0L0Nsb3NlLnN2Zyc7XG5pbXBvcnQgeyBSZWFjdFNWR0NvbXBvbmVudFR5cGUsIGdldERhdGFzZXRQcm9wcyB9IGZyb20gJ0BwcmVwbHkvZHMtd2ViLWNvcmUnO1xuaW1wb3J0IFJlYWN0LCB7IEZDLCBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCB7IEljb24gfSBmcm9tICcuLi9JY29uL0ljb24nO1xuXG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc3R5bGUvaW5kZXgubW9kdWxlLmxlc3MnO1xuXG5pbnRlcmZhY2UgQ2hpcHNQcm9wcyB7XG4gICAgLyoqXG4gICAgICogVGhlIENoaXAgbGlzdCB2YXJpYW50O1xuICAgICAqIC0gRm9yIHNpbXBsZSBjaGVja2JveC1saWtlIGJlaGF2aW91ciwgdXNlIGBjaG9pY2VgLlxuICAgICAqIC0gRm9yIG1vcmUgY29tcGxleCBmaWx0ZXJpbmcgY29udHJvbHMsIHVzZSBgZmlsdGVyYC5cbiAgICAgKlxuICAgICAqIEBkZWZhdWx0IGNob2ljZVxuICAgICAqL1xuICAgIHZhcmlhbnQ/OiAnY2hvaWNlJyB8ICdmaWx0ZXInO1xuICAgIC8qKlxuICAgICAqIEFsbG93cyBhc3Npc3RpdmUgdGVjaG5vbG9naWVzIHRvIGNvcnJlY3RseSBpZGVudGlmeSBhbmQgYW5ub3VuY2VcbiAgICAgKiB0aGUgQ2hpcCBsaXN0LlxuICAgICAqXG4gICAgICogQGV4YW1wbGVcbiAgICAgKiA8Q2hpcHMgYXJpYS1sYWJlbD1cInR1dG9yIGZpbHRlclwiPlxuICAgICAqICAgLy8gV2hlbiB0aGUgQ2hpcCBiZWxvdyBpcyBpbiBmb2N1cywgc2NyZWVuIHJlYWRlcnMgbWF5IGFubm91bmNlIGl0IGFzOlxuICAgICAqICAgLy8gXCJ0dXRvciBmaWx0ZXIgbGlzdCwgb3B0aW9uIDEsIEF2YWlsYWJpbGl0eSwgcHJlc3MgdG8gdG9nZ2xlXCJcbiAgICAgKiAgIDxDaGlwcy5JdGVtIGxhYmVsPVwiQXZhaWxhYmlsaXR5XCIgLz5cbiAgICAgKiA8L0NoaXBzPlxuICAgICAqL1xuICAgICdhcmlhLWxhYmVsJzogc3RyaW5nO1xuICAgIC8qKlxuICAgICAqIFRoZXNlIHNob3VsZCBiZSB7QGxpbmsgQ2hpcHMuSXRlbX1zLlxuICAgICAqL1xuICAgIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gICAgZGF0YXNldD86IERhdGFzZXQ7XG59XG5cbmludGVyZmFjZSBDaGlwc1N1YmNvbXBvbmVudHMge1xuICAgIC8qKlxuICAgICAqIEEgc2luZ2xlIHtAbGluayBDaGlwc30gbGlzdCBpdGVtLlxuICAgICAqL1xuICAgIEl0ZW06IEZDPENoaXBzSXRlbVByb3BzPjtcbn1cblxuLyoqXG4gKiBBIENoaXBzIGNvbnRhaW5lcjsgYWRkIHtAbGluayBDaGlwcy5JdGVtfSBjaGlsZHJlbiB0byByZW5kZXIgYSBsaXN0IG9mIENoaXBzLlxuICovXG5leHBvcnQgY29uc3QgQ2hpcHM6IEZDPENoaXBzUHJvcHM+ICYgQ2hpcHNTdWJjb21wb25lbnRzID0gKHtcbiAgICB2YXJpYW50ID0gJ2Nob2ljZScsXG4gICAgY2hpbGRyZW4sXG4gICAgJ2FyaWEtbGFiZWwnOiBhcmlhTGFiZWwsXG4gICAgZGF0YXNldCxcbn0pID0+IHtcbiAgICBjb25zdCBkYXRhQXR0cmlidXRlcyA9IHsgLi4uZGF0YXNldCwgdmFyaWFudCB9O1xuICAgIHJldHVybiAoXG4gICAgICAgIDx1bCBhcmlhLWxhYmVsPXthcmlhTGFiZWx9IGNsYXNzTmFtZT17c3R5bGVzLmNoaXBzfSB7Li4uZ2V0RGF0YXNldFByb3BzKGRhdGFBdHRyaWJ1dGVzKX0+XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDwvdWw+XG4gICAgKTtcbn07XG5cbmludGVyZmFjZSBDaGlwc0l0ZW1Qcm9wcyB7XG4gICAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgICBsZWFkaW5nU3ZnSWNvbj86IFJlYWN0U1ZHQ29tcG9uZW50VHlwZTtcbiAgICAvKipcbiAgICAgKiBUaGUgY3VycmVudCBzdGF0ZSBvZiB0aGUgQ2hpcDsgdGhpcyBuZWVkcyB0byBiZSBjb250cm9sbGVkIG1hbnVhbGx5LFxuICAgICAqIHRvIGNhdGVyIGZvciBjYXNlcyBpbiB3aGljaCBhIENoaXAgYWxzbyBjb250cm9scyBhIHNlcGVyYXRlIGZpbHRlciBtZW51LlxuICAgICAqL1xuICAgIHByZXNzZWQ6IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQ2FsbGVkIHdoZW4gdGhlIENoaXAgaXMgcHJlc3NlZCwgYW5kIHJldHVybnMgdGhlIHJlc3VsdGluZyBzdGF0ZSB1ZHBhdGUuXG4gICAgICpcbiAgICAgKiBAc2VlIHtAbGluayBDaGlwSXRlbVByb3BzLnByZXNzZWR9IGZvciBjb250cm9sbGluZyB0aGUgQ2hpcCBzdGF0ZS5cbiAgICAgKiBAc2VlIHtAbGluayBDaGlwSXRlbVByb3BzLm9uUmVtb3ZlfSBmb3Igd2hlbiB0aGUgdXNlciByZW1vdmVzIHRoZSBDaGlwLlxuICAgICAqL1xuICAgIG9uVG9nZ2xlPzogKG5ld1N0YXRlOiBib29sZWFuKSA9PiB2b2lkO1xuICAgIC8qKlxuICAgICAqIENhbGxlZCB3aGVuIHRoZSBDaGlwJ3MgcmVtb3ZlIChgWGApIGJ1dHRvbiBpcyBjbGlja2VkLlxuICAgICAqIFRoaXMgaXMgb25seSBhdmFpbGFibGUgZm9yIGBmaWx0ZXJgIENoaXBzLlxuICAgICAqL1xuICAgIG9uUmVtb3ZlPzogKCkgPT4gdm9pZDtcbiAgICAvKipcbiAgICAgKiBJZiB0aGUgQ2hpcCB0b2dnbGVzIHRoZSBwcmVzZW5jZSBvciBjb250ZW50IG9mIGFub3RoZXIgZWxlbWVudCwgc2V0IHRoaXNcbiAgICAgKiBwcm9wIHRvIHRoZSBJRCBvZiB0aGF0IGVsZW1lbnQuXG4gICAgICpcbiAgICAgKiBAZXhhbXBsZVxuICAgICAqIDxDaGlwcyB2YXJpYW50PVwiZmlsdGVyXCI+XG4gICAgICogICA8Q2hpcHMuSXRlbVxuICAgICAqICAgICBsYWJlbD1cIkF2YWlsYWJpbGl0eVwiXG4gICAgICogICAgIHByZXNzZWQ9e2ZpbHRlckJ5QXZhaWxhYmlsaXR5fVxuICAgICAqICAgICBhcmlhLWNvbnRyb2xzPVwidHV0b3Itc2VhcmNoLWxpc3RcIlxuICAgICAqICAgLz5cbiAgICAgKiA8L0NoaXBzPlxuICAgICAqIC4uLlxuICAgICAqIDxUdXRvclNlYXJjaExpc3QgaWQ9XCJ0dXRvci1zZWFyY2gtbGlzdFwiIC8+XG4gICAgICovXG4gICAgJ2FyaWEtY29udHJvbHMnPzogc3RyaW5nO1xuICAgIGRhdGFzZXQ/OiBEYXRhc2V0O1xufVxuXG5DaGlwcy5JdGVtID0gZnVuY3Rpb24gQ2hpcHNJdGVtKHtcbiAgICBsYWJlbCxcbiAgICBsZWFkaW5nU3ZnSWNvbixcbiAgICBwcmVzc2VkLFxuICAgIG9uVG9nZ2xlLFxuICAgIG9uUmVtb3ZlLFxuICAgICdhcmlhLWNvbnRyb2xzJzogYXJpYUNvbnRyb2xzLFxuICAgIGRhdGFzZXQsXG59KSB7XG4gICAgY29uc3QgdG9nZ2xlID0gKCkgPT4gb25Ub2dnbGU/LighcHJlc3NlZCk7XG4gICAgY29uc3QgcmVtb3ZlID0gb25SZW1vdmUgPz8gdG9nZ2xlO1xuICAgIHJldHVybiAoXG4gICAgICAgIDxsaVxuICAgICAgICAgICAgcm9sZT1cImdyb3VwXCJcbiAgICAgICAgICAgIGNsYXNzTmFtZT17c3R5bGVzLmNoaXB9XG4gICAgICAgICAgICB7Li4uZ2V0RGF0YXNldFByb3BzKGRhdGFzZXQsIHsgcHJlcGx5RHNDb21wb25lbnQ6ICdDaGlwJyB9KX1cbiAgICAgICAgPlxuICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIGNsYXNzTmFtZT17c3R5bGVzWydjaGlwLXRvZ2dsZSddfVxuICAgICAgICAgICAgICAgIGFyaWEtcHJlc3NlZD17cHJlc3NlZH1cbiAgICAgICAgICAgICAgICBhcmlhLWNvbnRyb2xzPXthcmlhQ29udHJvbHN9XG4gICAgICAgICAgICAgICAgb25DbGljaz17dG9nZ2xlfVxuICAgICAgICAgICAgICAgIG9uS2V5VXA9e2UgPT4ge1xuICAgICAgICAgICAgICAgICAgICBzd2l0Y2ggKGUua2V5KSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBjYXNlICdCYWNrc3BhY2UnOlxuICAgICAgICAgICAgICAgICAgICAgICAgY2FzZSAnRGVsZXRlJzpcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAoIXByZXNzZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB0b2dnbGUoKTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgICAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9fVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtsZWFkaW5nU3ZnSWNvbiAmJiA8SWNvbiBzaXplPVwiMjRcIiBzdmc9e2xlYWRpbmdTdmdJY29ufSAvPn1cbiAgICAgICAgICAgICAgICB7bGFiZWx9XG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgIDxidXR0b25cbiAgICAgICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWU9e3N0eWxlc1snY2hpcC1yZW1vdmUnXX1cbiAgICAgICAgICAgICAgICBvbkNsaWNrPXtyZW1vdmV9XG4gICAgICAgICAgICAgICAgYXJpYS1sYWJlbD1cIlJlbW92ZVwiXG4gICAgICAgICAgICAgICAgYXJpYS1jb250cm9scz17YXJpYUNvbnRyb2xzfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxJY29uIHNpemU9XCIyNFwiIHN2Zz17Q2xvc2VJY29ufSAvPlxuICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDwvbGk+XG4gICAgKTtcbn07XG4iXSwibmFtZXMiOlsiUmVhY3QiXSwibWFwcGluZ3MiOiI7Ozs7OztBQTRDQTs7O01BR2EsS0FBSyxHQUF3QyxDQUFDLEVBQ3ZELE9BQU8sR0FBRyxRQUFRLEVBQ2xCLFFBQVEsRUFDUixZQUFZLEVBQUUsU0FBUyxFQUN2QixPQUFPLEdBQ1Y7SUFDRyxNQUFNLGNBQWMsR0FBRyxFQUFFLEdBQUcsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQy9DLFFBQ0lBLG1EQUFnQixTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxLQUFLLEtBQU0sZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUNsRixRQUFRLENBQ1IsRUFDUDtBQUNOLEVBQUU7QUF5Q0YsS0FBSyxDQUFDLElBQUksR0FBRyxTQUFTLFNBQVMsQ0FBQyxFQUM1QixLQUFLLEVBQ0wsY0FBYyxFQUNkLE9BQU8sRUFDUCxRQUFRLEVBQ1IsUUFBUSxFQUNSLGVBQWUsRUFBRSxZQUFZLEVBQzdCLE9BQU8sR0FDVjtJQUNHLE1BQU0sTUFBTSxHQUFHLE1BQU0sUUFBUSxhQUFSLFFBQVEsdUJBQVIsUUFBUSxDQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDMUMsTUFBTSxNQUFNLEdBQUcsUUFBUSxhQUFSLFFBQVEsY0FBUixRQUFRLEdBQUksTUFBTSxDQUFDO0lBQ2xDLFFBQ0lBLHFDQUNJLElBQUksRUFBQyxPQUFPLEVBQ1osU0FBUyxFQUFFLE1BQU0sQ0FBQyxJQUFJLEtBQ2xCLGVBQWUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUUzREEseUNBQ0ksSUFBSSxFQUFDLFFBQVEsRUFDYixTQUFTLEVBQUUsTUFBTSxDQUFDLGFBQWEsQ0FBQyxrQkFDbEIsT0FBTyxtQkFDTixZQUFZLEVBQzNCLE9BQU8sRUFBRSxNQUFNLEVBQ2YsT0FBTyxFQUFFLENBQUM7Z0JBQ04sUUFBUSxDQUFDLENBQUMsR0FBRztvQkFDVCxLQUFLLFdBQVcsQ0FBQztvQkFDakIsS0FBSyxRQUFRO3dCQUNULElBQUksQ0FBQyxPQUFPLEVBQUU7NEJBQ1YsT0FBTzt5QkFDVjt3QkFDRCxNQUFNLEVBQUUsQ0FBQzt3QkFDVCxNQUFNO2lCQUViO2FBQ0o7WUFFQSxjQUFjLElBQUlBLDZCQUFDLElBQUksSUFBQyxJQUFJLEVBQUMsSUFBSSxFQUFDLEdBQUcsRUFBRSxjQUFjLEdBQUk7WUFDekQsS0FBSyxDQUNEO1FBQ1RBLHlDQUNJLElBQUksRUFBQyxRQUFRLEVBQ2IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFDaEMsT0FBTyxFQUFFLE1BQU0sZ0JBQ0osUUFBUSxtQkFDSixZQUFZO1lBRTNCQSw2QkFBQyxJQUFJLElBQUMsSUFBSSxFQUFDLElBQUksRUFBQyxHQUFHLEVBQUUsU0FBUyxHQUFJLENBQzdCLENBQ1IsRUFDUDtBQUNOLENBQUM7Ozs7In0=
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { StoryFn } from '@storybook/react';
|
|
2
|
+
import { Chips } from './Chips';
|
|
3
|
+
declare type ChipsStory = StoryFn<typeof Chips>;
|
|
4
|
+
export declare const Choice: ChipsStory;
|
|
5
|
+
export declare const ChoiceWithIcons: StoryFn<typeof Chips>;
|
|
6
|
+
export declare const Filter: StoryFn<typeof Chips>;
|
|
7
|
+
export declare const FilterWithIcons: StoryFn<typeof Chips>;
|
|
8
|
+
export declare const ComplexFilter: StoryFn<typeof Chips>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=Chips.stories.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Chips.stories.d.ts","sourceRoot":"","sources":["../../../src/components/Chips/Chips.stories.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAG3C,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,aAAK,UAAU,GAAG,OAAO,CAAC,OAAO,KAAK,CAAC,CAAC;AAExC,eAAO,MAAM,MAAM,EAAE,UAqBpB,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,OAAO,CAAC,OAAO,KAAK,CAsBjD,CAAC;AAEF,eAAO,MAAM,MAAM,EAAE,OAAO,CAAC,OAAO,KAAK,CAqBxC,CAAC;AAEF,eAAO,MAAM,eAAe,EAAE,OAAO,CAAC,OAAO,KAAK,CAsBjD,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,OAAO,CAAC,OAAO,KAAK,CAkD/C,CAAC"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import FavIcon from '@preply/ds-media-icons/dist/24/TokyoUIFav.svg';
|
|
2
|
+
import React__default, { useState } from 'react';
|
|
3
|
+
import { Chips } from './Chips.js';
|
|
4
|
+
|
|
5
|
+
const Choice = () => {
|
|
6
|
+
const [choices, setChoices] = useState({
|
|
7
|
+
Ambition: false,
|
|
8
|
+
Boldness: false,
|
|
9
|
+
Collaboration: false,
|
|
10
|
+
});
|
|
11
|
+
return (React__default.createElement(Chips, { variant: "choice", "aria-label": "Principle choices" }, Object.entries(choices).map(([name, pressed]) => (React__default.createElement(Chips.Item, { key: name, label: name, pressed: pressed, onToggle: newState => {
|
|
12
|
+
setChoices(prev => ({ ...prev, [name]: newState }));
|
|
13
|
+
} })))));
|
|
14
|
+
};
|
|
15
|
+
const ChoiceWithIcons = () => {
|
|
16
|
+
const [choices, setChoices] = useState({
|
|
17
|
+
Ambition: false,
|
|
18
|
+
Boldness: false,
|
|
19
|
+
Collaboration: false,
|
|
20
|
+
});
|
|
21
|
+
return (React__default.createElement(Chips, { variant: "choice", "aria-label": "Principle choices" }, Object.entries(choices).map(([name, pressed]) => (React__default.createElement(Chips.Item, { key: name, label: name, leadingSvgIcon: FavIcon, pressed: pressed, onToggle: newState => {
|
|
22
|
+
setChoices(prev => ({ ...prev, [name]: newState }));
|
|
23
|
+
} })))));
|
|
24
|
+
};
|
|
25
|
+
const Filter = () => {
|
|
26
|
+
const [filters, setFilters] = useState({
|
|
27
|
+
Ambition: false,
|
|
28
|
+
Boldness: false,
|
|
29
|
+
Collaboration: false,
|
|
30
|
+
});
|
|
31
|
+
return (React__default.createElement(Chips, { variant: "filter", "aria-label": "Principle filters" }, Object.entries(filters).map(([name, pressed]) => (React__default.createElement(Chips.Item, { key: name, label: name, pressed: pressed, onToggle: newState => {
|
|
32
|
+
setFilters(prev => ({ ...prev, [name]: newState }));
|
|
33
|
+
} })))));
|
|
34
|
+
};
|
|
35
|
+
const FilterWithIcons = () => {
|
|
36
|
+
const [filters, setFilters] = useState({
|
|
37
|
+
Ambition: false,
|
|
38
|
+
Boldness: false,
|
|
39
|
+
Collaboration: false,
|
|
40
|
+
});
|
|
41
|
+
return (React__default.createElement(Chips, { variant: "filter", "aria-label": "Principle filters" }, Object.entries(filters).map(([name, pressed]) => (React__default.createElement(Chips.Item, { key: name, label: name, leadingSvgIcon: FavIcon, pressed: pressed, onToggle: newState => {
|
|
42
|
+
setFilters(prev => ({ ...prev, [name]: newState }));
|
|
43
|
+
} })))));
|
|
44
|
+
};
|
|
45
|
+
const ComplexFilter = () => {
|
|
46
|
+
const [filterPrinciple, setFilterPrinciple] = useState(false);
|
|
47
|
+
const [principle, setPrinciple] = useState(undefined);
|
|
48
|
+
return (React__default.createElement("div", null,
|
|
49
|
+
React__default.createElement(Chips, { variant: "filter", "aria-label": "Principle filters" },
|
|
50
|
+
React__default.createElement(Chips.Item, { label: "Principles", pressed: filterPrinciple, onToggle: newState => {
|
|
51
|
+
if (principle !== undefined) {
|
|
52
|
+
setPrinciple(undefined);
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
setFilterPrinciple(newState);
|
|
56
|
+
}, onRemove: () => {
|
|
57
|
+
setPrinciple(undefined);
|
|
58
|
+
setFilterPrinciple(false);
|
|
59
|
+
}, "aria-controls": "principle-menu" })),
|
|
60
|
+
React__default.createElement("div", { id: "principle-menu" }, filterPrinciple &&
|
|
61
|
+
(principle ? (React__default.createElement(React__default.Fragment, null,
|
|
62
|
+
React__default.createElement("p", null, "Your favorite principle is:"),
|
|
63
|
+
React__default.createElement("p", null, principle))) : (React__default.createElement(React__default.Fragment, null,
|
|
64
|
+
React__default.createElement("p", null, "What's your favorite principle?"),
|
|
65
|
+
React__default.createElement("form", { onSubmit: e => {
|
|
66
|
+
e.preventDefault();
|
|
67
|
+
// @ts-expect-error - submitter exists https://developer.mozilla.org/en-US/docs/Web/API/SubmitEvent/submitter
|
|
68
|
+
setPrinciple(e.nativeEvent.submitter.value);
|
|
69
|
+
} },
|
|
70
|
+
React__default.createElement("input", { type: "submit", value: "Ambition" }),
|
|
71
|
+
React__default.createElement("input", { type: "submit", value: "Boldness" }),
|
|
72
|
+
React__default.createElement("input", { type: "submit", value: "Collaboration" }))))))));
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export { Choice, ChoiceWithIcons, ComplexFilter, Filter, FilterWithIcons };
|
|
76
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"Chips.stories.js","sources":["../../../src/components/Chips/Chips.stories.tsx"],"sourcesContent":["import FavIcon from '@preply/ds-media-icons/dist/24/TokyoUIFav.svg';\nimport { StoryFn } from '@storybook/react';\nimport React, { useState } from 'react';\n\nimport { Chips } from './Chips';\n\ntype ChipsStory = StoryFn<typeof Chips>;\n\nexport const Choice: ChipsStory = () => {\n    const [choices, setChoices] = useState({\n        Ambition: false,\n        Boldness: false,\n        Collaboration: false,\n    });\n\n    return (\n        <Chips variant=\"choice\" aria-label=\"Principle choices\">\n            {Object.entries(choices).map(([name, pressed]) => (\n                <Chips.Item\n                    key={name}\n                    label={name}\n                    pressed={pressed}\n                    onToggle={newState => {\n                        setChoices(prev => ({ ...prev, [name]: newState }));\n                    }}\n                />\n            ))}\n        </Chips>\n    );\n};\n\nexport const ChoiceWithIcons: StoryFn<typeof Chips> = () => {\n    const [choices, setChoices] = useState({\n        Ambition: false,\n        Boldness: false,\n        Collaboration: false,\n    });\n\n    return (\n        <Chips variant=\"choice\" aria-label=\"Principle choices\">\n            {Object.entries(choices).map(([name, pressed]) => (\n                <Chips.Item\n                    key={name}\n                    label={name}\n                    leadingSvgIcon={FavIcon}\n                    pressed={pressed}\n                    onToggle={newState => {\n                        setChoices(prev => ({ ...prev, [name]: newState }));\n                    }}\n                />\n            ))}\n        </Chips>\n    );\n};\n\nexport const Filter: StoryFn<typeof Chips> = () => {\n    const [filters, setFilters] = useState({\n        Ambition: false,\n        Boldness: false,\n        Collaboration: false,\n    });\n\n    return (\n        <Chips variant=\"filter\" aria-label=\"Principle filters\">\n            {Object.entries(filters).map(([name, pressed]) => (\n                <Chips.Item\n                    key={name}\n                    label={name}\n                    pressed={pressed}\n                    onToggle={newState => {\n                        setFilters(prev => ({ ...prev, [name]: newState }));\n                    }}\n                />\n            ))}\n        </Chips>\n    );\n};\n\nexport const FilterWithIcons: StoryFn<typeof Chips> = () => {\n    const [filters, setFilters] = useState({\n        Ambition: false,\n        Boldness: false,\n        Collaboration: false,\n    });\n\n    return (\n        <Chips variant=\"filter\" aria-label=\"Principle filters\">\n            {Object.entries(filters).map(([name, pressed]) => (\n                <Chips.Item\n                    key={name}\n                    label={name}\n                    leadingSvgIcon={FavIcon}\n                    pressed={pressed}\n                    onToggle={newState => {\n                        setFilters(prev => ({ ...prev, [name]: newState }));\n                    }}\n                />\n            ))}\n        </Chips>\n    );\n};\n\nexport const ComplexFilter: StoryFn<typeof Chips> = () => {\n    const [filterPrinciple, setFilterPrinciple] = useState(false);\n    const [principle, setPrinciple] = useState<string | undefined>(undefined);\n\n    return (\n        <div>\n            <Chips variant=\"filter\" aria-label=\"Principle filters\">\n                <Chips.Item\n                    label=\"Principles\"\n                    pressed={filterPrinciple}\n                    onToggle={newState => {\n                        if (principle !== undefined) {\n                            setPrinciple(undefined);\n                            return;\n                        }\n                        setFilterPrinciple(newState);\n                    }}\n                    onRemove={() => {\n                        setPrinciple(undefined);\n                        setFilterPrinciple(false);\n                    }}\n                    aria-controls=\"principle-menu\"\n                />\n            </Chips>\n            <div id=\"principle-menu\">\n                {filterPrinciple &&\n                    (principle ? (\n                        <>\n                            <p>Your favorite principle is:</p>\n                            <p>{principle}</p>\n                        </>\n                    ) : (\n                        <>\n                            <p>What&apos;s your favorite principle?</p>\n                            <form\n                                onSubmit={e => {\n                                    e.preventDefault();\n                                    // @ts-expect-error - submitter exists https://developer.mozilla.org/en-US/docs/Web/API/SubmitEvent/submitter\n                                    setPrinciple(e.nativeEvent.submitter.value);\n                                }}\n                            >\n                                <input type=\"submit\" value=\"Ambition\" />\n                                <input type=\"submit\" value=\"Boldness\" />\n                                <input type=\"submit\" value=\"Collaboration\" />\n                            </form>\n                        </>\n                    ))}\n            </div>\n        </div>\n    );\n};\n"],"names":["React"],"mappings":"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"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
@import '@preply/ds-web-core/dist/generated/tokens.less';
|
|
2
|
+
@import '@preply/ds-web-core/dist/generated/hover.less';
|
|
3
|
+
|
|
4
|
+
.chips {
|
|
5
|
+
&:is(ul) {
|
|
6
|
+
list-style: none;
|
|
7
|
+
margin: 0;
|
|
8
|
+
padding: 0;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
display: flex;
|
|
12
|
+
gap: @spacing-12;
|
|
13
|
+
flex-wrap: wrap;
|
|
14
|
+
|
|
15
|
+
& .chip {
|
|
16
|
+
& button {
|
|
17
|
+
all: unset;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
box-sizing: border-box;
|
|
21
|
+
cursor: pointer;
|
|
22
|
+
height: @sizing-40;
|
|
23
|
+
width: fit-content;
|
|
24
|
+
font-size: @text-default-semibold-body-fontSize;
|
|
25
|
+
font-weight: @text-default-semibold-body-fontWeight;
|
|
26
|
+
line-height: @text-default-semibold-body-lineHeight;
|
|
27
|
+
color: @color-text-primary;
|
|
28
|
+
background-color: @color-background-primary;
|
|
29
|
+
border: solid @sizing-2;
|
|
30
|
+
border-radius: @radius-8;
|
|
31
|
+
border-color: @color-border-primary;
|
|
32
|
+
display: flex;
|
|
33
|
+
align-items: center;
|
|
34
|
+
|
|
35
|
+
.onHover({
|
|
36
|
+
background-color: @color-background-secondary;
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
&:has(.chip-toggle:focus-visible) {
|
|
40
|
+
outline: solid @sizing-2 @color-border-focus;
|
|
41
|
+
outline-offset: @spacing-2;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
&:has(.chip-toggle:active) {
|
|
45
|
+
border-color: @color-border-secondary;
|
|
46
|
+
background-color: @color-background-tertiary;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
&:has(.chip-toggle[aria-pressed="true"]) {
|
|
50
|
+
border-color: @color-border-secondary;
|
|
51
|
+
background-color: @color-background-tertiary;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
& .chip-toggle {
|
|
55
|
+
padding: @spacing-8 @spacing-12;
|
|
56
|
+
display: flex;
|
|
57
|
+
gap: @spacing-8;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
& .chip-remove {
|
|
61
|
+
height: fit-content;
|
|
62
|
+
width: fit-content;
|
|
63
|
+
display: flex;
|
|
64
|
+
justify-content: center;
|
|
65
|
+
align-items: center;
|
|
66
|
+
padding: @spacing-8 @spacing-12 @spacing-8 0;
|
|
67
|
+
border-radius: inherit;
|
|
68
|
+
|
|
69
|
+
&:focus-visible {
|
|
70
|
+
outline: solid @sizing-2 @color-border-focus;
|
|
71
|
+
outline-offset: @spacing-1 @spacing-2;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
&[data-variant="choice"] .chip {
|
|
77
|
+
&:has(.chip-toggle[aria-pressed="true"]) {
|
|
78
|
+
color: @color-text-inverted;
|
|
79
|
+
background-color: @color-background-primaryInverted;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
& .chip-remove {
|
|
83
|
+
display: none;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
&[data-variant="filter"] .chip {
|
|
88
|
+
&:has(.chip-toggle[aria-pressed="false"]) {
|
|
89
|
+
& .chip-remove {
|
|
90
|
+
display: none;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|