@dxc-technology/halstack-react 0.0.0-cd617f3 → 0.0.0-cedf067

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 (332) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +28 -64
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +43 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -87
  41. package/button/Button.stories.tsx +232 -242
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +14 -18
  44. package/card/Card.d.ts +4 -0
  45. package/card/Card.js +38 -77
  46. package/card/Card.stories.tsx +201 -0
  47. package/card/Card.test.js +50 -0
  48. package/card/ice-cream.jpg +0 -0
  49. package/card/types.d.ts +67 -0
  50. package/card/types.js +5 -0
  51. package/checkbox/Checkbox.d.ts +1 -1
  52. package/checkbox/Checkbox.js +45 -41
  53. package/checkbox/Checkbox.stories.tsx +188 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +9 -6
  56. package/chip/Chip.d.ts +4 -0
  57. package/chip/Chip.js +16 -76
  58. package/chip/Chip.stories.tsx +119 -0
  59. package/chip/Chip.test.js +56 -0
  60. package/chip/types.d.ts +45 -0
  61. package/chip/types.js +5 -0
  62. package/common/variables.js +301 -373
  63. package/date-input/DateInput.js +63 -52
  64. package/date-input/DateInput.stories.tsx +138 -0
  65. package/date-input/DateInput.test.js +479 -0
  66. package/date-input/types.d.ts +16 -9
  67. package/dialog/Dialog.d.ts +4 -0
  68. package/dialog/Dialog.js +10 -56
  69. package/dialog/Dialog.stories.tsx +212 -0
  70. package/dialog/Dialog.test.js +40 -0
  71. package/dialog/types.d.ts +43 -0
  72. package/dialog/types.js +5 -0
  73. package/dropdown/Dropdown.d.ts +4 -0
  74. package/dropdown/Dropdown.js +28 -87
  75. package/dropdown/Dropdown.stories.tsx +249 -0
  76. package/dropdown/Dropdown.test.js +189 -0
  77. package/dropdown/types.d.ts +80 -0
  78. package/dropdown/types.js +5 -0
  79. package/file-input/FileInput.d.ts +4 -0
  80. package/file-input/FileInput.js +172 -111
  81. package/file-input/FileInput.stories.tsx +507 -0
  82. package/file-input/FileInput.test.js +457 -0
  83. package/file-input/FileItem.d.ts +14 -0
  84. package/file-input/FileItem.js +16 -23
  85. package/file-input/types.d.ts +112 -0
  86. package/file-input/types.js +5 -0
  87. package/flex/Flex.d.ts +4 -0
  88. package/flex/Flex.js +57 -0
  89. package/flex/Flex.stories.tsx +103 -0
  90. package/flex/types.d.ts +21 -0
  91. package/flex/types.js +5 -0
  92. package/footer/Footer.d.ts +4 -0
  93. package/footer/Footer.js +36 -148
  94. package/footer/Footer.stories.tsx +130 -0
  95. package/footer/Footer.test.js +109 -0
  96. package/footer/Icons.d.ts +2 -0
  97. package/footer/Icons.js +4 -4
  98. package/footer/types.d.ts +65 -0
  99. package/footer/types.js +5 -0
  100. package/header/Header.d.ts +7 -0
  101. package/header/Header.js +55 -78
  102. package/header/Header.stories.tsx +172 -0
  103. package/header/Header.test.js +79 -0
  104. package/header/Icons.d.ts +2 -0
  105. package/header/Icons.js +2 -27
  106. package/header/types.d.ts +47 -0
  107. package/header/types.js +5 -0
  108. package/heading/Heading.d.ts +4 -0
  109. package/heading/Heading.js +7 -24
  110. package/heading/Heading.stories.tsx +54 -0
  111. package/heading/Heading.test.js +186 -0
  112. package/heading/types.d.ts +33 -0
  113. package/heading/types.js +5 -0
  114. package/inset/Inset.d.ts +3 -0
  115. package/inset/Inset.js +51 -0
  116. package/inset/Inset.stories.tsx +229 -0
  117. package/inset/types.d.ts +37 -0
  118. package/inset/types.js +5 -0
  119. package/layout/ApplicationLayout.d.ts +20 -0
  120. package/layout/ApplicationLayout.js +71 -135
  121. package/layout/ApplicationLayout.stories.tsx +161 -0
  122. package/layout/Icons.d.ts +5 -0
  123. package/layout/Icons.js +13 -2
  124. package/layout/SidenavContext.d.ts +5 -0
  125. package/layout/SidenavContext.js +19 -0
  126. package/layout/types.d.ts +42 -0
  127. package/layout/types.js +5 -0
  128. package/link/Link.d.ts +4 -0
  129. package/link/Link.js +60 -107
  130. package/link/Link.stories.tsx +193 -0
  131. package/link/Link.test.js +83 -0
  132. package/link/types.d.ts +54 -0
  133. package/link/types.js +5 -0
  134. package/main.d.ts +12 -12
  135. package/main.js +64 -58
  136. package/number-input/NumberInput.d.ts +4 -0
  137. package/number-input/NumberInput.js +16 -68
  138. package/number-input/NumberInput.stories.tsx +115 -0
  139. package/number-input/NumberInput.test.js +506 -0
  140. package/number-input/NumberInputContext.d.ts +4 -0
  141. package/number-input/NumberInputContext.js +5 -2
  142. package/number-input/numberInputContextTypes.d.ts +19 -0
  143. package/number-input/numberInputContextTypes.js +5 -0
  144. package/number-input/types.d.ts +124 -0
  145. package/number-input/types.js +5 -0
  146. package/package.json +10 -6
  147. package/paginator/Paginator.js +19 -46
  148. package/paginator/Paginator.stories.tsx +63 -0
  149. package/paginator/Paginator.test.js +308 -0
  150. package/paragraph/Paragraph.d.ts +6 -0
  151. package/paragraph/Paragraph.js +38 -0
  152. package/paragraph/Paragraph.stories.tsx +44 -0
  153. package/password-input/PasswordInput.d.ts +4 -0
  154. package/password-input/PasswordInput.js +22 -55
  155. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  156. package/password-input/PasswordInput.test.js +180 -0
  157. package/password-input/types.d.ts +110 -0
  158. package/password-input/types.js +5 -0
  159. package/progress-bar/ProgressBar.d.ts +4 -0
  160. package/progress-bar/ProgressBar.js +64 -71
  161. package/progress-bar/ProgressBar.stories.jsx +60 -0
  162. package/progress-bar/ProgressBar.test.js +110 -0
  163. package/progress-bar/types.d.ts +36 -0
  164. package/progress-bar/types.js +5 -0
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +118 -0
  167. package/quick-nav/QuickNav.stories.tsx +264 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +4 -0
  171. package/radio-group/Radio.js +141 -0
  172. package/radio-group/RadioGroup.d.ts +4 -0
  173. package/radio-group/RadioGroup.js +283 -0
  174. package/radio-group/RadioGroup.stories.tsx +100 -0
  175. package/radio-group/RadioGroup.test.js +695 -0
  176. package/radio-group/types.d.ts +114 -0
  177. package/radio-group/types.js +5 -0
  178. package/resultsetTable/ResultsetTable.d.ts +4 -0
  179. package/resultsetTable/ResultsetTable.js +9 -29
  180. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  181. package/resultsetTable/ResultsetTable.test.js +348 -0
  182. package/resultsetTable/types.d.ts +67 -0
  183. package/resultsetTable/types.js +5 -0
  184. package/select/Icons.d.ts +10 -0
  185. package/select/Icons.js +93 -0
  186. package/select/Listbox.d.ts +4 -0
  187. package/select/Listbox.js +199 -0
  188. package/select/Option.d.ts +4 -0
  189. package/select/Option.js +110 -0
  190. package/select/Select.d.ts +4 -0
  191. package/select/Select.js +158 -380
  192. package/select/Select.stories.tsx +627 -0
  193. package/select/Select.test.js +2175 -0
  194. package/select/types.d.ts +210 -0
  195. package/select/types.js +5 -0
  196. package/sidenav/Sidenav.d.ts +10 -0
  197. package/sidenav/Sidenav.js +186 -63
  198. package/sidenav/Sidenav.stories.tsx +180 -0
  199. package/sidenav/Sidenav.test.js +44 -0
  200. package/sidenav/types.d.ts +73 -0
  201. package/sidenav/types.js +5 -0
  202. package/slider/Slider.d.ts +4 -0
  203. package/slider/Slider.js +63 -85
  204. package/slider/Slider.stories.tsx +177 -0
  205. package/slider/Slider.test.js +150 -0
  206. package/slider/types.d.ts +82 -0
  207. package/slider/types.js +5 -0
  208. package/spinner/Spinner.d.ts +4 -0
  209. package/spinner/Spinner.js +9 -26
  210. package/spinner/Spinner.stories.jsx +103 -0
  211. package/spinner/Spinner.test.js +64 -0
  212. package/spinner/types.d.ts +32 -0
  213. package/spinner/types.js +5 -0
  214. package/switch/Switch.d.ts +1 -1
  215. package/switch/Switch.js +37 -21
  216. package/switch/Switch.stories.tsx +160 -0
  217. package/switch/Switch.test.js +98 -0
  218. package/switch/types.d.ts +6 -2
  219. package/table/Table.d.ts +4 -0
  220. package/table/Table.js +3 -3
  221. package/table/Table.stories.jsx +277 -0
  222. package/table/Table.test.js +26 -0
  223. package/table/types.d.ts +21 -0
  224. package/table/types.js +5 -0
  225. package/tabs/Tabs.d.ts +4 -0
  226. package/tabs/Tabs.js +24 -72
  227. package/tabs/Tabs.stories.tsx +112 -0
  228. package/tabs/Tabs.test.js +140 -0
  229. package/tabs/types.d.ts +82 -0
  230. package/tabs/types.js +5 -0
  231. package/tabs-nav/NavTabs.d.ts +8 -0
  232. package/tabs-nav/NavTabs.js +125 -0
  233. package/tabs-nav/NavTabs.stories.tsx +170 -0
  234. package/tabs-nav/NavTabs.test.js +82 -0
  235. package/tabs-nav/Tab.d.ts +4 -0
  236. package/tabs-nav/Tab.js +132 -0
  237. package/tabs-nav/types.d.ts +53 -0
  238. package/tabs-nav/types.js +5 -0
  239. package/tag/Tag.d.ts +4 -0
  240. package/tag/Tag.js +34 -59
  241. package/tag/Tag.stories.tsx +142 -0
  242. package/tag/Tag.test.js +60 -0
  243. package/tag/types.d.ts +69 -0
  244. package/tag/types.js +5 -0
  245. package/text-input/Suggestion.d.ts +4 -0
  246. package/text-input/Suggestion.js +55 -0
  247. package/text-input/TextInput.d.ts +4 -0
  248. package/text-input/TextInput.js +91 -146
  249. package/text-input/TextInput.stories.tsx +474 -0
  250. package/text-input/TextInput.test.js +1712 -0
  251. package/text-input/types.d.ts +178 -0
  252. package/text-input/types.js +5 -0
  253. package/textarea/Textarea.d.ts +4 -0
  254. package/textarea/Textarea.js +39 -79
  255. package/textarea/Textarea.stories.jsx +157 -0
  256. package/textarea/Textarea.test.js +437 -0
  257. package/textarea/types.d.ts +137 -0
  258. package/textarea/types.js +5 -0
  259. package/toggle-group/ToggleGroup.d.ts +4 -0
  260. package/toggle-group/ToggleGroup.js +18 -46
  261. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  262. package/toggle-group/ToggleGroup.test.js +156 -0
  263. package/toggle-group/types.d.ts +105 -0
  264. package/toggle-group/types.js +5 -0
  265. package/typography/Typography.d.ts +4 -0
  266. package/typography/Typography.js +131 -0
  267. package/typography/Typography.stories.tsx +198 -0
  268. package/typography/types.d.ts +18 -0
  269. package/typography/types.js +5 -0
  270. package/useTheme.d.ts +2 -0
  271. package/useTheme.js +2 -2
  272. package/useTranslatedLabels.d.ts +2 -0
  273. package/useTranslatedLabels.js +20 -0
  274. package/wizard/Wizard.d.ts +4 -0
  275. package/wizard/Wizard.js +118 -104
  276. package/wizard/Wizard.stories.tsx +233 -0
  277. package/wizard/Wizard.test.js +141 -0
  278. package/wizard/types.d.ts +65 -0
  279. package/wizard/types.js +5 -0
  280. package/ThemeContext.js +0 -246
  281. package/V3Select/V3Select.js +0 -455
  282. package/V3Select/index.d.ts +0 -27
  283. package/V3Textarea/V3Textarea.js +0 -260
  284. package/V3Textarea/index.d.ts +0 -27
  285. package/box/index.d.ts +0 -25
  286. package/card/index.d.ts +0 -22
  287. package/chip/index.d.ts +0 -22
  288. package/date/Date.js +0 -373
  289. package/date/index.d.ts +0 -27
  290. package/dialog/index.d.ts +0 -18
  291. package/dropdown/index.d.ts +0 -26
  292. package/file-input/index.d.ts +0 -81
  293. package/footer/index.d.ts +0 -25
  294. package/header/index.d.ts +0 -25
  295. package/heading/index.d.ts +0 -17
  296. package/input-text/Icons.js +0 -22
  297. package/input-text/InputText.js +0 -611
  298. package/input-text/index.d.ts +0 -36
  299. package/link/index.d.ts +0 -23
  300. package/number-input/index.d.ts +0 -113
  301. package/password-input/index.d.ts +0 -94
  302. package/progress-bar/index.d.ts +0 -18
  303. package/radio/Radio.d.ts +0 -4
  304. package/radio/Radio.js +0 -174
  305. package/radio/types.d.ts +0 -54
  306. package/resultsetTable/index.d.ts +0 -19
  307. package/select/index.d.ts +0 -131
  308. package/sidenav/index.d.ts +0 -13
  309. package/slider/index.d.ts +0 -29
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tabs/index.d.ts +0 -19
  313. package/tag/index.d.ts +0 -24
  314. package/text-input/index.d.ts +0 -135
  315. package/textarea/index.d.ts +0 -117
  316. package/toggle/Toggle.js +0 -186
  317. package/toggle/index.d.ts +0 -21
  318. package/toggle-group/index.d.ts +0 -21
  319. package/upload/Upload.js +0 -201
  320. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  321. package/upload/buttons-upload/Icons.js +0 -40
  322. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  323. package/upload/dragAndDropArea/Icons.js +0 -39
  324. package/upload/file-upload/FileToUpload.js +0 -115
  325. package/upload/file-upload/Icons.js +0 -66
  326. package/upload/files-upload/FilesToUpload.js +0 -109
  327. package/upload/index.d.ts +0 -15
  328. package/upload/transaction/Icons.js +0 -160
  329. package/upload/transaction/Transaction.js +0 -104
  330. package/upload/transactions/Transactions.js +0 -94
  331. package/wizard/Icons.js +0 -65
  332. 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
