@dxc-technology/halstack-react 0.0.0-b39a1d2 → 0.0.0-b3b8a35

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