@dxc-technology/halstack-react 0.0.0-b92e300 → 0.0.0-b98c25c

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 (335) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +124 -137
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -37
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +17 -10
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +29 -65
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +44 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -87
  41. package/button/Button.stories.tsx +232 -242
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +14 -18
  44. package/card/Card.js +26 -30
  45. package/card/Card.stories.tsx +201 -0
  46. package/card/Card.test.js +50 -0
  47. package/card/ice-cream.jpg +0 -0
  48. package/card/types.d.ts +5 -6
  49. package/checkbox/Checkbox.d.ts +1 -1
  50. package/checkbox/Checkbox.js +104 -108
  51. package/checkbox/Checkbox.stories.tsx +188 -0
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +11 -7
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +16 -76
  56. package/chip/Chip.stories.tsx +119 -0
  57. package/chip/Chip.test.js +56 -0
  58. package/chip/types.d.ts +45 -0
  59. package/chip/types.js +5 -0
  60. package/common/variables.js +319 -380
  61. package/date-input/DateInput.js +66 -55
  62. package/date-input/DateInput.stories.tsx +138 -0
  63. package/date-input/DateInput.test.js +479 -0
  64. package/date-input/types.d.ts +16 -9
  65. package/dialog/Dialog.d.ts +4 -0
  66. package/dialog/Dialog.js +52 -74
  67. package/dialog/Dialog.stories.tsx +267 -0
  68. package/dialog/Dialog.test.js +70 -0
  69. package/dialog/types.d.ts +44 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +4 -0
  72. package/dropdown/Dropdown.js +240 -303
  73. package/dropdown/Dropdown.stories.tsx +312 -0
  74. package/dropdown/Dropdown.test.js +591 -0
  75. package/dropdown/DropdownMenu.d.ts +4 -0
  76. package/dropdown/DropdownMenu.js +80 -0
  77. package/dropdown/DropdownMenuItem.d.ts +4 -0
  78. package/dropdown/DropdownMenuItem.js +92 -0
  79. package/dropdown/types.d.ts +100 -0
  80. package/dropdown/types.js +5 -0
  81. package/file-input/FileInput.d.ts +4 -0
  82. package/file-input/FileInput.js +172 -111
  83. package/file-input/FileInput.stories.tsx +507 -0
  84. package/file-input/FileInput.test.js +457 -0
  85. package/file-input/FileItem.d.ts +14 -0
  86. package/file-input/FileItem.js +16 -23
  87. package/file-input/types.d.ts +112 -0
  88. package/file-input/types.js +5 -0
  89. package/flex/Flex.d.ts +4 -0
  90. package/flex/Flex.js +57 -0
  91. package/flex/Flex.stories.tsx +103 -0
  92. package/flex/types.d.ts +21 -0
  93. package/flex/types.js +5 -0
  94. package/footer/Footer.d.ts +4 -0
  95. package/footer/Footer.js +36 -148
  96. package/footer/Footer.stories.tsx +137 -0
  97. package/footer/Footer.test.js +109 -0
  98. package/footer/Icons.d.ts +2 -0
  99. package/footer/Icons.js +4 -4
  100. package/footer/types.d.ts +66 -0
  101. package/footer/types.js +5 -0
  102. package/header/Header.d.ts +7 -0
  103. package/header/Header.js +119 -140
  104. package/header/Header.stories.tsx +172 -0
  105. package/header/Header.test.js +79 -0
  106. package/header/Icons.d.ts +2 -0
  107. package/header/Icons.js +4 -29
  108. package/header/types.d.ts +48 -0
  109. package/header/types.js +5 -0
  110. package/heading/Heading.d.ts +4 -0
  111. package/heading/Heading.js +7 -24
  112. package/heading/Heading.stories.tsx +54 -0
  113. package/heading/Heading.test.js +186 -0
  114. package/heading/types.d.ts +33 -0
  115. package/heading/types.js +5 -0
  116. package/inset/Inset.d.ts +3 -0
  117. package/inset/Inset.js +51 -0
  118. package/inset/Inset.stories.tsx +229 -0
  119. package/inset/types.d.ts +37 -0
  120. package/inset/types.js +5 -0
  121. package/layout/ApplicationLayout.d.ts +20 -0
  122. package/layout/ApplicationLayout.js +71 -135
  123. package/layout/ApplicationLayout.stories.tsx +162 -0
  124. package/layout/Icons.d.ts +5 -0
  125. package/layout/Icons.js +13 -2
  126. package/layout/SidenavContext.d.ts +5 -0
  127. package/layout/SidenavContext.js +19 -0
  128. package/layout/types.d.ts +42 -0
  129. package/layout/types.js +5 -0
  130. package/link/Link.d.ts +4 -0
  131. package/link/Link.js +60 -107
  132. package/link/Link.stories.tsx +193 -0
  133. package/link/Link.test.js +83 -0
  134. package/link/types.d.ts +54 -0
  135. package/link/types.js +5 -0
  136. package/main.d.ts +12 -12
  137. package/main.js +64 -58
  138. package/number-input/NumberInput.d.ts +4 -0
  139. package/number-input/NumberInput.js +16 -68
  140. package/number-input/NumberInput.stories.tsx +115 -0
  141. package/number-input/NumberInput.test.js +506 -0
  142. package/number-input/NumberInputContext.d.ts +4 -0
  143. package/number-input/NumberInputContext.js +5 -2
  144. package/number-input/numberInputContextTypes.d.ts +19 -0
  145. package/number-input/numberInputContextTypes.js +5 -0
  146. package/number-input/types.d.ts +124 -0
  147. package/number-input/types.js +5 -0
  148. package/package.json +16 -12
  149. package/paginator/Paginator.js +19 -46
  150. package/paginator/Paginator.stories.tsx +63 -0
  151. package/paginator/Paginator.test.js +308 -0
  152. package/paragraph/Paragraph.d.ts +6 -0
  153. package/paragraph/Paragraph.js +38 -0
  154. package/paragraph/Paragraph.stories.tsx +44 -0
  155. package/password-input/PasswordInput.d.ts +4 -0
  156. package/password-input/PasswordInput.js +22 -55
  157. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  158. package/password-input/PasswordInput.test.js +180 -0
  159. package/password-input/types.d.ts +110 -0
  160. package/password-input/types.js +5 -0
  161. package/progress-bar/ProgressBar.d.ts +2 -2
  162. package/progress-bar/ProgressBar.js +60 -54
  163. package/progress-bar/ProgressBar.stories.jsx +60 -0
  164. package/progress-bar/ProgressBar.test.js +110 -0
  165. package/progress-bar/types.d.ts +3 -4
  166. package/quick-nav/QuickNav.d.ts +4 -0
  167. package/quick-nav/QuickNav.js +115 -0
  168. package/quick-nav/QuickNav.stories.tsx +300 -0
  169. package/quick-nav/types.d.ts +21 -0
  170. package/quick-nav/types.js +5 -0
  171. package/radio-group/Radio.d.ts +4 -0
  172. package/radio-group/Radio.js +156 -0
  173. package/radio-group/RadioGroup.d.ts +4 -0
  174. package/radio-group/RadioGroup.js +279 -0
  175. package/radio-group/RadioGroup.stories.tsx +101 -0
  176. package/radio-group/RadioGroup.test.js +665 -0
  177. package/radio-group/types.d.ts +114 -0
  178. package/radio-group/types.js +5 -0
  179. package/resultsetTable/ResultsetTable.d.ts +4 -0
  180. package/resultsetTable/ResultsetTable.js +9 -29
  181. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  182. package/resultsetTable/ResultsetTable.test.js +348 -0
  183. package/resultsetTable/types.d.ts +67 -0
  184. package/resultsetTable/types.js +5 -0
  185. package/select/Icons.d.ts +10 -0
  186. package/select/Icons.js +93 -0
  187. package/select/Listbox.d.ts +4 -0
  188. package/select/Listbox.js +198 -0
  189. package/select/Option.d.ts +4 -0
  190. package/select/Option.js +110 -0
  191. package/select/Select.d.ts +4 -0
  192. package/select/Select.js +158 -380
  193. package/select/Select.stories.tsx +627 -0
  194. package/select/Select.test.js +2175 -0
  195. package/select/types.d.ts +210 -0
  196. package/select/types.js +5 -0
  197. package/sidenav/Sidenav.d.ts +10 -0
  198. package/sidenav/Sidenav.js +186 -63
  199. package/sidenav/Sidenav.stories.tsx +180 -0
  200. package/sidenav/Sidenav.test.js +44 -0
  201. package/sidenav/types.d.ts +73 -0
  202. package/sidenav/types.js +5 -0
  203. package/slider/Slider.d.ts +1 -1
  204. package/slider/Slider.js +145 -109
  205. package/slider/Slider.stories.tsx +183 -0
  206. package/slider/Slider.test.js +250 -0
  207. package/slider/types.d.ts +8 -9
  208. package/spinner/Spinner.d.ts +4 -0
  209. package/spinner/Spinner.js +9 -26
  210. package/spinner/Spinner.stories.jsx +103 -0
  211. package/spinner/Spinner.test.js +64 -0
  212. package/spinner/types.d.ts +32 -0
  213. package/spinner/types.js +5 -0
  214. package/switch/Switch.d.ts +2 -2
  215. package/switch/Switch.js +149 -67
  216. package/switch/Switch.stories.tsx +138 -0
  217. package/switch/Switch.test.js +225 -0
  218. package/switch/types.d.ts +9 -6
  219. package/table/Table.d.ts +4 -0
  220. package/table/Table.js +3 -3
  221. package/table/Table.stories.jsx +277 -0
  222. package/table/Table.test.js +26 -0
  223. package/table/types.d.ts +21 -0
  224. package/table/types.js +5 -0
  225. package/tabs/Tab.d.ts +4 -0
  226. package/tabs/Tab.js +135 -0
  227. package/tabs/Tabs.d.ts +4 -0
  228. package/tabs/Tabs.js +364 -156
  229. package/tabs/Tabs.stories.tsx +186 -0
  230. package/tabs/Tabs.test.js +351 -0
  231. package/tabs/types.d.ts +92 -0
  232. package/tabs/types.js +5 -0
  233. package/tabs-nav/NavTabs.d.ts +8 -0
  234. package/tabs-nav/NavTabs.js +125 -0
  235. package/tabs-nav/NavTabs.stories.tsx +170 -0
  236. package/tabs-nav/NavTabs.test.js +82 -0
  237. package/tabs-nav/Tab.d.ts +4 -0
  238. package/tabs-nav/Tab.js +130 -0
  239. package/tabs-nav/types.d.ts +53 -0
  240. package/tabs-nav/types.js +5 -0
  241. package/tag/Tag.d.ts +4 -0
  242. package/tag/Tag.js +35 -60
  243. package/tag/Tag.stories.tsx +142 -0
  244. package/tag/Tag.test.js +60 -0
  245. package/tag/types.d.ts +69 -0
  246. package/tag/types.js +5 -0
  247. package/text-input/Icons.d.ts +8 -0
  248. package/text-input/Icons.js +60 -0
  249. package/text-input/Suggestion.d.ts +4 -0
  250. package/text-input/Suggestion.js +57 -0
  251. package/text-input/Suggestions.d.ts +4 -0
  252. package/text-input/Suggestions.js +134 -0
  253. package/text-input/TextInput.d.ts +4 -0
  254. package/text-input/TextInput.js +166 -328
  255. package/text-input/TextInput.stories.tsx +481 -0
  256. package/text-input/TextInput.test.js +1713 -0
  257. package/text-input/types.d.ts +192 -0
  258. package/text-input/types.js +5 -0
  259. package/textarea/Textarea.d.ts +4 -0
  260. package/textarea/Textarea.js +39 -79
  261. package/textarea/Textarea.stories.jsx +37 -15
  262. package/textarea/Textarea.test.js +437 -0
  263. package/textarea/types.d.ts +137 -0
  264. package/textarea/types.js +5 -0
  265. package/toggle-group/ToggleGroup.d.ts +4 -0
  266. package/toggle-group/ToggleGroup.js +18 -46
  267. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  268. package/toggle-group/ToggleGroup.test.js +156 -0
  269. package/toggle-group/types.d.ts +105 -0
  270. package/toggle-group/types.js +5 -0
  271. package/typography/Typography.d.ts +4 -0
  272. package/typography/Typography.js +131 -0
  273. package/typography/Typography.stories.tsx +198 -0
  274. package/typography/types.d.ts +18 -0
  275. package/typography/types.js +5 -0
  276. package/useTheme.d.ts +2 -0
  277. package/useTheme.js +2 -2
  278. package/useTranslatedLabels.d.ts +2 -0
  279. package/useTranslatedLabels.js +20 -0
  280. package/wizard/Wizard.d.ts +4 -0
  281. package/wizard/Wizard.js +118 -104
  282. package/wizard/Wizard.stories.tsx +233 -0
  283. package/wizard/Wizard.test.js +141 -0
  284. package/wizard/types.d.ts +65 -0
  285. package/wizard/types.js +5 -0
  286. package/ThemeContext.js +0 -246
  287. package/V3Select/V3Select.js +0 -455
  288. package/V3Select/index.d.ts +0 -27
  289. package/V3Textarea/V3Textarea.js +0 -260
  290. package/V3Textarea/index.d.ts +0 -27
  291. package/box/index.d.ts +0 -25
  292. package/chip/index.d.ts +0 -22
  293. package/date/Date.js +0 -373
  294. package/date/index.d.ts +0 -27
  295. package/dialog/index.d.ts +0 -18
  296. package/dropdown/index.d.ts +0 -26
  297. package/file-input/index.d.ts +0 -81
  298. package/footer/index.d.ts +0 -25
  299. package/header/index.d.ts +0 -25
  300. package/heading/index.d.ts +0 -17
  301. package/input-text/Icons.js +0 -22
  302. package/input-text/InputText.js +0 -611
  303. package/input-text/index.d.ts +0 -36
  304. package/link/index.d.ts +0 -23
  305. package/number-input/index.d.ts +0 -113
  306. package/password-input/index.d.ts +0 -94
  307. package/radio/Radio.d.ts +0 -4
  308. package/radio/Radio.js +0 -174
  309. package/radio/types.d.ts +0 -54
  310. package/resultsetTable/index.d.ts +0 -19
  311. package/select/index.d.ts +0 -131
  312. package/sidenav/index.d.ts +0 -13
  313. package/spinner/index.d.ts +0 -17
  314. package/table/index.d.ts +0 -13
  315. package/tabs/index.d.ts +0 -19
  316. package/tag/index.d.ts +0 -24
  317. package/text-input/index.d.ts +0 -135
  318. package/textarea/index.d.ts +0 -117
  319. package/toggle/Toggle.js +0 -186
  320. package/toggle/index.d.ts +0 -21
  321. package/toggle-group/index.d.ts +0 -21
  322. package/upload/Upload.js +0 -201
  323. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  324. package/upload/buttons-upload/Icons.js +0 -40
  325. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  326. package/upload/dragAndDropArea/Icons.js +0 -39
  327. package/upload/file-upload/FileToUpload.js +0 -115
  328. package/upload/file-upload/Icons.js +0 -66
  329. package/upload/files-upload/FilesToUpload.js +0 -109
  330. package/upload/index.d.ts +0 -15
  331. package/upload/transaction/Icons.js +0 -160
  332. package/upload/transaction/Transaction.js +0 -104
  333. package/upload/transactions/Transactions.js +0 -94
  334. package/wizard/Icons.js +0 -65
  335. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,312 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcDropdown from "./Dropdown";
