@ndlib/component-library 1.0.20 → 1.0.22
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/README.md +26 -8
- package/dist/assets/index-3cfb730f.js +1 -0
- package/dist/components/composites/Card/Card.stories.js +2 -0
- package/dist/components/composites/Card/index.js +4 -3
- package/dist/components/composites/CardV2/CardV2.module.css +74 -0
- package/dist/components/composites/CardV2/CardV2.stories.d.ts +19 -0
- package/dist/components/composites/CardV2/CardV2.stories.js +187 -0
- package/dist/components/composites/CardV2/CardV2.test.js +67 -0
- package/dist/components/composites/CardV2/index.d.ts +42 -0
- package/dist/components/composites/CardV2/index.js +97 -0
- package/dist/components/composites/DragDropList/DragDropList.stories.js +3 -1
- package/dist/components/composites/DropdownLinks/DropdownLinks.stories.js +2 -0
- package/dist/components/composites/DropdownLinks/index.d.ts +1 -1
- package/dist/components/composites/EmptyState/EmptyState.stories.js +2 -0
- package/dist/components/composites/EmptyState/index.js +1 -1
- package/dist/components/composites/Modal/Modal.stories.js +5 -2
- package/dist/components/composites/Modal/index.js +3 -2
- package/dist/components/composites/ModalV2/ModalV2.stories.d.ts +6 -0
- package/dist/components/composites/ModalV2/ModalV2.stories.js +41 -0
- package/dist/components/composites/ModalV2/ModalV2.test.js +37 -0
- package/dist/components/composites/ModalV2/index.d.ts +20 -0
- package/dist/components/composites/ModalV2/index.js +65 -0
- package/dist/components/composites/NavMenu/NavMenu.stories.js +2 -0
- package/dist/components/composites/NavMenu/index.js +1 -1
- package/dist/components/composites/Seo/seo.stories.js +2 -0
- package/dist/components/composites/SnackBar/SnackBar.stories.js +2 -0
- package/dist/components/composites/StructuredData/StructuredData.stories.js +2 -0
- package/dist/components/elements/Alerts/Alert.stories.js +2 -0
- package/dist/components/elements/Alerts/Alerts.stories.js +2 -0
- package/dist/components/elements/Alerts/index.js +2 -1
- package/dist/components/elements/ArrowLink/ArrowLink.stories.js +2 -0
- package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.stories.js +6 -4
- package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.test.js +1 -1
- package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/index.js +3 -3
- package/dist/components/elements/BrandingBar/BrandingBar.stories.js +2 -0
- package/dist/components/elements/Button/Button.stories.js +4 -2
- package/dist/components/elements/ButtonV2/ButtonV2.module.css +25 -0
- package/dist/components/elements/ButtonV2/ButtonV2.stories.d.ts +15 -0
- package/dist/components/elements/ButtonV2/ButtonV2.stories.js +90 -0
- package/dist/components/elements/ButtonV2/ButtonV2.test.js +45 -0
- package/dist/components/elements/ButtonV2/index.d.ts +49 -0
- package/dist/components/elements/ButtonV2/index.js +136 -0
- package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.stories.js +3 -1
- package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.test.js +1 -1
- package/dist/components/elements/{Fields/Checkbox → Checkbox}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/Checkbox → Checkbox}/index.js +2 -2
- package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.stories.js +3 -1
- package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.test.js +1 -1
- package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/index.js +7 -7
- package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.stories.d.ts +8 -0
- package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.stories.js +31 -0
- package/dist/components/elements/CheckboxGroupV2/CheckboxGroupV2.test.js +34 -0
- package/dist/components/elements/CheckboxGroupV2/index.d.ts +17 -0
- package/dist/components/elements/CheckboxGroupV2/index.js +50 -0
- package/dist/components/elements/CheckboxV2/CheckboxV2.module.css +5 -0
- package/dist/components/elements/CheckboxV2/CheckboxV2.stories.d.ts +6 -0
- package/dist/components/elements/CheckboxV2/CheckboxV2.stories.js +19 -0
- package/dist/components/elements/CheckboxV2/CheckboxV2.test.js +35 -0
- package/dist/components/elements/CheckboxV2/index.d.ts +9 -0
- package/dist/components/elements/CheckboxV2/index.js +22 -0
- package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.stories.js +3 -1
- package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.test.js +1 -1
- package/dist/components/elements/{Fields/DatePicker → DatePicker}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/DatePicker → DatePicker}/index.js +2 -2
- package/dist/components/elements/Dropdown/Dropdown.stories.js +3 -1
- package/dist/components/elements/Dropdown/index.js +1 -1
- package/dist/components/elements/GroupV2/index.d.ts +22 -0
- package/dist/components/elements/GroupV2/index.js +71 -0
- package/dist/components/elements/{text/Heading → Heading}/Heading.stories.js +5 -3
- package/dist/components/elements/{text/Heading → Heading}/Heading.test.js +3 -3
- package/dist/components/elements/{text/Heading → Heading}/index.d.ts +3 -3
- package/dist/components/elements/{text/Heading → Heading}/index.js +10 -9
- package/dist/components/elements/HeadingV2/HeadingV2.module.css +8 -0
- package/dist/components/elements/HeadingV2/HeadingV2.stories.d.ts +8 -0
- package/dist/components/elements/HeadingV2/HeadingV2.stories.js +37 -0
- package/dist/components/elements/HeadingV2/HeadingV2.test.js +51 -0
- package/dist/components/elements/HeadingV2/index.d.ts +22 -0
- package/dist/components/elements/HeadingV2/index.js +100 -0
- package/dist/components/elements/Icon/Icon.stories.js +3 -1
- package/dist/components/elements/IconV2/IconV2.module.css +10 -0
- package/dist/components/elements/IconV2/IconV2.stories.d.ts +7 -0
- package/dist/components/elements/IconV2/IconV2.stories.js +31 -0
- package/dist/components/elements/IconV2/IconV2.test.js +62 -0
- package/dist/components/elements/IconV2/index.d.ts +10 -0
- package/dist/components/elements/IconV2/index.js +33 -0
- package/dist/components/elements/{text/Inline → Inline}/Inline.stories.js +2 -0
- package/dist/components/elements/{text/Inline → Inline}/index.d.ts +1 -1
- package/dist/components/elements/{text/Inline → Inline}/index.js +1 -1
- package/dist/components/elements/{text/Label → Label}/Label.stories.js +4 -2
- package/dist/components/elements/Label/Label.test.d.ts +1 -0
- package/dist/components/elements/{text/Label → Label}/Label.test.js +3 -3
- package/dist/components/elements/{text/Label → Label}/index.d.ts +2 -2
- package/dist/components/elements/{text/Label → Label}/index.js +3 -3
- package/dist/components/elements/LabelV2/LabelV2.stories.d.ts +6 -0
- package/dist/components/elements/LabelV2/LabelV2.stories.js +22 -0
- package/dist/components/elements/LabelV2/LabelV2.test.d.ts +1 -0
- package/dist/components/elements/LabelV2/LabelV2.test.js +56 -0
- package/dist/components/elements/LabelV2/index.d.ts +20 -0
- package/dist/components/elements/LabelV2/index.js +41 -0
- package/dist/components/elements/Link/Link.stories.js +3 -1
- package/dist/components/elements/List/List.stories.js +3 -1
- package/dist/components/elements/List/index.js +1 -1
- package/dist/components/elements/ListBox/Listbox.stories.js +2 -0
- package/dist/components/elements/ListBox/index.d.ts +1 -1
- package/dist/components/elements/ListBox/index.js +1 -1
- package/dist/components/elements/ListBoxV2/ListBoxV2.module.css +33 -0
- package/dist/components/elements/ListBoxV2/ListBoxV2.stories.d.ts +6 -0
- package/dist/components/elements/ListBoxV2/ListBoxV2.stories.js +19 -0
- package/dist/components/elements/ListBoxV2/index.d.ts +33 -0
- package/dist/components/elements/ListBoxV2/index.js +35 -0
- package/dist/components/elements/Markdown/Markdown.stories.js +2 -0
- package/dist/components/elements/Markdown/index.js +4 -4
- package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.stories.js +3 -1
- package/dist/components/elements/MonthPicker/MonthPicker.test.d.ts +1 -0
- package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.test.js +1 -1
- package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/index.js +2 -2
- package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.stories.js +5 -3
- package/dist/components/elements/Paragraph/Paragraph.test.d.ts +1 -0
- package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.test.js +1 -1
- package/dist/components/elements/{text/Paragraph → Paragraph}/index.d.ts +2 -2
- package/dist/components/elements/{text/Paragraph → Paragraph}/index.js +6 -5
- package/dist/components/elements/ParagraphV2/ParagraphV2.stories.d.ts +7 -0
- package/dist/components/elements/ParagraphV2/ParagraphV2.stories.js +33 -0
- package/dist/components/elements/ParagraphV2/ParagraphV2.test.d.ts +1 -0
- package/dist/components/elements/ParagraphV2/ParagraphV2.test.js +9 -0
- package/dist/components/elements/ParagraphV2/index.d.ts +15 -0
- package/dist/components/elements/ParagraphV2/index.js +39 -0
- package/dist/components/elements/Pill/Pill.stories.js +3 -1
- package/dist/components/elements/Pill/index.js +2 -1
- package/dist/components/elements/{Fields/Radio → Radio}/Radio.stories.js +3 -1
- package/dist/components/elements/Radio/Radio.test.d.ts +1 -0
- package/dist/components/elements/{Fields/Radio → Radio}/Radio.test.js +3 -3
- package/dist/components/elements/{Fields/Radio → Radio}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/Radio → Radio}/index.js +1 -1
- package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.stories.js +3 -1
- package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.test.js +1 -1
- package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/index.js +6 -6
- package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.stories.js +5 -3
- package/dist/components/elements/ReadMore/ReadMore.test.d.ts +1 -0
- package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.test.js +4 -9
- package/dist/components/elements/{text/ReadMore → ReadMore}/index.d.ts +2 -2
- package/dist/components/elements/{text/ReadMore → ReadMore}/index.js +10 -9
- package/dist/components/elements/ReadMoreV2/ReadMoreV2.module.css +19 -0
- package/dist/components/elements/ReadMoreV2/ReadMoreV2.stories.d.ts +8 -0
- package/dist/components/elements/ReadMoreV2/ReadMoreV2.stories.js +28 -0
- package/dist/components/elements/ReadMoreV2/ReadMoreV2.test.d.ts +1 -0
- package/dist/components/elements/ReadMoreV2/ReadMoreV2.test.js +30 -0
- package/dist/components/elements/ReadMoreV2/index.d.ts +12 -0
- package/dist/components/elements/ReadMoreV2/index.js +81 -0
- package/dist/components/elements/{Fields/Select → Select}/Select.stories.js +6 -4
- package/dist/components/elements/Select/Select.test.d.ts +1 -0
- package/dist/components/elements/{Fields/Select → Select}/Select.test.js +1 -1
- package/dist/components/elements/{Fields/Select → Select}/index.d.ts +1 -1
- package/dist/components/elements/{Fields/Select → Select}/index.js +9 -9
- package/dist/components/elements/SelectV2/SelectV2.module.css +27 -0
- package/dist/components/elements/SelectV2/SelectV2.stories.d.ts +8 -0
- package/dist/components/elements/SelectV2/SelectV2.stories.js +41 -0
- package/dist/components/elements/SelectV2/SelectV2.test.d.ts +1 -0
- package/dist/components/elements/SelectV2/SelectV2.test.js +52 -0
- package/dist/components/elements/SelectV2/index.d.ts +18 -0
- package/dist/components/elements/SelectV2/index.js +164 -0
- package/dist/components/elements/Spinner/Spinner.stories.js +2 -0
- package/dist/components/elements/Spinner/index.js +1 -1
- package/dist/components/elements/SpinnerV2/SpinnerV2.module.css +12 -0
- package/dist/components/elements/SpinnerV2/SpinnerV2.stories.d.ts +7 -0
- package/dist/components/elements/SpinnerV2/SpinnerV2.stories.js +29 -0
- package/dist/components/elements/SpinnerV2/SpinnerV2.test.d.ts +1 -0
- package/dist/components/elements/SpinnerV2/SpinnerV2.test.js +9 -0
- package/dist/components/elements/SpinnerV2/index.d.ts +14 -0
- package/dist/components/elements/SpinnerV2/index.js +35 -0
- package/dist/components/elements/TabList/TabList.stories.js +2 -0
- package/dist/components/elements/Table/Table.stories.js +2 -0
- package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.stories.js +6 -4
- package/dist/components/elements/TextInput/TextInput.test.d.ts +1 -0
- package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.test.js +2 -2
- package/dist/components/elements/{Fields/TextInput → TextInput}/index.d.ts +3 -3
- package/dist/components/elements/{Fields/TextInput → TextInput}/index.js +9 -8
- package/dist/components/elements/TextInputV2/TextInputV2.module.css +71 -0
- package/dist/components/elements/TextInputV2/TextInputV2.stories.d.ts +9 -0
- package/dist/components/elements/TextInputV2/TextInputV2.stories.js +37 -0
- package/dist/components/elements/TextInputV2/TextInputV2.test.d.ts +1 -0
- package/dist/components/elements/TextInputV2/TextInputV2.test.js +59 -0
- package/dist/components/elements/TextInputV2/index.d.ts +45 -0
- package/dist/components/elements/TextInputV2/index.js +97 -0
- package/dist/components/elements/layout/Box.stories.js +2 -0
- package/dist/components/elements/layout/Flex.stories.js +3 -1
- package/dist/components/elements/layoutV2/BoxV2.d.ts +9 -0
- package/dist/components/elements/layoutV2/BoxV2.js +19 -0
- package/dist/components/elements/layoutV2/BoxV2.stories.d.ts +6 -0
- package/dist/components/elements/layoutV2/BoxV2.stories.js +14 -0
- package/dist/components/elements/layoutV2/ColumnV2.d.ts +8 -0
- package/dist/components/elements/layoutV2/ColumnV2.js +21 -0
- package/dist/components/elements/layoutV2/RowV2.d.ts +19 -0
- package/dist/components/elements/layoutV2/RowV2.js +54 -0
- package/dist/components/providers/alerts.js +5 -4
- package/dist/components/providers/alerts.test.d.ts +1 -0
- package/dist/components/providers/alerts.test.js +115 -0
- package/dist/components/providers/componentConfigV2.d.ts +25 -0
- package/dist/components/providers/componentConfigV2.js +37 -0
- package/dist/components/providers/media.js +1 -1
- package/dist/components/providers/mediaV2.d.ts +11 -0
- package/dist/components/providers/mediaV2.js +48 -0
- package/dist/components/providers/uiV2.d.ts +20 -0
- package/dist/components/providers/uiV2.js +16 -0
- package/dist/index.d.ts +34 -14
- package/dist/index.html +14 -0
- package/dist/index.js +33 -13
- package/dist/theme/Color.stories.js +3 -1
- package/dist/theme/GlobalStylesV2.d.ts +2 -0
- package/dist/theme/GlobalStylesV2.js +212 -0
- package/dist/theme/Typography.stories.js +3 -1
- package/dist/theme/css-variables.css +57 -0
- package/dist/theme/index.d.ts +127 -1
- package/dist/theme/index.js +14 -0
- package/dist/theme/typography.js +2 -2
- package/dist/utils/decorators/UIVersion1.d.ts +2 -0
- package/dist/utils/decorators/UIVersion1.js +7 -0
- package/dist/utils/decorators/UIVersion2.d.ts +2 -0
- package/dist/utils/decorators/UIVersion2.js +7 -0
- package/dist/utils/hooks/useFocus.d.ts +7 -0
- package/dist/utils/hooks/useFocus.js +12 -0
- package/dist/utils/processSx.d.ts +3 -0
- package/dist/utils/processSx.js +135 -0
- package/package.json +7 -4
- /package/dist/components/{elements/Fields/Checkbox/Checkbox.test.d.ts → composites/CardV2/CardV2.test.d.ts} +0 -0
- /package/dist/components/{elements/Fields/CheckboxGroup/CheckboxGroup.test.d.ts → composites/ModalV2/ModalV2.test.d.ts} +0 -0
- /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/AutoComplete.test.d.ts +0 -0
- /package/dist/components/elements/{Fields/AutoComplete → AutoComplete}/index.d.ts +0 -0
- /package/dist/components/elements/{Fields/DatePicker/DatePicker.test.d.ts → ButtonV2/ButtonV2.test.d.ts} +0 -0
- /package/dist/components/elements/{text/Caption → Caption}/index.d.ts +0 -0
- /package/dist/components/elements/{text/Caption → Caption}/index.js +0 -0
- /package/dist/components/elements/{Fields/Checkbox → Checkbox}/Checkbox.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/MonthPicker/MonthPicker.test.d.ts → Checkbox/Checkbox.test.d.ts} +0 -0
- /package/dist/components/elements/{Fields/CheckboxGroup → CheckboxGroup}/CheckboxGroup.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/Radio/Radio.test.d.ts → CheckboxGroup/CheckboxGroup.test.d.ts} +0 -0
- /package/dist/components/elements/{Fields/Select/Select.test.d.ts → CheckboxGroupV2/CheckboxGroupV2.test.d.ts} +0 -0
- /package/dist/components/elements/{text/Heading/Heading.test.d.ts → CheckboxV2/CheckboxV2.test.d.ts} +0 -0
- /package/dist/components/elements/{Fields/DatePicker → DatePicker}/DatePicker.stories.d.ts +0 -0
- /package/dist/components/elements/{text/Label/Label.test.d.ts → DatePicker/DatePicker.test.d.ts} +0 -0
- /package/dist/components/elements/{text/Heading → Heading}/Heading.stories.d.ts +0 -0
- /package/dist/components/elements/{text/Paragraph/Paragraph.test.d.ts → Heading/Heading.test.d.ts} +0 -0
- /package/dist/components/elements/{text/ReadMore/ReadMore.test.d.ts → HeadingV2/HeadingV2.test.d.ts} +0 -0
- /package/dist/components/elements/{Fields/RadioGroup/RadioGroup.test.d.ts → IconV2/IconV2.test.d.ts} +0 -0
- /package/dist/components/elements/{text/Inline → Inline}/Inline.stories.d.ts +0 -0
- /package/dist/components/elements/{text/Label → Label}/Label.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/MonthPicker → MonthPicker}/MonthPicker.stories.d.ts +0 -0
- /package/dist/components/elements/{text/Paragraph → Paragraph}/Paragraph.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/Radio → Radio}/Radio.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/RadioGroup → RadioGroup}/RadioGroup.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/TextInput/TextInput.test.d.ts → RadioGroup/RadioGroup.test.d.ts} +0 -0
- /package/dist/components/elements/{text/ReadMore → ReadMore}/ReadMore.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/Select → Select}/Select.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/TextInput → TextInput}/TextInput.stories.d.ts +0 -0
- /package/dist/components/elements/{Fields/option.d.ts → option.d.ts} +0 -0
- /package/dist/components/elements/{Fields/option.js → option.js} +0 -0
|
@@ -3,12 +3,14 @@ import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
|
|
|
3
3
|
import { Button } from '../../elements/Button';
|
|
4
4
|
import { Box } from '../../elements/layout/Box';
|
|
5
5
|
import { Dropdown } from '.';
|
|
6
|
-
import { Paragraph } from '../
|
|
6
|
+
import { Paragraph } from '../Paragraph';
|
|
7
7
|
import { Column } from '../layout/Column';
|
|
8
|
+
import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
|
|
8
9
|
const meta = {
|
|
9
10
|
title: 'Elements/Dropdown',
|
|
10
11
|
component: Dropdown,
|
|
11
12
|
tags: ['autodocs'],
|
|
13
|
+
decorators: [UIVersion1],
|
|
12
14
|
};
|
|
13
15
|
export default meta;
|
|
14
16
|
const lorem = `Lorem ipsum dolor sit amet, consectetur adipiscing elit.
|
|
@@ -50,7 +50,7 @@ export const Dropdown = (_a) => {
|
|
|
50
50
|
}),
|
|
51
51
|
],
|
|
52
52
|
});
|
|
53
|
-
const dropdownBoxStyles = Object.assign(Object.assign({}, floatingStyles), { minWidth: dropdownMinWidth, maxWidth: dropdownMaxWidth, zIndex: Z_INDEX.DIALOG, backgroundColor: COLOR.WHITE, boxShadow: boxShadow.NORMAL });
|
|
53
|
+
const dropdownBoxStyles = Object.assign(Object.assign({}, floatingStyles), { minWidth: dropdownMinWidth, maxWidth: dropdownMaxWidth, zIndex: Z_INDEX.DIALOG, backgroundColor: COLOR.WHITE, boxShadow: boxShadow === null || boxShadow === void 0 ? void 0 : boxShadow.NORMAL });
|
|
54
54
|
const onClick = useCallback(() => {
|
|
55
55
|
setIsOpen(!isOpen);
|
|
56
56
|
}, [isOpen]);
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { StyledElementPropsV2 } from '../../../theme';
|
|
3
|
+
type GroupV2ContextType = {
|
|
4
|
+
level: number;
|
|
5
|
+
labelId: string;
|
|
6
|
+
trackHeadingRendered: () => void;
|
|
7
|
+
labelTargetId: string;
|
|
8
|
+
type?: GROUPV2_TYPE;
|
|
9
|
+
};
|
|
10
|
+
export declare enum GROUPV2_TYPE {
|
|
11
|
+
REGION = "region",
|
|
12
|
+
GROUP = "group",
|
|
13
|
+
RAW = "raw"
|
|
14
|
+
}
|
|
15
|
+
export declare const useGroupV2: () => GroupV2ContextType;
|
|
16
|
+
type GroupV2Props = Omit<StyledElementPropsV2<HTMLDivElement, {
|
|
17
|
+
type?: GROUPV2_TYPE;
|
|
18
|
+
}>, 'children'> & {
|
|
19
|
+
children: React.ReactNode | ((context: GroupV2ContextType) => React.ReactNode);
|
|
20
|
+
};
|
|
21
|
+
export declare const GroupV2: React.FC<GroupV2Props>;
|
|
22
|
+
export {};
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
|
+
import React, { useEffect, useId, useRef } from 'react';
|
|
14
|
+
import { useEnvironment } from '../../providers/env';
|
|
15
|
+
import { processSx } from '../../../utils/processSx';
|
|
16
|
+
export var GROUPV2_TYPE;
|
|
17
|
+
(function (GROUPV2_TYPE) {
|
|
18
|
+
GROUPV2_TYPE["REGION"] = "region";
|
|
19
|
+
GROUPV2_TYPE["GROUP"] = "group";
|
|
20
|
+
GROUPV2_TYPE["RAW"] = "raw";
|
|
21
|
+
})(GROUPV2_TYPE || (GROUPV2_TYPE = {}));
|
|
22
|
+
const GROUPV2_TYPE_ROLE_MAP = {
|
|
23
|
+
[GROUPV2_TYPE.REGION]: 'region',
|
|
24
|
+
[GROUPV2_TYPE.GROUP]: 'group',
|
|
25
|
+
[GROUPV2_TYPE.RAW]: 'group',
|
|
26
|
+
};
|
|
27
|
+
const GroupV2Context = React.createContext({
|
|
28
|
+
level: 0,
|
|
29
|
+
labelId: '',
|
|
30
|
+
labelTargetId: '',
|
|
31
|
+
trackHeadingRendered: () => { },
|
|
32
|
+
});
|
|
33
|
+
export const useGroupV2 = () => React.useContext(GroupV2Context);
|
|
34
|
+
export const GroupV2 = (_a) => {
|
|
35
|
+
var { type: typeProp, children, sx } = _a, rest = __rest(_a, ["type", "children", "sx"]);
|
|
36
|
+
const processedStyles = processSx(sx);
|
|
37
|
+
const { level: parentLevel } = useGroupV2();
|
|
38
|
+
const { flagInDevelopment } = useEnvironment();
|
|
39
|
+
const type = typeProp || GROUPV2_TYPE.REGION;
|
|
40
|
+
const uniqueId = useId();
|
|
41
|
+
const labelId = `group-label-${uniqueId}`;
|
|
42
|
+
const labelTargetId = `labeled-${uniqueId}`;
|
|
43
|
+
const headingRenderTracker = useRef({
|
|
44
|
+
hasHeadingRendered: false,
|
|
45
|
+
});
|
|
46
|
+
const trackHeadingRendered = () => {
|
|
47
|
+
headingRenderTracker.current.hasHeadingRendered = true;
|
|
48
|
+
};
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
if (type === GROUPV2_TYPE.REGION) {
|
|
51
|
+
setTimeout(() => {
|
|
52
|
+
if (!headingRenderTracker.current.hasHeadingRendered) {
|
|
53
|
+
flagInDevelopment('Every <GroupV2> component of type "region" must render a <Heading> component within it');
|
|
54
|
+
}
|
|
55
|
+
}, 500);
|
|
56
|
+
}
|
|
57
|
+
}, [flagInDevelopment, type]);
|
|
58
|
+
const level = Math.min(parentLevel + (type === GROUPV2_TYPE.REGION ? 1 : 0), 5);
|
|
59
|
+
const contextValue = {
|
|
60
|
+
level,
|
|
61
|
+
type,
|
|
62
|
+
trackHeadingRendered,
|
|
63
|
+
labelId,
|
|
64
|
+
labelTargetId,
|
|
65
|
+
};
|
|
66
|
+
const Main = (_jsx(GroupV2Context.Provider, Object.assign({ value: contextValue }, { children: typeof children === 'function' ? children(contextValue) : children })));
|
|
67
|
+
if (type === GROUPV2_TYPE.RAW) {
|
|
68
|
+
return Main;
|
|
69
|
+
}
|
|
70
|
+
return (_jsx("div", Object.assign({ role: GROUPV2_TYPE_ROLE_MAP[type], "aria-labelledby": labelId, style: Object.assign({ marginTop: '0.5rem', marginBottom: '0.5rem' }, processedStyles) }, rest, { children: Main })));
|
|
71
|
+
};
|
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { GROUP_TYPE, Group } from '
|
|
2
|
+
import { GROUP_TYPE, Group } from '../Group';
|
|
3
3
|
import { HEADING_SIZE, Heading } from '.';
|
|
4
|
-
import { Column } from '
|
|
5
|
-
import { COLOR } from '
|
|
4
|
+
import { Column } from '../layout/Column';
|
|
5
|
+
import { COLOR } from '../../../theme/colors';
|
|
6
|
+
import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
|
|
6
7
|
const meta = {
|
|
7
8
|
title: 'Elements/Heading',
|
|
8
9
|
component: Heading,
|
|
9
10
|
tags: ['autodocs'],
|
|
11
|
+
decorators: [UIVersion1],
|
|
10
12
|
};
|
|
11
13
|
export default meta;
|
|
12
14
|
const sizes = [
|
|
@@ -9,10 +9,10 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
9
9
|
};
|
|
10
10
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
11
11
|
import { vi } from 'vitest';
|
|
12
|
-
import { render as _render } from '
|
|
12
|
+
import { render as _render } from '../../../utils/test';
|
|
13
13
|
import { Heading } from '.';
|
|
14
|
-
import { GROUP_TYPE, Group } from '
|
|
15
|
-
import { ENVIRONMENT } from '
|
|
14
|
+
import { GROUP_TYPE, Group } from '../Group';
|
|
15
|
+
import { ENVIRONMENT } from '../../providers/env';
|
|
16
16
|
const render = (component) => {
|
|
17
17
|
return _render(component, { env: ENVIRONMENT.DEV });
|
|
18
18
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { TYPOGRAPHY_TYPE } from '
|
|
3
|
-
import { StyledElementProps } from '
|
|
4
|
-
import { COLOR } from '
|
|
2
|
+
import { TYPOGRAPHY_TYPE } from '../../../theme/typography';
|
|
3
|
+
import { StyledElementProps } from '../../../theme';
|
|
4
|
+
import { COLOR } from '../../../theme/colors';
|
|
5
5
|
type HeaderProps = StyledElementProps<HTMLSpanElement, {
|
|
6
6
|
size?: HEADING_SIZE;
|
|
7
7
|
standalone?: boolean;
|
|
@@ -11,12 +11,12 @@ var __rest = (this && this.__rest) || function (s, e) {
|
|
|
11
11
|
};
|
|
12
12
|
import { jsx as _jsx } from "theme-ui/jsx-runtime";
|
|
13
13
|
import { useEffect } from 'react';
|
|
14
|
-
import { getTypographyStyles, TYPOGRAPHY_TYPE
|
|
15
|
-
import { useTheme } from '
|
|
16
|
-
import { GROUP_TYPE, useGroup } from '
|
|
17
|
-
import { COLOR } from '
|
|
18
|
-
import { useEnvironment } from '
|
|
19
|
-
import { multiplyRemSize } from '
|
|
14
|
+
import { getTypographyStyles, TYPOGRAPHY_TYPE } from '../../../theme/typography';
|
|
15
|
+
import { useTheme } from '../../../theme';
|
|
16
|
+
import { GROUP_TYPE, useGroup } from '../Group';
|
|
17
|
+
import { COLOR } from '../../../theme/colors';
|
|
18
|
+
import { useEnvironment } from '../../providers/env';
|
|
19
|
+
import { multiplyRemSize } from '../../../utils/misc';
|
|
20
20
|
export var HEADING_SIZE;
|
|
21
21
|
(function (HEADING_SIZE) {
|
|
22
22
|
HEADING_SIZE["SM"] = "sm";
|
|
@@ -39,7 +39,8 @@ const LEVEL_TYPOGRAPHY_MAP = {
|
|
|
39
39
|
6: TYPOGRAPHY_TYPE.HEADING_SMALL,
|
|
40
40
|
};
|
|
41
41
|
export const Heading = (_a) => {
|
|
42
|
-
var
|
|
42
|
+
var _b, _c;
|
|
43
|
+
var { sx, size, standalone, id, underline, underlineColor, typography: typographyProp, level: levelParam } = _a, rest = __rest(_a, ["sx", "size", "standalone", "id", "underline", "underlineColor", "typography", "level"]);
|
|
43
44
|
const { level: groupLevel, type, trackHeadingRendered } = useGroup();
|
|
44
45
|
const { flagInDevelopment } = useEnvironment();
|
|
45
46
|
const theme = useTheme();
|
|
@@ -68,9 +69,9 @@ export const Heading = (_a) => {
|
|
|
68
69
|
}
|
|
69
70
|
return 0.55;
|
|
70
71
|
};
|
|
71
|
-
const marginHeightMultiple = theme.lineHeights[typographyStyles.lineHeight] *
|
|
72
|
+
const marginHeightMultiple = (((_b = theme.lineHeights) === null || _b === void 0 ? void 0 : _b[typographyStyles.lineHeight]) || 1.625) *
|
|
72
73
|
getMarginHeightMultiple(level);
|
|
73
|
-
const fontSize = theme.fontSizes[typographyStyles.fontSize];
|
|
74
|
+
const fontSize = ((_c = theme.fontSizes) === null || _c === void 0 ? void 0 : _c[typographyStyles.fontSize]) || '1rem';
|
|
74
75
|
const topMargin = multiplyRemSize({
|
|
75
76
|
size: fontSize,
|
|
76
77
|
multiple: marginHeightMultiple,
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { HeadingV2 } from '.';
|
|
3
|
+
declare const meta: Meta<typeof HeadingV2>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof HeadingV2>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const Color: Story;
|
|
8
|
+
export declare const Underline: Story;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
|
|
3
|
+
import { HEADINGV2_SIZE, HeadingV2 } from '.';
|
|
4
|
+
import { ColumnV2 } from '../layoutV2/ColumnV2';
|
|
5
|
+
import { COLOR } from '../../../theme/colors';
|
|
6
|
+
import { UIVersion2 } from '../../../utils/decorators/UIVersion2';
|
|
7
|
+
const meta = {
|
|
8
|
+
title: 'Elements/HeadingV2',
|
|
9
|
+
component: HeadingV2,
|
|
10
|
+
tags: ['autodocs'],
|
|
11
|
+
decorators: [UIVersion2],
|
|
12
|
+
};
|
|
13
|
+
export default meta;
|
|
14
|
+
const sizes = [
|
|
15
|
+
{ size: HEADINGV2_SIZE.XL, label: 'Extra Large (Default Level 1)' },
|
|
16
|
+
{ size: HEADINGV2_SIZE.LG, label: 'Large (Default Level 2)' },
|
|
17
|
+
{ size: HEADINGV2_SIZE.MD, label: 'Medium (Default Level 3)' },
|
|
18
|
+
{ size: HEADINGV2_SIZE.SM, label: 'Small (Default Level 4-6)' },
|
|
19
|
+
];
|
|
20
|
+
export const Default = {
|
|
21
|
+
render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size }, { children: size.label })) })))) })),
|
|
22
|
+
args: {
|
|
23
|
+
children: 'Heading V2',
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
export const Color = {
|
|
27
|
+
render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size, sx: { color: COLOR.TEXT } }, { children: size.label })) })))) })),
|
|
28
|
+
args: {
|
|
29
|
+
children: 'Heading V2',
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
export const Underline = {
|
|
33
|
+
render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: _jsx(HeadingV2, Object.assign({ size: size.size, underline: true }, { children: size.label })) })))) })),
|
|
34
|
+
args: {
|
|
35
|
+
children: 'Heading V2',
|
|
36
|
+
},
|
|
37
|
+
};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
11
|
+
import { vi } from 'vitest';
|
|
12
|
+
import { render as _render } from '../../../utils/test';
|
|
13
|
+
import { HeadingV2 } from '.';
|
|
14
|
+
import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
|
|
15
|
+
import { ENVIRONMENT } from '../../providers/env';
|
|
16
|
+
const render = (component) => {
|
|
17
|
+
return _render(component, { env: ENVIRONMENT.DEV });
|
|
18
|
+
};
|
|
19
|
+
describe('HeadingV2', () => {
|
|
20
|
+
const originalError = console.error;
|
|
21
|
+
beforeEach(() => {
|
|
22
|
+
console.error = vi.fn();
|
|
23
|
+
});
|
|
24
|
+
afterEach(() => {
|
|
25
|
+
console.error = originalError;
|
|
26
|
+
vi.useRealTimers();
|
|
27
|
+
});
|
|
28
|
+
it('renders without an error if passed standalone prop', () => {
|
|
29
|
+
const { getByText } = render(_jsx(HeadingV2, Object.assign({ standalone: true }, { children: "Foo" })));
|
|
30
|
+
expect(getByText('Foo')).toBeInTheDocument();
|
|
31
|
+
});
|
|
32
|
+
it('renders without an error if used within region Group component', () => {
|
|
33
|
+
const { getByText } = render(_jsx(GroupV2, { children: _jsx(HeadingV2, { children: "Foo" }) }));
|
|
34
|
+
expect(getByText('Foo')).toBeInTheDocument();
|
|
35
|
+
});
|
|
36
|
+
it('throws if used outside a Group component', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
37
|
+
expect(() => render(_jsx(HeadingV2, { children: "Foo" }))).toThrow();
|
|
38
|
+
}));
|
|
39
|
+
it('throws if used within non-region Group component', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
40
|
+
expect(() => render(_jsx(GroupV2, Object.assign({ type: GROUPV2_TYPE.GROUP }, { children: _jsx(HeadingV2, { children: "Foo" }) })))).toThrow();
|
|
41
|
+
}));
|
|
42
|
+
it('labels group target automatically', () => {
|
|
43
|
+
const { getByText } = render(_jsx(GroupV2, { children: _jsx(HeadingV2, { children: "Foo" }) }));
|
|
44
|
+
expect(getByText('Foo')).toBeDefined();
|
|
45
|
+
});
|
|
46
|
+
it('is required to render region Group component', () => __awaiter(void 0, void 0, void 0, function* () {
|
|
47
|
+
vi.useFakeTimers();
|
|
48
|
+
render(_jsx(GroupV2, { children: "Foo" }));
|
|
49
|
+
expect(() => vi.runAllTimers()).toThrow();
|
|
50
|
+
}));
|
|
51
|
+
});
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { TYPOGRAPHY_TYPE } from '../../../theme/typography';
|
|
3
|
+
import { StyledElementPropsV2 } from '../../../theme';
|
|
4
|
+
import { COLOR } from '../../../theme/colors';
|
|
5
|
+
type HeaderV2Props = StyledElementPropsV2<HTMLSpanElement, {
|
|
6
|
+
size?: HEADINGV2_SIZE;
|
|
7
|
+
standalone?: boolean;
|
|
8
|
+
id?: string;
|
|
9
|
+
underline?: boolean;
|
|
10
|
+
underlineColor?: COLOR;
|
|
11
|
+
typography?: TYPOGRAPHY_TYPE;
|
|
12
|
+
headlineStyles?: any;
|
|
13
|
+
level?: number;
|
|
14
|
+
}>;
|
|
15
|
+
export declare enum HEADINGV2_SIZE {
|
|
16
|
+
SM = "sm",
|
|
17
|
+
MD = "md",
|
|
18
|
+
LG = "lg",
|
|
19
|
+
XL = "xl"
|
|
20
|
+
}
|
|
21
|
+
export declare const HeadingV2: React.FC<HeaderV2Props>;
|
|
22
|
+
export {};
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
|
+
import { useEffect } from 'react';
|
|
14
|
+
import { fontStyles, getTypographyStyles, TYPOGRAPHY_TYPE, } from '../../../theme/typography';
|
|
15
|
+
import { GROUPV2_TYPE, useGroupV2 } from '../GroupV2';
|
|
16
|
+
import { useEnvironment } from '../../providers/env';
|
|
17
|
+
import { multiplyRemSize } from '../../../utils/misc';
|
|
18
|
+
import { processSx } from '../../../utils/processSx';
|
|
19
|
+
import * as styles from './HeadingV2.module.css';
|
|
20
|
+
export var HEADINGV2_SIZE;
|
|
21
|
+
(function (HEADINGV2_SIZE) {
|
|
22
|
+
HEADINGV2_SIZE["SM"] = "sm";
|
|
23
|
+
HEADINGV2_SIZE["MD"] = "md";
|
|
24
|
+
HEADINGV2_SIZE["LG"] = "lg";
|
|
25
|
+
HEADINGV2_SIZE["XL"] = "xl";
|
|
26
|
+
})(HEADINGV2_SIZE || (HEADINGV2_SIZE = {}));
|
|
27
|
+
const SIZE_TYPOGRAPHY_MAP = {
|
|
28
|
+
[HEADINGV2_SIZE.SM]: TYPOGRAPHY_TYPE.HEADING_SMALL,
|
|
29
|
+
[HEADINGV2_SIZE.MD]: TYPOGRAPHY_TYPE.HEADING_MEDIUM,
|
|
30
|
+
[HEADINGV2_SIZE.LG]: TYPOGRAPHY_TYPE.HEADING_LARGE,
|
|
31
|
+
[HEADINGV2_SIZE.XL]: TYPOGRAPHY_TYPE.HEADING_XLARGE,
|
|
32
|
+
};
|
|
33
|
+
const LEVEL_TYPOGRAPHY_MAP = {
|
|
34
|
+
1: TYPOGRAPHY_TYPE.HEADING_XLARGE,
|
|
35
|
+
2: TYPOGRAPHY_TYPE.HEADING_LARGE,
|
|
36
|
+
3: TYPOGRAPHY_TYPE.HEADING_MEDIUM,
|
|
37
|
+
4: TYPOGRAPHY_TYPE.HEADING_SMALL,
|
|
38
|
+
5: TYPOGRAPHY_TYPE.HEADING_SMALL,
|
|
39
|
+
6: TYPOGRAPHY_TYPE.HEADING_SMALL,
|
|
40
|
+
};
|
|
41
|
+
export const HeadingV2 = (_a) => {
|
|
42
|
+
var { sx, size, standalone, id, underline, underlineColor, typography: typographyProp, level: levelParam } = _a, rest = __rest(_a, ["sx", "size", "standalone", "id", "underline", "underlineColor", "typography", "level"]);
|
|
43
|
+
const { level: groupLevel, type, trackHeadingRendered } = useGroupV2();
|
|
44
|
+
const { flagInDevelopment } = useEnvironment();
|
|
45
|
+
const level = levelParam || groupLevel;
|
|
46
|
+
useEffect(() => {
|
|
47
|
+
trackHeadingRendered();
|
|
48
|
+
});
|
|
49
|
+
let typography = TYPOGRAPHY_TYPE.HEADING_MEDIUM;
|
|
50
|
+
if (typographyProp) {
|
|
51
|
+
typography = typographyProp;
|
|
52
|
+
}
|
|
53
|
+
else if (size) {
|
|
54
|
+
typography = SIZE_TYPOGRAPHY_MAP[size];
|
|
55
|
+
}
|
|
56
|
+
else if (level) {
|
|
57
|
+
typography =
|
|
58
|
+
LEVEL_TYPOGRAPHY_MAP[level];
|
|
59
|
+
}
|
|
60
|
+
const typographyStyles = getTypographyStyles(typography);
|
|
61
|
+
const typeSafeStyles = styles;
|
|
62
|
+
const getMarginHeightMultiple = (level) => {
|
|
63
|
+
if (level > 4) {
|
|
64
|
+
return 0.75;
|
|
65
|
+
}
|
|
66
|
+
if (level === 1 || level === 2) {
|
|
67
|
+
return 0.375;
|
|
68
|
+
}
|
|
69
|
+
return 0.55;
|
|
70
|
+
};
|
|
71
|
+
const marginHeightMultiple = fontStyles.lineHeights[typographyStyles.lineHeight] *
|
|
72
|
+
getMarginHeightMultiple(level);
|
|
73
|
+
const fontSize = fontStyles.fontSizes[typographyStyles.fontSize];
|
|
74
|
+
const topMargin = multiplyRemSize({
|
|
75
|
+
size: fontSize,
|
|
76
|
+
multiple: marginHeightMultiple,
|
|
77
|
+
});
|
|
78
|
+
if (type !== GROUPV2_TYPE.REGION && !standalone) {
|
|
79
|
+
flagInDevelopment('Heading component should be used within a Group component with property type={GROUP_TYPE.REGION} or given the standalone flag');
|
|
80
|
+
}
|
|
81
|
+
const processedStyles = processSx(sx);
|
|
82
|
+
const processedTypography = processSx(getTypographyStyles(typography));
|
|
83
|
+
const headerProps = Object.assign({ id: id, role: 'heading', 'aria-level': level, style: Object.assign(Object.assign({ borderBottomWidth: underline ? '2px' : 0, borderBottomColor: underlineColor ? underlineColor : '', marginTop: topMargin }, processedTypography), processedStyles) }, rest);
|
|
84
|
+
switch (level) {
|
|
85
|
+
case 1:
|
|
86
|
+
return _jsx("h1", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
87
|
+
case 2:
|
|
88
|
+
return _jsx("h2", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
89
|
+
case 3:
|
|
90
|
+
return _jsx("h3", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
91
|
+
case 4:
|
|
92
|
+
return _jsx("h4", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
93
|
+
case 5:
|
|
94
|
+
return _jsx("h5", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
95
|
+
case 6:
|
|
96
|
+
return _jsx("h6", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
97
|
+
default:
|
|
98
|
+
return _jsx("h6", Object.assign({ className: typeSafeStyles.heading }, headerProps));
|
|
99
|
+
}
|
|
100
|
+
};
|
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { GROUP_TYPE, Group } from '../Group';
|
|
3
|
-
import { HEADING_SIZE, Heading } from '../
|
|
3
|
+
import { HEADING_SIZE, Heading } from '../Heading';
|
|
4
4
|
import { Column } from '../layout/Column';
|
|
5
5
|
import { Icon } from './';
|
|
6
6
|
import AccessAlarmIcon from '@mui/icons-material/AccessAlarm';
|
|
7
7
|
import { COLOR } from '../../../theme/colors';
|
|
8
8
|
import { FONT_SIZE } from '../../../theme/typography';
|
|
9
|
+
import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
|
|
9
10
|
const meta = {
|
|
10
11
|
title: 'Elements/Icon',
|
|
11
12
|
component: Icon,
|
|
13
|
+
decorators: [UIVersion1],
|
|
12
14
|
};
|
|
13
15
|
export default meta;
|
|
14
16
|
const sizes = [
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { IconV2 } from '.';
|
|
3
|
+
declare const meta: Meta<typeof IconV2>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof IconV2>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const CustomColor: Story;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { GROUPV2_TYPE, GroupV2 } from '../GroupV2';
|
|
3
|
+
import { HEADINGV2_SIZE, HeadingV2 } from '../HeadingV2';
|
|
4
|
+
import { ColumnV2 } from '../layoutV2/ColumnV2';
|
|
5
|
+
import { IconV2 } from '.';
|
|
6
|
+
import AccessAlarmIcon from '@mui/icons-material/AccessAlarm';
|
|
7
|
+
import { COLOR } from '../../../theme/colors';
|
|
8
|
+
import { FONT_SIZE } from '../../../theme/typography';
|
|
9
|
+
import { UIVersion2 } from '../../../utils/decorators/UIVersion2';
|
|
10
|
+
const meta = {
|
|
11
|
+
title: 'Elements/IconV2',
|
|
12
|
+
component: IconV2,
|
|
13
|
+
decorators: [UIVersion2],
|
|
14
|
+
};
|
|
15
|
+
export default meta;
|
|
16
|
+
const sizes = [
|
|
17
|
+
{ size: FONT_SIZE.XXL, label: 'XX Large' },
|
|
18
|
+
{ size: FONT_SIZE.XL, label: 'X Large' },
|
|
19
|
+
{ size: FONT_SIZE.LG, label: 'Large' },
|
|
20
|
+
{ size: FONT_SIZE.ML, label: 'Medium Large' },
|
|
21
|
+
{ size: FONT_SIZE.MD, label: 'Medium' },
|
|
22
|
+
{ size: FONT_SIZE.MS, label: 'Medium Small' },
|
|
23
|
+
{ size: FONT_SIZE.SM, label: 'Small' },
|
|
24
|
+
{ size: FONT_SIZE.XS, label: 'X Small' },
|
|
25
|
+
];
|
|
26
|
+
export const Default = {
|
|
27
|
+
render: () => (_jsx(ColumnV2, { children: sizes.map((size) => (_jsxs(GroupV2, Object.assign({ type: GROUPV2_TYPE.REGION }, { children: [_jsx(HeadingV2, Object.assign({ size: HEADINGV2_SIZE.MD }, { children: size.label })), _jsx(IconV2, { icon: AccessAlarmIcon, size: size.size })] })))) })),
|
|
28
|
+
};
|
|
29
|
+
export const CustomColor = {
|
|
30
|
+
render: () => (_jsx(IconV2, { icon: AccessAlarmIcon, color: COLOR.SECONDARY, size: FONT_SIZE.LG })),
|
|
31
|
+
};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { render, screen, fireEvent } from '@testing-library/react';
|
|
3
|
+
import '@testing-library/jest-dom';
|
|
4
|
+
import { vi, describe, it, beforeEach, afterEach, expect } from 'vitest';
|
|
5
|
+
import { IconV2 } from '.';
|
|
6
|
+
import { COLOR } from '../../../theme/colors';
|
|
7
|
+
import { FONT_SIZE } from '../../../theme/typography';
|
|
8
|
+
import { useEnvironment } from '../../providers/env';
|
|
9
|
+
vi.mock('../../providers/env', () => ({
|
|
10
|
+
useEnvironment: vi.fn(),
|
|
11
|
+
}));
|
|
12
|
+
describe('IconV2 Component', () => {
|
|
13
|
+
const MockIcon = () => _jsx("svg", { "data-testid": "mock-icon" });
|
|
14
|
+
const mockFlagInDevelopment = vi.fn();
|
|
15
|
+
beforeEach(() => {
|
|
16
|
+
;
|
|
17
|
+
useEnvironment.mockReturnValue({
|
|
18
|
+
flagInDevelopment: mockFlagInDevelopment,
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
afterEach(() => {
|
|
22
|
+
vi.clearAllMocks();
|
|
23
|
+
});
|
|
24
|
+
it('renders the icon component', () => {
|
|
25
|
+
render(_jsx(IconV2, { icon: MockIcon }));
|
|
26
|
+
expect(screen.getByTestId('mock-icon')).toBeInTheDocument();
|
|
27
|
+
});
|
|
28
|
+
it('applies the correct size and color', () => {
|
|
29
|
+
render(_jsx(IconV2, { icon: MockIcon, size: FONT_SIZE.LG, color: COLOR.SECONDARY }));
|
|
30
|
+
const iconElement = screen.getByTestId('mock-icon');
|
|
31
|
+
expect(iconElement).toHaveStyle({
|
|
32
|
+
fontSize: 'inherit',
|
|
33
|
+
color: 'color: rgb(211, 159, 16)',
|
|
34
|
+
});
|
|
35
|
+
});
|
|
36
|
+
it('calls flagInDevelopment if onClick is provided without aria-label', () => {
|
|
37
|
+
render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn() }));
|
|
38
|
+
expect(mockFlagInDevelopment).toHaveBeenCalledWith('Icon component with onClick should have an aria-label and tabIndex={0}');
|
|
39
|
+
});
|
|
40
|
+
it('does not call flagInDevelopment if onClick is provided with aria-label', () => {
|
|
41
|
+
render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn(), "aria-label": "icon" }));
|
|
42
|
+
expect(mockFlagInDevelopment).not.toHaveBeenCalled();
|
|
43
|
+
});
|
|
44
|
+
it('renders with tabIndex and role when onClick is provided', () => {
|
|
45
|
+
render(_jsx(IconV2, { icon: MockIcon, onClick: vi.fn(), "aria-label": "icon" }));
|
|
46
|
+
const divElement = screen.getByRole('button');
|
|
47
|
+
expect(divElement).toHaveAttribute('tabIndex', '0');
|
|
48
|
+
});
|
|
49
|
+
it('does not render with tabIndex and role when onClick is not provided', () => {
|
|
50
|
+
render(_jsx(IconV2, { icon: MockIcon }));
|
|
51
|
+
const divElement = screen.getByTestId('mock-icon').parentElement;
|
|
52
|
+
expect(divElement).not.toHaveAttribute('tabIndex');
|
|
53
|
+
expect(divElement).not.toHaveAttribute('role', 'button');
|
|
54
|
+
});
|
|
55
|
+
it('handles onClick event', () => {
|
|
56
|
+
const handleClick = vi.fn();
|
|
57
|
+
render(_jsx(IconV2, { icon: MockIcon, onClick: handleClick, "aria-label": "icon" }));
|
|
58
|
+
const divElement = screen.getByRole('button');
|
|
59
|
+
fireEvent.click(divElement);
|
|
60
|
+
expect(handleClick).toHaveBeenCalledTimes(1);
|
|
61
|
+
});
|
|
62
|
+
});
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { COLOR } from '../../../theme/colors';
|
|
3
|
+
import { StyledElementPropsV2 } from '../../../theme';
|
|
4
|
+
import { FONT_SIZE } from '../../../theme/typography';
|
|
5
|
+
export type IconV2Props = StyledElementPropsV2<HTMLDivElement, {
|
|
6
|
+
icon: React.FC<any>;
|
|
7
|
+
size?: FONT_SIZE;
|
|
8
|
+
color?: COLOR;
|
|
9
|
+
}>;
|
|
10
|
+
export declare const IconV2: React.FC<IconV2Props>;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
|
+
import React from 'react';
|
|
14
|
+
import { COLOR, colors } from '../../../theme/colors';
|
|
15
|
+
import { useEnvironment } from '../../providers/env';
|
|
16
|
+
import { processSx } from '../../../utils/processSx';
|
|
17
|
+
import * as styles from './IconV2.module.css';
|
|
18
|
+
const typeSafeStyles = styles;
|
|
19
|
+
export const IconV2 = (_a) => {
|
|
20
|
+
var { icon, size, color, sx, onClick } = _a, rest = __rest(_a, ["icon", "size", "color", "sx", "onClick"]);
|
|
21
|
+
const InnerComponent = icon;
|
|
22
|
+
const processedStyles = processSx(Object.assign({ fontSize: size }, sx));
|
|
23
|
+
const { flagInDevelopment } = useEnvironment();
|
|
24
|
+
if (onClick && !rest['aria-label']) {
|
|
25
|
+
flagInDevelopment('Icon component with onClick should have an aria-label and tabIndex={0}');
|
|
26
|
+
}
|
|
27
|
+
return (_jsx("div", Object.assign({ tabIndex: onClick ? 0 : undefined, role: onClick ? 'button' : 'none', onClick: onClick, className: typeSafeStyles.iconWrapper, style: processedStyles }, rest, { children: React.createElement(InnerComponent, {
|
|
28
|
+
style: {
|
|
29
|
+
fontSize: 'inherit',
|
|
30
|
+
color: colors[color || COLOR.PRIMARY],
|
|
31
|
+
},
|
|
32
|
+
}) })));
|
|
33
|
+
};
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { Bold, Italic } from '.';
|
|
3
3
|
import { Paragraph } from '../Paragraph';
|
|
4
|
+
import { UIVersion1 } from '../../../utils/decorators/UIVersion1';
|
|
4
5
|
const meta = {
|
|
5
6
|
title: 'Elements/Inline',
|
|
6
7
|
component: Bold,
|
|
7
8
|
tags: ['autodocs'],
|
|
9
|
+
decorators: [UIVersion1],
|
|
8
10
|
};
|
|
9
11
|
export default meta;
|
|
10
12
|
export const Default = {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { StyledElementProps } from '
|
|
2
|
+
import { StyledElementProps } from '../../../theme';
|
|
3
3
|
type InlineProps = StyledElementProps<HTMLSpanElement>;
|
|
4
4
|
export declare const Bold: React.FC<InlineProps>;
|
|
5
5
|
export declare const Italic: React.FC<InlineProps>;
|