@dxc-technology/halstack-react 0.0.0-f4755a1 → 0.0.0-f53e801

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