+ });
@@ -0,0 +1,43 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Padding = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Props = {
10
+ /**
11
+ * If true, the close 'x' button will be visible.
12
+ */
13
+ isCloseVisible?: boolean;
14
+ /**
15
+ * This function will be called when the user clicks the close 'x' button.
16
+ * The responsibility of hiding the modal lies with the user.
17
+ */
18
+ onCloseClick?: () => void;
19
+ /**
20
+ * If true, the dialog will be displayed over a darker background that covers the content behind.
21
+ */
22
+ overlay?: boolean;
23
+ /**
24
+ * This function will be called when the user clicks background of the modal.
25
+ * The responsibility of hiding the modal lies with the user.
26
+ */
27
+ onBackgroundClick?: () => void;
28
+ /**
29
+ * Size of the padding to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
30
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
31
+ */
32
+ padding?: Padding | Space;
33
+ /**
34
+ * Value of the tabindex given to the close 'x' button.
35
+ */
36
+ tabIndex?: number;
37
+ /**
38
+ * The area inside the dialog. This area can be used to render
39
+ * custom content.
40
+ */
41
+ children: React.ReactNode;
42
+ };
43
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import DropdownPropsType from "./types";
3
+ declare const DxcDropdown: ({ options, optionsIconPosition, icon, iconPosition, label, caretHidden, onSelectOption, expandOnHover, margin, size, tabIndex, disabled, }: DropdownPropsType) => JSX.Element;
4
+ export default DxcDropdown;
@@ -9,20 +9,16 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
14
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
15
 
