@dxc-technology/halstack-react 0.0.0-d20b360 → 0.0.0-d3554d7

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 (273) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +26 -29
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +11 -22
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +57 -0
  9. package/accordion/types.d.ts +4 -8
  10. package/accordion-group/AccordionGroup.js +2 -2
  11. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  12. package/accordion-group/AccordionGroup.test.js +133 -0
  13. package/accordion-group/types.d.ts +4 -8
  14. package/alert/Alert.js +2 -2
  15. package/alert/Alert.stories.tsx +170 -0
  16. package/alert/Alert.test.js +92 -0
  17. package/alert/types.d.ts +1 -1
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +1 -1
  20. package/badge/types.d.ts +4 -0
  21. package/badge/types.js +5 -0
  22. package/bleed/Bleed.d.ts +3 -0
  23. package/bleed/Bleed.js +84 -0
  24. package/bleed/Bleed.stories.tsx +342 -0
  25. package/bleed/types.d.ts +13 -0
  26. package/bleed/types.js +5 -0
  27. package/box/Box.d.ts +4 -0
  28. package/box/Box.js +6 -32
  29. package/box/{Box.stories.jsx → Box.stories.tsx} +0 -0
  30. package/box/Box.test.js +18 -0
  31. package/box/types.d.ts +43 -0
  32. package/box/types.js +5 -0
  33. package/button/Button.d.ts +1 -1
  34. package/button/Button.js +15 -26
  35. package/button/Button.stories.tsx +223 -242
  36. package/button/Button.test.js +35 -0
  37. package/button/types.d.ts +9 -13
  38. package/card/Card.js +5 -6
  39. package/card/Card.stories.tsx +201 -0
  40. package/card/Card.test.js +50 -0
  41. package/card/ice-cream.jpg +0 -0
  42. package/card/types.d.ts +4 -6
  43. package/checkbox/Checkbox.js +2 -2
  44. package/checkbox/Checkbox.test.js +65 -0
  45. package/checkbox/types.d.ts +2 -2
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +16 -76
  48. package/chip/Chip.stories.tsx +119 -0
  49. package/chip/Chip.test.js +56 -0
  50. package/chip/types.d.ts +45 -0
  51. package/chip/types.js +5 -0
  52. package/common/variables.js +85 -281
  53. package/date-input/DateInput.js +10 -13
  54. package/date-input/DateInput.stories.tsx +138 -0
  55. package/date-input/DateInput.test.js +469 -0
  56. package/dialog/Dialog.js +4 -3
  57. package/dialog/Dialog.stories.tsx +212 -0
  58. package/dialog/Dialog.test.js +40 -0
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +13 -35
  61. package/dropdown/Dropdown.stories.tsx +249 -0
  62. package/dropdown/Dropdown.test.js +189 -0
  63. package/dropdown/types.d.ts +6 -15
  64. package/file-input/FileInput.d.ts +4 -0
  65. package/file-input/FileInput.js +167 -109
  66. package/file-input/FileInput.stories.tsx +507 -0
  67. package/file-input/FileInput.test.js +457 -0
  68. package/file-input/FileItem.d.ts +14 -0
  69. package/file-input/FileItem.js +12 -21
  70. package/file-input/types.d.ts +112 -0
  71. package/file-input/types.js +5 -0
  72. package/footer/Footer.d.ts +1 -1
  73. package/footer/Footer.js +28 -36
  74. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  75. package/footer/Footer.test.js +109 -0
  76. package/footer/Icons.d.ts +2 -0
  77. package/footer/Icons.js +3 -3
  78. package/footer/types.d.ts +22 -18
  79. package/header/Header.js +2 -2
  80. package/header/Header.stories.tsx +162 -0
  81. package/header/Header.test.js +63 -0
  82. package/header/Icons.d.ts +2 -0
  83. package/header/types.d.ts +4 -2
  84. package/heading/Heading.d.ts +4 -0
  85. package/heading/Heading.js +7 -24
  86. package/heading/Heading.stories.tsx +54 -0
  87. package/heading/Heading.test.js +186 -0
  88. package/heading/types.d.ts +33 -0
  89. package/heading/types.js +5 -0
  90. package/inset/Inset.d.ts +3 -0
  91. package/inset/Inset.js +84 -0
  92. package/inset/Inset.stories.tsx +229 -0
  93. package/inset/types.d.ts +13 -0
  94. package/inset/types.js +5 -0
  95. package/layout/ApplicationLayout.d.ts +10 -0
  96. package/layout/ApplicationLayout.js +17 -21
  97. package/layout/ApplicationLayout.stories.tsx +171 -0
  98. package/layout/types.d.ts +57 -0
  99. package/layout/types.js +5 -0
  100. package/link/Link.d.ts +3 -0
  101. package/link/Link.js +10 -40
  102. package/link/Link.stories.tsx +151 -0
  103. package/link/Link.test.js +91 -0
  104. package/link/types.d.ts +70 -0
  105. package/link/types.js +5 -0
  106. package/list/List.d.ts +4 -0
  107. package/list/List.js +47 -0
  108. package/list/List.stories.tsx +95 -0
  109. package/list/types.d.ts +7 -0
  110. package/list/types.js +5 -0
  111. package/main.d.ts +10 -8
  112. package/main.js +54 -38
  113. package/number-input/NumberInput.d.ts +4 -0
  114. package/number-input/NumberInput.js +5 -50
  115. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +0 -0
  116. package/number-input/NumberInput.test.js +508 -0
  117. package/number-input/NumberInputContext.d.ts +4 -0
  118. package/number-input/NumberInputContext.js +5 -2
  119. package/number-input/numberInputContextTypes.d.ts +19 -0
  120. package/number-input/numberInputContextTypes.js +5 -0
  121. package/number-input/types.d.ts +117 -0
  122. package/number-input/types.js +5 -0
  123. package/package.json +4 -2
  124. package/paginator/Paginator.js +2 -8
  125. package/paginator/Paginator.test.js +266 -0
  126. package/password-input/PasswordInput.d.ts +4 -0
  127. package/password-input/PasswordInput.js +19 -55
  128. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  129. package/password-input/PasswordInput.test.js +183 -0
  130. package/password-input/types.d.ts +107 -0
  131. package/password-input/types.js +5 -0
  132. package/progress-bar/ProgressBar.js +4 -4
  133. package/progress-bar/ProgressBar.stories.jsx +58 -0
  134. package/progress-bar/ProgressBar.test.js +65 -0
  135. package/radio/Radio.js +2 -2
  136. package/radio/Radio.test.js +71 -0
  137. package/radio/types.d.ts +2 -2
  138. package/radio-group/Radio.d.ts +4 -0
  139. package/radio-group/Radio.js +141 -0
  140. package/radio-group/RadioGroup.d.ts +4 -0
  141. package/radio-group/RadioGroup.js +279 -0
  142. package/radio-group/RadioGroup.stories.tsx +96 -0
  143. package/radio-group/RadioGroup.test.js +694 -0
  144. package/radio-group/types.d.ts +37 -0
  145. package/radio-group/types.js +5 -0
  146. package/resultsetTable/ResultsetTable.d.ts +4 -0
  147. package/resultsetTable/ResultsetTable.js +9 -29
  148. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  149. package/resultsetTable/ResultsetTable.test.js +306 -0
  150. package/resultsetTable/types.d.ts +67 -0
  151. package/resultsetTable/types.js +5 -0
  152. package/row/Row.d.ts +3 -0
  153. package/row/Row.js +127 -0
  154. package/row/Row.stories.tsx +237 -0
  155. package/row/types.d.ts +10 -0
  156. package/row/types.js +5 -0
  157. package/select/Select.d.ts +4 -0
  158. package/select/Select.js +26 -22
  159. package/select/Select.stories.tsx +582 -0
  160. package/select/Select.test.js +1900 -0
  161. package/select/types.d.ts +170 -0
  162. package/select/types.js +5 -0
  163. package/sidenav/Sidenav.d.ts +9 -0
  164. package/sidenav/Sidenav.js +6 -15
  165. package/sidenav/Sidenav.stories.tsx +182 -0
  166. package/sidenav/Sidenav.test.js +56 -0
  167. package/sidenav/types.d.ts +50 -0
  168. package/sidenav/types.js +5 -0
  169. package/slider/Slider.d.ts +1 -1
  170. package/slider/Slider.js +43 -32
  171. package/slider/Slider.stories.tsx +177 -0
  172. package/slider/Slider.test.js +129 -0
  173. package/slider/types.d.ts +2 -7
  174. package/spinner/Spinner.d.ts +4 -0
  175. package/spinner/Spinner.js +2 -19
  176. package/spinner/Spinner.stories.jsx +1 -0
  177. package/spinner/Spinner.test.js +64 -0
  178. package/spinner/types.d.ts +32 -0
  179. package/spinner/types.js +5 -0
  180. package/stack/Stack.d.ts +3 -0
  181. package/stack/Stack.js +97 -0
  182. package/stack/Stack.stories.tsx +164 -0
  183. package/stack/types.d.ts +9 -0
  184. package/stack/types.js +5 -0
  185. package/switch/Switch.js +4 -4
  186. package/switch/Switch.stories.tsx +160 -0
  187. package/switch/Switch.test.js +73 -0
  188. package/table/Table.d.ts +4 -0
  189. package/table/Table.js +3 -3
  190. package/table/Table.stories.jsx +2 -1
  191. package/table/Table.test.js +26 -0
  192. package/table/types.d.ts +21 -0
  193. package/table/types.js +5 -0
  194. package/tabs/Tabs.js +11 -9
  195. package/tabs/Tabs.stories.tsx +120 -0
  196. package/tabs/Tabs.test.js +123 -0
  197. package/tabs/types.d.ts +25 -18
  198. package/tag/Tag.d.ts +4 -0
  199. package/tag/Tag.js +26 -46
  200. package/tag/Tag.stories.tsx +138 -0
  201. package/tag/Tag.test.js +60 -0
  202. package/tag/types.d.ts +69 -0
  203. package/tag/types.js +5 -0
  204. package/text/Text.d.ts +7 -0
  205. package/text/Text.js +30 -0
  206. package/text/Text.stories.tsx +19 -0
  207. package/text-input/TextInput.d.ts +4 -0
  208. package/text-input/TextInput.js +59 -88
  209. package/text-input/TextInput.stories.tsx +474 -0
  210. package/text-input/TextInput.test.js +1691 -0
  211. package/text-input/types.d.ts +159 -0
  212. package/text-input/types.js +5 -0
  213. package/textarea/Textarea.d.ts +4 -0
  214. package/textarea/Textarea.js +32 -63
  215. package/textarea/Textarea.stories.jsx +34 -12
  216. package/textarea/Textarea.test.js +436 -0
  217. package/textarea/types.d.ts +130 -0
  218. package/textarea/types.js +5 -0
  219. package/toggle-group/ToggleGroup.d.ts +4 -0
  220. package/toggle-group/ToggleGroup.js +16 -45
  221. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  222. package/toggle-group/ToggleGroup.test.js +125 -0
  223. package/toggle-group/types.d.ts +97 -0
  224. package/toggle-group/types.js +5 -0
  225. package/useTheme.d.ts +2 -0
  226. package/useTheme.js +1 -1
  227. package/wizard/Wizard.d.ts +4 -0
  228. package/wizard/Wizard.js +69 -59
  229. package/wizard/Wizard.stories.tsx +224 -0
  230. package/wizard/Wizard.test.js +128 -0
  231. package/wizard/types.d.ts +60 -0
  232. package/wizard/types.js +5 -0
  233. package/V3Select/V3Select.js +0 -455
  234. package/V3Select/index.d.ts +0 -27
  235. package/V3Textarea/V3Textarea.js +0 -260
  236. package/V3Textarea/index.d.ts +0 -27
  237. package/box/index.d.ts +0 -25
  238. package/chip/index.d.ts +0 -22
  239. package/date/Date.js +0 -373
  240. package/date/index.d.ts +0 -27
  241. package/file-input/index.d.ts +0 -81
  242. package/heading/index.d.ts +0 -17
  243. package/input-text/Icons.js +0 -22
  244. package/input-text/InputText.js +0 -611
  245. package/input-text/index.d.ts +0 -36
  246. package/link/index.d.ts +0 -23
  247. package/number-input/index.d.ts +0 -113
  248. package/password-input/index.d.ts +0 -94
  249. package/resultsetTable/index.d.ts +0 -19
  250. package/select/index.d.ts +0 -131
  251. package/sidenav/index.d.ts +0 -13
  252. package/spinner/index.d.ts +0 -17
  253. package/table/index.d.ts +0 -13
  254. package/tag/index.d.ts +0 -24
  255. package/text-input/index.d.ts +0 -135
  256. package/textarea/index.d.ts +0 -117
  257. package/toggle/Toggle.js +0 -186
  258. package/toggle/index.d.ts +0 -21
  259. package/toggle-group/index.d.ts +0 -21
  260. package/upload/Upload.js +0 -201
  261. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  262. package/upload/buttons-upload/Icons.js +0 -40
  263. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  264. package/upload/dragAndDropArea/Icons.js +0 -39
  265. package/upload/file-upload/FileToUpload.js +0 -115
  266. package/upload/file-upload/Icons.js +0 -66
  267. package/upload/files-upload/FilesToUpload.js +0 -109
  268. package/upload/index.d.ts +0 -15
  269. package/upload/transaction/Icons.js +0 -160
  270. package/upload/transaction/Transaction.js +0 -104
  271. package/upload/transactions/Transactions.js +0 -94
  272. package/wizard/Icons.js +0 -65
  273. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,212 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcDialog from "./Dialog";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+
