@dxc-technology/halstack-react 0.0.0-da90bf9 → 0.0.0-da9270d

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 (403) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +8 -24
  3. package/HalstackContext.d.ts +1235 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +4 -0
  7. package/accordion/Accordion.js +120 -291
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +57 -0
  11. package/accordion/types.js +5 -0
  12. package/accordion-group/AccordionGroup.d.ts +8 -0
  13. package/accordion-group/AccordionGroup.js +57 -142
  14. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  15. package/accordion-group/AccordionGroup.test.js +98 -0
  16. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  17. package/accordion-group/AccordionGroupAccordion.js +31 -0
  18. package/accordion-group/types.d.ts +67 -0
  19. package/accordion-group/types.js +5 -0
  20. package/alert/Alert.d.ts +4 -0
  21. package/alert/Alert.js +55 -204
  22. package/alert/Alert.stories.tsx +198 -0
  23. package/alert/Alert.test.js +75 -0
  24. package/alert/types.d.ts +49 -0
  25. package/alert/types.js +5 -0
  26. package/badge/Badge.d.ts +4 -0
  27. package/badge/Badge.js +15 -30
  28. package/badge/types.d.ts +5 -0
  29. package/badge/types.js +5 -0
  30. package/bleed/Bleed.d.ts +3 -0
  31. package/bleed/Bleed.js +43 -0
  32. package/bleed/Bleed.stories.tsx +342 -0
  33. package/bleed/types.d.ts +37 -0
  34. package/bleed/types.js +5 -0
  35. package/box/Box.d.ts +4 -0
  36. package/box/Box.js +35 -116
  37. package/box/Box.stories.tsx +119 -0
  38. package/box/Box.test.js +13 -0
  39. package/box/types.d.ts +32 -0
  40. package/box/types.js +5 -0
  41. package/bulleted-list/BulletedList.d.ts +7 -0
  42. package/bulleted-list/BulletedList.js +89 -0
  43. package/bulleted-list/BulletedList.stories.tsx +115 -0
  44. package/bulleted-list/types.d.ts +38 -0
  45. package/bulleted-list/types.js +5 -0
  46. package/button/Button.d.ts +4 -0
  47. package/button/Button.js +67 -185
  48. package/button/Button.stories.tsx +344 -0
  49. package/button/Button.test.js +36 -0
  50. package/button/types.d.ts +57 -0
  51. package/button/types.js +5 -0
  52. package/card/Card.d.ts +4 -0
  53. package/card/Card.js +60 -194
  54. package/card/Card.stories.tsx +171 -0
  55. package/card/Card.test.js +39 -0
  56. package/card/types.d.ts +62 -0
  57. package/card/types.js +5 -0
  58. package/checkbox/Checkbox.d.ts +4 -0
  59. package/checkbox/Checkbox.js +147 -231
  60. package/checkbox/Checkbox.stories.tsx +222 -0
  61. package/checkbox/Checkbox.test.js +199 -0
  62. package/checkbox/types.d.ts +72 -0
  63. package/checkbox/types.js +5 -0
  64. package/chip/Chip.d.ts +4 -0
  65. package/chip/Chip.js +50 -194
  66. package/chip/Chip.stories.tsx +214 -0
  67. package/chip/Chip.test.js +41 -0
  68. package/chip/types.d.ts +45 -0
  69. package/chip/types.js +5 -0
  70. package/common/OpenSans.css +68 -80
  71. package/common/coreTokens.d.ts +237 -0
  72. package/common/coreTokens.js +184 -0
  73. package/common/utils.d.ts +1 -0
  74. package/common/utils.js +6 -12
  75. package/common/variables.d.ts +1381 -0
  76. package/common/variables.js +1006 -1319
  77. package/container/Container.d.ts +4 -0
  78. package/container/Container.js +194 -0
  79. package/container/Container.stories.tsx +214 -0
  80. package/container/types.d.ts +74 -0
  81. package/container/types.js +5 -0
  82. package/date-input/Calendar.d.ts +4 -0
  83. package/date-input/Calendar.js +214 -0
  84. package/date-input/DateInput.d.ts +4 -0
  85. package/date-input/DateInput.js +179 -356
  86. package/date-input/DateInput.stories.tsx +285 -0
  87. package/date-input/DateInput.test.js +808 -0
  88. package/date-input/DatePicker.d.ts +4 -0
  89. package/date-input/DatePicker.js +115 -0
  90. package/date-input/Icons.d.ts +6 -0
  91. package/date-input/Icons.js +58 -0
  92. package/date-input/YearPicker.d.ts +4 -0
  93. package/date-input/YearPicker.js +100 -0
  94. package/date-input/types.d.ts +164 -0
  95. package/date-input/types.js +5 -0
  96. package/dialog/Dialog.d.ts +4 -0
  97. package/dialog/Dialog.js +70 -184
  98. package/dialog/Dialog.stories.tsx +365 -0
  99. package/dialog/Dialog.test.js +307 -0
  100. package/dialog/types.d.ts +36 -0
  101. package/dialog/types.js +5 -0
  102. package/dropdown/Dropdown.d.ts +4 -0
  103. package/dropdown/Dropdown.js +247 -457
  104. package/dropdown/Dropdown.stories.tsx +438 -0
  105. package/dropdown/Dropdown.test.js +599 -0
  106. package/dropdown/DropdownMenu.d.ts +4 -0
  107. package/dropdown/DropdownMenu.js +63 -0
  108. package/dropdown/DropdownMenuItem.d.ts +4 -0
  109. package/dropdown/DropdownMenuItem.js +67 -0
  110. package/dropdown/types.d.ts +98 -0
  111. package/dropdown/types.js +5 -0
  112. package/file-input/FileInput.d.ts +4 -0
  113. package/file-input/FileInput.js +297 -462
  114. package/file-input/FileInput.stories.tsx +618 -0
  115. package/file-input/FileInput.test.js +459 -0
  116. package/file-input/FileItem.d.ts +4 -0
  117. package/file-input/FileItem.js +61 -213
  118. package/file-input/types.d.ts +129 -0
  119. package/file-input/types.js +5 -0
  120. package/flex/Flex.d.ts +4 -0
  121. package/flex/Flex.js +57 -0
  122. package/flex/Flex.stories.tsx +112 -0
  123. package/flex/types.d.ts +97 -0
  124. package/flex/types.js +5 -0
  125. package/footer/Footer.d.ts +4 -0
  126. package/footer/Footer.js +64 -360
  127. package/footer/Footer.stories.tsx +152 -0
  128. package/footer/Footer.test.js +85 -0
  129. package/footer/Icons.d.ts +2 -0
  130. package/footer/Icons.js +16 -21
  131. package/footer/types.d.ts +58 -0
  132. package/footer/types.js +5 -0
  133. package/grid/Grid.d.ts +7 -0
  134. package/grid/Grid.js +76 -0
  135. package/grid/Grid.stories.tsx +219 -0
  136. package/grid/types.d.ts +115 -0
  137. package/grid/types.js +5 -0
  138. package/header/Header.d.ts +8 -0
  139. package/header/Header.js +122 -372
  140. package/header/Header.stories.tsx +251 -0
  141. package/header/Header.test.js +66 -0
  142. package/header/Icons.d.ts +2 -0
  143. package/header/Icons.js +9 -39
  144. package/header/types.d.ts +33 -0
  145. package/header/types.js +5 -0
  146. package/heading/Heading.d.ts +4 -0
  147. package/heading/Heading.js +31 -124
  148. package/heading/Heading.stories.tsx +54 -0
  149. package/heading/Heading.test.js +169 -0
  150. package/heading/types.d.ts +33 -0
  151. package/heading/types.js +5 -0
  152. package/image/Image.d.ts +4 -0
  153. package/image/Image.js +70 -0
  154. package/image/Image.stories.tsx +127 -0
  155. package/image/types.d.ts +72 -0
  156. package/image/types.js +5 -0
  157. package/inset/Inset.d.ts +3 -0
  158. package/inset/Inset.js +43 -0
  159. package/inset/Inset.stories.tsx +230 -0
  160. package/inset/types.d.ts +37 -0
  161. package/inset/types.js +5 -0
  162. package/layout/ApplicationLayout.d.ts +20 -0
  163. package/layout/ApplicationLayout.js +85 -278
  164. package/layout/ApplicationLayout.stories.tsx +162 -0
  165. package/layout/Icons.d.ts +8 -0
  166. package/layout/Icons.js +51 -48
  167. package/layout/SidenavContext.d.ts +5 -0
  168. package/layout/SidenavContext.js +13 -0
  169. package/layout/types.d.ts +41 -0
  170. package/layout/types.js +5 -0
  171. package/link/Link.d.ts +4 -0
  172. package/link/Link.js +67 -189
  173. package/link/Link.stories.tsx +253 -0
  174. package/link/Link.test.js +63 -0
  175. package/link/types.d.ts +54 -0
  176. package/link/types.js +5 -0
  177. package/main.d.ts +46 -40
  178. package/main.js +117 -140
  179. package/nav-tabs/NavTabs.d.ts +8 -0
  180. package/nav-tabs/NavTabs.js +90 -0
  181. package/nav-tabs/NavTabs.stories.tsx +274 -0
  182. package/nav-tabs/NavTabs.test.js +75 -0
  183. package/nav-tabs/Tab.d.ts +4 -0
  184. package/nav-tabs/Tab.js +117 -0
  185. package/nav-tabs/types.d.ts +52 -0
  186. package/nav-tabs/types.js +5 -0
  187. package/number-input/NumberInput.d.ts +11 -0
  188. package/number-input/NumberInput.js +32 -101
  189. package/number-input/NumberInput.stories.tsx +131 -0
  190. package/number-input/NumberInput.test.js +830 -0
  191. package/number-input/types.d.ts +130 -0
  192. package/number-input/types.js +5 -0
  193. package/package.json +53 -49
  194. package/paginator/Icons.d.ts +5 -0
  195. package/paginator/Icons.js +26 -52
  196. package/paginator/Paginator.d.ts +4 -0
  197. package/paginator/Paginator.js +41 -211
  198. package/paginator/Paginator.stories.tsx +87 -0
  199. package/paginator/Paginator.test.js +335 -0
  200. package/paginator/types.d.ts +38 -0
  201. package/paginator/types.js +5 -0
  202. package/paragraph/Paragraph.d.ts +5 -0
  203. package/paragraph/Paragraph.js +22 -0
  204. package/paragraph/Paragraph.stories.tsx +27 -0
  205. package/password-input/Icons.d.ts +6 -0
  206. package/password-input/Icons.js +35 -0
  207. package/password-input/PasswordInput.d.ts +4 -0
  208. package/password-input/PasswordInput.js +66 -172
  209. package/password-input/PasswordInput.stories.tsx +99 -0
  210. package/password-input/PasswordInput.test.js +198 -0
  211. package/password-input/types.d.ts +111 -0
  212. package/password-input/types.js +5 -0
  213. package/progress-bar/ProgressBar.d.ts +4 -0
  214. package/progress-bar/ProgressBar.js +76 -174
  215. package/progress-bar/ProgressBar.stories.tsx +93 -0
  216. package/progress-bar/ProgressBar.test.js +93 -0
  217. package/progress-bar/types.d.ts +37 -0
  218. package/progress-bar/types.js +5 -0
  219. package/quick-nav/QuickNav.d.ts +4 -0
  220. package/quick-nav/QuickNav.js +94 -0
  221. package/quick-nav/QuickNav.stories.tsx +356 -0
  222. package/quick-nav/types.d.ts +21 -0
  223. package/quick-nav/types.js +5 -0
  224. package/radio-group/Radio.d.ts +4 -0
  225. package/radio-group/Radio.js +124 -0
  226. package/radio-group/RadioGroup.d.ts +4 -0
  227. package/radio-group/RadioGroup.js +235 -0
  228. package/radio-group/RadioGroup.stories.tsx +214 -0
  229. package/radio-group/RadioGroup.test.js +756 -0
  230. package/radio-group/types.d.ts +114 -0
  231. package/radio-group/types.js +5 -0
  232. package/resultset-table/Icons.d.ts +7 -0
  233. package/resultset-table/Icons.js +47 -0
  234. package/resultset-table/ResultsetTable.d.ts +4 -0
  235. package/resultset-table/ResultsetTable.js +159 -0
  236. package/resultset-table/ResultsetTable.stories.tsx +300 -0
  237. package/resultset-table/ResultsetTable.test.js +305 -0
  238. package/resultset-table/types.d.ts +67 -0
  239. package/resultset-table/types.js +5 -0
  240. package/select/Icons.d.ts +10 -0
  241. package/select/Icons.js +89 -0
  242. package/select/Listbox.d.ts +4 -0
  243. package/select/Listbox.js +143 -0
  244. package/select/Option.d.ts +4 -0
  245. package/select/Option.js +80 -0
  246. package/select/Select.d.ts +4 -0
  247. package/select/Select.js +294 -849
  248. package/select/Select.stories.tsx +971 -0
  249. package/select/Select.test.js +2370 -0
  250. package/select/types.d.ts +209 -0
  251. package/select/types.js +5 -0
  252. package/sidenav/Icons.d.ts +7 -0
  253. package/sidenav/Icons.js +47 -0
  254. package/sidenav/Sidenav.d.ts +10 -0
  255. package/sidenav/Sidenav.js +134 -117
  256. package/sidenav/Sidenav.stories.tsx +282 -0
  257. package/sidenav/Sidenav.test.js +37 -0
  258. package/sidenav/types.d.ts +76 -0
  259. package/sidenav/types.js +5 -0
  260. package/slider/Slider.d.ts +4 -0
  261. package/slider/Slider.js +172 -291
  262. package/slider/Slider.test.js +254 -0
  263. package/slider/types.d.ts +86 -0
  264. package/slider/types.js +5 -0
  265. package/spinner/Spinner.d.ts +4 -0
  266. package/spinner/Spinner.js +66 -241
  267. package/spinner/Spinner.stories.tsx +129 -0
  268. package/spinner/Spinner.test.js +55 -0
  269. package/spinner/types.d.ts +32 -0
  270. package/spinner/types.js +5 -0
  271. package/switch/Switch.d.ts +4 -0
  272. package/switch/Switch.js +153 -161
  273. package/switch/Switch.stories.tsx +137 -0
  274. package/switch/Switch.test.js +180 -0
  275. package/switch/types.d.ts +66 -0
  276. package/switch/types.js +5 -0
  277. package/table/Table.d.ts +4 -0
  278. package/table/Table.js +14 -50
  279. package/table/Table.stories.tsx +356 -0
  280. package/table/Table.test.js +21 -0
  281. package/table/types.d.ts +21 -0
  282. package/table/types.js +5 -0
  283. package/tabs/Tab.d.ts +4 -0
  284. package/tabs/Tab.js +113 -0
  285. package/tabs/Tabs.d.ts +4 -0
  286. package/tabs/Tabs.js +322 -281
  287. package/tabs/Tabs.stories.tsx +226 -0
  288. package/tabs/Tabs.test.js +294 -0
  289. package/tabs/types.d.ts +92 -0
  290. package/tabs/types.js +5 -0
  291. package/tag/Tag.d.ts +4 -0
  292. package/tag/Tag.js +61 -192
  293. package/tag/Tag.stories.tsx +155 -0
  294. package/tag/Tag.test.js +49 -0
  295. package/tag/types.d.ts +69 -0
  296. package/tag/types.js +5 -0
  297. package/text-input/Icons.d.ts +8 -0
  298. package/text-input/Icons.js +56 -0
  299. package/text-input/Suggestion.d.ts +4 -0
  300. package/text-input/Suggestion.js +67 -0
  301. package/text-input/Suggestions.d.ts +4 -0
  302. package/text-input/Suggestions.js +84 -0
  303. package/text-input/TextInput.d.ts +4 -0
  304. package/text-input/TextInput.js +360 -757
  305. package/text-input/TextInput.stories.tsx +465 -0
  306. package/text-input/TextInput.test.js +1739 -0
  307. package/text-input/types.d.ts +205 -0
  308. package/text-input/types.js +5 -0
  309. package/textarea/Textarea.d.ts +4 -0
  310. package/textarea/Textarea.js +105 -240
  311. package/textarea/Textarea.stories.tsx +174 -0
  312. package/textarea/Textarea.test.js +406 -0
  313. package/textarea/types.d.ts +141 -0
  314. package/textarea/types.js +5 -0
  315. package/toggle-group/ToggleGroup.d.ts +4 -0
  316. package/toggle-group/ToggleGroup.js +107 -233
  317. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  318. package/toggle-group/ToggleGroup.test.js +137 -0
  319. package/toggle-group/types.d.ts +114 -0
  320. package/toggle-group/types.js +5 -0
  321. package/typography/Typography.d.ts +4 -0
  322. package/typography/Typography.js +23 -0
  323. package/typography/Typography.stories.tsx +198 -0
  324. package/typography/types.d.ts +18 -0
  325. package/typography/types.js +5 -0
  326. package/useTheme.d.ts +1134 -0
  327. package/useTheme.js +4 -11
  328. package/useTranslatedLabels.d.ts +85 -0
  329. package/useTranslatedLabels.js +14 -0
  330. package/utils/BaseTypography.d.ts +21 -0
  331. package/utils/BaseTypography.js +94 -0
  332. package/utils/FocusLock.d.ts +13 -0
  333. package/utils/FocusLock.js +121 -0
  334. package/wizard/Wizard.d.ts +4 -0
  335. package/wizard/Wizard.js +138 -293
  336. package/wizard/Wizard.stories.tsx +253 -0
  337. package/wizard/Wizard.test.js +114 -0
  338. package/wizard/types.d.ts +64 -0
  339. package/wizard/types.js +5 -0
  340. package/ThemeContext.js +0 -250
  341. package/V3Select/V3Select.js +0 -549
  342. package/V3Select/index.d.ts +0 -27
  343. package/V3Textarea/V3Textarea.js +0 -264
  344. package/V3Textarea/index.d.ts +0 -27
  345. package/accordion/index.d.ts +0 -28
  346. package/accordion-group/index.d.ts +0 -16
  347. package/alert/index.d.ts +0 -51
  348. package/box/index.d.ts +0 -25
  349. package/button/Button.stories.js +0 -27
  350. package/button/index.d.ts +0 -24
  351. package/card/index.d.ts +0 -22
  352. package/checkbox/index.d.ts +0 -24
  353. package/chip/index.d.ts +0 -22
  354. package/common/RequiredComponent.js +0 -40
  355. package/date/Date.js +0 -379
  356. package/date/index.d.ts +0 -27
  357. package/date-input/index.d.ts +0 -95
  358. package/dialog/index.d.ts +0 -18
  359. package/dropdown/index.d.ts +0 -26
  360. package/file-input/index.d.ts +0 -81
  361. package/footer/index.d.ts +0 -25
  362. package/header/index.d.ts +0 -25
  363. package/heading/index.d.ts +0 -17
  364. package/input-text/Icons.js +0 -22
  365. package/input-text/InputText.js +0 -705
  366. package/input-text/index.d.ts +0 -36
  367. package/link/index.d.ts +0 -23
  368. package/number-input/NumberInputContext.js +0 -16
  369. package/number-input/index.d.ts +0 -113
  370. package/paginator/index.d.ts +0 -20
  371. package/password-input/index.d.ts +0 -94
  372. package/progress-bar/index.d.ts +0 -18
  373. package/radio/Radio.js +0 -209
  374. package/radio/index.d.ts +0 -23
  375. package/resultsetTable/ResultsetTable.js +0 -358
  376. package/resultsetTable/index.d.ts +0 -19
  377. package/select/index.d.ts +0 -131
  378. package/sidenav/index.d.ts +0 -13
  379. package/slider/index.d.ts +0 -29
  380. package/spinner/index.d.ts +0 -17
  381. package/switch/index.d.ts +0 -24
  382. package/table/index.d.ts +0 -13
  383. package/tabs/index.d.ts +0 -19
  384. package/tag/index.d.ts +0 -24
  385. package/text-input/index.d.ts +0 -135
  386. package/textarea/index.d.ts +0 -117
  387. package/toggle/Toggle.js +0 -220
  388. package/toggle/index.d.ts +0 -21
  389. package/toggle-group/index.d.ts +0 -21
  390. package/upload/Upload.js +0 -205
  391. package/upload/buttons-upload/ButtonsUpload.js +0 -135
  392. package/upload/buttons-upload/Icons.js +0 -40
  393. package/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  394. package/upload/dragAndDropArea/Icons.js +0 -39
  395. package/upload/file-upload/FileToUpload.js +0 -189
  396. package/upload/file-upload/Icons.js +0 -66
  397. package/upload/files-upload/FilesToUpload.js +0 -123
  398. package/upload/index.d.ts +0 -15
  399. package/upload/transaction/Icons.js +0 -160
  400. package/upload/transaction/Transaction.js +0 -148
  401. package/upload/transactions/Transactions.js +0 -138
  402. package/wizard/Icons.js +0 -65
  403. package/wizard/index.d.ts +0 -18