16
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
-
18
16
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
17
 
20
18
  var _react = _interopRequireWildcard(require("react"));
21
19
 
22
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
21
 
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
22
  var _Popper = _interopRequireDefault(require("@material-ui/core/Popper"));
27
23
 
28
24
  var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
@@ -39,7 +35,7 @@ var _variables = require("../common/variables.js");
39
35
 
40
36
  var _utils = require("../common/utils.js");
41
37
 
42
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
38
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
43
39
 
44
40
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10;
45
41
 
@@ -48,29 +44,26 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
48
44
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
49
45
 
50
46
  var DxcDropdown = function DxcDropdown(_ref) {
51
- var _ref$options = _ref.options,
52
- options = _ref$options === void 0 ? [] : _ref$options,
47
+ var options = _ref.options,
53
48
  _ref$optionsIconPosit = _ref.optionsIconPosition,
54
49
  optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
55
50
  icon = _ref.icon,
56
- _ref$iconSrc = _ref.iconSrc,
57
- iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
58
51
  _ref$iconPosition = _ref.iconPosition,
59
52
  iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
60
53
  _ref$label = _ref.label,
61
54
  label = _ref$label === void 0 ? "" : _ref$label,
62
- _ref$disabled = _ref.disabled,
63
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
64
55
  _ref$caretHidden = _ref.caretHidden,
65
56
  caretHidden = _ref$caretHidden === void 0 ? false : _ref$caretHidden,
66
57
  onSelectOption = _ref.onSelectOption,
58
+ _ref$expandOnHover = _ref.expandOnHover,
59
+ expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover,
67
60
  margin = _ref.margin,
68
61
  _ref$size = _ref.size,
69
62
  size = _ref$size === void 0 ? "fitContent" : _ref$size,
70
- _ref$expandOnHover = _ref.expandOnHover,
71
- expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover,
72
63
  _ref$tabIndex = _ref.tabIndex,
73
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
64
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
65
+ _ref$disabled = _ref.disabled,
66
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled;
74
67
 
75
68
  var _useState = (0, _react.useState)(),
76
69
  _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
@@ -106,10 +99,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
106
99
 
107
100
  function handleMenuItemClick(option) {
108
101
  setAnchorEl(null);
109
-
110
- if (typeof onSelectOption === "function") {
111
- onSelectOption(option.value);
112
- }
102
+ onSelectOption(option.value);
113
103
  }
114
104
 
115
105
  function handleClose() {
@@ -148,6 +138,11 @@ var DxcDropdown = function DxcDropdown(_ref) {
148
138
  }));