7
+ export default {
8
+ title: "Dialog ",
9
+ component: DxcDialog,
10
+ };
11
+
12
+ export const DefaultDialog = () => (
13
+ <>
14
+ <ExampleContainer expanded={true}>
15
+ <Title title="Default dialog" theme="light" level={4} />
16
+ <DxcDialog>
17
+ {" "}
18
+ <p>
19
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
20
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
21
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
22
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
23
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
24
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
25
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
26
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
27
+ dignissim, pharetra neque molestie, molestie lectus.
28
+ </p>{" "}
29
+ </DxcDialog>
30
+ </ExampleContainer>
31
+ </>
32
+ );
33
+
34
+ export const DialogWithoutOverlay = () => (
35
+ <ExampleContainer expanded={true}>
36
+ <Title title="Dialog Without Overlay" theme="light" level={4} />
37
+ <DxcDialog overlay={false}>
38
+ {" "}
39
+ <p>
40
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
41
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
42
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
43
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
44
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
45
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
46
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
47
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
48
+ dignissim, pharetra neque molestie, molestie lectus.
49
+ </p>{" "}
50
+ </DxcDialog>
51
+ </ExampleContainer>
52
+ );
53
+
54
+ export const DialogCloseVisibleFalse = () => (
55
+ <ExampleContainer expanded={true}>
56
+ <Title title="Dialog Close Visible" theme="dark" level={4} />
57
+ <DxcDialog isCloseVisible={false}>
58
+ {" "}
59
+ <p>
60
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
61
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
62
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
63
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
64
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
65
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
66
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
67
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
68
+ dignissim, pharetra neque molestie, molestie lectus.
69
+ </p>{" "}
70
+ </DxcDialog>
71
+ </ExampleContainer>
72
+ );
73
+
74
+ export const DialogWithXxsmallPadding = () => (
75
+ <ExampleContainer expanded={true}>
76
+ <Title title="Dialog With Xxsmall Padding" theme="light" level={4} />
77
+ <DxcDialog padding={"xxsmall"}>
78
+ {" "}
79
+ <p>
80
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
81
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
82
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
83
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
84
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
85
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
86
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
87
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
88
+ dignissim, pharetra neque molestie, molestie lectus.
89
+ </p>{" "}
90
+ </DxcDialog>
91
+ </ExampleContainer>
92
+ );
93
+
94
+ export const DialogWithXsmallPadding = () => (
95
+ <ExampleContainer expanded={true}>
96
+ <Title title="Dialog With Xsmall Padding" theme="light" level={4} />
97
+ <DxcDialog padding={"xsmall"}>
98
+ {" "}
99
+ <p>
100
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
101
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
102
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
103
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
104
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
105
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
106
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
107
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
108
+ dignissim, pharetra neque molestie, molestie lectus.
109
+ </p>{" "}
110
+ </DxcDialog>
111
+ </ExampleContainer>
112
+ );
113
+
114
+ export const DialogWithSmallPadding = () => (
115
+ <ExampleContainer expanded={true}>
116
+ <Title title="Dialog With Small Padding" theme="light" level={4} />
117
+ <DxcDialog padding={"small"}>
118
+ {" "}
119
+ <p>
120
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
121
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
122
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
123
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
124
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
125
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
126
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
127
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
128
+ dignissim, pharetra neque molestie, molestie lectus.
129
+ </p>{" "}
130
+ </DxcDialog>
131
+ </ExampleContainer>
132
+ );
133
+
134
+ export const DialogWithMediumPadding = () => (
135
+ <ExampleContainer expanded={true}>
136
+ <Title title="Dialog With Medium Padding" theme="light" level={4} />
137
+ <DxcDialog padding={"medium"}>
138
+ {" "}
139
+ <p>
140
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
141
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
142
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
143
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
144
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
145
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
146
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
147
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
148
+ dignissim, pharetra neque molestie, molestie lectus.
149
+ </p>{" "}
150
+ </DxcDialog>
151
+ </ExampleContainer>
152
+ );
153
+
154
+ export const DialogWithLargePadding = () => (
155
+ <ExampleContainer expanded={true}>
156
+ <Title title="Dialog With Large Padding" theme="light" level={4} />
157
+ <DxcDialog padding={"large"}>
158
+ {" "}
159
+ <p>
160
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
161
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
162
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
163
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
164
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
165
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
166
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
167
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
168
+ dignissim, pharetra neque molestie, molestie lectus.
169
+ </p>{" "}
170
+ </DxcDialog>
171
+ </ExampleContainer>
172
+ );
173
+
174
+ export const DialogWithXlargePadding = () => (
175
+ <ExampleContainer expanded={true}>
176
+ <Title title="Dialog With Xlarge Padding" theme="light" level={4} />
177
+ <DxcDialog padding={"xlarge"}>
178
+ {" "}
179
+ <p>
180
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
181
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
182
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
183
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
184
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
185
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
186
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
187
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
188
+ dignissim, pharetra neque molestie, molestie lectus.
189
+ </p>{" "}
190
+ </DxcDialog>
191
+ </ExampleContainer>
192
+ );
193
+
194
+ export const DialogWithXxlargePadding = () => (
195
+ <ExampleContainer expanded={true}>
196
+ <Title title="Dialog With Xxlarge Padding" theme="light" level={4} />
197
+ <DxcDialog padding={"xxlarge"}>
198
+ {" "}
199
+ <p>
200
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi egestas luctus porttitor. Donec massa magna,
201
+ placerat sit amet felis eget, venenatis fringilla ipsum. Lorem ipsum dolor sit amet, consectetur adipiscing
202
+ elit. Donec congue laoreet orci, nec elementum dolor consequat quis. Curabitur rhoncus justo sed dapibus
203
+ tincidunt. Vestibulum cursus ut risus sit amet congue. Nunc luctus, urna ullamcorper facilisis Jia Le, risus
204
+ eros aliquam erat, ut efficitur ante neque id odio. Nam orci leo, dignissim sit amet dolor ut, congue gravida
205
+ enim. Donec rhoncus aliquam nisl, ac cursus enim bibendum vitae. Nunc sit amet elit ornare, malesuada urna eu,
206
+ fringilla mauris. Vivamus bibendum turpis est, id elementum purus euismod sit amet. Etiam sit amet maximus
207
+ augue. Vivamus erat sapien, ultricies fringilla tellus id, condimentum blandit justo. Praesent quis nunc
208
+ dignissim, pharetra neque molestie, molestie lectus.
209
+ </p>{" "}
210
+ </DxcDialog>
211
+ </ExampleContainer>
212
+ );
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Dialog = _interopRequireDefault(require("./Dialog"));
10
+
11
+ describe("Dialog component tests", function () {
12
+ test("Dialog renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
14
+ getByText = _render.getByText;
15
+
16
+ expect(getByText("dialog-text")).toBeTruthy();
17
+ });
18
+ test("Dialog renders without close button", function () {
19
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
20
+ isCloseVisible: false
21
+ }, "dialog-text")),
22
+ queryByRole = _render2.queryByRole;
23
+
24
+ expect(queryByRole("button")).toBeFalsy();
25
+ });
26
+ test("Calls correct function onCloseClick", function () {
27
+ var onCloseClick = jest.fn();
28
+
29
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
30
+ onCloseClick: onCloseClick
31
+ }, "dialog-text")),
32
+ getByRole = _render3.getByRole;
33
+
34
+ var closeButton = getByRole("button");
35
+
36
+ _react2.fireEvent.click(closeButton);
37
+
38
+ expect(onCloseClick).toHaveBeenCalled();
39
+ });
40
+ });
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import DropdownPropsType from "./types";
3
- declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconSrc, iconPosition, label, caretHidden, onSelectOption, expandOnHover, margin, size, tabIndex, disabled, }: DropdownPropsType) => JSX.Element;
3
+ declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden, onSelectOption, expandOnHover, margin, size, tabIndex, disabled, }: DropdownPropsType) => JSX.Element;
4
4
  export default DxcDropdown;
