@dxc-technology/halstack-react 0.0.0-ff5083e → 0.0.0-ff6c8bf
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/BackgroundColorContext.d.ts +1 -10
- package/BackgroundColorContext.js +5 -22
- package/HalstackContext.d.ts +1240 -6
- package/HalstackContext.js +126 -111
- package/README.md +47 -0
- package/accordion/Accordion.accessibility.test.js +71 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +105 -160
- package/accordion/Accordion.stories.tsx +82 -148
- package/accordion/Accordion.test.js +25 -41
- package/accordion/types.d.ts +6 -17
- package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
- package/accordion-group/AccordionGroup.d.ts +2 -2
- package/accordion-group/AccordionGroup.js +31 -98
- package/accordion-group/AccordionGroup.stories.tsx +94 -67
- package/accordion-group/AccordionGroup.test.js +52 -105
- package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
- package/accordion-group/AccordionGroupAccordion.js +31 -0
- package/accordion-group/AccordionGroupContext.d.ts +3 -0
- package/accordion-group/AccordionGroupContext.js +8 -0
- package/accordion-group/types.d.ts +12 -17
- package/action-icon/ActionIcon.accessibility.test.js +63 -0
- package/action-icon/ActionIcon.d.ts +4 -0
- package/action-icon/ActionIcon.js +48 -0
- package/action-icon/ActionIcon.stories.tsx +41 -0
- package/action-icon/ActionIcon.test.js +64 -0
- package/action-icon/types.d.ts +26 -0
- package/alert/Alert.accessibility.test.js +95 -0
- package/alert/Alert.js +37 -127
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.accessibility.test.js +129 -0
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +142 -42
- package/badge/Badge.stories.tsx +210 -0
- package/badge/Badge.test.js +30 -0
- package/badge/types.d.ts +52 -3
- package/bleed/Bleed.js +13 -21
- package/bleed/Bleed.stories.tsx +64 -63
- package/bleed/types.d.ts +2 -2
- package/box/Box.accessibility.test.js +33 -0
- package/box/Box.d.ts +1 -1
- package/box/Box.js +19 -60
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -14
- package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
- package/breadcrumbs/Breadcrumbs.d.ts +4 -0
- package/breadcrumbs/Breadcrumbs.js +79 -0
- package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
- package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
- package/breadcrumbs/Breadcrumbs.test.js +169 -0
- package/breadcrumbs/Item.d.ts +4 -0
- package/breadcrumbs/Item.js +52 -0
- package/breadcrumbs/dropdownTheme.d.ts +53 -0
- package/breadcrumbs/dropdownTheme.js +62 -0
- package/breadcrumbs/types.d.ts +16 -0
- package/bulleted-list/BulletedList.accessibility.test.js +119 -0
- package/bulleted-list/BulletedList.js +35 -63
- package/bulleted-list/BulletedList.stories.tsx +18 -106
- package/bulleted-list/types.d.ts +32 -5
- package/button/Button.accessibility.test.js +127 -0
- package/button/Button.d.ts +1 -1
- package/button/Button.js +64 -117
- package/button/Button.stories.tsx +151 -100
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +12 -8
- package/card/Card.accessibility.test.js +36 -0
- package/card/Card.d.ts +1 -1
- package/card/Card.js +49 -89
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -11
- package/checkbox/Checkbox.accessibility.test.js +87 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +139 -181
- package/checkbox/Checkbox.stories.tsx +128 -94
- package/checkbox/Checkbox.test.js +160 -39
- package/checkbox/types.d.ts +11 -3
- package/chip/Chip.accessibility.test.js +67 -0
- package/chip/Chip.js +45 -80
- package/chip/Chip.stories.tsx +107 -27
- package/chip/Chip.test.js +18 -33
- package/chip/types.d.ts +4 -4
- package/common/coreTokens.d.ts +237 -0
- package/common/coreTokens.js +184 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +6 -12
- package/common/variables.d.ts +1392 -0
- package/common/variables.js +984 -1206
- package/container/Container.d.ts +4 -0
- package/container/Container.js +194 -0
- package/container/Container.stories.tsx +214 -0
- package/container/types.d.ts +74 -0
- package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
- package/contextual-menu/ContextualMenu.d.ts +5 -0
- package/contextual-menu/ContextualMenu.js +88 -0
- package/contextual-menu/ContextualMenu.stories.tsx +232 -0
- package/contextual-menu/ContextualMenu.test.js +205 -0
- package/contextual-menu/GroupItem.d.ts +4 -0
- package/contextual-menu/GroupItem.js +67 -0
- package/contextual-menu/ItemAction.d.ts +4 -0
- package/contextual-menu/ItemAction.js +51 -0
- package/contextual-menu/MenuItem.d.ts +4 -0
- package/contextual-menu/MenuItem.js +29 -0
- package/contextual-menu/SingleItem.d.ts +4 -0
- package/contextual-menu/SingleItem.js +38 -0
- package/contextual-menu/types.d.ts +58 -0
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.accessibility.test.js +228 -0
- package/date-input/DateInput.js +149 -299
- package/date-input/DateInput.stories.tsx +210 -56
- package/date-input/DateInput.test.js +700 -371
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +121 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +100 -0
- package/date-input/types.d.ts +72 -15
- package/dialog/Dialog.accessibility.test.js +69 -0
- package/dialog/Dialog.d.ts +1 -1
- package/dialog/Dialog.js +61 -106
- package/dialog/Dialog.stories.tsx +326 -167
- package/dialog/Dialog.test.js +287 -20
- package/dialog/types.d.ts +18 -25
- package/divider/Divider.accessibility.test.js +33 -0
- package/divider/Divider.d.ts +4 -0
- package/divider/Divider.js +36 -0
- package/divider/Divider.stories.tsx +223 -0
- package/divider/Divider.test.js +38 -0
- package/divider/types.d.ts +21 -0
- package/dropdown/Dropdown.accessibility.test.js +180 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +233 -303
- package/dropdown/Dropdown.stories.tsx +235 -57
- package/dropdown/Dropdown.test.js +575 -165
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +63 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +71 -0
- package/dropdown/types.d.ts +35 -19
- package/file-input/FileInput.accessibility.test.js +160 -0
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +241 -391
- package/file-input/FileInput.stories.tsx +123 -12
- package/file-input/FileInput.test.js +306 -367
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +56 -117
- package/file-input/types.d.ts +25 -8
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +57 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/footer/Footer.accessibility.test.js +125 -0
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +73 -118
- package/footer/Footer.stories.tsx +99 -21
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +54 -23
- package/footer/types.d.ts +26 -27
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +76 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/grid/types.js +5 -0
- package/header/Header.accessibility.test.js +93 -0
- package/header/Header.d.ts +4 -3
- package/header/Header.js +90 -183
- package/header/Header.stories.tsx +133 -38
- package/header/Header.test.js +13 -26
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +5 -15
- package/header/types.d.ts +7 -21
- package/heading/Heading.accessibility.test.js +33 -0
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- package/heading/types.d.ts +7 -7
- package/icon/Icon.accessibility.test.js +30 -0
- package/icon/Icon.d.ts +4 -0
- package/icon/Icon.js +33 -0
- package/icon/Icon.stories.tsx +28 -0
- package/icon/types.d.ts +4 -0
- package/icon/types.js +5 -0
- package/image/Image.accessibility.test.js +56 -0
- package/image/Image.d.ts +4 -0
- package/image/Image.js +70 -0
- package/image/Image.stories.tsx +129 -0
- package/image/types.d.ts +72 -0
- package/image/types.js +5 -0
- package/inset/Inset.js +13 -21
- package/inset/Inset.stories.tsx +5 -4
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +57 -119
- package/layout/ApplicationLayout.stories.tsx +81 -45
- package/layout/Icons.d.ts +7 -5
- package/layout/Icons.js +41 -59
- package/layout/types.d.ts +21 -32
- package/link/Link.accessibility.test.js +108 -0
- package/link/Link.js +32 -51
- package/link/Link.stories.tsx +76 -9
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -14
- package/main.d.ts +14 -12
- package/main.js +51 -88
- package/nav-tabs/NavTabs.accessibility.test.js +44 -0
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
- package/nav-tabs/NavTabs.stories.tsx +279 -0
- package/nav-tabs/NavTabs.test.js +77 -0
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +117 -0
- package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.accessibility.test.js +228 -0
- package/number-input/NumberInput.js +46 -36
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +860 -377
- package/number-input/NumberInputContext.d.ts +3 -4
- package/number-input/NumberInputContext.js +3 -14
- package/number-input/types.d.ts +17 -5
- package/package.json +51 -51
- package/paginator/Paginator.accessibility.test.js +79 -0
- package/paginator/Paginator.js +35 -68
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +280 -211
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.accessibility.test.js +28 -0
- package/paragraph/Paragraph.d.ts +3 -4
- package/paragraph/Paragraph.js +7 -23
- package/paragraph/Paragraph.stories.tsx +1 -18
- package/password-input/PasswordInput.accessibility.test.js +153 -0
- package/password-input/PasswordInput.js +58 -127
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +160 -142
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.accessibility.test.js +35 -0
- package/progress-bar/ProgressBar.js +68 -92
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
- package/progress-bar/ProgressBar.test.js +72 -44
- package/progress-bar/types.d.ts +3 -3
- package/quick-nav/QuickNav.accessibility.test.js +57 -0
- package/quick-nav/QuickNav.js +24 -42
- package/quick-nav/QuickNav.stories.tsx +146 -27
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +59 -76
- package/radio-group/RadioGroup.accessibility.test.js +97 -0
- package/radio-group/RadioGroup.js +68 -114
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +518 -457
- package/radio-group/types.d.ts +10 -10
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +171 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
- package/resultset-table/ResultsetTable.test.js +381 -0
- package/{resultsetTable → resultset-table}/types.d.ts +44 -11
- package/resultset-table/types.js +5 -0
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +68 -65
- package/select/Option.js +35 -56
- package/select/Select.accessibility.test.js +228 -0
- package/select/Select.js +171 -214
- package/select/Select.stories.tsx +515 -190
- package/select/Select.test.js +1934 -1789
- package/select/types.d.ts +17 -21
- package/sidenav/Sidenav.accessibility.test.js +59 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +132 -78
- package/sidenav/Sidenav.stories.tsx +246 -151
- package/sidenav/Sidenav.test.js +26 -45
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.accessibility.test.js +104 -0
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +149 -181
- package/slider/Slider.stories.tsx +64 -61
- package/slider/Slider.test.js +185 -81
- package/slider/types.d.ts +7 -3
- package/spinner/Spinner.accessibility.test.js +96 -0
- package/spinner/Spinner.js +34 -74
- package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
- package/spinner/Spinner.test.js +26 -35
- package/spinner/types.d.ts +3 -3
- package/status-light/StatusLight.accessibility.test.js +157 -0
- package/status-light/StatusLight.d.ts +4 -0
- package/status-light/StatusLight.js +51 -0
- package/status-light/StatusLight.stories.tsx +74 -0
- package/status-light/StatusLight.test.js +25 -0
- package/status-light/types.d.ts +17 -0
- package/status-light/types.js +5 -0
- package/switch/Switch.accessibility.test.js +98 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +145 -126
- package/switch/Switch.stories.tsx +49 -60
- package/switch/Switch.test.js +138 -56
- package/switch/types.d.ts +7 -3
- package/table/DropdownTheme.js +62 -0
- package/table/Table.accessibility.test.js +93 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +78 -35
- package/table/Table.stories.tsx +663 -0
- package/table/Table.test.js +95 -8
- package/table/types.d.ts +34 -6
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +117 -0
- package/tabs/Tabs.accessibility.test.js +56 -0
- package/tabs/Tabs.js +303 -141
- package/tabs/Tabs.stories.tsx +124 -6
- package/tabs/Tabs.test.js +213 -77
- package/tabs/types.d.ts +30 -20
- package/tag/Tag.accessibility.test.js +69 -0
- package/tag/Tag.js +35 -67
- package/tag/Tag.stories.tsx +18 -8
- package/tag/Tag.test.js +18 -37
- package/tag/types.d.ts +9 -9
- package/text-input/Suggestion.js +40 -28
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +94 -0
- package/text-input/TextInput.accessibility.test.js +321 -0
- package/text-input/TextInput.js +316 -515
- package/text-input/TextInput.stories.tsx +276 -276
- package/text-input/TextInput.test.js +1419 -1375
- package/text-input/types.d.ts +43 -16
- package/textarea/Textarea.accessibility.test.js +155 -0
- package/textarea/Textarea.js +71 -113
- package/textarea/Textarea.stories.tsx +174 -0
- package/textarea/Textarea.test.js +152 -183
- package/textarea/types.d.ts +9 -5
- package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
- package/toggle-group/ToggleGroup.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +94 -107
- package/toggle-group/ToggleGroup.stories.tsx +52 -7
- package/toggle-group/ToggleGroup.test.js +69 -88
- package/toggle-group/types.d.ts +28 -19
- package/typography/Typography.accessibility.test.js +339 -0
- package/typography/Typography.d.ts +2 -2
- package/typography/Typography.js +16 -124
- package/typography/Typography.stories.tsx +185 -162
- package/typography/types.d.ts +1 -1
- package/useTheme.d.ts +1144 -1
- package/useTheme.js +2 -9
- package/useTranslatedLabels.d.ts +84 -1
- package/useTranslatedLabels.js +1 -7
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +94 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +124 -0
- package/wizard/Wizard.accessibility.test.js +55 -0
- package/wizard/Wizard.js +34 -87
- package/wizard/Wizard.stories.tsx +59 -1
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +9 -9
- package/card/ice-cream.jpg +0 -0
- package/common/OpenSans.css +0 -81
- package/common/RequiredComponent.js +0 -32
- package/common/fonts/OpenSans-Bold.ttf +0 -0
- package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
- package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
- package/common/fonts/OpenSans-Italic.ttf +0 -0
- package/common/fonts/OpenSans-Light.ttf +0 -0
- package/common/fonts/OpenSans-LightItalic.ttf +0 -0
- package/common/fonts/OpenSans-Regular.ttf +0 -0
- package/common/fonts/OpenSans-SemiBold.ttf +0 -0
- package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
- package/number-input/numberInputContextTypes.d.ts +0 -19
- package/paginator/Icons.js +0 -66
- package/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -254
- package/resultsetTable/ResultsetTable.test.js +0 -306
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/select/Icons.d.ts +0 -10
- package/select/Icons.js +0 -93
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -24
- package/table/Table.stories.jsx +0 -277
- package/tabs-nav/NavTabs.d.ts +0 -8
- package/tabs-nav/NavTabs.stories.tsx +0 -170
- package/tabs-nav/NavTabs.test.js +0 -82
- package/tabs-nav/Tab.js +0 -132
- package/textarea/Textarea.stories.jsx +0 -157
- package/typography/typographyContextTypes.d.ts +0 -16
- /package/{resultsetTable → action-icon}/types.js +0 -0
- /package/{row → breadcrumbs}/types.js +0 -0
- /package/{stack → container}/types.js +0 -0
- /package/{tabs-nav → contextual-menu}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
- /package/{typography/typographyContextTypes.js → flex/types.js} +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
package/box/Box.stories.tsx
CHANGED
|
@@ -2,109 +2,88 @@ import React from "react";
|
|
|
2
2
|
import Title from "../../.storybook/components/Title";
|
|
3
3
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
4
4
|
import DxcBox from "./Box";
|
|
5
|
+
import DxcInset from "../inset/Inset";
|
|
6
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
5
7
|
|
|
6
8
|
export default {
|
|
7
9
|
title: "Box ",
|
|
8
10
|
component: DxcBox,
|
|
9
11
|
};
|
|
10
12
|
|
|
13
|
+
const opinionatedTheme = {
|
|
14
|
+
box: {
|
|
15
|
+
baseColor: "#ffffff",
|
|
16
|
+
},
|
|
17
|
+
};
|
|
18
|
+
|
|
11
19
|
export const Chromatic = () => (
|
|
12
20
|
<>
|
|
13
21
|
<Title title="Display flex" theme="light" level={2} />
|
|
14
22
|
<ExampleContainer>
|
|
15
|
-
<DxcBox display="flex"
|
|
16
|
-
Box
|
|
23
|
+
<DxcBox display="flex">
|
|
24
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
17
25
|
</DxcBox>
|
|
18
26
|
</ExampleContainer>
|
|
19
27
|
<Title title="ShadowDepth" theme="light" level={2} />
|
|
20
28
|
<ExampleContainer>
|
|
21
29
|
<Title title="ShadowDepth 0" theme="light" level={4} />
|
|
22
|
-
<DxcBox shadowDepth={0} margin="medium"
|
|
23
|
-
Box
|
|
30
|
+
<DxcBox shadowDepth={0} margin="medium">
|
|
31
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
24
32
|
</DxcBox>
|
|
25
33
|
</ExampleContainer>
|
|
26
34
|
<ExampleContainer>
|
|
27
35
|
<Title title="ShadowDepth 1" theme="light" level={4} />
|
|
28
|
-
<DxcBox shadowDepth={1} margin="medium"
|
|
29
|
-
Box
|
|
36
|
+
<DxcBox shadowDepth={1} margin="medium">
|
|
37
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
30
38
|
</DxcBox>
|
|
31
39
|
</ExampleContainer>
|
|
32
40
|
<ExampleContainer>
|
|
33
41
|
<Title title="ShadowDepth 2" theme="light" level={4} />
|
|
34
|
-
<DxcBox shadowDepth={2} margin="medium"
|
|
35
|
-
Box
|
|
42
|
+
<DxcBox shadowDepth={2} margin="medium">
|
|
43
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
36
44
|
</DxcBox>
|
|
37
45
|
</ExampleContainer>
|
|
38
|
-
<Title title="Paddings" theme="light" level={2} />
|
|
39
|
-
<ExampleContainer>
|
|
40
|
-
<Title title="Xxsmall padding" theme="light" level={4} />
|
|
41
|
-
<DxcBox padding="xxsmall">Box</DxcBox>
|
|
42
|
-
</ExampleContainer>
|
|
43
|
-
<ExampleContainer>
|
|
44
|
-
<Title title="Xsmall padding" theme="light" level={4} />
|
|
45
|
-
<DxcBox padding="xsmall">Box</DxcBox>
|
|
46
|
-
</ExampleContainer>
|
|
47
|
-
<ExampleContainer>
|
|
48
|
-
<Title title="Small padding" theme="light" level={4} />
|
|
49
|
-
<DxcBox padding="small">Box</DxcBox>
|
|
50
|
-
</ExampleContainer>
|
|
51
|
-
<ExampleContainer>
|
|
52
|
-
<Title title="Medium padding" theme="light" level={4} />
|
|
53
|
-
<DxcBox padding="medium">Box</DxcBox>
|
|
54
|
-
</ExampleContainer>
|
|
55
|
-
<ExampleContainer>
|
|
56
|
-
<Title title="Large padding" theme="light" level={4} />
|
|
57
|
-
<DxcBox padding="large">Box</DxcBox>
|
|
58
|
-
</ExampleContainer>
|
|
59
|
-
<ExampleContainer>
|
|
60
|
-
<Title title="Xlarge padding" theme="light" level={4} />
|
|
61
|
-
<DxcBox padding="xlarge">Box</DxcBox>
|
|
62
|
-
</ExampleContainer>
|
|
63
|
-
<ExampleContainer>
|
|
64
|
-
<Title title="Xxlarge padding" theme="light" level={4} />
|
|
65
|
-
<DxcBox padding="xxlarge">Box</DxcBox>
|
|
66
|
-
</ExampleContainer>
|
|
67
46
|
<Title title="Margins" theme="light" level={2} />
|
|
68
47
|
<ExampleContainer>
|
|
69
48
|
<Title title="Xxsmall margin" theme="light" level={4} />
|
|
70
|
-
<DxcBox margin="xxsmall"
|
|
71
|
-
Box
|
|
49
|
+
<DxcBox margin="xxsmall">
|
|
50
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
72
51
|
</DxcBox>
|
|
73
52
|
</ExampleContainer>
|
|
74
53
|
<ExampleContainer>
|
|
75
54
|
<Title title="Xsmall margin" theme="light" level={4} />
|
|
76
|
-
<DxcBox margin="xsmall"
|
|
77
|
-
Box
|
|
55
|
+
<DxcBox margin="xsmall">
|
|
56
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
78
57
|
</DxcBox>
|
|
79
58
|
</ExampleContainer>
|
|
80
59
|
<ExampleContainer>
|
|
81
60
|
<Title title="Small margin" theme="light" level={4} />
|
|
82
|
-
<DxcBox margin="small"
|
|
83
|
-
Box
|
|
61
|
+
<DxcBox margin="small">
|
|
62
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
84
63
|
</DxcBox>
|
|
85
64
|
</ExampleContainer>
|
|
86
65
|
<ExampleContainer>
|
|
87
66
|
<Title title="Medium margin" theme="light" level={4} />
|
|
88
|
-
<DxcBox margin="medium"
|
|
89
|
-
Box
|
|
67
|
+
<DxcBox margin="medium">
|
|
68
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
90
69
|
</DxcBox>
|
|
91
70
|
</ExampleContainer>
|
|
92
71
|
<ExampleContainer>
|
|
93
72
|
<Title title="Large margin" theme="light" level={4} />
|
|
94
|
-
<DxcBox margin="large"
|
|
95
|
-
Box
|
|
73
|
+
<DxcBox margin="large">
|
|
74
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
96
75
|
</DxcBox>
|
|
97
76
|
</ExampleContainer>
|
|
98
77
|
<ExampleContainer>
|
|
99
78
|
<Title title="Xlarge margin" theme="light" level={4} />
|
|
100
|
-
<DxcBox margin="xlarge"
|
|
101
|
-
Box
|
|
79
|
+
<DxcBox margin="xlarge">
|
|
80
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
102
81
|
</DxcBox>
|
|
103
82
|
</ExampleContainer>
|
|
104
83
|
<ExampleContainer>
|
|
105
84
|
<Title title="Xxlarge margin" theme="light" level={4} />
|
|
106
|
-
<DxcBox margin="xxlarge"
|
|
107
|
-
Box
|
|
85
|
+
<DxcBox margin="xxlarge">
|
|
86
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
108
87
|
</DxcBox>
|
|
109
88
|
</ExampleContainer>
|
|
110
89
|
<Title title="Sizes" theme="light" level={2} />
|
|
@@ -128,5 +107,13 @@ export const Chromatic = () => (
|
|
|
128
107
|
<Title title="FitContent" theme="light" level={4} />
|
|
129
108
|
<DxcBox size="fitContent">Box</DxcBox>
|
|
130
109
|
</ExampleContainer>
|
|
110
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
111
|
+
<ExampleContainer>
|
|
112
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
113
|
+
<DxcBox display="flex">
|
|
114
|
+
<DxcInset space="2rem">Box</DxcInset>
|
|
115
|
+
</DxcBox>
|
|
116
|
+
</HalstackProvider>
|
|
117
|
+
</ExampleContainer>
|
|
131
118
|
</>
|
|
132
119
|
);
|
package/box/Box.test.js
CHANGED
|
@@ -1,18 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
4
|
var _react = _interopRequireDefault(require("react"));
|
|
6
|
-
|
|
7
5
|
var _react2 = require("@testing-library/react");
|
|
8
|
-
|
|
9
|
-
var _Card = _interopRequireDefault(require("../card/Card"));
|
|
10
|
-
|
|
6
|
+
var _Card = _interopRequireDefault(require("../card/Card.tsx"));
|
|
11
7
|
describe("Box component tests", function () {
|
|
12
8
|
test("Box renders with correct text", function () {
|
|
13
9
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Card["default"], null, "test-box")),
|
|
14
|
-
|
|
15
|
-
|
|
10
|
+
getByText = _render.getByText;
|
|
16
11
|
expect(getByText("test-box")).toBeTruthy();
|
|
17
12
|
});
|
|
18
13
|
});
|
package/box/types.d.ts
CHANGED
|
@@ -1,18 +1,12 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
|
|
3
|
-
|
|
2
|
+
type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
|
|
3
|
+
type Margin = {
|
|
4
4
|
top?: Space;
|
|
5
5
|
bottom?: Space;
|
|
6
6
|
left?: Space;
|
|
7
7
|
right?: Space;
|
|
8
8
|
};
|
|
9
|
-
|
|
10
|
-
top?: Space;
|
|
11
|
-
bottom?: Space;
|
|
12
|
-
left?: Space;
|
|
13
|
-
right?: Space;
|
|
14
|
-
};
|
|
15
|
-
declare type Props = {
|
|
9
|
+
type Props = {
|
|
16
10
|
/**
|
|
17
11
|
* The size of the shadow to be displayed around the box.
|
|
18
12
|
*/
|
|
@@ -30,11 +24,6 @@ declare type Props = {
|
|
|
30
24
|
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
|
|
31
25
|
*/
|
|
32
26
|
margin?: Space | Margin;
|
|
33
|
-
/**
|
|
34
|
-
* Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
|
|
35
|
-
* You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
|
|
36
|
-
*/
|
|
37
|
-
padding?: Space | Padding;
|
|
38
27
|
/**
|
|
39
28
|
* Size of the component.
|
|
40
29
|
*/
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
5
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
6
|
+
var _react = _interopRequireDefault(require("react"));
|
|
7
|
+
var _react2 = require("@testing-library/react");
|
|
8
|
+
var _axeHelper = require("../../test/accessibility/axe-helper.js");
|
|
9
|
+
var _Breadcrumbs = _interopRequireDefault(require("./Breadcrumbs"));
|
|
10
|
+
var _disabledRules = require("../../test/accessibility/rules/specific/breadcrumbs/disabledRules.js");
|
|
11
|
+
var disabledRules = {
|
|
12
|
+
rules: _disabledRules.disabledRules.reduce(function (rulesObj, rule) {
|
|
13
|
+
rulesObj[rule] = {
|
|
14
|
+
enabled: false
|
|
15
|
+
};
|
|
16
|
+
return rulesObj;
|
|
17
|
+
}, {})
|
|
18
|
+
};
|
|
19
|
+
var items = [{
|
|
20
|
+
label: "Home",
|
|
21
|
+
href: "/"
|
|
22
|
+
}, {
|
|
23
|
+
label: "User Menu",
|
|
24
|
+
href: ""
|
|
25
|
+
}, {
|
|
26
|
+
label: "Preferences",
|
|
27
|
+
href: ""
|
|
28
|
+
}, {
|
|
29
|
+
label: "Dark Mode",
|
|
30
|
+
href: ""
|
|
31
|
+
}];
|
|
32
|
+
describe("Breadcrumbs component accessibility tests", function () {
|
|
33
|
+
it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
|
|
34
|
+
var _render, container, results;
|
|
35
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
36
|
+
while (1) switch (_context.prev = _context.next) {
|
|
37
|
+
case 0:
|
|
38
|
+
_render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], {
|
|
39
|
+
items: items,
|
|
40
|
+
ariaLabel: "example"
|
|
41
|
+
})), container = _render.container;
|
|
42
|
+
_context.next = 3;
|
|
43
|
+
return (0, _axeHelper.axe)(container, disabledRules);
|
|
44
|
+
case 3:
|
|
45
|
+
results = _context.sent;
|
|
46
|
+
expect(results).toHaveNoViolations();
|
|
47
|
+
case 5:
|
|
48
|
+
case "end":
|
|
49
|
+
return _context.stop();
|
|
50
|
+
}
|
|
51
|
+
}, _callee);
|
|
52
|
+
})));
|
|
53
|
+
it("Should not have basic accessibility issues when collapsed", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
|
|
54
|
+
var _render2, container, results;
|
|
55
|
+
return _regenerator["default"].wrap(function _callee2$(_context2) {
|
|
56
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
57
|
+
case 0:
|
|
58
|
+
_render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], {
|
|
59
|
+
items: items,
|
|
60
|
+
itemsBeforeCollapse: 3,
|
|
61
|
+
ariaLabel: "example"
|
|
62
|
+
})), container = _render2.container;
|
|
63
|
+
_context2.next = 3;
|
|
64
|
+
return (0, _axeHelper.axe)(container, disabledRules);
|
|
65
|
+
case 3:
|
|
66
|
+
results = _context2.sent;
|
|
67
|
+
expect(results).toHaveNoViolations();
|
|
68
|
+
case 5:
|
|
69
|
+
case "end":
|
|
70
|
+
return _context2.stop();
|
|
71
|
+
}
|
|
72
|
+
}, _callee2);
|
|
73
|
+
})));
|
|
74
|
+
it("Should not have basic accessibility issues without root", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
|
|
75
|
+
var _render3, container, results;
|
|
76
|
+
return _regenerator["default"].wrap(function _callee3$(_context3) {
|
|
77
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
78
|
+
case 0:
|
|
79
|
+
_render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Breadcrumbs["default"], {
|
|
80
|
+
items: items,
|
|
81
|
+
itemsBeforeCollapse: 3,
|
|
82
|
+
ariaLabel: "example",
|
|
83
|
+
showRoot: false
|
|
84
|
+
})), container = _render3.container;
|
|
85
|
+
_context3.next = 3;
|
|
86
|
+
return (0, _axeHelper.axe)(container, disabledRules);
|
|
87
|
+
case 3:
|
|
88
|
+
results = _context3.sent;
|
|
89
|
+
expect(results).toHaveNoViolations();
|
|
90
|
+
case 5:
|
|
91
|
+
case "end":
|
|
92
|
+
return _context3.stop();
|
|
93
|
+
}
|
|
94
|
+
}, _callee3);
|
|
95
|
+
})));
|
|
96
|
+
});
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports["default"] = void 0;
|
|
9
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
10
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
11
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
12
|
+
var _Dropdown = _interopRequireDefault(require("../dropdown/Dropdown"));
|
|
13
|
+
var _HalstackContext = require("../HalstackContext");
|
|
14
|
+
var _dropdownTheme = _interopRequireDefault(require("./dropdownTheme"));
|
|
15
|
+
var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
|
|
16
|
+
var _Icon = _interopRequireDefault(require("../icon/Icon"));
|
|
17
|
+
var _Item = _interopRequireDefault(require("./Item"));
|
|
18
|
+
var _Flex = _interopRequireDefault(require("../flex/Flex"));
|
|
19
|
+
var _templateObject;
|
|
20
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
21
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
22
|
+
var DxcBreadcrumbs = function DxcBreadcrumbs(_ref) {
|
|
23
|
+
var _ref$ariaLabel = _ref.ariaLabel,
|
|
24
|
+
ariaLabel = _ref$ariaLabel === void 0 ? "Breadcrumbs" : _ref$ariaLabel,
|
|
25
|
+
items = _ref.items,
|
|
26
|
+
_ref$itemsBeforeColla = _ref.itemsBeforeCollapse,
|
|
27
|
+
itemsBeforeCollapse = _ref$itemsBeforeColla === void 0 ? 4 : _ref$itemsBeforeColla,
|
|
28
|
+
onItemClick = _ref.onItemClick,
|
|
29
|
+
_ref$showRoot = _ref.showRoot,
|
|
30
|
+
showRoot = _ref$showRoot === void 0 ? true : _ref$showRoot;
|
|
31
|
+
var handleOnSelectOption = (0, _react.useCallback)(function (href) {
|
|
32
|
+
if (onItemClick) onItemClick(href);else window.location.href = href;
|
|
33
|
+
}, [items]);
|
|
34
|
+
return /*#__PURE__*/_react["default"].createElement("nav", {
|
|
35
|
+
"aria-label": ariaLabel
|
|
36
|
+
}, /*#__PURE__*/_react["default"].createElement(OrderedList, null, items && items.length > Math.max(itemsBeforeCollapse, 2) ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, showRoot && /*#__PURE__*/_react["default"].createElement(_Item["default"], {
|
|
37
|
+
href: items[0].href,
|
|
38
|
+
key: 0,
|
|
39
|
+
label: items[0].label
|
|
40
|
+
}), /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
|
|
41
|
+
alignItems: "center",
|
|
42
|
+
as: "li",
|
|
43
|
+
key: 1
|
|
44
|
+
}, /*#__PURE__*/_react["default"].createElement(_HalstackContext.HalstackProvider, {
|
|
45
|
+
advancedTheme: _dropdownTheme["default"]
|
|
46
|
+
}, /*#__PURE__*/_react["default"].createElement(_Dropdown["default"], {
|
|
47
|
+
caretHidden: true,
|
|
48
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
|
|
49
|
+
icon: "more_horiz"
|
|
50
|
+
}),
|
|
51
|
+
margin: showRoot && {
|
|
52
|
+
left: "small"
|
|
53
|
+
},
|
|
54
|
+
onSelectOption: handleOnSelectOption,
|
|
55
|
+
options: items.slice(showRoot ? 1 : 0, -1).map(function (_ref2) {
|
|
56
|
+
var label = _ref2.label,
|
|
57
|
+
href = _ref2.href;
|
|
58
|
+
return {
|
|
59
|
+
label: label,
|
|
60
|
+
value: href
|
|
61
|
+
};
|
|
62
|
+
})
|
|
63
|
+
}))), /*#__PURE__*/_react["default"].createElement(_Item["default"], {
|
|
64
|
+
isCurrentPage: true,
|
|
65
|
+
key: 2,
|
|
66
|
+
label: items[items.length - 1].label
|
|
67
|
+
})) : items.map(function (item, index, _ref3) {
|
|
68
|
+
var length = _ref3.length;
|
|
69
|
+
return /*#__PURE__*/_react["default"].createElement(_Item["default"], {
|
|
70
|
+
href: item.href,
|
|
71
|
+
isCurrentPage: index === length - 1,
|
|
72
|
+
key: index,
|
|
73
|
+
label: item.label,
|
|
74
|
+
onClick: onItemClick
|
|
75
|
+
});
|
|
76
|
+
})));
|
|
77
|
+
};
|
|
78
|
+
var OrderedList = _styledComponents["default"].ol(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n padding-left: ", ";\n display: flex;\n align-items: center;\n gap: ", ";\n list-style-type: none;\n\n > li:not(:first-child) {\n > a,\n > span {\n margin-left: ", ";\n }\n &::before {\n margin: ", " ", ";\n transform: rotate(15deg);\n border-right: ", " solid ", ";\n height: 1rem;\n content: \"\";\n }\n }\n"])), _coreTokens["default"].spacing_0, _coreTokens["default"].spacing_0, _coreTokens["default"].spacing_12, _coreTokens["default"].spacing_12, _coreTokens["default"].spacing_0, _coreTokens["default"].spacing_2, _coreTokens["default"].border_width_1, _coreTokens["default"].color_grey_500);
|
|
79
|
+
var _default = exports["default"] = DxcBreadcrumbs;
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import Title from "../../.storybook/components/Title";
|
|
3
|
+
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
4
|
+
import DxcBreadcrumbs from "./Breadcrumbs";
|
|
5
|
+
import DxcContainer from "../container/Container";
|
|
6
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
7
|
+
import { userEvent, within } from "@storybook/testing-library";
|
|
8
|
+
import { disabledRules } from "../../test/accessibility/rules/specific/breadcrumbs/disabledRules";
|
|
9
|
+
import preview from "../../.storybook/preview";
|
|
10
|
+
|
|
11
|
+
export default {
|
|
12
|
+
title: "Breadcrumbs",
|
|
13
|
+
component: DxcBreadcrumbs,
|
|
14
|
+
parameters: {
|
|
15
|
+
a11y: {
|
|
16
|
+
config: {
|
|
17
|
+
rules: [
|
|
18
|
+
...disabledRules.map((ruleId) => ({ id: ruleId, enabled: false })),
|
|
19
|
+
...preview?.parameters?.a11y?.config?.rules,
|
|
20
|
+
],
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const items = [
|
|
27
|
+
{
|
|
28
|
+
label: "Home",
|
|
29
|
+
href: "/",
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
label: "User Menu",
|
|
33
|
+
href: "",
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
label: "Preferences",
|
|
37
|
+
href: "",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
label: "Customization",
|
|
41
|
+
href: "",
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
label: "Dark Mode",
|
|
45
|
+
href: "",
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
|
|
49
|
+
const Breadcrumbs = () => (
|
|
50
|
+
<>
|
|
51
|
+
<Title title="Default" theme="light" level={3} />
|
|
52
|
+
<ExampleContainer>
|
|
53
|
+
<DxcBreadcrumbs
|
|
54
|
+
items={[
|
|
55
|
+
{
|
|
56
|
+
label: "Home",
|
|
57
|
+
href: "/",
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
label: "User Menu",
|
|
61
|
+
href: "",
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
label: "Preferences",
|
|
65
|
+
href: "",
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
label: "Dark Mode",
|
|
69
|
+
href: "",
|
|
70
|
+
},
|
|
71
|
+
]}
|
|
72
|
+
/>
|
|
73
|
+
</ExampleContainer>
|
|
74
|
+
<Title title="Collapsed variant" theme="light" level={3} />
|
|
75
|
+
<ExampleContainer>
|
|
76
|
+
<DxcBreadcrumbs items={items} />
|
|
77
|
+
</ExampleContainer>
|
|
78
|
+
<Title title="Collapsed variant without root" theme="light" level={3} />
|
|
79
|
+
<ExampleContainer>
|
|
80
|
+
<DxcBreadcrumbs items={items} showRoot={false} />
|
|
81
|
+
</ExampleContainer>
|
|
82
|
+
<Title title="Collapsed variant with dropdown menu opened" theme="light" level={3} />
|
|
83
|
+
<ExampleContainer>
|
|
84
|
+
<DxcContainer height="150px">
|
|
85
|
+
<DxcBreadcrumbs items={items} />
|
|
86
|
+
</DxcContainer>
|
|
87
|
+
</ExampleContainer>
|
|
88
|
+
<Title title="Focus state" theme="light" level={3} />
|
|
89
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
90
|
+
<DxcBreadcrumbs items={items} />
|
|
91
|
+
</ExampleContainer>
|
|
92
|
+
<Title title="Hover state" theme="light" level={3} />
|
|
93
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
94
|
+
<DxcBreadcrumbs items={items} />
|
|
95
|
+
</ExampleContainer>
|
|
96
|
+
<Title title="Active state" theme="light" level={3} />
|
|
97
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
98
|
+
<DxcBreadcrumbs items={items} />
|
|
99
|
+
</ExampleContainer>
|
|
100
|
+
<Title title="Truncation and text ellipsis with tooltip (only when collapsed)" theme="light" level={3} />
|
|
101
|
+
<ExampleContainer>
|
|
102
|
+
<DxcContainer width="200px">
|
|
103
|
+
<DxcBreadcrumbs
|
|
104
|
+
items={[
|
|
105
|
+
{
|
|
106
|
+
label: "Root",
|
|
107
|
+
href: "/",
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
label: "Main folder",
|
|
111
|
+
href: "",
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
label: "User",
|
|
115
|
+
href: "",
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
label: "Very long label for the link",
|
|
119
|
+
href: "",
|
|
120
|
+
},
|
|
121
|
+
]}
|
|
122
|
+
itemsBeforeCollapse={3}
|
|
123
|
+
/>
|
|
124
|
+
</DxcContainer>
|
|
125
|
+
</ExampleContainer>
|
|
126
|
+
<Title title="Truncation, text ellipsis with tooltip and without root" theme="light" level={3} />
|
|
127
|
+
<ExampleContainer>
|
|
128
|
+
<DxcContainer width="200px">
|
|
129
|
+
<DxcBreadcrumbs
|
|
130
|
+
items={[
|
|
131
|
+
{
|
|
132
|
+
label: "Root",
|
|
133
|
+
href: "/",
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
label: "Main folder",
|
|
137
|
+
href: "",
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
label: "User",
|
|
141
|
+
href: "",
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
label: "Very long label for the link",
|
|
145
|
+
href: "",
|
|
146
|
+
},
|
|
147
|
+
]}
|
|
148
|
+
itemsBeforeCollapse={3}
|
|
149
|
+
showRoot={false}
|
|
150
|
+
/>
|
|
151
|
+
</DxcContainer>
|
|
152
|
+
</ExampleContainer>
|
|
153
|
+
<Title title="Dropdown theming doesn't affect the collapsed trigger" theme="light" level={3} />
|
|
154
|
+
<ExampleContainer>
|
|
155
|
+
<Title title="Opinionated theming" theme="light" level={4} />
|
|
156
|
+
<ExampleContainer>
|
|
157
|
+
<HalstackProvider
|
|
158
|
+
theme={{
|
|
159
|
+
dropdown: {
|
|
160
|
+
baseColor: "#fabada",
|
|
161
|
+
fontColor: "#999",
|
|
162
|
+
optionFontColor: "#4d4d4d",
|
|
163
|
+
},
|
|
164
|
+
}}
|
|
165
|
+
>
|
|
166
|
+
<DxcBreadcrumbs items={items} itemsBeforeCollapse={3} />
|
|
167
|
+
</HalstackProvider>
|
|
168
|
+
</ExampleContainer>
|
|
169
|
+
<Title title="Advanced theming" theme="light" level={4} />
|
|
170
|
+
<ExampleContainer>
|
|
171
|
+
<HalstackProvider
|
|
172
|
+
advancedTheme={{
|
|
173
|
+
dropdown: {
|
|
174
|
+
buttonBackgroundColor: "#fabada",
|
|
175
|
+
buttonHeight: "100px",
|
|
176
|
+
buttonBorderThickness: "2px",
|
|
177
|
+
buttonBorderStyle: "solid",
|
|
178
|
+
buttonBorderColor: "#000",
|
|
179
|
+
},
|
|
180
|
+
}}
|
|
181
|
+
>
|
|
182
|
+
<DxcBreadcrumbs items={items} itemsBeforeCollapse={3} />
|
|
183
|
+
</HalstackProvider>
|
|
184
|
+
</ExampleContainer>
|
|
185
|
+
</ExampleContainer>
|
|
186
|
+
</>
|
|
187
|
+
);
|
|
188
|
+
|
|
189
|
+
export const Chromatic = Breadcrumbs.bind({});
|
|
190
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
191
|
+
const canvas = within(canvasElement);
|
|
192
|
+
const dropdowns = canvas.getAllByRole("button");
|
|
193
|
+
await userEvent.click(dropdowns[2]);
|
|
194
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|