149
139
  };
150
140
 
141
+ var labelComponent = /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, {
142
+ iconPosition: iconPosition,
143
+ label: label
144
+ }, label);
145
+
151
146
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
152
147
  theme: colorsTheme.dropdown
153
148
  }, /*#__PURE__*/_react["default"].createElement(DXCDropdownContainer, {
@@ -170,20 +165,14 @@ var DxcDropdown = function DxcDropdown(_ref) {
170
165
  ref: ref,
171
166
  tabIndex: tabIndex
172
167
  }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContainer, {
173
- iconPosition: iconPosition,
174
168
  caretHidden: caretHidden
175
- }, icon ? /*#__PURE__*/_react["default"].createElement(ButtonIconContainer, {
169
+ }, iconPosition === "after" && labelComponent, icon && /*#__PURE__*/_react["default"].createElement(ButtonIconContainer, {
176
170
  label: label,
177
171
  iconPosition: iconPosition,
178
172
  disabled: disabled
179
- }, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : iconSrc && /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
180
- label: label,
181
- src: iconSrc,
182
- iconPosition: iconPosition
183
- }), /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, {
184
- iconPosition: iconPosition,
185
- label: label
186
- }, label)), /*#__PURE__*/_react["default"].createElement(CaretIconContainer, {
173
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(ButtonIcon, {
174
+ src: icon
175
+ }) : icon), iconPosition === "before" && labelComponent), /*#__PURE__*/_react["default"].createElement(CaretIconContainer, {
187
176
  caretHidden: caretHidden,
188
177
  disabled: disabled
189
178
  }, !caretHidden && (anchorEl === null ? /*#__PURE__*/_react["default"].createElement(DownArrowIcon, null) : /*#__PURE__*/_react["default"].createElement(UpArrowIcon, null)))), /*#__PURE__*/_react["default"].createElement(DXCMenu, {
@@ -199,7 +188,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
199
188
  vertical: "top",
200
189
  horizontal: "left"
201
190
  },
202
- optionsIconPosition: optionsIconPosition,
203
191
  size: size,
204
192
  width: width,
205
193
  role: undefined,
@@ -221,14 +209,14 @@ var DxcDropdown = function DxcDropdown(_ref) {
221
209
  onClick: function onClick(event) {
222
210
  return handleMenuItemClick(option);
223
211
  }
224
- }, option.icon ? /*#__PURE__*/_react["default"].createElement(ListIconContainer, {
225
- label: option.label,
226
- iconPosition: optionsIconPosition
227
- }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : /*#__PURE__*/_react["default"].createElement(option.icon)) : option.iconSrc && /*#__PURE__*/_react["default"].createElement(ListIcon, {
212
+ }, optionsIconPosition === "after" && /*#__PURE__*/_react["default"].createElement("span", {
213
+ className: "optionLabel"
214
+ }, option.label), option.icon && /*#__PURE__*/_react["default"].createElement(ListIconContainer, {
228
215
  label: option.label,
229
- src: option.iconSrc,
230
216
  iconPosition: optionsIconPosition
231
- }), /*#__PURE__*/_react["default"].createElement("span", {
217
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement(ListIcon, {
218
+ src: option.icon
219
+ }) : option.icon), optionsIconPosition === "before" && /*#__PURE__*/_react["default"].createElement("span", {
232
220
  className: "optionLabel"
233
221
  }, option.label));
234
222
  })))));
