@dxc-technology/halstack-react 0.0.0-ba408d4 → 0.0.0-bb8df10

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 (351) 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 +4 -0
  6. package/accordion/Accordion.js +18 -81
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +61 -76
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +7 -23
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +6 -4
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +28 -64
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +1 -1
  44. package/button/Button.js +61 -87
  45. package/button/Button.stories.tsx +259 -282
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +14 -18
  48. package/card/Card.d.ts +4 -0
  49. package/card/Card.js +38 -77
  50. package/card/Card.stories.tsx +201 -0
  51. package/card/Card.test.js +50 -0
  52. package/card/ice-cream.jpg +0 -0
  53. package/card/types.d.ts +67 -0
  54. package/card/types.js +5 -0
  55. package/checkbox/Checkbox.d.ts +4 -0
  56. package/checkbox/Checkbox.js +45 -63
  57. package/checkbox/Checkbox.stories.tsx +188 -0
  58. package/checkbox/Checkbox.test.js +78 -0
  59. package/checkbox/types.d.ts +64 -0
  60. package/checkbox/types.js +5 -0
  61. package/chip/Chip.d.ts +4 -0
  62. package/chip/Chip.js +16 -76
  63. package/chip/Chip.stories.tsx +119 -0
  64. package/chip/Chip.test.js +56 -0
  65. package/chip/types.d.ts +45 -0
  66. package/chip/types.js +5 -0
  67. package/common/variables.js +316 -377
  68. package/date-input/DateInput.d.ts +4 -0
  69. package/date-input/DateInput.js +65 -89
  70. package/date-input/DateInput.stories.tsx +138 -0
  71. package/date-input/DateInput.test.js +479 -0
  72. package/date-input/types.d.ts +107 -0
  73. package/date-input/types.js +5 -0
  74. package/dialog/Dialog.d.ts +4 -0
  75. package/dialog/Dialog.js +52 -74
  76. package/dialog/Dialog.stories.tsx +211 -0
  77. package/dialog/Dialog.test.js +70 -0
  78. package/dialog/types.d.ts +43 -0
  79. package/dialog/types.js +5 -0
  80. package/dropdown/Dropdown.d.ts +4 -0
  81. package/dropdown/Dropdown.js +239 -302
  82. package/dropdown/Dropdown.stories.tsx +312 -0
  83. package/dropdown/Dropdown.test.js +591 -0
  84. package/dropdown/DropdownMenu.d.ts +4 -0
  85. package/dropdown/DropdownMenu.js +80 -0
  86. package/dropdown/DropdownMenuItem.d.ts +4 -0
  87. package/dropdown/DropdownMenuItem.js +92 -0
  88. package/dropdown/types.d.ts +100 -0
  89. package/dropdown/types.js +5 -0
  90. package/file-input/FileInput.d.ts +4 -0
  91. package/file-input/FileInput.js +172 -111
  92. package/file-input/FileInput.stories.tsx +507 -0
  93. package/file-input/FileInput.test.js +457 -0
  94. package/file-input/FileItem.d.ts +14 -0
  95. package/file-input/FileItem.js +16 -23
  96. package/file-input/types.d.ts +112 -0
  97. package/file-input/types.js +5 -0
  98. package/flex/Flex.d.ts +4 -0
  99. package/flex/Flex.js +57 -0
  100. package/flex/Flex.stories.tsx +103 -0
  101. package/flex/types.d.ts +21 -0
  102. package/flex/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +36 -148
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/footer/Icons.js +4 -4
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +119 -140
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/header/Icons.js +4 -29
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/heading/Heading.js +7 -24
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +51 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +37 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +20 -0
  131. package/layout/ApplicationLayout.js +71 -135
  132. package/layout/ApplicationLayout.stories.tsx +161 -0
  133. package/layout/Icons.d.ts +5 -0
  134. package/layout/Icons.js +13 -2
  135. package/layout/SidenavContext.d.ts +5 -0
  136. package/layout/SidenavContext.js +19 -0
  137. package/layout/types.d.ts +42 -0
  138. package/layout/types.js +5 -0
  139. package/link/Link.d.ts +4 -0
  140. package/link/Link.js +60 -107
  141. package/link/Link.stories.tsx +193 -0
  142. package/link/Link.test.js +83 -0
  143. package/link/types.d.ts +54 -0
  144. package/link/types.js +5 -0
  145. package/main.d.ts +12 -12
  146. package/main.js +64 -58
  147. package/number-input/NumberInput.d.ts +4 -0
  148. package/number-input/NumberInput.js +16 -68
  149. package/number-input/NumberInput.stories.tsx +115 -0
  150. package/number-input/NumberInput.test.js +506 -0
  151. package/number-input/NumberInputContext.d.ts +4 -0
  152. package/number-input/NumberInputContext.js +5 -2
  153. package/number-input/numberInputContextTypes.d.ts +19 -0
  154. package/number-input/numberInputContextTypes.js +5 -0
  155. package/number-input/types.d.ts +124 -0
  156. package/number-input/types.js +5 -0
  157. package/package.json +17 -13
  158. package/paginator/Paginator.js +19 -46
  159. package/paginator/Paginator.stories.tsx +63 -0
  160. package/paginator/Paginator.test.js +308 -0
  161. package/paragraph/Paragraph.d.ts +6 -0
  162. package/paragraph/Paragraph.js +38 -0
  163. package/paragraph/Paragraph.stories.tsx +44 -0
  164. package/password-input/PasswordInput.d.ts +4 -0
  165. package/password-input/PasswordInput.js +24 -57
  166. package/password-input/PasswordInput.stories.tsx +131 -0
  167. package/password-input/PasswordInput.test.js +180 -0
  168. package/password-input/types.d.ts +110 -0
  169. package/password-input/types.js +5 -0
  170. package/progress-bar/ProgressBar.d.ts +4 -0
  171. package/progress-bar/ProgressBar.js +60 -72
  172. package/progress-bar/ProgressBar.stories.jsx +60 -0
  173. package/progress-bar/ProgressBar.test.js +110 -0
  174. package/progress-bar/types.d.ts +36 -0
  175. package/progress-bar/types.js +5 -0
  176. package/quick-nav/QuickNav.d.ts +4 -0
  177. package/quick-nav/QuickNav.js +118 -0
  178. package/quick-nav/QuickNav.stories.tsx +264 -0
  179. package/quick-nav/types.d.ts +21 -0
  180. package/quick-nav/types.js +5 -0
  181. package/radio-group/Radio.d.ts +4 -0
  182. package/radio-group/Radio.js +141 -0
  183. package/radio-group/RadioGroup.d.ts +4 -0
  184. package/radio-group/RadioGroup.js +281 -0
  185. package/radio-group/RadioGroup.stories.tsx +100 -0
  186. package/radio-group/RadioGroup.test.js +695 -0
  187. package/radio-group/types.d.ts +114 -0
  188. package/radio-group/types.js +5 -0
  189. package/resultsetTable/ResultsetTable.d.ts +4 -0
  190. package/resultsetTable/ResultsetTable.js +9 -29
  191. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  192. package/resultsetTable/ResultsetTable.test.js +348 -0
  193. package/resultsetTable/types.d.ts +67 -0
  194. package/resultsetTable/types.js +5 -0
  195. package/select/Icons.d.ts +10 -0
  196. package/select/Icons.js +93 -0
  197. package/select/Listbox.d.ts +4 -0
  198. package/select/Listbox.js +199 -0
  199. package/select/Option.d.ts +4 -0
  200. package/select/Option.js +110 -0
  201. package/select/Select.d.ts +4 -0
  202. package/select/Select.js +158 -380
  203. package/select/Select.stories.tsx +627 -0
  204. package/select/Select.test.js +2175 -0
  205. package/select/types.d.ts +210 -0
  206. package/select/types.js +5 -0
  207. package/sidenav/Sidenav.d.ts +10 -0
  208. package/sidenav/Sidenav.js +186 -63
  209. package/sidenav/Sidenav.stories.tsx +180 -0
  210. package/sidenav/Sidenav.test.js +44 -0
  211. package/sidenav/types.d.ts +73 -0
  212. package/sidenav/types.js +5 -0
  213. package/slider/Slider.d.ts +4 -0
  214. package/slider/Slider.js +147 -154
  215. package/slider/Slider.stories.tsx +183 -0
  216. package/slider/Slider.test.js +250 -0
  217. package/slider/types.d.ts +82 -0
  218. package/slider/types.js +5 -0
  219. package/spinner/Spinner.d.ts +4 -0
  220. package/spinner/Spinner.js +9 -26
  221. package/spinner/Spinner.stories.jsx +103 -0
  222. package/spinner/Spinner.test.js +64 -0
  223. package/spinner/types.d.ts +32 -0
  224. package/spinner/types.js +5 -0
  225. package/switch/Switch.d.ts +4 -0
  226. package/switch/Switch.js +129 -86
  227. package/switch/Switch.stories.tsx +138 -0
  228. package/switch/Switch.test.js +212 -0
  229. package/switch/types.d.ts +61 -0
  230. package/switch/types.js +5 -0
  231. package/table/Table.d.ts +4 -0
  232. package/table/Table.js +3 -3
  233. package/table/Table.stories.jsx +277 -0
  234. package/table/Table.test.js +26 -0
  235. package/table/types.d.ts +21 -0
  236. package/table/types.js +5 -0
  237. package/tabs/Tab.d.ts +4 -0
  238. package/tabs/Tab.js +135 -0
  239. package/tabs/Tabs.d.ts +4 -0
  240. package/tabs/Tabs.js +364 -156
  241. package/tabs/Tabs.stories.tsx +186 -0
  242. package/tabs/Tabs.test.js +351 -0
  243. package/tabs/types.d.ts +92 -0
  244. package/tabs/types.js +5 -0
  245. package/tabs-nav/NavTabs.d.ts +8 -0
  246. package/tabs-nav/NavTabs.js +125 -0
  247. package/tabs-nav/NavTabs.stories.tsx +170 -0
  248. package/tabs-nav/NavTabs.test.js +82 -0
  249. package/tabs-nav/Tab.d.ts +4 -0
  250. package/tabs-nav/Tab.js +130 -0
  251. package/tabs-nav/types.d.ts +53 -0
  252. package/tabs-nav/types.js +5 -0
  253. package/tag/Tag.d.ts +4 -0
  254. package/tag/Tag.js +34 -59
  255. package/tag/Tag.stories.tsx +142 -0
  256. package/tag/Tag.test.js +60 -0
  257. package/tag/types.d.ts +69 -0
  258. package/tag/types.js +5 -0
  259. package/text-input/Suggestion.d.ts +4 -0
  260. package/text-input/Suggestion.js +55 -0
  261. package/text-input/TextInput.d.ts +4 -0
  262. package/text-input/TextInput.js +103 -167
  263. package/text-input/TextInput.stories.tsx +473 -0
  264. package/text-input/TextInput.test.js +1712 -0
  265. package/text-input/types.d.ts +178 -0
  266. package/text-input/types.js +5 -0
  267. package/textarea/Textarea.d.ts +4 -0
  268. package/textarea/Textarea.js +39 -79
  269. package/textarea/Textarea.stories.jsx +157 -0
  270. package/textarea/Textarea.test.js +437 -0
  271. package/textarea/types.d.ts +137 -0
  272. package/textarea/types.js +5 -0
  273. package/toggle-group/ToggleGroup.d.ts +4 -0
  274. package/toggle-group/ToggleGroup.js +18 -46
  275. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  276. package/toggle-group/ToggleGroup.test.js +156 -0
  277. package/toggle-group/types.d.ts +105 -0
  278. package/toggle-group/types.js +5 -0
  279. package/typography/Typography.d.ts +4 -0
  280. package/typography/Typography.js +131 -0
  281. package/typography/Typography.stories.tsx +198 -0
  282. package/typography/types.d.ts +18 -0
  283. package/typography/types.js +5 -0
  284. package/useTheme.d.ts +2 -0
  285. package/useTheme.js +2 -2
  286. package/useTranslatedLabels.d.ts +2 -0
  287. package/useTranslatedLabels.js +20 -0
  288. package/wizard/Wizard.d.ts +4 -0
  289. package/wizard/Wizard.js +118 -104
  290. package/wizard/Wizard.stories.tsx +233 -0
  291. package/wizard/Wizard.test.js +141 -0
  292. package/wizard/types.d.ts +65 -0
  293. package/wizard/types.js +5 -0
  294. package/ThemeContext.js +0 -246
  295. package/V3Select/V3Select.js +0 -455
  296. package/V3Select/index.d.ts +0 -27
  297. package/V3Textarea/V3Textarea.js +0 -260
  298. package/V3Textarea/index.d.ts +0 -27
  299. package/accordion/index.d.ts +0 -28
  300. package/accordion-group/index.d.ts +0 -16
  301. package/alert/index.d.ts +0 -51
  302. package/box/index.d.ts +0 -25
  303. package/card/index.d.ts +0 -22
  304. package/checkbox/index.d.ts +0 -24
  305. package/chip/index.d.ts +0 -22
  306. package/date/Date.js +0 -373
  307. package/date/index.d.ts +0 -27
  308. package/date-input/index.d.ts +0 -95
  309. package/dialog/index.d.ts +0 -18
  310. package/dropdown/index.d.ts +0 -26
  311. package/file-input/index.d.ts +0 -81
  312. package/footer/index.d.ts +0 -25
  313. package/header/index.d.ts +0 -25
  314. package/heading/index.d.ts +0 -17
  315. package/input-text/Icons.js +0 -22
  316. package/input-text/InputText.js +0 -611
  317. package/input-text/index.d.ts +0 -36
  318. package/link/index.d.ts +0 -23
  319. package/number-input/index.d.ts +0 -113
  320. package/password-input/index.d.ts +0 -94
  321. package/progress-bar/index.d.ts +0 -18
  322. package/radio/Radio.js +0 -195
  323. package/radio/index.d.ts +0 -23
  324. package/resultsetTable/index.d.ts +0 -19
  325. package/select/index.d.ts +0 -131
  326. package/sidenav/index.d.ts +0 -13
  327. package/slider/index.d.ts +0 -29
  328. package/spinner/index.d.ts +0 -17
  329. package/switch/index.d.ts +0 -24
  330. package/table/index.d.ts +0 -13
  331. package/tabs/index.d.ts +0 -19
  332. package/tag/index.d.ts +0 -24
  333. package/text-input/index.d.ts +0 -135
  334. package/textarea/index.d.ts +0 -117
  335. package/toggle/Toggle.js +0 -186
  336. package/toggle/index.d.ts +0 -21
  337. package/toggle-group/index.d.ts +0 -21
  338. package/upload/Upload.js +0 -201
  339. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  340. package/upload/buttons-upload/Icons.js +0 -40
  341. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  342. package/upload/dragAndDropArea/Icons.js +0 -39
  343. package/upload/file-upload/FileToUpload.js +0 -115
  344. package/upload/file-upload/Icons.js +0 -66
  345. package/upload/files-upload/FilesToUpload.js +0 -109
  346. package/upload/index.d.ts +0 -15
  347. package/upload/transaction/Icons.js +0 -160
  348. package/upload/transaction/Transaction.js +0 -104
  349. package/upload/transactions/Transactions.js +0 -94
  350. package/wizard/Icons.js +0 -65
  351. 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
+ };