@dxc-technology/halstack-react 0.0.0-f0d662d → 0.0.0-f1bbdfe
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 +2 -2
- package/BackgroundColorContext.js +1 -1
- package/HalstackContext.d.ts +1336 -0
- package/HalstackContext.js +335 -0
- package/accordion/Accordion.d.ts +1 -1
- package/accordion/Accordion.js +118 -142
- package/accordion/Accordion.stories.tsx +115 -27
- package/accordion/Accordion.test.js +71 -0
- package/accordion/types.d.ts +8 -7
- package/accordion-group/AccordionGroup.d.ts +1 -1
- package/accordion-group/AccordionGroup.js +17 -38
- package/accordion-group/AccordionGroup.stories.tsx +28 -2
- package/accordion-group/AccordionGroup.test.js +126 -0
- package/accordion-group/types.d.ts +14 -7
- package/alert/Alert.js +8 -7
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +92 -0
- package/badge/Badge.d.ts +4 -0
- package/badge/Badge.js +5 -3
- package/badge/types.d.ts +5 -0
- package/bleed/Bleed.js +1 -34
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +25 -1
- package/box/Box.js +25 -37
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +18 -0
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +125 -0
- package/bulleted-list/BulletedList.stories.tsx +206 -0
- package/bulleted-list/types.d.ts +38 -0
- package/button/Button.js +52 -70
- package/button/Button.stories.tsx +159 -8
- package/button/Button.test.js +35 -0
- package/button/types.d.ts +5 -5
- package/card/Card.js +33 -37
- package/card/Card.stories.tsx +12 -13
- package/card/Card.test.js +50 -0
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +107 -110
- package/checkbox/Checkbox.stories.tsx +198 -130
- package/checkbox/Checkbox.test.js +155 -0
- package/checkbox/types.d.ts +11 -3
- package/chip/Chip.d.ts +1 -1
- package/chip/Chip.js +22 -68
- package/chip/Chip.stories.tsx +98 -13
- package/chip/Chip.test.js +54 -0
- package/chip/types.d.ts +5 -13
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +146 -0
- package/common/coreTokens.js +167 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1482 -0
- package/common/variables.js +1097 -1348
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +169 -258
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +835 -0
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +67 -9
- package/dialog/Dialog.js +76 -93
- package/dialog/Dialog.stories.tsx +230 -123
- package/dialog/Dialog.test.js +369 -0
- package/dialog/types.d.ts +1 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +248 -277
- package/dropdown/Dropdown.stories.tsx +255 -64
- package/dropdown/Dropdown.test.js +586 -0
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +74 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +79 -0
- package/dropdown/types.d.ts +27 -16
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +180 -223
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +457 -0
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +44 -66
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +71 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/footer/Footer.js +17 -92
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +97 -0
- package/footer/Icons.js +1 -1
- package/footer/types.d.ts +2 -1
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +91 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/header/Header.d.ts +3 -2
- package/header/Header.js +108 -129
- package/header/Header.stories.tsx +189 -36
- package/header/Header.test.js +79 -0
- package/header/Icons.js +2 -2
- package/header/types.d.ts +1 -0
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.js +186 -0
- package/inset/Inset.js +1 -34
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +25 -1
- package/layout/ApplicationLayout.d.ts +16 -6
- package/layout/ApplicationLayout.js +72 -126
- package/layout/ApplicationLayout.stories.tsx +84 -93
- package/layout/Icons.d.ts +5 -0
- package/layout/Icons.js +13 -2
- package/layout/SidenavContext.d.ts +5 -0
- package/layout/SidenavContext.js +19 -0
- package/layout/types.d.ts +19 -35
- package/link/Link.d.ts +3 -2
- package/link/Link.js +63 -88
- package/link/Link.stories.tsx +159 -52
- package/link/Link.test.js +81 -0
- package/link/types.d.ts +7 -27
- package/main.d.ts +12 -15
- package/main.js +57 -75
- package/nav-tabs/NavTabs.d.ts +8 -0
- package/nav-tabs/NavTabs.js +125 -0
- package/nav-tabs/NavTabs.stories.tsx +260 -0
- package/nav-tabs/NavTabs.test.js +82 -0
- package/nav-tabs/Tab.d.ts +4 -0
- package/nav-tabs/Tab.js +150 -0
- package/nav-tabs/types.d.ts +53 -0
- package/nav-tabs/types.js +5 -0
- package/number-input/NumberInput.js +11 -18
- package/number-input/NumberInput.stories.tsx +5 -5
- package/number-input/NumberInput.test.js +542 -0
- package/number-input/types.d.ts +17 -10
- package/package.json +20 -23
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +19 -48
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +305 -0
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.js +7 -4
- package/password-input/PasswordInput.test.js +181 -0
- package/password-input/types.d.ts +14 -11
- package/progress-bar/ProgressBar.js +61 -55
- package/progress-bar/ProgressBar.stories.jsx +47 -12
- package/progress-bar/ProgressBar.test.js +110 -0
- package/quick-nav/QuickNav.d.ts +4 -0
- package/quick-nav/QuickNav.js +117 -0
- package/quick-nav/QuickNav.stories.tsx +356 -0
- package/quick-nav/types.d.ts +21 -0
- package/quick-nav/types.js +5 -0
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +53 -37
- package/radio-group/RadioGroup.js +67 -57
- package/radio-group/RadioGroup.stories.tsx +171 -36
- package/radio-group/RadioGroup.test.js +563 -89
- package/radio-group/types.d.ts +82 -4
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +50 -106
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +325 -0
- package/resultsetTable/types.d.ts +1 -1
- package/select/Icons.d.ts +10 -0
- package/select/Icons.js +93 -0
- package/select/Listbox.d.ts +4 -0
- package/select/Listbox.js +169 -0
- package/select/Option.d.ts +4 -0
- package/select/Option.js +97 -0
- package/select/Select.js +189 -386
- package/select/Select.stories.tsx +600 -201
- package/select/Select.test.js +2228 -0
- package/select/types.d.ts +53 -13
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +51 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +146 -44
- package/sidenav/Sidenav.stories.tsx +251 -151
- package/sidenav/Sidenav.test.js +44 -0
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +123 -98
- package/slider/Slider.stories.tsx +72 -9
- package/slider/Slider.test.js +250 -0
- package/slider/types.d.ts +8 -0
- package/spinner/Spinner.js +18 -24
- package/spinner/Spinner.stories.jsx +53 -27
- package/spinner/Spinner.test.js +64 -0
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +152 -69
- package/switch/Switch.stories.tsx +53 -42
- package/switch/Switch.test.js +225 -0
- package/switch/types.d.ts +10 -2
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +26 -0
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +132 -0
- package/tabs/Tabs.d.ts +1 -1
- package/tabs/Tabs.js +360 -112
- package/tabs/Tabs.stories.tsx +119 -13
- package/tabs/Tabs.test.js +350 -0
- package/tabs/types.d.ts +17 -3
- package/tag/Tag.d.ts +1 -1
- package/tag/Tag.js +24 -36
- package/tag/Tag.stories.tsx +37 -27
- package/tag/Tag.test.js +60 -0
- package/tag/types.d.ts +23 -14
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.d.ts +4 -0
- package/text-input/Suggestion.js +84 -0
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +224 -345
- package/text-input/TextInput.stories.tsx +310 -197
- package/text-input/TextInput.test.js +1723 -0
- package/text-input/types.d.ts +50 -12
- package/textarea/Textarea.js +22 -30
- package/textarea/Textarea.stories.jsx +93 -13
- package/textarea/Textarea.test.js +435 -0
- package/textarea/types.d.ts +18 -11
- package/toggle-group/ToggleGroup.d.ts +1 -1
- package/toggle-group/ToggleGroup.js +12 -8
- package/toggle-group/ToggleGroup.stories.tsx +46 -4
- package/toggle-group/ToggleGroup.test.js +156 -0
- package/toggle-group/types.d.ts +10 -2
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +32 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1234 -1
- package/useTheme.js +3 -3
- package/useTranslatedLabels.d.ts +85 -0
- package/useTranslatedLabels.js +20 -0
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +139 -0
- package/wizard/Wizard.d.ts +1 -1
- package/wizard/Wizard.js +59 -55
- package/wizard/Wizard.stories.tsx +48 -19
- package/wizard/Wizard.test.js +141 -0
- package/wizard/types.d.ts +8 -4
- package/ThemeContext.d.ts +0 -15
- package/ThemeContext.js +0 -243
- package/V3Select/V3Select.js +0 -455
- package/V3Select/index.d.ts +0 -27
- package/V3Textarea/V3Textarea.js +0 -260
- package/V3Textarea/index.d.ts +0 -27
- package/common/RequiredComponent.js +0 -32
- package/date/Date.js +0 -373
- package/date/index.d.ts +0 -27
- package/input-text/Icons.js +0 -22
- package/input-text/InputText.js +0 -611
- package/input-text/index.d.ts +0 -36
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/radio/Radio.d.ts +0 -4
- package/radio/Radio.js +0 -174
- package/radio/Radio.stories.tsx +0 -192
- package/radio/types.d.ts +0 -54
- 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 -10
- 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 -9
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- package/toggle/Toggle.js +0 -186
- package/toggle/index.d.ts +0 -21
- package/upload/Upload.js +0 -201
- package/upload/buttons-upload/ButtonsUpload.js +0 -111
- package/upload/buttons-upload/Icons.js +0 -40
- package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
- package/upload/dragAndDropArea/Icons.js +0 -39
- package/upload/file-upload/FileToUpload.js +0 -115
- package/upload/file-upload/Icons.js +0 -66
- package/upload/files-upload/FilesToUpload.js +0 -109
- package/upload/index.d.ts +0 -15
- package/upload/transaction/Icons.js +0 -160
- package/upload/transaction/Transaction.js +0 -104
- package/upload/transactions/Transactions.js +0 -94
- /package/{list → badge}/types.js +0 -0
- /package/{radio → bulleted-list}/types.js +0 -0
- /package/{row → flex}/types.js +0 -0
- /package/{stack → grid}/types.js +0 -0
|
@@ -3,36 +3,72 @@ import { userEvent, within } from "@storybook/testing-library";
|
|
|
3
3
|
import DxcDropdown from "./Dropdown";
|
|
4
4
|
import Title from "../../.storybook/components/Title";
|
|
5
5
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
6
|
+
import DropdownMenu from "./DropdownMenu";
|
|
7
|
+
import { Option } from "./types";
|
|
8
|
+
import useTheme from "../useTheme";
|
|
9
|
+
import DxcFlex from "../flex/Flex";
|
|
10
|
+
import { HalstackProvider } from "../HalstackContext";
|
|
11
|
+
import { ThemeProvider } from "styled-components";
|
|
6
12
|
|
|
7
13
|
export default {
|
|
8
14
|
title: "Dropdown",
|
|
9
15
|
component: DxcDropdown,
|
|
10
16
|
};
|
|
11
17
|
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
<
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
</g>
|
|
31
|
-
</svg>
|
|
32
|
-
);
|
|
33
|
-
};
|
|
18
|
+
const hamburguerIcon = (
|
|
19
|
+
<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20">
|
|
20
|
+
<path d="M3 14.5V13h14v1.5Zm0-3.75v-1.5h14v1.5ZM3 7V5.5h14V7Z" />
|
|
21
|
+
</svg>
|
|
22
|
+
);
|
|
23
|
+
const iconSVG = (
|
|
24
|
+
<svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
|
|
25
|
+
<path d="M0 0h24v24H0z" fill="none" />
|
|
26
|
+
<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" />
|
|
27
|
+
</svg>
|
|
28
|
+
);
|
|
29
|
+
const iconSVGLarge = (
|
|
30
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 48 48" height="48" width="48">
|
|
31
|
+
<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" />
|
|
32
|
+
</svg>
|
|
33
|
+
);
|
|
34
|
+
const iconUrl = "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png";
|
|
35
|
+
const icons = [iconSVG, iconSVGLarge, iconUrl];
|
|
34
36
|
|
|
35
|
-
const
|
|
37
|
+
const defaultOptions: Option[] = [
|
|
38
|
+
{
|
|
39
|
+
value: "1",
|
|
40
|
+
label: "Amazon",
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
value: "2",
|
|
44
|
+
label: "Ebay",
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
value: "3",
|
|
48
|
+
label: "Apple",
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
value: "4",
|
|
52
|
+
label: "Wallapop",
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
value: "5",
|
|
56
|
+
label: "Aliexpress",
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
value: "6",
|
|
60
|
+
label: "Etsy",
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
value: "7",
|
|
64
|
+
label: "Alibaba",
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
value: "8",
|
|
68
|
+
label: "Gearbest shop",
|
|
69
|
+
},
|
|
70
|
+
];
|
|
71
|
+
const options: Option[] = [
|
|
36
72
|
{
|
|
37
73
|
value: "1",
|
|
38
74
|
label: "Amazon with a very long text",
|
|
@@ -46,17 +82,25 @@ const options: any = [
|
|
|
46
82
|
label: "Apple",
|
|
47
83
|
},
|
|
48
84
|
];
|
|
49
|
-
|
|
50
|
-
const option: any = [
|
|
85
|
+
const optionWithIcon: Option[] = [
|
|
51
86
|
{
|
|
52
87
|
value: "1",
|
|
53
88
|
label: "Ebay",
|
|
89
|
+
icon: iconUrl,
|
|
54
90
|
},
|
|
55
91
|
];
|
|
56
92
|
|
|
57
|
-
const optionsIcon: any = options.map((op, i) => ({ ...op, icon: i
|
|
93
|
+
const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
|
|
58
94
|
|
|
59
|
-
|
|
95
|
+
const opinionatedTheme = {
|
|
96
|
+
dropdown: {
|
|
97
|
+
baseColor: "#ffffff",
|
|
98
|
+
fontColor: "#000000",
|
|
99
|
+
optionFontColor: "#000000",
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
const Dropdown = () => (
|
|
60
104
|
<>
|
|
61
105
|
<ExampleContainer>
|
|
62
106
|
<Title title="Default" theme="light" level={4} />
|
|
@@ -66,7 +110,7 @@ export const Chromatic = () => (
|
|
|
66
110
|
<Title title="Hovered" theme="light" level={4} />
|
|
67
111
|
<DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
|
|
68
112
|
</ExampleContainer>
|
|
69
|
-
<ExampleContainer pseudoState="pseudo-focus
|
|
113
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
70
114
|
<Title title="Focused" theme="light" level={4} />
|
|
71
115
|
<DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
|
|
72
116
|
</ExampleContainer>
|
|
@@ -92,7 +136,7 @@ export const Chromatic = () => (
|
|
|
92
136
|
label="Icon after"
|
|
93
137
|
options={options}
|
|
94
138
|
onSelectOption={(value) => {}}
|
|
95
|
-
icon=
|
|
139
|
+
icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
|
|
96
140
|
iconPosition="after"
|
|
97
141
|
/>
|
|
98
142
|
</ExampleContainer>
|
|
@@ -101,9 +145,22 @@ export const Chromatic = () => (
|
|
|
101
145
|
<DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
102
146
|
</ExampleContainer>
|
|
103
147
|
<ExampleContainer>
|
|
104
|
-
<Title title="
|
|
148
|
+
<Title title="Only icon without caret" theme="light" level={4} />
|
|
149
|
+
<DxcDropdown options={options} onSelectOption={(value) => {}} icon={hamburguerIcon} caretHidden />
|
|
150
|
+
</ExampleContainer>
|
|
151
|
+
<ExampleContainer>
|
|
152
|
+
<Title title="Large icon (SVG)" theme="light" level={4} />
|
|
105
153
|
<DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
|
|
106
154
|
</ExampleContainer>
|
|
155
|
+
<ExampleContainer>
|
|
156
|
+
<Title title="Large icon (image)" theme="light" level={4} />
|
|
157
|
+
<DxcDropdown
|
|
158
|
+
label="Large icon"
|
|
159
|
+
options={options}
|
|
160
|
+
onSelectOption={(value) => {}}
|
|
161
|
+
icon="https://upload.wikimedia.org/wikipedia/commons/thumb/b/b2/Hamburger_icon.svg/2048px-Hamburger_icon.svg.png"
|
|
162
|
+
/>
|
|
163
|
+
</ExampleContainer>
|
|
107
164
|
<ExampleContainer>
|
|
108
165
|
<Title title="Disabled with icon" theme="light" level={4} />
|
|
109
166
|
<DxcDropdown
|
|
@@ -186,62 +243,196 @@ export const Chromatic = () => (
|
|
|
186
243
|
size="fillParent"
|
|
187
244
|
/>
|
|
188
245
|
</ExampleContainer>
|
|
246
|
+
<ExampleContainer expanded>
|
|
247
|
+
<Title title="Opened menu" theme="light" level={4} />
|
|
248
|
+
<DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} margin={{ top: "xxlarge" }} />
|
|
249
|
+
</ExampleContainer>
|
|
189
250
|
</>
|
|
190
251
|
);
|
|
191
252
|
|
|
192
|
-
const
|
|
193
|
-
|
|
194
|
-
<Title title="Options" theme="light" level={4} />
|
|
195
|
-
<DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
|
|
196
|
-
</ExampleContainer>
|
|
197
|
-
);
|
|
253
|
+
const DropdownListStates = () => {
|
|
254
|
+
const colorsTheme: any = useTheme();
|
|
198
255
|
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
256
|
+
return (
|
|
257
|
+
<>
|
|
258
|
+
<Title title="Dropdown Menu" theme="light" level={2} />
|
|
259
|
+
<ExampleContainer>
|
|
260
|
+
<Title
|
|
261
|
+
title="List dialog uses a Radix Popover to appear over elements with a certain z-index"
|
|
262
|
+
theme="light"
|
|
263
|
+
level={3}
|
|
264
|
+
/>
|
|
265
|
+
<div
|
|
266
|
+
style={{
|
|
267
|
+
position: "relative",
|
|
268
|
+
display: "flex",
|
|
269
|
+
flexDirection: "column",
|
|
270
|
+
gap: "20px",
|
|
271
|
+
height: "150px",
|
|
272
|
+
width: "min-content",
|
|
273
|
+
marginBottom: "100px",
|
|
274
|
+
padding: "20px",
|
|
275
|
+
border: "1px solid black",
|
|
276
|
+
borderRadius: "4px",
|
|
277
|
+
overflow: "auto",
|
|
278
|
+
zIndex: "1300",
|
|
279
|
+
}}
|
|
280
|
+
>
|
|
281
|
+
<DxcDropdown
|
|
282
|
+
label="Select a platform"
|
|
283
|
+
options={defaultOptions}
|
|
284
|
+
onSelectOption={(option) => {}}
|
|
285
|
+
size="medium"
|
|
286
|
+
/>
|
|
287
|
+
<button style={{ zIndex: "1", width: "100px" }}>Submit</button>
|
|
288
|
+
</div>
|
|
289
|
+
</ExampleContainer>
|
|
290
|
+
<ThemeProvider theme={colorsTheme.dropdown}>
|
|
291
|
+
<Title title="Option states" theme="light" level={3} />
|
|
292
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
293
|
+
<Title title="Hovered option" theme="light" level={4} />
|
|
294
|
+
<DropdownMenu
|
|
295
|
+
id="x"
|
|
296
|
+
dropdownTriggerId="dtx"
|
|
297
|
+
iconsPosition="before"
|
|
298
|
+
visualFocusIndex={-1}
|
|
299
|
+
menuItemOnClick={(value) => {}}
|
|
300
|
+
onKeyDown={(e) => {}}
|
|
301
|
+
options={optionWithIcon}
|
|
302
|
+
styles={{ width: 240 }}
|
|
303
|
+
/>
|
|
304
|
+
</ExampleContainer>
|
|
305
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
306
|
+
<Title title="Active option" theme="light" level={4} />
|
|
307
|
+
<DropdownMenu
|
|
308
|
+
id="x"
|
|
309
|
+
dropdownTriggerId="dtx"
|
|
310
|
+
iconsPosition="before"
|
|
311
|
+
visualFocusIndex={-1}
|
|
312
|
+
menuItemOnClick={(value) => {}}
|
|
313
|
+
onKeyDown={(e) => {}}
|
|
314
|
+
options={optionWithIcon}
|
|
315
|
+
styles={{ width: 240 }}
|
|
316
|
+
/>
|
|
317
|
+
</ExampleContainer>
|
|
318
|
+
<ExampleContainer>
|
|
319
|
+
<Title title="Focused option" theme="light" level={4} />
|
|
320
|
+
<DropdownMenu
|
|
321
|
+
id="x"
|
|
322
|
+
dropdownTriggerId="dtx"
|
|
323
|
+
iconsPosition="before"
|
|
324
|
+
visualFocusIndex={0}
|
|
325
|
+
menuItemOnClick={(value) => {}}
|
|
326
|
+
onKeyDown={(e) => {}}
|
|
327
|
+
options={options}
|
|
328
|
+
styles={{ width: 240 }}
|
|
329
|
+
/>
|
|
330
|
+
</ExampleContainer>
|
|
331
|
+
<Title title="Icons" theme="light" level={3} />
|
|
332
|
+
<ExampleContainer>
|
|
333
|
+
<Title title="Before" theme="light" level={4} />
|
|
334
|
+
<DropdownMenu
|
|
335
|
+
id="x"
|
|
336
|
+
dropdownTriggerId="dtx"
|
|
337
|
+
iconsPosition="before"
|
|
338
|
+
visualFocusIndex={-1}
|
|
339
|
+
menuItemOnClick={(value) => {}}
|
|
340
|
+
onKeyDown={(e) => {}}
|
|
341
|
+
options={optionsIcon}
|
|
342
|
+
styles={{ width: 240 }}
|
|
343
|
+
/>
|
|
344
|
+
<Title title="After" theme="light" level={4} />
|
|
345
|
+
<DropdownMenu
|
|
346
|
+
id="x"
|
|
347
|
+
dropdownTriggerId="dtx"
|
|
348
|
+
iconsPosition="after"
|
|
349
|
+
visualFocusIndex={-1}
|
|
350
|
+
menuItemOnClick={(value) => {}}
|
|
351
|
+
onKeyDown={(e) => {}}
|
|
352
|
+
options={optionsIcon}
|
|
353
|
+
styles={{ width: 240 }}
|
|
354
|
+
/>
|
|
355
|
+
</ExampleContainer>
|
|
356
|
+
</ThemeProvider>
|
|
357
|
+
</>
|
|
358
|
+
);
|
|
359
|
+
};
|
|
205
360
|
|
|
206
|
-
const
|
|
207
|
-
<ExampleContainer
|
|
208
|
-
<Title title="
|
|
209
|
-
<
|
|
361
|
+
const DropdownRightAlignment = () => (
|
|
362
|
+
<ExampleContainer expanded>
|
|
363
|
+
<Title title="Dropdown collisions on the right boundary (right)" theme="light" level={4} />
|
|
364
|
+
<DxcFlex justifyContent="flex-end">
|
|
365
|
+
<DxcDropdown label="Label" options={options} onSelectOption={(value) => {}} />
|
|
366
|
+
</DxcFlex>
|
|
210
367
|
</ExampleContainer>
|
|
211
368
|
);
|
|
212
369
|
|
|
213
|
-
const
|
|
370
|
+
const DropdownCenterAlignment = () => (
|
|
214
371
|
<ExampleContainer expanded>
|
|
215
|
-
<Title title="
|
|
216
|
-
<
|
|
217
|
-
label="
|
|
218
|
-
|
|
219
|
-
onSelectOption={(value) => {}}
|
|
220
|
-
optionsIconPosition="after"
|
|
221
|
-
/>
|
|
372
|
+
<Title title="Dropdown collisions on the right boundary (centered)" theme="light" level={4} />
|
|
373
|
+
<DxcFlex justifyContent="flex-end">
|
|
374
|
+
<DxcDropdown label="Label" options={defaultOptions} onSelectOption={(value) => {}} margin="small" />
|
|
375
|
+
</DxcFlex>
|
|
222
376
|
</ExampleContainer>
|
|
223
377
|
);
|
|
224
378
|
|
|
225
|
-
export const
|
|
226
|
-
|
|
379
|
+
export const Chromatic = Dropdown.bind({});
|
|
380
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
227
381
|
const canvas = within(canvasElement);
|
|
228
|
-
|
|
382
|
+
const buttonList = canvas.getAllByRole("button");
|
|
383
|
+
await userEvent.click(buttonList[buttonList.length - 1]);
|
|
229
384
|
};
|
|
230
385
|
|
|
231
|
-
export const
|
|
232
|
-
|
|
386
|
+
export const OpinionatedTheme = () => (
|
|
387
|
+
<>
|
|
388
|
+
<Title title="Opinionated theme" theme="light" level={2} />
|
|
389
|
+
<ExampleContainer>
|
|
390
|
+
<Title title="Default" theme="light" level={4} />
|
|
391
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
392
|
+
<DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
393
|
+
</HalstackProvider>
|
|
394
|
+
</ExampleContainer>
|
|
395
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
396
|
+
<Title title="Hovered" theme="light" level={4} />
|
|
397
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
398
|
+
<DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
399
|
+
</HalstackProvider>
|
|
400
|
+
</ExampleContainer>
|
|
401
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
402
|
+
<Title title="Actived" theme="light" level={4} />
|
|
403
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
404
|
+
<DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
405
|
+
</HalstackProvider>
|
|
406
|
+
</ExampleContainer>
|
|
407
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
408
|
+
<Title title="Focused" theme="light" level={4} />
|
|
409
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
410
|
+
<DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
411
|
+
</HalstackProvider>
|
|
412
|
+
</ExampleContainer>
|
|
413
|
+
<ExampleContainer>
|
|
414
|
+
<Title title="Disabled" theme="light" level={4} />
|
|
415
|
+
<HalstackProvider theme={opinionatedTheme}>
|
|
416
|
+
<DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} icon={iconSVG} disabled />
|
|
417
|
+
</HalstackProvider>
|
|
418
|
+
</ExampleContainer>
|
|
419
|
+
</>
|
|
420
|
+
);
|
|
421
|
+
|
|
422
|
+
export const DropdownMenuStates = DropdownListStates.bind({});
|
|
423
|
+
DropdownMenuStates.play = async ({ canvasElement }) => {
|
|
233
424
|
const canvas = within(canvasElement);
|
|
234
|
-
await userEvent.click(canvas.
|
|
425
|
+
await userEvent.click(canvas.getAllByRole("button")[0]);
|
|
235
426
|
};
|
|
236
427
|
|
|
237
|
-
export const
|
|
238
|
-
|
|
428
|
+
export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
|
|
429
|
+
DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
|
|
239
430
|
const canvas = within(canvasElement);
|
|
240
431
|
await userEvent.click(canvas.getByRole("button"));
|
|
241
432
|
};
|
|
242
433
|
|
|
243
|
-
export const
|
|
244
|
-
|
|
434
|
+
export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
|
|
435
|
+
DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
|
|
245
436
|
const canvas = within(canvasElement);
|
|
246
437
|
await userEvent.click(canvas.getByRole("button"));
|
|
247
438
|
};
|