4
+ import Title from "../../.storybook/components/Title";
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
+
11
+
12
+ export default {
13
+ title: "Dropdown",
14
+ component: DxcDropdown,
15
+ };
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
+ );
22
+ const iconSVG = (
23
+ <svg viewBox="0 0 24 24" fill="currentColor">
24
+ <path d="M0 0h24v24H0z" fill="none" />
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" />
26
+ </svg>
27
+ );
28
+ const iconSVGLarge = (
29
+ <svg enableBackground="new 0 0 24 24" height="48" viewBox="0 0 24 24" width="48" fill="currentColor">
30
+ <g>
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>
37
+ </svg>
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];
41
+
42
+ const defaultOptions: Option[] = [
43
+ {
44
+ value: "1",
45
+ label: "Amazon",
46
+ },
47
+ {
48
+ value: "2",
49
+ label: "Ebay",
50
+ },
51
+ {
52
+ value: "3",
53
+ label: "Apple",
54
+ },
55
+ {
56
+ value: "4",
57
+ label: "Wallapop",
58
+ },
59
+ {
60
+ value: "5",
61
+ label: "Aliexpress",
62
+ },
63
+ ];
64
+ const options: Option[] = [
65
+ {
66
+ value: "1",
67
+ label: "Amazon with a very long text",
68
+ },
69
+ {
70
+ value: "2",
71
+ label: "Ebay",
72
+ },
73
+ {
74
+ value: "3",
75
+ label: "Apple",
76
+ },
77
+ ];
78
+ const optionWithIcon: Option[] = [
79
+ {
80
+ value: "1",
81
+ label: "Ebay",
82
+ icon: iconUrl,
83
+ },
84
+ ];
85
+
86
+ const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
87
+
88
+ export const Chromatic = () => (
89
+ <>
90
+ <ExampleContainer>
91
+ <Title title="Default" theme="light" level={4} />
92
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} />
93
+ </ExampleContainer>
94
+ <ExampleContainer pseudoState="pseudo-hover">
95
+ <Title title="Hovered" theme="light" level={4} />
96
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
97
+ </ExampleContainer>
98
+ <ExampleContainer pseudoState="pseudo-focus">
99
+ <Title title="Focused" theme="light" level={4} />
100
+ <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
101
+ </ExampleContainer>
102
+ <ExampleContainer pseudoState="pseudo-active">
103
+ <Title title="Actived" theme="light" level={4} />
104
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Disabled" theme="light" level={4} />
108
+ <DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} disabled />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Caret hidden" theme="light" level={4} />
112
+ <DxcDropdown label="Caret hidden" options={options} onSelectOption={(value) => {}} caretHidden />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="With icon before" theme="light" level={4} />
116
+ <DxcDropdown label="Icon before" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="With icon after" theme="light" level={4} />
120
+ <DxcDropdown
121
+ label="Icon after"
122
+ options={options}
123
+ onSelectOption={(value) => {}}
124
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
125
+ iconPosition="after"
126
+ />
127
+ </ExampleContainer>
128
+ <ExampleContainer>
129
+ <Title title="Only icon" theme="light" level={4} />
130
+ <DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
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>
136
+ <ExampleContainer>
137
+ <Title title="Large icon" theme="light" level={4} />
138
+ <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
139
+ </ExampleContainer>
140
+ <ExampleContainer>
141
+ <Title title="Disabled with icon" theme="light" level={4} />
142
+ <DxcDropdown
143
+ label="Disabled with icon"
144
+ options={options}
145
+ onSelectOption={(value) => {}}
146
+ icon={iconSVG}
147
+ disabled
148
+ />
149
+ </ExampleContainer>
150
+ <ExampleContainer>
151
+ <Title title="Ellipsis" theme="light" level={4} />
152
+ <DxcDropdown
153
+ label="Very long text in dropdown button"
154
+ options={options}
155
+ onSelectOption={(value) => {}}
156
+ icon={iconSVG}
157
+ size="medium"
158
+ />
159
+ </ExampleContainer>
160
+ <Title title="Margins" theme="light" level={2} />
161
+ <ExampleContainer>
162
+ <Title title="Xxsmall" theme="light" level={4} />
163
+ <DxcDropdown label="Xxsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxsmall" />
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Xsmall" theme="light" level={4} />
167
+ <DxcDropdown label="Xsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xsmall" />
168
+ </ExampleContainer>
169
+ <ExampleContainer>
170
+ <Title title="Small" theme="light" level={4} />
171
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="small" />
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Medium" theme="light" level={4} />
175
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="medium" />
176
+ </ExampleContainer>
177
+ <ExampleContainer>
178
+ <Title title="Large" theme="light" level={4} />
179
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="large" />
180
+ </ExampleContainer>
181
+ <ExampleContainer>
182
+ <Title title="Xlarge" theme="light" level={4} />
183
+ <DxcDropdown label="Xlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xlarge" />
184
+ </ExampleContainer>
185
+ <ExampleContainer>
186
+ <Title title="Xxlarge" theme="light" level={4} />
187
+ <DxcDropdown label="Xxlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxlarge" />
188
+ </ExampleContainer>
189
+ <Title title="Sizes" theme="light" level={2} />
190
+ <ExampleContainer>
191
+ <Title title="Small" theme="light" level={4} />
192
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="small" />
193
+ </ExampleContainer>
194
+ <ExampleContainer>
195
+ <Title title="Medium" theme="light" level={4} />
196
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="medium" />
197
+ </ExampleContainer>
198
+ <ExampleContainer>
199
+ <Title title="Large" theme="light" level={4} />
200
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="large" />
201
+ </ExampleContainer>
202
+ <ExampleContainer>
203
+ <Title title="FitContent" theme="light" level={4} />
204
+ <DxcDropdown
205
+ label="FitContent"
206
+ options={options}
207
+ onSelectOption={(value) => {}}
208
+ icon={iconSVG}
209
+ size="fitContent"
210
+ />
211
+ </ExampleContainer>
212
+ <ExampleContainer>
213
+ <Title title="FillParent" theme="light" level={4} />
214
+ <DxcDropdown
215
+ label="FillParent"
216
+ options={options}
217
+ onSelectOption={(value) => {}}
218
+ icon={iconSVG}
219
+ size="fillParent"
220
+ />
221
+ </ExampleContainer>
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
+ </>
306
+ );
307
+
308
+ export const DropdownMenuStates = DropdownListStates.bind({});
309
+ DropdownMenuStates.play = async ({ canvasElement }) => {
310
+ const canvas = within(canvasElement);
311
+ await userEvent.click(canvas.getByRole("button"));
312
+ };