@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.
Files changed (92) hide show
  1. package/accordion/Accordion.js +122 -103
  2. package/accordion/Accordion.stories.tsx +1 -2
  3. package/accordion/Accordion.test.js +9 -10
  4. package/accordion/types.d.ts +4 -4
  5. package/accordion-group/AccordionGroup.js +1 -21
  6. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  7. package/accordion-group/AccordionGroup.test.js +20 -45
  8. package/accordion-group/types.d.ts +9 -3
  9. package/alert/Alert.js +1 -1
  10. package/box/Box.js +1 -1
  11. package/bulleted-list/types.d.ts +1 -1
  12. package/button/Button.js +43 -61
  13. package/button/Button.stories.tsx +9 -0
  14. package/button/types.d.ts +7 -7
  15. package/checkbox/Checkbox.js +88 -95
  16. package/checkbox/Checkbox.test.js +93 -16
  17. package/checkbox/types.d.ts +2 -2
  18. package/chip/types.d.ts +1 -1
  19. package/common/variables.js +23 -10
  20. package/date-input/DateInput.js +3 -3
  21. package/dialog/Dialog.js +52 -28
  22. package/dialog/Dialog.stories.tsx +1 -2
  23. package/dialog/Dialog.test.js +34 -4
  24. package/dialog/types.d.ts +2 -2
  25. package/dropdown/Dropdown.d.ts +1 -1
  26. package/dropdown/Dropdown.js +243 -247
  27. package/dropdown/Dropdown.stories.tsx +126 -63
  28. package/dropdown/Dropdown.test.js +510 -108
  29. package/dropdown/DropdownMenu.d.ts +4 -0
  30. package/dropdown/DropdownMenu.js +80 -0
  31. package/dropdown/DropdownMenuItem.d.ts +4 -0
  32. package/dropdown/DropdownMenuItem.js +92 -0
  33. package/dropdown/types.d.ts +25 -5
  34. package/flex/Flex.js +1 -1
  35. package/flex/types.d.ts +1 -1
  36. package/footer/Footer.stories.tsx +8 -1
  37. package/footer/types.d.ts +1 -1
  38. package/header/Header.js +74 -72
  39. package/header/Header.stories.tsx +4 -4
  40. package/header/Icons.js +2 -2
  41. package/header/types.d.ts +2 -2
  42. package/layout/ApplicationLayout.js +3 -3
  43. package/layout/ApplicationLayout.stories.tsx +1 -0
  44. package/link/Link.js +1 -1
  45. package/link/Link.stories.tsx +12 -5
  46. package/link/types.d.ts +1 -1
  47. package/package.json +10 -10
  48. package/progress-bar/ProgressBar.d.ts +2 -2
  49. package/progress-bar/ProgressBar.js +56 -50
  50. package/progress-bar/ProgressBar.stories.jsx +3 -1
  51. package/progress-bar/ProgressBar.test.js +67 -22
  52. package/progress-bar/types.d.ts +3 -4
  53. package/radio-group/RadioGroup.js +11 -13
  54. package/select/Listbox.d.ts +1 -1
  55. package/select/Listbox.js +25 -2
  56. package/select/Select.js +14 -31
  57. package/select/Select.stories.tsx +6 -5
  58. package/select/Select.test.js +63 -50
  59. package/select/types.d.ts +2 -4
  60. package/sidenav/Sidenav.js +15 -3
  61. package/sidenav/types.d.ts +1 -1
  62. package/slider/Slider.js +114 -93
  63. package/slider/Slider.stories.tsx +7 -1
  64. package/slider/Slider.test.js +121 -21
  65. package/slider/types.d.ts +2 -2
  66. package/switch/Switch.d.ts +1 -1
  67. package/switch/Switch.js +111 -55
  68. package/switch/Switch.stories.tsx +8 -30
  69. package/switch/Switch.test.js +122 -8
  70. package/switch/types.d.ts +3 -4
  71. package/tabs/Tab.d.ts +4 -0
  72. package/tabs/Tab.js +135 -0
  73. package/tabs/Tabs.js +360 -104
  74. package/tabs/Tabs.stories.tsx +74 -0
  75. package/tabs/Tabs.test.js +217 -6
  76. package/tabs/types.d.ts +15 -5
  77. package/tabs-nav/NavTabs.js +5 -5
  78. package/tabs-nav/Tab.js +3 -5
  79. package/tabs-nav/types.d.ts +1 -1
  80. package/tag/Tag.js +1 -1
  81. package/tag/types.d.ts +1 -1
  82. package/text-input/Icons.d.ts +8 -0
  83. package/text-input/Icons.js +60 -0
  84. package/text-input/Suggestion.js +7 -5
  85. package/text-input/Suggestions.d.ts +4 -0
  86. package/text-input/Suggestions.js +134 -0
  87. package/text-input/TextInput.js +115 -222
  88. package/text-input/TextInput.stories.tsx +189 -182
  89. package/text-input/TextInput.test.js +163 -162
  90. package/text-input/types.d.ts +17 -3
  91. package/toggle-group/types.d.ts +1 -1
  92. 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="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
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 options: any = [
42
+ const defaultOptions: Option[] = [
32
43
  {
33
44
  value: "1",
34
- label: "Amazon with a very long text",
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
- const icons = [
54
- iconSVG,
55
- iconSVGLarge,
56
- "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png",
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-visible">
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 DropdownWithOptions = () => (
195
- <ExampleContainer expanded>
196
- <Title title="Options" theme="light" level={4} />
197
- <DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
198
- </ExampleContainer>
199
- );
200
-
201
- const DropdownHoverOption = () => (
202
- <ExampleContainer pseudoState="pseudo-hover" expanded>
203
- <Title title="Hovered option" theme="light" level={4} />
204
- <DxcDropdown label="Hovered options" options={option} onSelectOption={(value) => {}} />
205
- </ExampleContainer>
206
- );
207
-
208
- const DropdownActiveOption = () => (
209
- <ExampleContainer pseudoState="pseudo-active" expanded>
210
- <Title title="Actived option" theme="light" level={4} />
211
- <DxcDropdown label="Actived options" options={option} onSelectOption={(value) => {}} />
212
- </ExampleContainer>
213
- );
214
-
215
- const DropdownWithOptionsIconAfter = () => (
216
- <ExampleContainer expanded>
217
- <Title title="Icon after options" theme="light" level={4} />
218
- <DxcDropdown
219
- label="Icon after options"
220
- options={optionsIcon}
221
- onSelectOption={(value) => {}}
222
- optionsIconPosition="after"
223
- />
224
- </ExampleContainer>
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 DropdownOptions = DropdownWithOptions.bind({});
228
- DropdownOptions.play = async ({ canvasElement }) => {
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
  };