@@ -9,10 +9,10 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
17
 
18
18
  var _react = _interopRequireWildcard(require("react"));
@@ -35,7 +35,7 @@ var _variables = require("../common/variables.js");
35
35
 
36
36
  var _utils = require("../common/utils.js");
37
37
 
38
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
38
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
39
39
 
40
40
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
41
41
 
@@ -48,8 +48,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
48
48
  _ref$optionsIconPosit = _ref.optionsIconPosition,
49
49
  optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
50
50
  icon = _ref.icon,
51
- _ref$iconSrc = _ref.iconSrc,
52
- iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
53
51
  _ref$iconPosition = _ref.iconPosition,
54
52
  iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
55
53
  _ref$label = _ref.label,
@@ -164,15 +162,13 @@ var DxcDropdown = function DxcDropdown(_ref) {
164
162
  }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContainer, {
165
163
  iconPosition: iconPosition,
166
164
  caretHidden: caretHidden
167
- }, icon ? /*#__PURE__*/_react["default"].createElement(ButtonIconContainer, {
165
+ }, icon && /*#__PURE__*/_react["default"].createElement(ButtonIconContainer, {
168
166
  label: label,
169
167
  iconPosition: iconPosition,
170
168
  disabled: disabled
171
- }, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : iconSrc && /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
172
- label: label,
173
- src: iconSrc,
174
- iconPosition: iconPosition
175
- }), /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, {
169
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
170
+ src: icon
171
+ }) : icon), /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, {
176
172
  iconPosition: iconPosition,
177
173
  label: label
178
174
  }, label)), /*#__PURE__*/_react["default"].createElement(CaretIconContainer, {
@@ -213,14 +209,12 @@ var DxcDropdown = function DxcDropdown(_ref) {
213
209
  onClick: function onClick(event) {
214
210
  return handleMenuItemClick(option);
215
211
  }
216
- }, option.icon ? /*#__PURE__*/_react["default"].createElement(ListIconContainer, {
217
- label: option.label,
218
- iconPosition: optionsIconPosition
219
- }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : /*#__PURE__*/_react["default"].createElement(option.icon)) : option.iconSrc && /*#__PURE__*/_react["default"].createElement(ListIcon, {
212
+ }, option.icon && /*#__PURE__*/_react["default"].createElement(ListIconContainer, {
220
213
  label: option.label,
221
- src: option.iconSrc,
222
214
  iconPosition: optionsIconPosition
223
- }), /*#__PURE__*/_react["default"].createElement("span", {
215
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement(ListIcon, {
216
+ src: option.icon
217
+ }) : option.icon), /*#__PURE__*/_react["default"].createElement("span", {
224
218
  className: "optionLabel"
225
219
  }, option.label));
226
220
  })))));
