@dxc-technology/halstack-react 0.0.0-b41d935 → 0.0.0-b4aec06
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 +1243 -6
- package/HalstackContext.js +126 -111
- package/README.md +47 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +42 -118
- package/accordion/Accordion.stories.tsx +85 -139
- package/accordion/Accordion.test.js +19 -34
- package/accordion/types.d.ts +6 -18
- package/accordion-group/AccordionGroup.d.ts +2 -2
- package/accordion-group/AccordionGroup.js +29 -77
- package/accordion-group/AccordionGroup.stories.tsx +78 -77
- package/accordion-group/AccordionGroup.test.js +44 -72
- 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 +7 -19
- 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.js +31 -124
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +29 -46
- package/alert/types.d.ts +5 -5
- package/badge/Badge.d.ts +1 -1
- package/badge/Badge.js +141 -43
- 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 +1 -0
- package/bleed/types.d.ts +2 -2
- package/box/Box.d.ts +1 -1
- package/box/Box.js +18 -59
- package/box/Box.stories.tsx +38 -51
- package/box/Box.test.js +2 -7
- package/box/types.d.ts +3 -15
- package/bulleted-list/BulletedList.js +19 -53
- package/bulleted-list/BulletedList.stories.tsx +8 -93
- package/bulleted-list/types.d.ts +32 -5
- package/button/Button.d.ts +1 -1
- package/button/Button.js +71 -106
- package/button/Button.stories.tsx +144 -101
- package/button/Button.test.js +20 -17
- package/button/types.d.ts +9 -5
- package/card/Card.d.ts +1 -1
- package/card/Card.js +48 -89
- package/card/Card.stories.tsx +12 -42
- package/card/Card.test.js +11 -22
- package/card/types.d.ts +6 -12
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +90 -124
- package/checkbox/Checkbox.stories.tsx +68 -54
- package/checkbox/Checkbox.test.js +108 -64
- package/checkbox/types.d.ts +11 -3
- package/chip/Chip.js +39 -79
- package/chip/Chip.stories.tsx +121 -26
- package/chip/Chip.test.js +16 -31
- 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 +1395 -0
- package/common/variables.js +914 -1156
- 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.d.ts +7 -0
- package/contextual-menu/ContextualMenu.js +71 -0
- package/contextual-menu/ContextualMenu.stories.tsx +182 -0
- package/contextual-menu/ContextualMenu.test.js +71 -0
- package/contextual-menu/MenuItemAction.d.ts +4 -0
- package/contextual-menu/MenuItemAction.js +46 -0
- package/contextual-menu/types.d.ts +22 -0
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +214 -0
- package/date-input/DateInput.js +150 -299
- package/date-input/DateInput.stories.tsx +203 -56
- package/date-input/DateInput.test.js +700 -371
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +115 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +58 -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.d.ts +1 -1
- package/dialog/Dialog.js +61 -119
- package/dialog/Dialog.stories.tsx +310 -212
- package/dialog/Dialog.test.js +269 -32
- package/dialog/types.d.ts +18 -26
- 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/divider/types.js +5 -0
- package/dropdown/Dropdown.js +84 -153
- package/dropdown/Dropdown.stories.tsx +209 -94
- package/dropdown/Dropdown.test.js +409 -400
- package/dropdown/DropdownMenu.js +20 -37
- package/dropdown/DropdownMenuItem.js +15 -37
- package/dropdown/types.d.ts +20 -24
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +193 -262
- package/file-input/FileInput.stories.tsx +86 -3
- package/file-input/FileInput.test.js +356 -395
- package/file-input/FileItem.js +15 -41
- package/file-input/types.d.ts +13 -9
- package/flex/Flex.js +27 -39
- package/flex/Flex.stories.tsx +35 -26
- package/flex/types.d.ts +74 -9
- package/footer/Footer.d.ts +1 -1
- package/footer/Footer.js +70 -117
- package/footer/Footer.stories.tsx +55 -21
- package/footer/Footer.test.js +33 -57
- package/footer/Icons.d.ts +3 -2
- package/footer/Icons.js +66 -7
- package/footer/types.d.ts +25 -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.d.ts +4 -3
- package/header/Header.js +48 -133
- package/header/Header.stories.tsx +115 -36
- package/header/Header.test.js +13 -26
- package/header/Icons.d.ts +2 -2
- package/header/Icons.js +2 -7
- package/header/types.d.ts +7 -22
- package/heading/Heading.js +10 -32
- package/heading/Heading.test.js +71 -88
- package/heading/types.d.ts +7 -7
- 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.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 +2 -1
- package/inset/types.d.ts +2 -2
- package/layout/ApplicationLayout.d.ts +5 -5
- package/layout/ApplicationLayout.js +30 -67
- package/layout/ApplicationLayout.stories.tsx +1 -1
- package/layout/Icons.d.ts +8 -5
- package/layout/Icons.js +51 -59
- package/layout/types.d.ts +5 -6
- package/link/Link.js +25 -46
- package/link/Link.stories.tsx +60 -0
- package/link/Link.test.js +24 -44
- package/link/types.d.ts +14 -14
- package/main.d.ts +10 -5
- package/main.js +47 -59
- package/nav-tabs/NavTabs.d.ts +7 -0
- package/{tabs-nav → nav-tabs}/NavTabs.js +25 -57
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +115 -9
- package/{tabs-nav → nav-tabs}/NavTabs.test.js +39 -45
- package/nav-tabs/NavTabsContext.d.ts +3 -0
- package/nav-tabs/NavTabsContext.js +8 -0
- package/nav-tabs/Tab.js +118 -0
- package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.js +46 -36
- package/number-input/NumberInput.stories.tsx +42 -26
- package/number-input/NumberInput.test.js +860 -414
- 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 +37 -40
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +21 -47
- package/paginator/Paginator.js +22 -58
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +252 -225
- package/paginator/types.d.ts +3 -3
- package/paragraph/Paragraph.d.ts +3 -4
- package/paragraph/Paragraph.js +6 -22
- package/paragraph/Paragraph.stories.tsx +0 -17
- package/password-input/Icons.d.ts +6 -0
- package/password-input/Icons.js +35 -0
- package/password-input/PasswordInput.js +57 -126
- package/password-input/PasswordInput.stories.tsx +1 -33
- package/password-input/PasswordInput.test.js +158 -141
- package/password-input/types.d.ts +8 -7
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +23 -55
- package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
- package/progress-bar/ProgressBar.test.js +36 -53
- package/progress-bar/types.d.ts +4 -3
- package/quick-nav/QuickNav.js +4 -27
- package/quick-nav/QuickNav.stories.tsx +15 -1
- package/quick-nav/types.d.ts +10 -10
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +31 -63
- package/radio-group/RadioGroup.js +45 -93
- package/radio-group/RadioGroup.stories.tsx +131 -18
- package/radio-group/RadioGroup.test.js +505 -471
- package/radio-group/types.d.ts +8 -8
- package/resultset-table/Icons.d.ts +7 -0
- package/resultset-table/Icons.js +47 -0
- package/resultset-table/ResultsetTable.d.ts +7 -0
- package/resultset-table/ResultsetTable.js +170 -0
- package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -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/Icons.d.ts +7 -7
- package/select/Icons.js +1 -5
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +17 -72
- package/select/Option.js +27 -50
- package/select/Select.js +120 -175
- package/select/Select.stories.tsx +497 -153
- package/select/Select.test.js +1974 -1837
- package/select/types.d.ts +16 -17
- package/sidenav/Icons.d.ts +7 -0
- package/{text-input → sidenav}/Icons.js +10 -23
- package/sidenav/Sidenav.d.ts +2 -2
- package/sidenav/Sidenav.js +83 -154
- package/sidenav/Sidenav.stories.tsx +165 -63
- package/sidenav/Sidenav.test.js +3 -10
- package/{layout → sidenav}/SidenavContext.d.ts +1 -1
- package/{layout → sidenav}/SidenavContext.js +3 -9
- package/sidenav/types.d.ts +31 -28
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +77 -134
- package/slider/Slider.test.js +108 -104
- package/slider/types.d.ts +7 -3
- package/spinner/Spinner.js +31 -75
- 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.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.d.ts +3 -3
- package/switch/Switch.js +56 -103
- package/switch/Switch.stories.tsx +33 -34
- package/switch/Switch.test.js +52 -97
- package/switch/types.d.ts +8 -3
- package/table/DropdownTheme.js +62 -0
- package/table/Table.d.ts +6 -2
- package/table/Table.js +78 -35
- package/table/Table.stories.tsx +651 -0
- package/table/Table.test.js +95 -8
- package/table/types.d.ts +34 -6
- package/tabs/Tab.js +26 -45
- package/tabs/Tabs.js +62 -145
- package/tabs/Tabs.stories.tsx +46 -6
- package/tabs/Tabs.test.js +66 -123
- package/tabs/types.d.ts +19 -19
- package/tag/Tag.js +28 -60
- package/tag/Tag.stories.tsx +14 -1
- package/tag/Tag.test.js +20 -31
- package/tag/types.d.ts +7 -7
- package/text-input/Suggestion.js +35 -25
- package/text-input/Suggestions.d.ts +1 -1
- package/text-input/Suggestions.js +19 -67
- package/text-input/TextInput.js +223 -333
- package/text-input/TextInput.stories.tsx +139 -155
- package/text-input/TextInput.test.js +1389 -1404
- package/text-input/types.d.ts +25 -17
- package/textarea/Textarea.js +70 -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.d.ts +2 -2
- package/toggle-group/ToggleGroup.js +92 -106
- package/toggle-group/ToggleGroup.stories.tsx +49 -4
- package/toggle-group/ToggleGroup.test.js +69 -88
- package/toggle-group/types.d.ts +26 -17
- package/typography/Typography.d.ts +2 -2
- package/typography/Typography.js +15 -123
- package/typography/Typography.stories.tsx +1 -1
- package/typography/types.d.ts +1 -1
- package/useTheme.d.ts +1147 -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.js +16 -51
- package/wizard/Wizard.stories.tsx +20 -0
- package/wizard/Wizard.test.js +54 -81
- package/wizard/types.d.ts +9 -10
- 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/resultsetTable/ResultsetTable.d.ts +0 -4
- package/resultsetTable/ResultsetTable.js +0 -252
- package/resultsetTable/ResultsetTable.test.js +0 -348
- package/slider/Slider.stories.tsx +0 -183
- package/table/Table.stories.jsx +0 -277
- package/tabs-nav/NavTabs.d.ts +0 -8
- package/tabs-nav/Tab.js +0 -130
- package/text-input/Icons.d.ts +0 -8
- package/textarea/Textarea.stories.jsx +0 -157
- /package/{resultsetTable → action-icon}/types.js +0 -0
- /package/{tabs-nav → container}/types.js +0 -0
- /package/{number-input/numberInputContextTypes.js → contextual-menu/types.js} +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
|
@@ -4,40 +4,29 @@ import DxcDropdown from "./Dropdown";
|
|
|
4
4
|
import Title from "../../.storybook/components/Title";
|
|
5
5
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
6
|
import DropdownMenu from "./DropdownMenu";
|
|
7
|
-
import DxcCheckbox from "../checkbox/Checkbox";
|
|
8
|
-
import DxcTextInput from "../text-input/TextInput";
|
|
9
7
|
import { Option } from "./types";
|
|
10
|
-
|
|
8
|
+
import useTheme from "../useTheme";
|
|
9
|
+
import DxcFlex from "../flex/Flex";
|
|
10
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
11
|
+
import { ThemeProvider } from "styled-components";
|
|
11
12
|
|
|
12
13
|
export default {
|
|
13
14
|
title: "Dropdown",
|
|
14
15
|
component: DxcDropdown,
|
|
15
16
|
};
|
|
16
17
|
|
|
17
|
-
const hamburguerIcon = (
|
|
18
|
-
<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20">
|
|
19
|
-
<path d="M3 14.5V13h14v1.5Zm0-3.75v-1.5h14v1.5ZM3 7V5.5h14V7Z" />
|
|
20
|
-
</svg>
|
|
21
|
-
);
|
|
22
18
|
const iconSVG = (
|
|
23
|
-
<svg viewBox="0 0 24 24" fill="currentColor">
|
|
19
|
+
<svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
|
|
24
20
|
<path d="M0 0h24v24H0z" fill="none" />
|
|
25
21
|
<path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
|
|
26
22
|
</svg>
|
|
27
23
|
);
|
|
28
24
|
const iconSVGLarge = (
|
|
29
|
-
<svg
|
|
30
|
-
<
|
|
31
|
-
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
32
|
-
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
33
|
-
</g>
|
|
34
|
-
<g>
|
|
35
|
-
<path d="M12,17.27L18.18,21l-1.64-7.03L22,9.24l-7.19-0.61L12,2L9.19,8.63L2,9.24l5.46,4.73L5.82,21L12,17.27z" />
|
|
36
|
-
</g>
|
|
25
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48" height="48" width="48">
|
|
26
|
+
<path d="M11 44q-1.2 0-2.1-.9Q8 42.2 8 41V15q0-1.2.9-2.1.9-.9 2.1-.9h5.5v-.5q0-3.15 2.175-5.325Q20.85 4 24 4q3.15 0 5.325 2.175Q31.5 8.35 31.5 11.5v.5H37q1.2 0 2.1.9.9.9.9 2.1v26q0 1.2-.9 2.1-.9.9-2.1.9Zm0-3h26V15h-5.5v4.5q0 .65-.425 1.075Q30.65 21 30 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15h-9v4.5q0 .65-.425 1.075Q18.65 21 18 21q-.65 0-1.075-.425-.425-.425-.425-1.075V15H11v26Zm8.5-29h9v-.5q0-1.9-1.3-3.2Q25.9 7 24 7q-1.9 0-3.2 1.3-1.3 1.3-1.3 3.2ZM11 41V15v26Z" />
|
|
37
27
|
</svg>
|
|
38
28
|
);
|
|
39
|
-
const
|
|
40
|
-
const icons = [iconSVG, iconSVGLarge, iconUrl];
|
|
29
|
+
const icons = [iconSVG, iconSVGLarge, "nutrition"];
|
|
41
30
|
|
|
42
31
|
const defaultOptions: Option[] = [
|
|
43
32
|
{
|
|
@@ -60,6 +49,18 @@ const defaultOptions: Option[] = [
|
|
|
60
49
|
value: "5",
|
|
61
50
|
label: "Aliexpress",
|
|
62
51
|
},
|
|
52
|
+
{
|
|
53
|
+
value: "6",
|
|
54
|
+
label: "Etsy",
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
value: "7",
|
|
58
|
+
label: "Alibaba",
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
value: "8",
|
|
62
|
+
label: "Gearbest shop",
|
|
63
|
+
},
|
|
63
64
|
];
|
|
64
65
|
const options: Option[] = [
|
|
65
66
|
{
|
|
@@ -79,13 +80,21 @@ const optionWithIcon: Option[] = [
|
|
|
79
80
|
{
|
|
80
81
|
value: "1",
|
|
81
82
|
label: "Ebay",
|
|
82
|
-
icon:
|
|
83
|
+
icon: "shopping_cart",
|
|
83
84
|
},
|
|
84
85
|
];
|
|
85
86
|
|
|
86
87
|
const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
|
|
87
88
|
|
|
88
|
-
|
|
89
|
+
const opinionatedTheme = {
|
|
90
|
+
dropdown: {
|
|
91
|
+
baseColor: "#ffffff",
|
|
92
|
+
fontColor: "#000000",
|
|
93
|
+
optionFontColor: "#000000",
|
|
94
|
+
},
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
const Dropdown = () => (
|
|
89
98
|
<>
|
|
90
99
|
<ExampleContainer>
|
|
91
100
|
<Title title="Default" theme="light" level={4} />
|
|
@@ -121,7 +130,7 @@ export const Chromatic = () => (
|
|
|
121
130
|
label="Icon after"
|
|
122
131
|
options={options}
|
|
123
132
|
onSelectOption={(value) => {}}
|
|
124
|
-
icon="
|
|
133
|
+
icon="shopping_cart"
|
|
125
134
|
iconPosition="after"
|
|
126
135
|
/>
|
|
127
136
|
</ExampleContainer>
|
|
@@ -131,12 +140,16 @@ export const Chromatic = () => (
|
|
|
131
140
|
</ExampleContainer>
|
|
132
141
|
<ExampleContainer>
|
|
133
142
|
<Title title="Only icon without caret" theme="light" level={4} />
|
|
134
|
-
<DxcDropdown options={options} onSelectOption={(value) => {}} icon=
|
|
143
|
+
<DxcDropdown options={options} onSelectOption={(value) => {}} icon="menu" caretHidden />
|
|
135
144
|
</ExampleContainer>
|
|
136
145
|
<ExampleContainer>
|
|
137
|
-
<Title title="Large icon" theme="light" level={4} />
|
|
146
|
+
<Title title="Large icon (SVG)" theme="light" level={4} />
|
|
138
147
|
<DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
|
|
139
148
|
</ExampleContainer>
|
|
149
|
+
<ExampleContainer>
|
|
150
|
+
<Title title="Large icon (image)" theme="light" level={4} />
|
|
151
|
+
<DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon="menu" />
|
|
152
|
+
</ExampleContainer>
|
|
140
153
|
<ExampleContainer>
|
|
141
154
|
<Title title="Disabled with icon" theme="light" level={4} />
|
|
142
155
|
<DxcDropdown
|
|
@@ -219,94 +232,196 @@ export const Chromatic = () => (
|
|
|
219
232
|
size="fillParent"
|
|
220
233
|
/>
|
|
221
234
|
</ExampleContainer>
|
|
235
|
+
<ExampleContainer expanded>
|
|
236
|
+
<Title title="Opened menu" theme="light" level={4} />
|
|
237
|
+
<DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} margin={{ top: "xxlarge" }} />
|
|
238
|
+
</ExampleContainer>
|
|
222
239
|
</>
|
|
223
240
|
);
|
|
224
241
|
|
|
225
|
-
const DropdownListStates = () =>
|
|
242
|
+
const DropdownListStates = () => {
|
|
243
|
+
const colorsTheme: any = useTheme();
|
|
244
|
+
|
|
245
|
+
return (
|
|
246
|
+
<>
|
|
247
|
+
<Title title="Dropdown Menu" theme="light" level={2} />
|
|
248
|
+
<ExampleContainer>
|
|
249
|
+
<Title
|
|
250
|
+
title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
|
|
251
|
+
theme="light"
|
|
252
|
+
level={3}
|
|
253
|
+
/>
|
|
254
|
+
<div
|
|
255
|
+
style={{
|
|
256
|
+
position: "relative",
|
|
257
|
+
display: "flex",
|
|
258
|
+
flexDirection: "column",
|
|
259
|
+
gap: "20px",
|
|
260
|
+
height: "150px",
|
|
261
|
+
width: "min-content",
|
|
262
|
+
marginBottom: "100px",
|
|
263
|
+
padding: "20px",
|
|
264
|
+
border: "1px solid black",
|
|
265
|
+
borderRadius: "4px",
|
|
266
|
+
overflow: "auto",
|
|
267
|
+
zIndex: "1300",
|
|
268
|
+
}}
|
|
269
|
+
>
|
|
270
|
+
<DxcDropdown
|
|
271
|
+
label="Select a platform"
|
|
272
|
+
options={defaultOptions}
|
|
273
|
+
onSelectOption={(option) => {}}
|
|
274
|
+
size="medium"
|
|
275
|
+
/>
|
|
276
|
+
<button style={{ zIndex: "1", width: "100px" }}>Submit</button>
|
|
277
|
+
</div>
|
|
278
|
+
</ExampleContainer>
|
|
279
|
+
<ThemeProvider theme={colorsTheme.dropdown}>
|
|
280
|
+
<Title title="Option states" theme="light" level={3} />
|
|
281
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
282
|
+
<Title title="Hovered option" theme="light" level={4} />
|
|
283
|
+
<DropdownMenu
|
|
284
|
+
id="x"
|
|
285
|
+
dropdownTriggerId="dtx"
|
|
286
|
+
iconsPosition="before"
|
|
287
|
+
visualFocusIndex={-1}
|
|
288
|
+
menuItemOnClick={(value) => {}}
|
|
289
|
+
onKeyDown={(e) => {}}
|
|
290
|
+
options={optionWithIcon}
|
|
291
|
+
styles={{ width: 240 }}
|
|
292
|
+
/>
|
|
293
|
+
</ExampleContainer>
|
|
294
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
295
|
+
<Title title="Active option" theme="light" level={4} />
|
|
296
|
+
<DropdownMenu
|
|
297
|
+
id="x"
|
|
298
|
+
dropdownTriggerId="dtx"
|
|
299
|
+
iconsPosition="before"
|
|
300
|
+
visualFocusIndex={-1}
|
|
301
|
+
menuItemOnClick={(value) => {}}
|
|
302
|
+
onKeyDown={(e) => {}}
|
|
303
|
+
options={optionWithIcon}
|
|
304
|
+
styles={{ width: 240 }}
|
|
305
|
+
/>
|
|
306
|
+
</ExampleContainer>
|
|
307
|
+
<ExampleContainer>
|
|
308
|
+
<Title title="Focused option" theme="light" level={4} />
|
|
309
|
+
<DropdownMenu
|
|
310
|
+
id="x"
|
|
311
|
+
dropdownTriggerId="dtx"
|
|
312
|
+
iconsPosition="before"
|
|
313
|
+
visualFocusIndex={0}
|
|
314
|
+
menuItemOnClick={(value) => {}}
|
|
315
|
+
onKeyDown={(e) => {}}
|
|
316
|
+
options={options}
|
|
317
|
+
styles={{ width: 240 }}
|
|
318
|
+
/>
|
|
319
|
+
</ExampleContainer>
|
|
320
|
+
<Title title="Icons" theme="light" level={3} />
|
|
321
|
+
<ExampleContainer>
|
|
322
|
+
<Title title="Before" theme="light" level={4} />
|
|
323
|
+
<DropdownMenu
|
|
324
|
+
id="x"
|
|
325
|
+
dropdownTriggerId="dtx"
|
|
326
|
+
iconsPosition="before"
|
|
327
|
+
visualFocusIndex={-1}
|
|
328
|
+
menuItemOnClick={(value) => {}}
|
|
329
|
+
onKeyDown={(e) => {}}
|
|
330
|
+
options={optionsIcon}
|
|
331
|
+
styles={{ width: 240 }}
|
|
332
|
+
/>
|
|
333
|
+
<Title title="After" theme="light" level={4} />
|
|
334
|
+
<DropdownMenu
|
|
335
|
+
id="x"
|
|
336
|
+
dropdownTriggerId="dtx"
|
|
337
|
+
iconsPosition="after"
|
|
338
|
+
visualFocusIndex={-1}
|
|
339
|
+
menuItemOnClick={(value) => {}}
|
|
340
|
+
onKeyDown={(e) => {}}
|
|
341
|
+
options={optionsIcon}
|
|
342
|
+
styles={{ width: 240 }}
|
|
343
|
+
/>
|
|
344
|
+
</ExampleContainer>
|
|
345
|
+
</ThemeProvider>
|
|
346
|
+
</>
|
|
347
|
+
);
|
|
348
|
+
};
|
|
349
|
+
|
|
350
|
+
const DropdownRightAlignment = () => (
|
|
351
|
+
<ExampleContainer expanded>
|
|
352
|
+
<Title title="Dropdown collisions on the right boundary (right)" theme="light" level={4} />
|
|
353
|
+
<DxcFlex justifyContent="flex-end">
|
|
354
|
+
<DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} />
|
|
355
|
+
</DxcFlex>
|
|
356
|
+
</ExampleContainer>
|
|
357
|
+
);
|
|
358
|
+
|
|
359
|
+
const DropdownCenterAlignment = () => (
|
|
360
|
+
<ExampleContainer expanded>
|
|
361
|
+
<Title title="Dropdown collisions on the right boundary (centered)" theme="light" level={4} />
|
|
362
|
+
<DxcFlex justifyContent="flex-end">
|
|
363
|
+
<DxcDropdown label="Label" options={defaultOptions} onSelectOption={(value) => {}} margin="small" />
|
|
364
|
+
</DxcFlex>
|
|
365
|
+
</ExampleContainer>
|
|
366
|
+
);
|
|
367
|
+
|
|
368
|
+
export const Chromatic = Dropdown.bind({});
|
|
369
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
370
|
+
const canvas = within(canvasElement);
|
|
371
|
+
const buttonList = canvas.getAllByRole("button");
|
|
372
|
+
await userEvent.click(buttonList[buttonList.length - 1]);
|
|
373
|
+
};
|
|
374
|
+
|
|
375
|
+
export const OpinionatedTheme = () => (
|
|
226
376
|
<>
|
|
227
|
-
<Title title="
|
|
228
|
-
<Title title="Default with opened menu" theme="light" level={3} />
|
|
377
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
229
378
|
<ExampleContainer>
|
|
230
|
-
<
|
|
231
|
-
|
|
232
|
-
<
|
|
233
|
-
|
|
234
|
-
label="You understand the selection and give your consent"
|
|
235
|
-
onChange={() => {}}
|
|
236
|
-
labelPosition="after"
|
|
237
|
-
/>
|
|
238
|
-
</div>
|
|
379
|
+
<Title title="Default" theme="light" level={4} />
|
|
380
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
381
|
+
<DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
382
|
+
</HalstackProvider>
|
|
239
383
|
</ExampleContainer>
|
|
240
|
-
<Title title="Option states" theme="light" level={3} />
|
|
241
384
|
<ExampleContainer pseudoState="pseudo-hover">
|
|
242
|
-
<Title title="Hovered
|
|
243
|
-
<
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
iconsPosition="before"
|
|
247
|
-
visualFocusIndex={-1}
|
|
248
|
-
optionOnClick={(option) => {}}
|
|
249
|
-
onKeyDown={(e) => {}}
|
|
250
|
-
options={optionWithIcon}
|
|
251
|
-
styles={{ width: 240 }}
|
|
252
|
-
/>
|
|
385
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
386
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
387
|
+
<DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
388
|
+
</HalstackProvider>
|
|
253
389
|
</ExampleContainer>
|
|
254
390
|
<ExampleContainer pseudoState="pseudo-active">
|
|
255
|
-
<Title title="
|
|
256
|
-
<
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
iconsPosition="before"
|
|
260
|
-
visualFocusIndex={-1}
|
|
261
|
-
optionOnClick={(option) => {}}
|
|
262
|
-
onKeyDown={(e) => {}}
|
|
263
|
-
options={optionWithIcon}
|
|
264
|
-
styles={{ width: 240 }}
|
|
265
|
-
/>
|
|
391
|
+
<Title title="Actived" theme="light" level={4} />
|
|
392
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
393
|
+
<DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
394
|
+
</HalstackProvider>
|
|
266
395
|
</ExampleContainer>
|
|
267
|
-
<ExampleContainer>
|
|
268
|
-
<Title title="Focused
|
|
269
|
-
<
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
iconsPosition="before"
|
|
273
|
-
visualFocusIndex={0}
|
|
274
|
-
optionOnClick={(option) => {}}
|
|
275
|
-
onKeyDown={(e) => {}}
|
|
276
|
-
options={options}
|
|
277
|
-
styles={{ width: 240 }}
|
|
278
|
-
/>
|
|
396
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
397
|
+
<Title title="Focused" theme="light" level={4} />
|
|
398
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
399
|
+
<DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
400
|
+
</HalstackProvider>
|
|
279
401
|
</ExampleContainer>
|
|
280
|
-
<Title title="Icons" theme="light" level={3} />
|
|
281
402
|
<ExampleContainer>
|
|
282
|
-
<Title title="
|
|
283
|
-
<
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
iconsPosition="before"
|
|
287
|
-
visualFocusIndex={-1}
|
|
288
|
-
optionOnClick={(option) => {}}
|
|
289
|
-
onKeyDown={(e) => {}}
|
|
290
|
-
options={optionsIcon}
|
|
291
|
-
styles={{ width: 240 }}
|
|
292
|
-
/>
|
|
293
|
-
<Title title="After" theme="light" level={4} />
|
|
294
|
-
<DropdownMenu
|
|
295
|
-
id="x"
|
|
296
|
-
dropdownId="dX"
|
|
297
|
-
iconsPosition="after"
|
|
298
|
-
visualFocusIndex={-1}
|
|
299
|
-
optionOnClick={(option) => {}}
|
|
300
|
-
onKeyDown={(e) => {}}
|
|
301
|
-
options={optionsIcon}
|
|
302
|
-
styles={{ width: 240 }}
|
|
303
|
-
/>
|
|
403
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
404
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
405
|
+
<DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} icon={iconSVG} disabled />
|
|
406
|
+
</HalstackProvider>
|
|
304
407
|
</ExampleContainer>
|
|
305
408
|
</>
|
|
306
409
|
);
|
|
307
410
|
|
|
308
411
|
export const DropdownMenuStates = DropdownListStates.bind({});
|
|
309
412
|
DropdownMenuStates.play = async ({ canvasElement }) => {
|
|
413
|
+
const canvas = within(canvasElement);
|
|
414
|
+
await userEvent.click(canvas.getAllByRole("button")[0]);
|
|
415
|
+
};
|
|
416
|
+
|
|
417
|
+
export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
|
|
418
|
+
DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
|
|
419
|
+
const canvas = within(canvasElement);
|
|
420
|
+
await userEvent.click(canvas.getByRole("button"));
|
|
421
|
+
};
|
|
422
|
+
|
|
423
|
+
export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
|
|
424
|
+
DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
|
|
310
425
|
const canvas = within(canvasElement);
|
|
311
426
|
await userEvent.click(canvas.getByRole("button"));
|
|
312
427
|
};
|