@@ -265,7 +253,7 @@ var DXCDropdownContainer = _styledComponents["default"].div(_templateObject || (
265
253
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
266
254
  });
267
255
 
268
- var DXCMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1;\n\n .MuiMenuItem-gutters {\n width: ", ";\n }\n .MuiMenuItem-root {\n min-height: 36px;\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n height: auto;\n }\n .MuiPaper-root {\n min-width: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0px;\n border-top-right-radius: 0px;\n max-height: 230px;\n overflow-y: auto;\n\n ::-webkit-scrollbar {\n width: 3px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n\n .MuiList-padding {\n padding-top: 0px;\n padding-bottom: 0px;\n }\n .MuiListItem-button {\n display: flex;\n flex-direction: ", ";\n justify-content: ", ";\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n cursor: pointer;\n }\n .MuiListItem-button:focus {\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n .MuiListItem-button:hover {\n background-color: ", ";\n }\n .MuiListItem-button:active {\n background-color: ", ";\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n }\n"])), function (props) {
256
+ var DXCMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n z-index: 1;\n\n .MuiMenuItem-gutters {\n width: ", ";\n }\n .MuiMenuItem-root {\n min-height: 36px;\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n height: auto;\n }\n .MuiPaper-root {\n min-width: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n border-bottom-left-radius: ", ";\n border-bottom-right-radius: ", ";\n border-top-left-radius: 0px;\n border-top-right-radius: 0px;\n max-height: 230px;\n overflow-y: auto;\n\n ::-webkit-scrollbar {\n width: 3px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n\n .MuiList-padding {\n padding-top: 0px;\n padding-bottom: 0px;\n }\n .MuiListItem-button {\n display: flex;\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n cursor: pointer;\n }\n .MuiListItem-button:focus {\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n .MuiListItem-button:hover {\n background-color: ", ";\n }\n .MuiListItem-button:active {\n background-color: ", ";\n outline: ", " solid 2px;\n outline-offset: -2px;\n }\n }\n"])), function (props) {
269
257
  return calculateWidth(props.margin, props.size);
270
258
  }, function (props) {
271
259
  return props.theme.optionPaddingTop;
@@ -291,10 +279,6 @@ var DXCMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObj
291
279
  return props.theme.scrollBarTrackColor;
292
280
  }, function (props) {
293
281
  return props.theme.scrollBarThumbColor;
294
- }, function (props) {
295
- return props.optionsIconPosition === "after" && "row-reverse" || "row";
296
- }, function (props) {
297
- return props.optionsIconPosition === "after" && "flex-end" || "";
298
282
  }, function (props) {
299
283
  return props.theme.optionBackgroundColor;
300
284
  }, function (props) {
@@ -359,21 +343,11 @@ var DropdownTrigger = _styledComponents["default"].button(_templateObject3 || (_
359
343
 
360
344
  var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n text-overflow: ellipsis;\n overflow: hidden;\n"])));
361
345
 
362
- var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n flex-direction: ", ";\n margin-left: 0px;\n margin-right: 0px;\n width: ", ";\n white-space: nowrap;\n"])), function (props) {
363
- return props.iconPosition === "after" && "row-reverse" || "row";
364
- }, function (props) {
346
+ var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n margin-left: 0px;\n margin-right: 0px;\n width: ", ";\n white-space: nowrap;\n"])), function (props) {
365
347
  return props.caretHidden ? "100%" : "calc(100% - 36px)";
366
348
  });
367
349
 
368
- var ButtonIcon = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
369
- return props.theme.buttonIconSize;
370
- }, function (props) {
371
- return props.theme.buttonIconSize;
372
- }, function (props) {
373
- return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
374
- }, function (props) {
375
- return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
376
- });
350
+ var ButtonIcon = _styledComponents["default"].img(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])([""])));
377
351
 