@@ -1,351 +1,269 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
-
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
-
16
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
-
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
18
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
-
20
12
  var _react = _interopRequireWildcard(require("react"));
21
-
22
13
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
-
24
- var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
- var _Popper = _interopRequireDefault(require("@material-ui/core/Popper"));
27
-
28
- var _MenuItem = _interopRequireDefault(require("@material-ui/core/MenuItem"));
29
-
30
- var _core = require("@material-ui/core");
31
-
32
- var _Grow = _interopRequireDefault(require("@material-ui/core/Grow"));
33
-
34
- var _Paper = _interopRequireDefault(require("@material-ui/core/Paper"));
35
-
36
- var _MenuList = _interopRequireDefault(require("@material-ui/core/MenuList"));
37
-
38
- var _variables = require("../common/variables.js");
39
-
40
- var _utils = require("../common/utils.js");
41
-
42
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
43
-
44
- function _templateObject10() {
45
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n margin-left: ", ";\n color: ", ";\n\n svg {\n width: ", ";\n height: ", ";\n }\n"]);
46
-
47
- _templateObject10 = function _templateObject10() {
48
- return data;
49
- };
50
-
51
- return data;
52
- }
53
-
54
- function _templateObject9() {
55
- var data = (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"]);
56
-
57
- _templateObject9 = function _templateObject9() {
58
- return data;
59
- };
60
-
61
- return data;
62
- }
63
-
64
- function _templateObject8() {
65
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"]);
66
-
67
- _templateObject8 = function _templateObject8() {
68
- return data;
14
+ var _variables = require("../common/variables");
15
+ var _utils = require("../common/utils");
16
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
17
+ var _uuid = require("uuid");
18
+ var Popover = _interopRequireWildcard(require("@radix-ui/react-popover"));
19
+ var _DropdownMenu = _interopRequireDefault(require("./DropdownMenu"));
20
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
21
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
22
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
23
+ var upArrowIcon = /*#__PURE__*/_react["default"].createElement("svg", {
24
+ xmlns: "http://www.w3.org/2000/svg",
25
+ width: "24",
26
+ height: "24",
27
+ viewBox: "0 0 24 24",
28
+ fill: "currentColor"
29
+ }, /*#__PURE__*/_react["default"].createElement("path", {
30
+ d: "M7 14l5-5 5 5z"
31
+ }), /*#__PURE__*/_react["default"].createElement("path", {
32
+ d: "M0 0h24v24H0z",
33
+ fill: "none"
34
+ }));
35
+ var downArrowIcon = /*#__PURE__*/_react["default"].createElement("svg", {
36
+ xmlns: "http://www.w3.org/2000/svg",
37
+ width: "24",
38
+ height: "24",
39
+ viewBox: "0 0 24 24",
40
+ fill: "currentColor"
41
+ }, /*#__PURE__*/_react["default"].createElement("path", {
42
+ d: "M7 10l5 5 5-5z"
43
+ }), /*#__PURE__*/_react["default"].createElement("path", {
44
+ d: "M0 0h24v24H0z",
45
+ fill: "none"
46
+ }));
47
+ var useWidth = function useWidth(target) {
48
+ var _useState = (0, _react.useState)(0),
49
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
50
+ width = _useState2[0],
51
+ setWidth = _useState2[1];
52
+ (0, _react.useEffect)(function () {
53
+ if (target != null) {
54
+ setWidth(target.getBoundingClientRect().width);
55
+ var triggerObserver = new ResizeObserver(function (entries) {
56
+ var rect = entries[0].target.getBoundingClientRect();
57
+ setWidth(rect === null || rect === void 0 ? void 0 : rect.width);
58
+ });
59
+ triggerObserver.observe(target);
60
+ return function () {
61
+ triggerObserver.unobserve(target);
62
+ };
63
+ }
64
+ }, [target]);
65
+ return width;
66
+ };
67
+ var DxcDropdown = function DxcDropdown(_ref) {
68
+ var options = _ref.options,
69
+ _ref$optionsIconPosit = _ref.optionsIconPosition,
70
+ optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
71
+ icon = _ref.icon,
72
+ _ref$iconPosition = _ref.iconPosition,
73
+ iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
74
+ _ref$label = _ref.label,
75
+ label = _ref$label === void 0 ? "" : _ref$label,
76
+ _ref$caretHidden = _ref.caretHidden,
77
+ caretHidden = _ref$caretHidden === void 0 ? false : _ref$caretHidden,
78
+ _ref$disabled = _ref.disabled,
79
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
80
+ _ref$expandOnHover = _ref.expandOnHover,
81
+ expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover,
82
+ onSelectOption = _ref.onSelectOption,
83
+ margin = _ref.margin,
84
+ _ref$size = _ref.size,
85
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
86
+ _ref$tabIndex = _ref.tabIndex,
87
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
88
+ var _useState3 = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
89
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
90
+ triggerId = _useState4[0];
91
+ var menuId = "menu-".concat(triggerId);
92
+ var _useState5 = (0, _react.useState)(false),
93
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
94
+ isOpen = _useState6[0],
95
+ changeIsOpen = _useState6[1];
96
+ var _useState7 = (0, _react.useState)(0),
97
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
98
+ visualFocusIndex = _useState8[0],
99
+ setVisualFocusIndex = _useState8[1];
100
+ var colorsTheme = (0, _useTheme["default"])();
101
+ var triggerRef = (0, _react.useRef)(null);
102
+ var menuRef = (0, _react.useRef)(null);
103
+ var width = useWidth(triggerRef.current);
104
+ var handleOnOpenMenu = function handleOnOpenMenu() {
105
+ changeIsOpen(true);
69
106
  };
70
-
71
- return data;
72
- }
73
-
74
- function _templateObject7() {
75
- var data = (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"]);
76
-
77
- _templateObject7 = function _templateObject7() {
78
- return data;
107
+ var handleOnCloseMenu = function handleOnCloseMenu() {
108
+ changeIsOpen(false);
109
+ setVisualFocusIndex(0);
79
110
  };
80
-
81
- return data;
82
- }
83
-
84
- function _templateObject6() {
85
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n margin-left: ", ";\n margin-right: ", ";\n"]);
86
-
87
- _templateObject6 = function _templateObject6() {
88
- return data;
111
+ var handleMenuItemOnClick = (0, _react.useCallback)(function (value) {
112
+ var _triggerRef$current;
113
+ onSelectOption(value);
114
+ handleOnCloseMenu();
115
+ (_triggerRef$current = triggerRef.current) === null || _triggerRef$current === void 0 ? void 0 : _triggerRef$current.focus();
116
+ }, [onSelectOption]);
117
+ var handleOnBlur = function handleOnBlur(event) {
118
+ !event.currentTarget.contains(event.relatedTarget) && handleOnCloseMenu();
89
119
  };
90
-
91
- return data;
92
- }
93
-
94
- function _templateObject5() {
95
- var data = (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"]);
96
-
97
- _templateObject5 = function _templateObject5() {
98
- return data;
120
+ var handleTriggerOnClick = function handleTriggerOnClick() {
121
+ changeIsOpen(function (isOpen) {
122
+ return !isOpen;
123
+ });
99
124
  };
100
-
101
- return data;
102
- }
103
-
104
- function _templateObject4() {
105
- var data = (0, _taggedTemplateLiteral2["default"])(["\n text-align: left;\n text-overflow: ellipsis;\n overflow: hidden;\n"]);
106
-
107
- _templateObject4 = function _templateObject4() {
108
- return data;
109
- };
110
-
111
- return data;
112
- }
113
-
114
- function _templateObject3() {
115
- var data = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n height: auto;\n min-height: 40px;\n cursor: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n min-width: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n background-color: ", ";\n color: ", ";\n border-bottom-right-radius: ", ";\n border-bottom-left-radius: ", ";\n\n ", ";\n"]);
116
-
117
- _templateObject3 = function _templateObject3() {
118
- return data;
119
- };
120
-
121
- return data;
122
- }
123
-
124
- function _templateObject2() {
125
- var data = (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"]);
126
-
127
- _templateObject2 = function _templateObject2() {
128
- return data;
125
+ var handleTriggerOnKeyDown = function handleTriggerOnKeyDown(event) {
126
+ switch (event.key) {
127
+ case "Up":
128
+ case "ArrowUp":
129
+ event.preventDefault();
130
+ setVisualFocusIndex(options.length - 1);
131
+ handleOnOpenMenu();
132
+ break;
133
+ case " ":
134
+ case "Down":
135
+ case "ArrowDown":
136
+ case "Enter":
137
+ event.preventDefault();
138
+ handleOnOpenMenu();
139
+ break;
140
+ }
129
141
  };
130
-
131
- return data;
132
- }
133
-
134
- function _templateObject() {
135
- var data = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n display: inline-block;\n"]);
136
-
137
- _templateObject = function _templateObject() {
138
- return data;
142
+ var setPreviousIndexFocus = function setPreviousIndexFocus() {
143
+ setVisualFocusIndex(function (currentFocusIndex) {
144
+ var index = currentFocusIndex === 0 ? options.length - 1 : currentFocusIndex - 1;
145
+ return index;
146
+ });
139
147
  };
140
-
141
- return data;
142
- }
143
-
144
- var DxcDropdown = function DxcDropdown(_ref) {
145
- var _ref$options = _ref.options,
146
- options = _ref$options === void 0 ? [] : _ref$options,
147
- _ref$optionsIconPosit = _ref.optionsIconPosition,
148
- optionsIconPosition = _ref$optionsIconPosit === void 0 ? "before" : _ref$optionsIconPosit,
149
- icon = _ref.icon,
150
- _ref$iconSrc = _ref.iconSrc,
151
- iconSrc = _ref$iconSrc === void 0 ? "" : _ref$iconSrc,
152
- _ref$iconPosition = _ref.iconPosition,
153
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
154
- _ref$label = _ref.label,
155
- label = _ref$label === void 0 ? "" : _ref$label,
156
- _ref$disabled = _ref.disabled,
157
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
158
- _ref$caretHidden = _ref.caretHidden,
159
- caretHidden = _ref$caretHidden === void 0 ? false : _ref$caretHidden,
160
- onSelectOption = _ref.onSelectOption,
161
- margin = _ref.margin,
162
- _ref$size = _ref.size,
163
- size = _ref$size === void 0 ? "fitContent" : _ref$size,
164
- _ref$expandOnHover = _ref.expandOnHover,
165
- expandOnHover = _ref$expandOnHover === void 0 ? false : _ref$expandOnHover,
166
- _ref$tabIndex = _ref.tabIndex,
167
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
168
-
169
- var _useState = (0, _react.useState)(),
170
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
171
- width = _useState2[0],
172
- setWidth = _useState2[1];
173
-
174
- var colorsTheme = (0, _useTheme["default"])();
175
- var ref = (0, _react.useRef)(null);
176
-
177
- var handleResize = function handleResize() {
178
- if (ref.current) setWidth(ref.current.offsetWidth);
148
+ var setNextIndexFocus = function setNextIndexFocus() {
149
+ setVisualFocusIndex(function (currentFocusIndex) {
150
+ var index = currentFocusIndex === options.length - 1 ? 0 : currentFocusIndex + 1;
151
+ return index;
152
+ });
179
153
  };
180
-
181
- (0, _react.useEffect)(function () {
182
- if (ref.current) {
183
- ref.current.addEventListener("resize", handleResize);
184
- handleResize();
154
+ var handleMenuOnKeyDown = (0, _react.useCallback)(function (event) {
155
+ var _triggerRef$current2, _triggerRef$current3;
156
+ switch (event.key) {
157
+ case "Up":
158
+ case "ArrowUp":
159
+ event.preventDefault();
160
+ setPreviousIndexFocus();
161
+ break;
162
+ case "Down":
163
+ case "ArrowDown":
164
+ event.preventDefault();
165
+ setNextIndexFocus();
166
+ break;
167
+ case " ":
168
+ case "Enter":
169
+ event.preventDefault();
170
+ handleMenuItemOnClick(options[visualFocusIndex].value);
171
+ break;
172
+ case "Esc":
173
+ case "Escape":
174
+ event.preventDefault();
175
+ handleOnCloseMenu();
176
+ (_triggerRef$current2 = triggerRef.current) === null || _triggerRef$current2 === void 0 ? void 0 : _triggerRef$current2.focus();
177
+ break;
178
+ case "Home":
179
+ case "PageUp":
180
+ event.preventDefault();
181
+ setVisualFocusIndex(0);
182
+ break;
183
+ case "End":
184
+ case "PageDown":
185
+ event.preventDefault();
186
+ setVisualFocusIndex(options.length - 1);
187
+ break;
188
+ case "Tab":
189
+ handleOnCloseMenu();
190
+ (_triggerRef$current3 = triggerRef.current) === null || _triggerRef$current3 === void 0 ? void 0 : _triggerRef$current3.focus();
191
+ break;
185
192
  }
186
-
187
- return function () {
188
- if (ref.current) ref.current.removeEventListener("resize", handleResize);
189
- };
190
- }, []);
191
-
192
- var _useState3 = (0, _react.useState)(null),
193
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
194
- anchorEl = _useState4[0],
195
- setAnchorEl = _useState4[1];
196
-
197
- function handleClickListItem(event) {
198
- setAnchorEl(event.currentTarget);
199
- }
200
-
201
- function handleMenuItemClick(option) {
202
- setAnchorEl(null);
203
-
204
- if (typeof onSelectOption === "function") {
205
- onSelectOption(option.value);
206
- }
207
- }
208
-
209
- function handleClose() {
210
- setAnchorEl(null);
211
- }
212
-
213
- var handleCloseOver = expandOnHover ? handleClose : undefined;
214
-
215
- var UpArrowIcon = function UpArrowIcon() {
216
- return _react["default"].createElement("svg", {
217
- xmlns: "http://www.w3.org/2000/svg",
218
- width: "24",
219
- height: "24",
220
- viewBox: "0 0 24 24",
221
- fill: "currentColor"
222
- }, _react["default"].createElement("path", {
223
- d: "M7 14l5-5 5 5z"
224
- }), _react["default"].createElement("path", {
225
- d: "M0 0h24v24H0z",
226
- fill: "none"
227
- }));
228
- };
229
-
230
- var DownArrowIcon = function DownArrowIcon() {
231
- return _react["default"].createElement("svg", {
232
- xmlns: "http://www.w3.org/2000/svg",
233
- width: "24",
234
- height: "24",
235
- viewBox: "0 0 24 24",
236
- fill: "currentColor"
237
- }, _react["default"].createElement("path", {
238
- d: "M7 10l5 5 5-5z"
239
- }), _react["default"].createElement("path", {
240
- d: "M0 0h24v24H0z",
241
- fill: "none"
242
- }));
243
- };
244
-
245
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
193
+ }, [onSelectOption, visualFocusIndex, options]);
194
+ (0, _react.useLayoutEffect)(function () {
195
+ var _menuRef$current, _visualFocusedMenuIte;
196
+ var visualFocusedMenuItem = menuRef === null || menuRef === void 0 ? void 0 : (_menuRef$current = menuRef.current) === null || _menuRef$current === void 0 ? void 0 : _menuRef$current.querySelectorAll("[role='menuitem']")[visualFocusIndex];
197
+ visualFocusedMenuItem === null || visualFocusedMenuItem === void 0 ? void 0 : (_visualFocusedMenuIte = visualFocusedMenuItem.scrollIntoView) === null || _visualFocusedMenuIte === void 0 ? void 0 : _visualFocusedMenuIte.call(visualFocusedMenuItem, {
198
+ block: "nearest",
199
+ inline: "start"
200
+ });
201
+ }, [visualFocusIndex]);
202
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
246
203
  theme: colorsTheme.dropdown
247
- }, _react["default"].createElement(DXCDropdownContainer, {
204
+ }, /*#__PURE__*/_react["default"].createElement(DropdownContainer, {
205
+ onMouseEnter: !disabled && expandOnHover ? handleOnOpenMenu : undefined,
206
+ onMouseLeave: !disabled && expandOnHover ? handleOnCloseMenu : undefined,
207
+ onBlur: !disabled ? handleOnBlur : undefined,
248
208
  margin: margin,
249
- size: size,
250
- disabled: disabled
251
- }, _react["default"].createElement("div", {
252
- onMouseOver: expandOnHover && !disabled ? handleClickListItem : undefined,
253
- onMouseOut: handleCloseOver,
254
- onFocus: handleCloseOver,
255
- onBlur: handleCloseOver
256
- }, _react["default"].createElement(DropdownTrigger, {
257
- opened: anchorEl === null ? false : true,
258
- onClick: handleClickListItem,
209
+ size: size
210
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Root, {
211
+ open: isOpen
212
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
213
+ asChild: true,
214
+ type: undefined
215
+ }, /*#__PURE__*/_react["default"].createElement(DropdownTrigger, {
216
+ onClick: handleTriggerOnClick,
217
+ onKeyDown: handleTriggerOnKeyDown,
218
+ onBlur: function onBlur(event) {
219
+ event.stopPropagation();
220
+ },
259
221
  disabled: disabled,
260
222
  label: label,
261
- caretHidden: caretHidden,
262
223
  margin: margin,
263
224
  size: size,
264
- ref: ref,
265
- tabIndex: tabIndex
266
- }, _react["default"].createElement(DropdownTriggerContainer, {
267
- iconPosition: iconPosition,
268
- caretHidden: caretHidden
269
- }, icon ? _react["default"].createElement(ButtonIconContainer, {
270
- label: label,
271
- iconPosition: iconPosition,
272
- disabled: disabled
273
- }, (0, _typeof2["default"])(icon) === "object" ? icon : _react["default"].createElement(icon)) : iconSrc && _react["default"].createElement(ButtonIcon, {
274
- label: label,
275
- src: iconSrc,
276
- iconPosition: iconPosition
277
- }), _react["default"].createElement(DropdownTriggerLabel, {
278
- iconPosition: iconPosition,
279
- label: label
280
- }, label)), _react["default"].createElement(CaretIconContainer, {
281
- caretHidden: caretHidden,
225
+ id: triggerId,
226
+ "aria-haspopup": "true",
227
+ "aria-controls": menuId,
228
+ "aria-expanded": isOpen ? true : undefined,
229
+ tabIndex: tabIndex,
230
+ ref: triggerRef
231
+ }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContent, null, label && iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(DropdownTriggerIcon, {
232
+ disabled: disabled,
233
+ role: typeof icon === "string" ? undefined : "img"
234
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
235
+ src: icon
236
+ }) : icon), label && iconPosition === "before" && /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, null, label)), !caretHidden && /*#__PURE__*/_react["default"].createElement(CaretIcon, {
282
237
  disabled: disabled
283
- }, !caretHidden && (anchorEl === null ? _react["default"].createElement(DownArrowIcon, null) : _react["default"].createElement(UpArrowIcon, null)))), _react["default"].createElement(DXCMenu, {
284
- anchorEl: anchorEl,
285
- open: Boolean(anchorEl),
286
- onClose: handleClose,
287
- getContentAnchorEl: null,
288
- anchorOrigin: {
289
- vertical: "bottom",
290
- horizontal: "left"
291
- },
292
- transformOrigin: {
293
- vertical: "top",
294
- horizontal: "left"
238
+ }, isOpen ? upArrowIcon : downArrowIcon))), /*#__PURE__*/_react["default"].createElement(Popover.Portal, null, /*#__PURE__*/_react["default"].createElement(Popover.Content, {
239
+ asChild: true,
240
+ sideOffset: 1
241
+ }, /*#__PURE__*/_react["default"].createElement(_DropdownMenu["default"], {
242
+ id: menuId,
243
+ dropdownTriggerId: triggerId,
244
+ options: options,
245
+ iconsPosition: optionsIconPosition,
246
+ visualFocusIndex: visualFocusIndex,
247
+ menuItemOnClick: handleMenuItemOnClick,
248
+ onKeyDown: handleMenuOnKeyDown,
249
+ styles: {
250
+ width: width,
251
+ zIndex: "2147483647"
295
252
  },
296
- optionsIconPosition: optionsIconPosition,
297
- size: size,
298
- width: width,
299
- role: undefined,
300
- transition: true,
301
- disablePortal: true,
302
- placement: "bottom-start"
303
- }, function (_ref2) {
304
- var TransitionProps = _ref2.TransitionProps;
305
- return _react["default"].createElement(_Grow["default"], TransitionProps, _react["default"].createElement(_Paper["default"], null, _react["default"].createElement(_core.ClickAwayListener, {
306
- onClickAway: handleClose
307
- }, _react["default"].createElement(_MenuList["default"], {
308
- autoFocusItem: Boolean(anchorEl),
309
- id: "menu-list-grow"
310
- }, options.map(function (option) {
311
- return _react["default"].createElement(_MenuItem["default"], {
312
- key: option.value,
313
- value: option.value,
314
- disableRipple: true,
315
- onClick: function onClick(event) {
316
- return handleMenuItemClick(option);
317
- }
318
- }, option.icon ? _react["default"].createElement(ListIconContainer, {
319
- label: option.label,
320
- iconPosition: optionsIconPosition
321
- }, (0, _typeof2["default"])(option.icon) === "object" ? option.icon : _react["default"].createElement(option.icon)) : option.iconSrc && _react["default"].createElement(ListIcon, {
322
- label: option.label,
323
- src: option.iconSrc,
324
- iconPosition: optionsIconPosition
325
- }), _react["default"].createElement("span", {
326
- className: "optionLabel"
327
- }, option.label));
328
- })))));
329
- }))));
253
+ ref: menuRef
254
+ }))))));
330
255
  };
331
-
332
256
  var sizes = {
333
257
  small: "60px",
334
258
  medium: "240px",
335
259
  large: "480px",
336
260
  fillParent: "100%",
337
- fitContent: "unset"
261
+ fitContent: "fit-content"
338
262
  };
339
-
340
263
  var calculateWidth = function calculateWidth(margin, size) {
341
- if (size === "fillParent") {
342
- return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
343
- }
344
-
345
- return sizes[size];
264
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
346
265
  };
347
-
348
- var DXCDropdownContainer = _styledComponents["default"].div(_templateObject(), function (props) {
266
+ var DropdownContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-block;\n width: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
349
267
  return calculateWidth(props.margin, props.size);
350
268
  }, function (props) {
351
269
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
@@ -358,69 +276,10 @@ var DXCDropdownContainer = _styledComponents["default"].div(_templateObject(), f
358
276
  }, function (props) {
359
277
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
360
278
  });
361
-
362
- var DXCMenu = (0, _styledComponents["default"])(_Popper["default"])(_templateObject2(), function (props) {
363
- return calculateWidth(props.margin, props.size);
364
- }, function (props) {
365
- return props.theme.optionPaddingTop;
366
- }, function (props) {
367
- return props.theme.optionPaddingBottom;
368
- }, function (props) {
369
- return props.theme.optionPaddingLeft;
370
- }, function (props) {
371
- return props.theme.optionPaddingRight;
372
- }, function (props) {
373
- return "".concat(props.width, "px");
374
- }, function (props) {
375
- return props.theme.borderThickness;
376
- }, function (props) {
377
- return props.theme.borderStyle;
378
- }, function (props) {
379
- return props.theme.borderColor;
380
- }, function (props) {
381
- return props.theme.borderRadius;
382
- }, function (props) {
383
- return props.theme.borderRadius;
384
- }, function (props) {
385
- return props.theme.scrollBarTrackColor;
386
- }, function (props) {
387
- return props.theme.scrollBarThumbColor;
388
- }, function (props) {
389
- return props.optionsIconPosition === "after" && "row-reverse" || "row";
390
- }, function (props) {
391
- return props.optionsIconPosition === "after" && "flex-end" || "";
392
- }, function (props) {
393
- return props.theme.optionBackgroundColor;
394
- }, function (props) {
395
- return props.theme.optionFontFamily;
396
- }, function (props) {
397
- return props.theme.optionFontSize;
398
- }, function (props) {
399
- return props.theme.optionFontStyle;
400
- }, function (props) {
401
- return props.theme.optionFontWeight;
402
- }, function (props) {
403
- return props.theme.optionFontColor;
404
- }, function (props) {
405
- return props.theme.focusColor;
406
- }, function (props) {
407
- return props.theme.hoverOptionBackgroundColor;
408
- }, function (props) {
409
- return props.theme.activeOptionBackgroundColor;
410
- }, function (props) {
411
- return props.theme.focusColor;
412
- });
413
-
414
- var DropdownTrigger = _styledComponents["default"].button(_templateObject3(), function (props) {
415
- return props.disabled ? "not-allowed" : "pointer";
416
- }, function (props) {
417
- return props.theme.buttonFontFamily;
418
- }, function (props) {
419
- return props.theme.buttonFontSize;
420
- }, function (props) {
421
- return props.theme.buttonFontStyle;
279
+ var DropdownTrigger = _styledComponents["default"].button(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n align-items: center;\n gap: ", ";\n width: 100%;\n min-height: 40px;\n min-width: ", ";\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n padding-top: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n padding-right: ", ";\n background-color: ", ";\n color: ", ";\n cursor: ", ";\n\n ", ";\n"])), function (props) {
280
+ return props.theme.caretIconSpacing;
422
281
  }, function (props) {
423
- return props.theme.buttonFontWeight;
282
+ return props.label === "" ? "0px" : calculateWidth(props.margin, props.size);
424
283
  }, function (props) {
425
284
  return props.theme.borderRadius;
426
285
  }, function (props) {
@@ -429,8 +288,6 @@ var DropdownTrigger = _styledComponents["default"].button(_templateObject3(), fu
429
288
  return props.theme.borderStyle;
430
289
  }, function (props) {
431
290
  return props.disabled ? props.theme.disabledBorderColor : props.theme.borderColor;
432
- }, function (props) {
433
- return props.label === "" ? "0px" : calculateWidth(props.margin, props.size);
434
291
  }, function (props) {
435
292
  return props.theme.buttonPaddingTop;
436
293
  }, function (props) {
@@ -444,101 +301,34 @@ var DropdownTrigger = _styledComponents["default"].button(_templateObject3(), fu
444
301
  }, function (props) {
445
302
  return props.disabled ? props.theme.disabledColor : props.theme.buttonFontColor;
446
303
  }, function (props) {
447
- return props.opened ? "0px" : props.theme.borderRadius;
448
- }, function (props) {
449
- return props.opened ? "0px" : props.theme.borderRadius;
304
+ return props.disabled ? "not-allowed" : "pointer";
450
305
  }, function (props) {
451
- return !props.disabled && " \n &:focus {\n outline: none;\n }\n &:focus-visible {\n outline: ".concat(props.theme.focusColor, " solid 2px;\n outline-offset: -2px;\n }\n &:hover {\n background-color: ").concat(props.theme.hoverButtonBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(props.theme.activeButtonBackgroundColor, ";\n }\n ");
306
+ return !props.disabled && "\n &:focus {\n outline: ".concat(props.theme.focusColor, " solid 2px;\n outline-offset: -2px;\n }\n &:hover {\n background-color: ").concat(props.theme.hoverButtonBackgroundColor, ";\n }\n &:active {\n background-color: ").concat(props.theme.activeButtonBackgroundColor, ";\n }\n ");
452
307
  });
453
-
454
- var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4());
455
-
456
- var DropdownTriggerContainer = _styledComponents["default"].span(_templateObject5(), function (props) {
457
- return props.iconPosition === "after" && "row-reverse" || "row";
458
- }, function (props) {
459
- return props.caretHidden ? "100%" : "calc(100% - 36px)";
308
+ var DropdownTriggerContent = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n gap: ", ";\n margin-left: 0px;\n margin-right: 0px;\n width: 100%;\n overflow: hidden;\n white-space: nowrap;\n"])), function (props) {
309
+ return props.theme.buttonIconSpacing;
460
310
  });
461
-
462
- var ButtonIcon = _styledComponents["default"].img(_templateObject6(), function (props) {
463
- return props.theme.buttonIconSize;
311
+ var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-overflow: ellipsis;\n overflow: hidden;\n"])), function (props) {
312
+ return props.theme.buttonFontFamily;
464
313
  }, function (props) {
465
- return props.theme.buttonIconSize;
314
+ return props.theme.buttonFontSize;
466
315
  }, function (props) {
467
- return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
316
+ return props.theme.buttonFontStyle;
468
317
  }, function (props) {
469
- return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
318
+ return props.theme.buttonFontWeight;
470
319
  });
471
-
472
- var ButtonIconContainer = _styledComponents["default"].div(_templateObject7(), function (props) {
473
- return props.theme.buttonIconSize;
474
- }, function (props) {
475
- return props.theme.buttonIconSize;
476
- }, function (props) {
477
- return props.iconPosition === "after" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
478
- }, function (props) {
479
- return props.iconPosition === "before" && props.label !== "" && props.theme.buttonIconSpacing || "0px";
480
- }, function (props) {
320
+ var DropdownTriggerIcon = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
481
321
  return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
482
- });
483
-
484
- var ListIcon = _styledComponents["default"].img(_templateObject8(), function (props) {
485
- return props.theme.optionIconSize;
486
- }, function (props) {
487
- return props.theme.optionIconSize;
488
- }, function (props) {
489
- return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
490
- }, function (props) {
491
- return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
492
- });
493
-
494
- var ListIconContainer = _styledComponents["default"].div(_templateObject9(), function (props) {
495
- return props.theme.optionIconSize;
496
322
  }, function (props) {
497
- return props.theme.optionIconSize;
498
- }, function (props) {
499
- return props.iconPosition === "after" && props.label !== "" && props.theme.optionIconSpacing || "0px";
500
- }, function (props) {
501
- return props.iconPosition === "before" && props.label !== "" && props.theme.optionIconSpacing || "0px";
323
+ return props.theme.buttonIconSize;
502
324
  }, function (props) {
503
- return props.theme.optionIconColor;
325
+ return props.theme.buttonIconSize;
504
326
  });
505
-
506
- var CaretIconContainer = _styledComponents["default"].div(_templateObject10(), function (props) {
507
- return props.caretHidden ? "none" : "inline-flex";
508
- }, function (props) {
509
- return props.theme.caretIconSpacing;
510
- }, function (props) {
327
+ var CaretIcon = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
511
328
  return props.disabled ? props.theme.disabledColor : props.theme.caretIconColor;
512
329
  }, function (props) {
513
330
  return props.theme.caretIconSize;
514
331
  }, function (props) {
515
332
  return props.theme.caretIconSize;
516
333
  });
517
-
518
- DxcDropdown.propTypes = {
519
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
520
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
521
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
522
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
523
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
524
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
525
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
526
- optionsIconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
527
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
528
- iconSrc: _propTypes["default"].string,
529
- iconPosition: _propTypes["default"].oneOf(["after", "before", ""]),
530
- label: _propTypes["default"].string,
531
- caretHidden: _propTypes["default"].bool,
532
- disabled: _propTypes["default"].bool,
533
- expandOnHover: _propTypes["default"].bool,
534
- onSelectOption: _propTypes["default"].func,
535
- options: _propTypes["default"].arrayOf(_propTypes["default"].shape({
536
- value: _propTypes["default"].any.isRequired,
537
- label: _propTypes["default"].any.isRequired,
538
- icon: _propTypes["default"].oneOfType([_propTypes["default"].element, _propTypes["default"].func]),
539
- iconSrc: _propTypes["default"].string
540
- })),
541
- tabIndex: _propTypes["default"].number
542
- };
543
- var _default = DxcDropdown;
544
- exports["default"] = _default;
334
+ var _default = exports["default"] = DxcDropdown;