@dxc-technology/halstack-react 6.0.0 → 6.2.0
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/accordion/Accordion.js +122 -103
- package/accordion/Accordion.stories.tsx +1 -2
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +4 -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 +9 -3
- package/alert/Alert.js +1 -1
- package/box/Box.js +1 -1
- package/bulleted-list/types.d.ts +1 -1
- package/button/Button.js +43 -61
- package/button/Button.stories.tsx +9 -0
- package/button/types.d.ts +7 -7
- package/checkbox/Checkbox.js +88 -95
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +2 -2
- package/chip/types.d.ts +1 -1
- package/common/variables.js +23 -10
- package/date-input/DateInput.js +3 -3
- package/dialog/Dialog.js +52 -28
- package/dialog/Dialog.stories.tsx +1 -2
- package/dialog/Dialog.test.js +34 -4
- package/dialog/types.d.ts +2 -2
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +243 -247
- package/dropdown/Dropdown.stories.tsx +126 -63
- package/dropdown/Dropdown.test.js +510 -108
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +80 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +92 -0
- package/dropdown/types.d.ts +25 -5
- package/flex/Flex.js +1 -1
- package/flex/types.d.ts +1 -1
- package/footer/Footer.stories.tsx +8 -1
- package/footer/types.d.ts +1 -1
- package/header/Header.js +74 -72
- package/header/Header.stories.tsx +4 -4
- package/header/Icons.js +2 -2
- package/header/types.d.ts +2 -2
- package/layout/ApplicationLayout.js +3 -3
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/link/Link.js +1 -1
- package/link/Link.stories.tsx +12 -5
- package/link/types.d.ts +1 -1
- package/package.json +10 -10
- package/progress-bar/ProgressBar.d.ts +2 -2
- package/progress-bar/ProgressBar.js +56 -50
- package/progress-bar/ProgressBar.stories.jsx +3 -1
- package/progress-bar/ProgressBar.test.js +67 -22
- package/progress-bar/types.d.ts +3 -4
- package/radio-group/RadioGroup.js +11 -13
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +25 -2
- package/select/Select.js +14 -31
- package/select/Select.stories.tsx +6 -5
- package/select/Select.test.js +63 -50
- package/select/types.d.ts +2 -4
- package/sidenav/Sidenav.js +15 -3
- package/sidenav/types.d.ts +1 -1
- package/slider/Slider.js +114 -93
- package/slider/Slider.stories.tsx +7 -1
- package/slider/Slider.test.js +121 -21
- package/slider/types.d.ts +2 -2
- package/switch/Switch.d.ts +1 -1
- package/switch/Switch.js +111 -55
- package/switch/Switch.stories.tsx +8 -30
- package/switch/Switch.test.js +122 -8
- package/switch/types.d.ts +3 -4
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +135 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +74 -0
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +15 -5
- package/tabs-nav/NavTabs.js +5 -5
- package/tabs-nav/Tab.js +3 -5
- package/tabs-nav/types.d.ts +1 -1
- package/tag/Tag.js +1 -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 +7 -5
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +115 -222
- package/text-input/TextInput.stories.tsx +189 -182
- package/text-input/TextInput.test.js +163 -162
- package/text-input/types.d.ts +17 -3
- package/toggle-group/types.d.ts +1 -1
- package/wizard/types.d.ts +1 -1
|
@@ -3,21 +3,30 @@ 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 DxcCheckbox from "../checkbox/Checkbox";
|
|
8
|
+
import DxcTextInput from "../text-input/TextInput";
|
|
9
|
+
import { Option } from "./types";
|
|
10
|
+
|
|
6
11
|
|
|
7
12
|
export default {
|
|
8
13
|
title: "Dropdown",
|
|
9
14
|
component: DxcDropdown,
|
|
10
15
|
};
|
|
11
16
|
|
|
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
|
+
);
|
|
12
22
|
const iconSVG = (
|
|
13
23
|
<svg viewBox="0 0 24 24" fill="currentColor">
|
|
14
24
|
<path d="M0 0h24v24H0z" fill="none" />
|
|
15
25
|
<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
26
|
</svg>
|
|
17
27
|
);
|
|
18
|
-
|
|
19
28
|
const iconSVGLarge = (
|
|
20
|
-
<svg enableBackground="new 0 0 24 24" height="
|
|
29
|
+
<svg enableBackground="new 0 0 24 24" height="48" viewBox="0 0 24 24" width="48" fill="currentColor">
|
|
21
30
|
<g>
|
|
22
31
|
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
23
32
|
<path d="M0,0h24v24H0V0z" fill="none" />
|
|
@@ -27,11 +36,13 @@ const iconSVGLarge = (
|
|
|
27
36
|
</g>
|
|
28
37
|
</svg>
|
|
29
38
|
);
|
|
39
|
+
const iconUrl = "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png";
|
|
40
|
+
const icons = [iconSVG, iconSVGLarge, iconUrl];
|
|
30
41
|
|
|
31
|
-
const
|
|
42
|
+
const defaultOptions: Option[] = [
|
|
32
43
|
{
|
|
33
44
|
value: "1",
|
|
34
|
-
label: "Amazon
|
|
45
|
+
label: "Amazon",
|
|
35
46
|
},
|
|
36
47
|
{
|
|
37
48
|
value: "2",
|
|
@@ -41,19 +52,35 @@ const options: any = [
|
|
|
41
52
|
value: "3",
|
|
42
53
|
label: "Apple",
|
|
43
54
|
},
|
|
55
|
+
{
|
|
56
|
+
value: "4",
|
|
57
|
+
label: "Wallapop",
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
value: "5",
|
|
61
|
+
label: "Aliexpress",
|
|
62
|
+
},
|
|
44
63
|
];
|
|
45
|
-
|
|
46
|
-
const option: any = [
|
|
64
|
+
const options: Option[] = [
|
|
47
65
|
{
|
|
48
66
|
value: "1",
|
|
67
|
+
label: "Amazon with a very long text",
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
value: "2",
|
|
49
71
|
label: "Ebay",
|
|
50
72
|
},
|
|
73
|
+
{
|
|
74
|
+
value: "3",
|
|
75
|
+
label: "Apple",
|
|
76
|
+
},
|
|
51
77
|
];
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
78
|
+
const optionWithIcon: Option[] = [
|
|
79
|
+
{
|
|
80
|
+
value: "1",
|
|
81
|
+
label: "Ebay",
|
|
82
|
+
icon: iconUrl,
|
|
83
|
+
},
|
|
57
84
|
];
|
|
58
85
|
|
|
59
86
|
const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
|
|
@@ -68,7 +95,7 @@ export const Chromatic = () => (
|
|
|
68
95
|
<Title title="Hovered" theme="light" level={4} />
|
|
69
96
|
<DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
|
|
70
97
|
</ExampleContainer>
|
|
71
|
-
<ExampleContainer pseudoState="pseudo-focus
|
|
98
|
+
<ExampleContainer pseudoState="pseudo-focus">
|
|
72
99
|
<Title title="Focused" theme="light" level={4} />
|
|
73
100
|
<DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
|
|
74
101
|
</ExampleContainer>
|
|
@@ -102,6 +129,10 @@ export const Chromatic = () => (
|
|
|
102
129
|
<Title title="Only icon" theme="light" level={4} />
|
|
103
130
|
<DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
|
|
104
131
|
</ExampleContainer>
|
|
132
|
+
<ExampleContainer>
|
|
133
|
+
<Title title="Only icon without caret" theme="light" level={4} />
|
|
134
|
+
<DxcDropdown options={options} onSelectOption={(value) => {}} icon={hamburguerIcon} caretHidden />
|
|
135
|
+
</ExampleContainer>
|
|
105
136
|
<ExampleContainer>
|
|
106
137
|
<Title title="Large icon" theme="light" level={4} />
|
|
107
138
|
<DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
|
|
@@ -191,59 +222,91 @@ export const Chromatic = () => (
|
|
|
191
222
|
</>
|
|
192
223
|
);
|
|
193
224
|
|
|
194
|
-
const
|
|
195
|
-
|
|
196
|
-
<Title title="
|
|
197
|
-
<
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
<
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
+
const DropdownListStates = () => (
|
|
226
|
+
<>
|
|
227
|
+
<Title title="Dropdown Menu" theme="light" level={2} />
|
|
228
|
+
<Title title="Default with opened menu" theme="light" level={3} />
|
|
229
|
+
<ExampleContainer>
|
|
230
|
+
<div style={{ display: "flex", gap: "30px", flexDirection: "column", marginBottom: "80px" }}>
|
|
231
|
+
<DxcDropdown label="Select a platform" options={defaultOptions} onSelectOption={(option) => {}} size="medium" />
|
|
232
|
+
<DxcTextInput label="Your name" onChange={() => {}} />
|
|
233
|
+
<DxcCheckbox
|
|
234
|
+
label="You understand the selection and give your consent"
|
|
235
|
+
onChange={() => {}}
|
|
236
|
+
labelPosition="after"
|
|
237
|
+
/>
|
|
238
|
+
</div>
|
|
239
|
+
</ExampleContainer>
|
|
240
|
+
<Title title="Option states" theme="light" level={3} />
|
|
241
|
+
<ExampleContainer pseudoState="pseudo-hover">
|
|
242
|
+
<Title title="Hovered option" theme="light" level={4} />
|
|
243
|
+
<DropdownMenu
|
|
244
|
+
id="x"
|
|
245
|
+
dropdownId="dX"
|
|
246
|
+
iconsPosition="before"
|
|
247
|
+
visualFocusIndex={-1}
|
|
248
|
+
optionOnClick={(option) => {}}
|
|
249
|
+
onKeyDown={(e) => {}}
|
|
250
|
+
options={optionWithIcon}
|
|
251
|
+
styles={{ width: 240 }}
|
|
252
|
+
/>
|
|
253
|
+
</ExampleContainer>
|
|
254
|
+
<ExampleContainer pseudoState="pseudo-active">
|
|
255
|
+
<Title title="Active option" theme="light" level={4} />
|
|
256
|
+
<DropdownMenu
|
|
257
|
+
id="x"
|
|
258
|
+
dropdownId="dX"
|
|
259
|
+
iconsPosition="before"
|
|
260
|
+
visualFocusIndex={-1}
|
|
261
|
+
optionOnClick={(option) => {}}
|
|
262
|
+
onKeyDown={(e) => {}}
|
|
263
|
+
options={optionWithIcon}
|
|
264
|
+
styles={{ width: 240 }}
|
|
265
|
+
/>
|
|
266
|
+
</ExampleContainer>
|
|
267
|
+
<ExampleContainer>
|
|
268
|
+
<Title title="Focused option" theme="light" level={4} />
|
|
269
|
+
<DropdownMenu
|
|
270
|
+
id="x"
|
|
271
|
+
dropdownId="dX"
|
|
272
|
+
iconsPosition="before"
|
|
273
|
+
visualFocusIndex={0}
|
|
274
|
+
optionOnClick={(option) => {}}
|
|
275
|
+
onKeyDown={(e) => {}}
|
|
276
|
+
options={options}
|
|
277
|
+
styles={{ width: 240 }}
|
|
278
|
+
/>
|
|
279
|
+
</ExampleContainer>
|
|
280
|
+
<Title title="Icons" theme="light" level={3} />
|
|
281
|
+
<ExampleContainer>
|
|
282
|
+
<Title title="Before" theme="light" level={4} />
|
|
283
|
+
<DropdownMenu
|
|
284
|
+
id="x"
|
|
285
|
+
dropdownId="dX"
|
|
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
|
+
/>
|
|
304
|
+
</ExampleContainer>
|
|
305
|
+
</>
|
|
225
306
|
);
|
|
226
307
|
|
|
227
|
-
export const
|
|
228
|
-
|
|
229
|
-
const canvas = within(canvasElement);
|
|
230
|
-
await userEvent.click(canvas.getByRole("button"));
|
|
231
|
-
};
|
|
232
|
-
|
|
233
|
-
export const DropdownHoveredOption = DropdownHoverOption.bind({});
|
|
234
|
-
DropdownHoveredOption.play = async ({ canvasElement }) => {
|
|
235
|
-
const canvas = within(canvasElement);
|
|
236
|
-
await userEvent.click(canvas.getByRole("button"));
|
|
237
|
-
};
|
|
238
|
-
|
|
239
|
-
export const DropdownActivedOption = DropdownActiveOption.bind({});
|
|
240
|
-
DropdownActivedOption.play = async ({ canvasElement }) => {
|
|
241
|
-
const canvas = within(canvasElement);
|
|
242
|
-
await userEvent.click(canvas.getByRole("button"));
|
|
243
|
-
};
|
|
244
|
-
|
|
245
|
-
export const DropdownOptionsIconAfter = DropdownWithOptionsIconAfter.bind({});
|
|
246
|
-
DropdownOptionsIconAfter.play = async ({ canvasElement }) => {
|
|
308
|
+
export const DropdownMenuStates = DropdownListStates.bind({});
|
|
309
|
+
DropdownMenuStates.play = async ({ canvasElement }) => {
|
|
247
310
|
const canvas = within(canvasElement);
|
|
248
311
|
await userEvent.click(canvas.getByRole("button"));
|
|
249
312
|
};
|