378
352
  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) {
379
353
  return props.theme.buttonIconSize;
@@ -387,15 +361,7 @@ var ButtonIconContainer = _styledComponents["default"].div(_templateObject7 || (
387
361
  return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
388
362
  });
389
363
 
390
- var ListIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
391
- return props.theme.optionIconSize;
392
- }, function (props) {
393
- return props.theme.optionIconSize;
394
- }, function (props) {
395
- return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
396
- }, function (props) {
397
- return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
398
- });
364
+ var ListIcon = _styledComponents["default"].img(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])([""])));
399
365
 
400
366
  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) {
401
367
  return props.theme.optionIconSize;
@@ -421,30 +387,5 @@ var CaretIconContainer = _styledComponents["default"].div(_templateObject10 || (
421
387
  return props.theme.caretIconSize;
422
388
  });
423
389
 
424
- DxcDropdown.propTypes = {
425
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
426
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
427
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
428
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
429
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
430
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
431
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
432
- optionsIconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
433
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
434
- iconSrc: _propTypes["default"].string,
435
- iconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
436
- label: _propTypes["default"].string,
437
- caretHidden: _propTypes["default"].bool,
438
- disabled: _propTypes["default"].bool,
439
- expandOnHover: _propTypes["default"].bool,
440
- onSelectOption: _propTypes["default"].func,
441
- options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
442
- value: _propTypes["default"].any.isRequired,
443
- label: _propTypes["default"].any.isRequired,
444
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
445
- iconSrc: _propTypes["default"].string
446
- })),
447
- tabIndex: _propTypes["default"].number
448
- };
449
390
  var _default = DxcDropdown;
450
391
  exports["default"] = _default;