@@ -357,15 +351,7 @@ var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject
357
351
  return props.caretHidden ? "100%" : "calc(100% - 36px)";
358
352
  });
359
353
 
360
- var ButtonIcon = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
361
- return props.theme.buttonIconSize;
362
- }, function (props) {
363
- return props.theme.buttonIconSize;
364
- }, function (props) {
365
- return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
366
- }, function (props) {
367
- return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
368
- });
354
+ var ButtonIcon = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])([""])));
369
355
 
370
356
  var ButtonIconContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
371
357
  return props.theme.buttonIconSize;
@@ -379,15 +365,7 @@ var ButtonIconContainer = _styledComponents["default"].div(_templateObject7 || (
379
365
  return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
380
366
  });
381
367
 
382
- var ListIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
383
- return props.theme.optionIconSize;
384
- }, function (props) {
385
- return props.theme.optionIconSize;
386
- }, function (props) {
387
- return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
388
- }, function (props) {
389
- return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
390
- });
368
+ var ListIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])([""])));
391
369
 
392
370
  var ListIconContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
393
371
  return props.theme.optionIconSize;
@@ -0,0 +1,249 @@
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
+
7
+ export default {
8
+ title: "Dropdown",
9
+ component: DxcDropdown,
10
+ };
11
+
12
+ const iconSVG = (
13
+ <svg viewBox="0 0 24 24" fill="currentColor">
14
+ <path d="M0 0h24v24H0z" fill="none" />
15
+ <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" />
16
+ </svg>
17
+ );
18
+
19
+ const iconSVGLarge = (
20
+ <svg enable-background="new 0 0 24 24" height="48px" viewBox="0 0 24 24" width="48px" fill="currentColor">
21
+ <g>
22
+ <path d="M0,0h24v24H0V0z" fill="none" />
23
+ <path d="M0,0h24v24H0V0z" fill="none" />
24
+ </g>
25
+ <g>
26
+ <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" />
27
+ </g>
28
+ </svg>
29
+ );
30
+
31
+ const options: any = [
32
+ {
33
+ value: "1",
34
+ label: "Amazon with a very long text",
35
+ },
36
+ {
37
+ value: "2",
38
+ label: "Ebay",
39
+ },
40
+ {
41
+ value: "3",
42
+ label: "Apple",
43
+ },
44
+ ];
45
+
46
+ const option: any = [
47
+ {
48
+ value: "1",
49
+ label: "Ebay",
50
+ },
51
+ ];
52
+
53
+ const icons = [
54
+ iconSVG,
55
+ iconSVGLarge,
56
+ "https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png",
57
+ ];
58
+
59
+ const optionsIcon: any = options.map((op, i) => ({ ...op, icon: icons[i] }));
60
+
61
+ export const Chromatic = () => (
62
+ <>
63
+ <ExampleContainer>
64
+ <Title title="Default" theme="light" level={4} />
65
+ <DxcDropdown label="Default" options={options} onSelectOption={(value) => {}} />
66
+ </ExampleContainer>
67
+ <ExampleContainer pseudoState="pseudo-hover">
68
+ <Title title="Hovered" theme="light" level={4} />
69
+ <DxcDropdown label="Hovered" options={options} onSelectOption={(value) => {}} />
70
+ </ExampleContainer>
71
+ <ExampleContainer pseudoState="pseudo-focus-visible">
72
+ <Title title="Focused" theme="light" level={4} />
73
+ <DxcDropdown label="Focused" options={options} onSelectOption={(value) => {}} />
74
+ </ExampleContainer>
75
+ <ExampleContainer pseudoState="pseudo-active">
76
+ <Title title="Actived" theme="light" level={4} />
77
+ <DxcDropdown label="Actived" options={options} onSelectOption={(value) => {}} />
78
+ </ExampleContainer>
79
+ <ExampleContainer>
80
+ <Title title="Disabled" theme="light" level={4} />
81
+ <DxcDropdown label="Disabled" options={options} onSelectOption={(value) => {}} disabled />
82
+ </ExampleContainer>
83
+ <ExampleContainer>
84
+ <Title title="Caret hidden" theme="light" level={4} />
85
+ <DxcDropdown label="Caret hidden" options={options} onSelectOption={(value) => {}} caretHidden />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="With icon before" theme="light" level={4} />
89
+ <DxcDropdown label="Icon before" options={options} onSelectOption={(value) => {}} icon={iconSVG} />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="With icon after" theme="light" level={4} />
93
+ <DxcDropdown
94
+ label="Icon after"
95
+ options={options}
96
+ onSelectOption={(value) => {}}
97
+ icon="https://iconape.com/wp-content/files/yd/367773/svg/logo-linkedin-logo-icon-png-svg.png"
98
+ iconPosition="after"
99
+ />
100
+ </ExampleContainer>
101
+ <ExampleContainer>
102
+ <Title title="Only icon" theme="light" level={4} />
103
+ <DxcDropdown options={options} onSelectOption={(value) => {}} icon={iconSVG} />
104
+ </ExampleContainer>
105
+ <ExampleContainer>
106
+ <Title title="Large icon" theme="light" level={4} />
107
+ <DxcDropdown label="Large icon" options={options} onSelectOption={(value) => {}} icon={iconSVGLarge} />
108
+ </ExampleContainer>
109
+ <ExampleContainer>
110
+ <Title title="Disabled with icon" theme="light" level={4} />
111
+ <DxcDropdown
112
+ label="Disabled with icon"
113
+ options={options}
114
+ onSelectOption={(value) => {}}
115
+ icon={iconSVG}
116
+ disabled
117
+ />
118
+ </ExampleContainer>
119
+ <ExampleContainer>
120
+ <Title title="Ellipsis" theme="light" level={4} />
121
+ <DxcDropdown
122
+ label="Very long text in dropdown button"
123
+ options={options}
124
+ onSelectOption={(value) => {}}
125
+ icon={iconSVG}
126
+ size="medium"
127
+ />
128
+ </ExampleContainer>
129
+ <Title title="Margins" theme="light" level={2} />
130
+ <ExampleContainer>
131
+ <Title title="Xxsmall" theme="light" level={4} />
132
+ <DxcDropdown label="Xxsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxsmall" />
133
+ </ExampleContainer>
134
+ <ExampleContainer>
135
+ <Title title="Xsmall" theme="light" level={4} />
136
+ <DxcDropdown label="Xsmall" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xsmall" />
137
+ </ExampleContainer>
138
+ <ExampleContainer>
139
+ <Title title="Small" theme="light" level={4} />
140
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="small" />
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Medium" theme="light" level={4} />
144
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="medium" />
145
+ </ExampleContainer>
146
+ <ExampleContainer>
147
+ <Title title="Large" theme="light" level={4} />
148
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="large" />
149
+ </ExampleContainer>
150
+ <ExampleContainer>
151
+ <Title title="Xlarge" theme="light" level={4} />
152
+ <DxcDropdown label="Xlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xlarge" />
153
+ </ExampleContainer>
154
+ <ExampleContainer>
155
+ <Title title="Xxlarge" theme="light" level={4} />
156
+ <DxcDropdown label="Xxlarge" options={options} onSelectOption={(value) => {}} icon={iconSVG} margin="xxlarge" />
157
+ </ExampleContainer>
158
+ <Title title="Sizes" theme="light" level={2} />
159
+ <ExampleContainer>
160
+ <Title title="Small" theme="light" level={4} />
161
+ <DxcDropdown label="Small" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="small" />
162
+ </ExampleContainer>
163
+ <ExampleContainer>
164
+ <Title title="Medium" theme="light" level={4} />
165
+ <DxcDropdown label="Medium" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="medium" />
166
+ </ExampleContainer>
167
+ <ExampleContainer>
168
+ <Title title="Large" theme="light" level={4} />
169
+ <DxcDropdown label="Large" options={options} onSelectOption={(value) => {}} icon={iconSVG} size="large" />
170
+ </ExampleContainer>
171
+ <ExampleContainer>
172
+ <Title title="FitContent" theme="light" level={4} />
173
+ <DxcDropdown
174
+ label="FitContent"
175
+ options={options}
176
+ onSelectOption={(value) => {}}
177
+ icon={iconSVG}
178
+ size="fitContent"
179
+ />
180
+ </ExampleContainer>
181
+ <ExampleContainer>
182
+ <Title title="FillParent" theme="light" level={4} />
183
+ <DxcDropdown
184
+ label="FillParent"
185
+ options={options}
186
+ onSelectOption={(value) => {}}
187
+ icon={iconSVG}
188
+ size="fillParent"
189
+ />
190
+ </ExampleContainer>
191
+ </>
192
+ );
193
+
194
+ const DropdownWithOptions = () => (
195
+ <ExampleContainer expanded>
196
+ <Title title="Options" theme="light" level={4} />
197
+ <DxcDropdown label="Options with icon" options={optionsIcon} onSelectOption={(value) => {}} />
198
+ </ExampleContainer>
199
+ );
200
+
201
+ const DropdownHoverOption = () => (
202
+ <ExampleContainer pseudoState="pseudo-hover" expanded>
203
+ <Title title="Hovered option" theme="light" level={4} />
204
+ <DxcDropdown label="Hovered options" options={option} onSelectOption={(value) => {}} />
205
+ </ExampleContainer>
206
+ );
207
+
208
+ const DropdownActiveOption = () => (
209
+ <ExampleContainer pseudoState="pseudo-active" expanded>
210
+ <Title title="Actived option" theme="light" level={4} />
211
+ <DxcDropdown label="Actived options" options={option} onSelectOption={(value) => {}} />
212
+ </ExampleContainer>
213
+ );
214
+
215
+ const DropdownWithOptionsIconAfter = () => (
216
+ <ExampleContainer expanded>
217
+ <Title title="Icon after options" theme="light" level={4} />
218
+ <DxcDropdown
219
+ label="Icon after options"
220
+ options={optionsIcon}
221
+ onSelectOption={(value) => {}}
222
+ optionsIconPosition="after"
223
+ />
224
+ </ExampleContainer>
225
+ );
226
+
227
+ export const DropdownOptions = DropdownWithOptions.bind({});
228
+ DropdownOptions.play = async ({ canvasElement }) => {
229
+ const canvas = within(canvasElement);
230
+ await userEvent.click(canvas.getByRole("button"));
231
+ };
232
+
233
+ export const DropdownHoveredOption = DropdownHoverOption.bind({});
234
+ DropdownHoveredOption.play = async ({ canvasElement }) => {
235
+ const canvas = within(canvasElement);
236
+ await userEvent.click(canvas.getByRole("button"));
237
+ };
238
+
239
+ export const DropdownActivedOption = DropdownActiveOption.bind({});
240
+ DropdownActivedOption.play = async ({ canvasElement }) => {
241
+ const canvas = within(canvasElement);
242
+ await userEvent.click(canvas.getByRole("button"));
243
+ };
244
+
245
+ export const DropdownOptionsIconAfter = DropdownWithOptionsIconAfter.bind({});
246
+ DropdownOptionsIconAfter.play = async ({ canvasElement }) => {
247
+ const canvas = within(canvasElement);
248
+ await userEvent.click(canvas.getByRole("button"));
249
+ };