@dxc-technology/halstack-react 0.0.0-eca8a89 → 0.0.0-ecc45e2

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