@dxc-technology/halstack-react 0.0.0-dcd93c4 → 0.0.0-dcee34a
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/HalstackContext.js +98 -50
- package/accordion/Accordion.js +117 -104
- package/accordion/Accordion.stories.tsx +103 -15
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +5 -4
- package/accordion-group/AccordionGroup.js +1 -21
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +20 -45
- package/accordion-group/types.d.ts +10 -3
- package/alert/Alert.js +1 -1
- package/alert/Alert.stories.tsx +28 -0
- package/bleed/Bleed.stories.tsx +63 -63
- package/box/Box.js +1 -1
- package/box/Box.stories.tsx +15 -0
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +123 -0
- package/bulleted-list/BulletedList.stories.tsx +200 -0
- package/bulleted-list/types.d.ts +11 -0
- package/button/Button.js +50 -70
- package/button/Button.stories.tsx +159 -8
- package/button/types.d.ts +7 -7
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +92 -99
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +6 -2
- package/chip/Chip.js +16 -22
- package/chip/Chip.stories.tsx +96 -9
- package/chip/types.d.ts +1 -1
- package/common/variables.js +328 -260
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +134 -237
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +494 -138
- 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 +51 -0
- package/dialog/Dialog.js +50 -28
- package/dialog/Dialog.stories.tsx +99 -22
- package/dialog/Dialog.test.js +34 -4
- package/dialog/types.d.ts +3 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +246 -249
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +504 -108
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +70 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +81 -0
- package/dropdown/types.d.ts +25 -5
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +177 -219
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +53 -12
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +38 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +69 -0
- package/flex/Flex.stories.tsx +103 -0
- package/flex/types.d.ts +32 -0
- package/footer/Footer.stories.tsx +99 -1
- package/footer/types.d.ts +2 -1
- package/header/Header.js +87 -87
- package/header/Header.stories.tsx +152 -9
- package/header/Icons.js +2 -2
- package/header/types.d.ts +3 -2
- package/inset/Inset.stories.tsx +4 -4
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +36 -64
- package/layout/ApplicationLayout.stories.tsx +80 -44
- package/layout/types.d.ts +17 -27
- package/link/Link.js +2 -2
- package/link/Link.stories.tsx +72 -5
- package/link/types.d.ts +1 -1
- package/main.d.ts +6 -10
- package/main.js +28 -60
- package/{tabs-nav → nav-tabs}/NavTabs.js +6 -6
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/Tab.js +37 -20
- package/{tabs-nav → nav-tabs}/types.d.ts +1 -1
- package/number-input/NumberInput.test.js +43 -7
- package/package.json +16 -21
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +6 -12
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +18 -11
- package/paragraph/Paragraph.d.ts +6 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.test.js +13 -12
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +59 -53
- package/progress-bar/ProgressBar.stories.jsx +38 -3
- package/progress-bar/ProgressBar.test.js +67 -22
- package/progress-bar/types.d.ts +3 -4
- package/quick-nav/QuickNav.js +18 -17
- package/quick-nav/QuickNav.stories.tsx +145 -26
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +24 -24
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +123 -96
- package/radio-group/types.d.ts +2 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +48 -107
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +40 -63
- package/resultsetTable/types.d.ts +2 -2
- package/select/Listbox.js +4 -10
- package/select/Option.js +11 -24
- package/select/Select.js +54 -50
- package/select/Select.stories.tsx +494 -149
- package/select/Select.test.js +338 -272
- package/select/types.d.ts +3 -5
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +174 -55
- package/sidenav/Sidenav.stories.tsx +249 -149
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +50 -27
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +120 -95
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +121 -21
- package/slider/types.d.ts +6 -2
- package/spinner/Spinner.js +2 -2
- package/spinner/Spinner.stories.jsx +27 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +135 -68
- package/switch/Switch.stories.tsx +41 -30
- package/switch/Switch.test.js +144 -17
- package/switch/types.d.ts +6 -2
- package/table/Table.js +1 -1
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +133 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +15 -5
- package/tag/Tag.js +1 -1
- package/tag/Tag.stories.tsx +14 -1
- package/tag/types.d.ts +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +38 -9
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +195 -292
- package/text-input/TextInput.stories.tsx +280 -185
- package/text-input/TextInput.test.js +737 -725
- package/text-input/types.d.ts +22 -3
- package/textarea/Textarea.stories.jsx +60 -1
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/types.d.ts +1 -1
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +131 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/wizard/Wizard.js +9 -16
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/types.d.ts +5 -4
- package/common/RequiredComponent.js +0 -32
- package/inline/Inline.d.ts +0 -4
- package/inline/Inline.js +0 -60
- package/inline/Inline.stories.tsx +0 -319
- package/inline/types.d.ts +0 -36
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -89
- package/list/types.d.ts +0 -7
- 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/stack/Stack.d.ts +0 -4
- package/stack/Stack.js +0 -56
- package/stack/Stack.stories.tsx +0 -263
- package/stack/types.d.ts +0 -32
- package/tabs-nav/types.js +0 -5
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- /package/{inline → bulleted-list}/types.js +0 -0
- /package/{list → flex}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.test.js +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{row → nav-tabs}/types.js +0 -0
- /package/{stack → typography}/types.js +0 -0
|
@@ -3,35 +3,41 @@ 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
|
|
|
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
|
+
);
|
|
12
23
|
const iconSVG = (
|
|
13
|
-
<svg viewBox="0 0 24 24" fill="currentColor">
|
|
24
|
+
<svg viewBox="0 0 24 24" height="24" width="24" fill="currentColor">
|
|
14
25
|
<path d="M0 0h24v24H0z" fill="none" />
|
|
15
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" />
|
|
16
27
|
</svg>
|
|
17
28
|
);
|
|
18
|
-
|
|
19
29
|
const iconSVGLarge = (
|
|
20
|
-
<svg
|
|
21
|
-
<
|
|
22
|
-
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
23
|
-
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
24
|
-
</g>
|
|
25
|
-
<g>
|
|
26
|
-
<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" />
|
|
27
|
-
</g>
|
|
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" />
|
|
28
32
|
</svg>
|
|
29
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];
|
|
30
36
|
|
|
31
|
-
const
|
|
37
|
+
const defaultOptions: Option[] = [
|
|
32
38
|
{
|
|
33
39
|
value: "1",
|
|
34
|
-
label: "Amazon
|
|
40
|
+
label: "Amazon",
|
|
35
41
|
},
|
|
36
42
|
{
|
|
37
43
|
value: "2",
|
|
@@ -41,24 +47,60 @@ const options: any = [
|
|
|
41
47
|
value: "3",
|
|
42
48
|
label: "Apple",
|
|
43
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
|
+
},
|
|
44
70
|
];
|
|
45
|
-
|
|
46
|
-
const option: any = [
|
|
71
|
+
const options: Option[] = [
|
|
47
72
|
{
|
|
48
73
|
value: "1",
|
|
74
|
+
label: "Amazon with a very long text",
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
value: "2",
|
|
49
78
|
label: "Ebay",
|
|
50
79
|
},
|
|
80
|
+
{
|
|
81
|
+
value: "3",
|
|
82
|
+
label: "Apple",
|
|
83
|
+
},
|
|
51
84
|
];
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
85
|
+
const optionWithIcon: Option[] = [
|
|
86
|
+
{
|
|
87
|
+
value: "1",
|
|
88
|
+
label: "Ebay",
|
|
89
|
+
icon: iconUrl,
|
|
90
|
+
},
|
|
57
91
|
];
|
|
58
92
|
|
|
59
93
|
const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
|
|
60
94
|
|
|
61
|
-
|
|
95
|
+
const opinionatedTheme = {
|
|
96
|
+
dropdown: {
|
|
97
|
+
baseColor: "#ffffff",
|
|
98
|
+
fontColor: "#000000",
|
|
99
|
+
optionFontColor: "#000000",
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
const Dropdown = () => (
|
|
62
104
|
<>
|
|
63
105
|
<ExampleContainer>
|
|
64
106
|
<Title title="Default" theme="light" level={4} />
|
|
@@ -68,7 +110,7 @@ export const Chromatic = () => (
|
|
|
68
110
|
<Title title="Hovered" theme="light" level={4} />
|
|
69
111
|
<DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
|
|
70
112
|
</ExampleContainer>
|
|
71
|
-
<ExampleContainer pseudoState="pseudo-focus
|
|
113
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
72
114
|
<Title title="Focused" theme="light" level={4} />
|
|
73
115
|
<DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
|
|
74
116
|
</ExampleContainer>
|
|
@@ -103,9 +145,22 @@ export const Chromatic = () => (
|
|
|
103
145
|
<DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
104
146
|
</ExampleContainer>
|
|
105
147
|
<ExampleContainer>
|
|
106
|
-
<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} />
|
|
107
153
|
<DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
|
|
108
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>
|
|
109
164
|
<ExampleContainer>
|
|
110
165
|
<Title title="Disabled with icon" theme="light" level={4} />
|
|
111
166
|
<DxcDropdown
|
|
@@ -188,62 +243,196 @@ export const Chromatic = () => (
|
|
|
188
243
|
size="fillParent"
|
|
189
244
|
/>
|
|
190
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>
|
|
191
250
|
</>
|
|
192
251
|
);
|
|
193
252
|
|
|
194
|
-
const
|
|
195
|
-
|
|
196
|
-
<Title title="Options" theme="light" level={4} />
|
|
197
|
-
<DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
|
|
198
|
-
</ExampleContainer>
|
|
199
|
-
);
|
|
253
|
+
const DropdownListStates = () => {
|
|
254
|
+
const colorsTheme: any = useTheme();
|
|
200
255
|
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
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
|
+
};
|
|
207
360
|
|
|
208
|
-
const
|
|
209
|
-
<ExampleContainer
|
|
210
|
-
<Title title="
|
|
211
|
-
<
|
|
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>
|
|
212
367
|
</ExampleContainer>
|
|
213
368
|
);
|
|
214
369
|
|
|
215
|
-
const
|
|
370
|
+
const DropdownCenterAlignment = () => (
|
|
216
371
|
<ExampleContainer expanded>
|
|
217
|
-
<Title title="
|
|
218
|
-
<
|
|
219
|
-
label="
|
|
220
|
-
|
|
221
|
-
onSelectOption={(value) => {}}
|
|
222
|
-
optionsIconPosition="after"
|
|
223
|
-
/>
|
|
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>
|
|
224
376
|
</ExampleContainer>
|
|
225
377
|
);
|
|
226
378
|
|
|
227
|
-
export const
|
|
228
|
-
|
|
379
|
+
export const Chromatic = Dropdown.bind({});
|
|
380
|
+
Chromatic.play = async ({ canvasElement }) => {
|
|
229
381
|
const canvas = within(canvasElement);
|
|
230
|
-
|
|
382
|
+
const buttonList = canvas.getAllByRole("button");
|
|
383
|
+
await userEvent.click(buttonList[buttonList.length - 1]);
|
|
231
384
|
};
|
|
232
385
|
|
|
233
|
-
export const
|
|
234
|
-
|
|
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 }) => {
|
|
235
424
|
const canvas = within(canvasElement);
|
|
236
|
-
await userEvent.click(canvas.
|
|
425
|
+
await userEvent.click(canvas.getAllByRole("button")[0]);
|
|
237
426
|
};
|
|
238
427
|
|
|
239
|
-
export const
|
|
240
|
-
|
|
428
|
+
export const DropdownMenuAlignedRight = DropdownRightAlignment.bind({});
|
|
429
|
+
DropdownMenuAlignedRight.play = async ({ canvasElement }) => {
|
|
241
430
|
const canvas = within(canvasElement);
|
|
242
431
|
await userEvent.click(canvas.getByRole("button"));
|
|
243
432
|
};
|
|
244
433
|
|
|
245
|
-
export const
|
|
246
|
-
|
|
434
|
+
export const DropdownMenuAlignedCenter = DropdownCenterAlignment.bind({});
|
|
435
|
+
DropdownMenuAlignedCenter.play = async ({ canvasElement }) => {
|
|
247
436
|
const canvas = within(canvasElement);
|
|
248
437
|
await userEvent.click(canvas.getByRole("button"));
|
|
249
438
|
};
|