@dxc-technology/halstack-react 0.0.0-ebb089f → 0.0.0-ebf4fe2

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 (438) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +226 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +169 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +43 -153
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +61 -0
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +116 -0
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/button/Button.d.ts +4 -0
  39. package/{dist/button → button}/Button.js +33 -97
  40. package/button/Button.stories.tsx +274 -0
  41. package/button/Button.test.js +35 -0
  42. package/button/types.d.ts +53 -0
  43. package/button/types.js +5 -0
  44. package/card/Card.d.ts +4 -0
  45. package/card/Card.js +161 -0
  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 +4 -0
  52. package/{dist/checkbox → checkbox}/Checkbox.js +52 -94
  53. package/checkbox/Checkbox.stories.tsx +188 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +64 -0
  56. package/checkbox/types.js +5 -0
  57. package/chip/Chip.d.ts +4 -0
  58. package/chip/Chip.js +161 -0
  59. package/chip/Chip.stories.tsx +119 -0
  60. package/chip/Chip.test.js +56 -0
  61. package/chip/types.d.ts +45 -0
  62. package/chip/types.js +5 -0
  63. package/{dist/common → common}/OpenSans.css +0 -0
  64. package/{dist/common → common}/RequiredComponent.js +3 -11
  65. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  68. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  75. package/{dist/common → common}/utils.js +0 -0
  76. package/{dist/common → common}/variables.js +302 -406
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/{dist/date-input → date-input}/DateInput.js +80 -108
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +479 -0
  81. package/date-input/types.d.ts +107 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/dialog/Dialog.js +138 -0
  85. package/dialog/Dialog.stories.tsx +212 -0
  86. package/dialog/Dialog.test.js +40 -0
  87. package/dialog/types.d.ts +43 -0
  88. package/dialog/types.js +5 -0
  89. package/dropdown/Dropdown.d.ts +4 -0
  90. package/{dist/dropdown → dropdown}/Dropdown.js +54 -207
  91. package/dropdown/Dropdown.stories.tsx +249 -0
  92. package/dropdown/Dropdown.test.js +189 -0
  93. package/dropdown/types.d.ts +80 -0
  94. package/dropdown/types.js +5 -0
  95. package/file-input/FileInput.d.ts +4 -0
  96. package/file-input/FileInput.js +593 -0
  97. package/file-input/FileInput.stories.tsx +507 -0
  98. package/file-input/FileInput.test.js +457 -0
  99. package/file-input/FileItem.d.ts +14 -0
  100. package/file-input/FileItem.js +186 -0
  101. package/file-input/types.d.ts +112 -0
  102. package/file-input/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +185 -0
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/{dist/footer → footer}/Icons.js +16 -16
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +303 -0
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/{dist/header → header}/Icons.js +7 -32
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/{dist/heading → heading}/Heading.js +25 -96
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inline/Inline.d.ts +4 -0
  126. package/inline/Inline.js +60 -0
  127. package/inline/Inline.stories.tsx +305 -0
  128. package/inline/types.d.ts +36 -0
  129. package/inline/types.js +5 -0
  130. package/inset/Inset.d.ts +3 -0
  131. package/inset/Inset.js +51 -0
  132. package/inset/Inset.stories.tsx +229 -0
  133. package/inset/types.d.ts +37 -0
  134. package/inset/types.js +5 -0
  135. package/layout/ApplicationLayout.d.ts +11 -0
  136. package/layout/ApplicationLayout.js +199 -0
  137. package/layout/ApplicationLayout.stories.tsx +126 -0
  138. package/layout/Icons.d.ts +5 -0
  139. package/{dist/layout → layout}/Icons.js +19 -8
  140. package/layout/SidenavContext.d.ts +5 -0
  141. package/layout/SidenavContext.js +19 -0
  142. package/layout/types.d.ts +52 -0
  143. package/layout/types.js +5 -0
  144. package/link/Link.d.ts +4 -0
  145. package/link/Link.js +136 -0
  146. package/link/Link.stories.tsx +186 -0
  147. package/link/Link.test.js +83 -0
  148. package/link/types.d.ts +54 -0
  149. package/link/types.js +5 -0
  150. package/list/List.d.ts +4 -0
  151. package/list/List.js +47 -0
  152. package/list/List.stories.tsx +89 -0
  153. package/list/types.d.ts +7 -0
  154. package/list/types.js +5 -0
  155. package/main.d.ts +48 -0
  156. package/{dist/main.js → main.js} +138 -96
  157. package/number-input/NumberInput.d.ts +4 -0
  158. package/number-input/NumberInput.js +76 -0
  159. package/number-input/NumberInput.stories.tsx +115 -0
  160. package/number-input/NumberInput.test.js +506 -0
  161. package/number-input/NumberInputContext.d.ts +4 -0
  162. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  163. package/number-input/numberInputContextTypes.d.ts +19 -0
  164. package/number-input/numberInputContextTypes.js +5 -0
  165. package/number-input/types.d.ts +124 -0
  166. package/number-input/types.js +5 -0
  167. package/package.json +27 -20
  168. package/{dist/paginator → paginator}/Icons.js +9 -9
  169. package/paginator/Paginator.d.ts +4 -0
  170. package/paginator/Paginator.js +171 -0
  171. package/paginator/Paginator.stories.tsx +63 -0
  172. package/paginator/Paginator.test.js +308 -0
  173. package/paginator/types.d.ts +38 -0
  174. package/paginator/types.js +5 -0
  175. package/password-input/PasswordInput.d.ts +4 -0
  176. package/{dist/password-input → password-input}/PasswordInput.js +40 -77
  177. package/password-input/PasswordInput.stories.tsx +131 -0
  178. package/password-input/PasswordInput.test.js +180 -0
  179. package/password-input/types.d.ts +110 -0
  180. package/password-input/types.js +5 -0
  181. package/progress-bar/ProgressBar.d.ts +4 -0
  182. package/{dist/progress-bar → progress-bar}/ProgressBar.js +23 -95
  183. package/progress-bar/ProgressBar.stories.jsx +58 -0
  184. package/progress-bar/ProgressBar.test.js +65 -0
  185. package/progress-bar/types.d.ts +37 -0
  186. package/progress-bar/types.js +5 -0
  187. package/quick-nav/QuickNav.d.ts +4 -0
  188. package/quick-nav/QuickNav.js +116 -0
  189. package/quick-nav/QuickNav.stories.tsx +237 -0
  190. package/quick-nav/types.d.ts +21 -0
  191. package/quick-nav/types.js +5 -0
  192. package/radio-group/Radio.d.ts +4 -0
  193. package/radio-group/Radio.js +141 -0
  194. package/radio-group/RadioGroup.d.ts +4 -0
  195. package/radio-group/RadioGroup.js +282 -0
  196. package/radio-group/RadioGroup.stories.tsx +100 -0
  197. package/radio-group/RadioGroup.test.js +695 -0
  198. package/radio-group/types.d.ts +114 -0
  199. package/radio-group/types.js +5 -0
  200. package/resultsetTable/ResultsetTable.d.ts +4 -0
  201. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  202. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  203. package/resultsetTable/ResultsetTable.test.js +348 -0
  204. package/resultsetTable/types.d.ts +67 -0
  205. package/resultsetTable/types.js +5 -0
  206. package/row/Row.d.ts +3 -0
  207. package/row/Row.js +127 -0
  208. package/row/Row.stories.tsx +237 -0
  209. package/row/types.d.ts +28 -0
  210. package/row/types.js +5 -0
  211. package/select/Icons.d.ts +10 -0
  212. package/select/Icons.js +93 -0
  213. package/select/Listbox.d.ts +4 -0
  214. package/select/Listbox.js +175 -0
  215. package/select/Option.d.ts +4 -0
  216. package/select/Option.js +110 -0
  217. package/select/Select.d.ts +4 -0
  218. package/select/Select.js +660 -0
  219. package/select/Select.stories.tsx +626 -0
  220. package/select/Select.test.js +2162 -0
  221. package/select/types.d.ts +212 -0
  222. package/select/types.js +5 -0
  223. package/sidenav/Sidenav.d.ts +9 -0
  224. package/sidenav/Sidenav.js +147 -0
  225. package/sidenav/Sidenav.stories.tsx +182 -0
  226. package/sidenav/Sidenav.test.js +56 -0
  227. package/sidenav/types.d.ts +50 -0
  228. package/sidenav/types.js +5 -0
  229. package/slider/Slider.d.ts +4 -0
  230. package/{dist/slider → slider}/Slider.js +76 -162
  231. package/slider/Slider.stories.tsx +177 -0
  232. package/slider/Slider.test.js +150 -0
  233. package/slider/types.d.ts +82 -0
  234. package/slider/types.js +5 -0
  235. package/spinner/Spinner.d.ts +4 -0
  236. package/spinner/Spinner.js +250 -0
  237. package/spinner/Spinner.stories.jsx +103 -0
  238. package/spinner/Spinner.test.js +64 -0
  239. package/spinner/types.d.ts +32 -0
  240. package/spinner/types.js +5 -0
  241. package/stack/Stack.d.ts +4 -0
  242. package/stack/Stack.js +52 -0
  243. package/stack/Stack.stories.tsx +225 -0
  244. package/stack/types.d.ts +28 -0
  245. package/stack/types.js +5 -0
  246. package/switch/Switch.d.ts +4 -0
  247. package/switch/Switch.js +195 -0
  248. package/switch/Switch.stories.tsx +160 -0
  249. package/switch/Switch.test.js +98 -0
  250. package/switch/types.d.ts +62 -0
  251. package/switch/types.js +5 -0
  252. package/table/Table.d.ts +4 -0
  253. package/{dist/table → table}/Table.js +12 -26
  254. package/table/Table.stories.jsx +277 -0
  255. package/table/Table.test.js +26 -0
  256. package/table/types.d.ts +21 -0
  257. package/table/types.js +5 -0
  258. package/tabs/Tabs.d.ts +4 -0
  259. package/tabs/Tabs.js +211 -0
  260. package/tabs/Tabs.stories.tsx +112 -0
  261. package/tabs/Tabs.test.js +140 -0
  262. package/tabs/types.d.ts +82 -0
  263. package/tabs/types.js +5 -0
  264. package/tabs-nav/NavTabs.d.ts +8 -0
  265. package/tabs-nav/NavTabs.js +125 -0
  266. package/tabs-nav/NavTabs.stories.tsx +170 -0
  267. package/tabs-nav/NavTabs.test.js +82 -0
  268. package/tabs-nav/Tab.d.ts +4 -0
  269. package/tabs-nav/Tab.js +132 -0
  270. package/tabs-nav/types.d.ts +53 -0
  271. package/tabs-nav/types.js +5 -0
  272. package/tag/Tag.d.ts +4 -0
  273. package/tag/Tag.js +183 -0
  274. package/tag/Tag.stories.tsx +142 -0
  275. package/tag/Tag.test.js +60 -0
  276. package/tag/types.d.ts +69 -0
  277. package/tag/types.js +5 -0
  278. package/text/Text.d.ts +7 -0
  279. package/text/Text.js +30 -0
  280. package/text/Text.stories.tsx +19 -0
  281. package/text-input/Suggestion.d.ts +4 -0
  282. package/text-input/Suggestion.js +55 -0
  283. package/text-input/TextInput.d.ts +4 -0
  284. package/{dist/text-input → text-input}/TextInput.js +282 -486
  285. package/text-input/TextInput.stories.tsx +474 -0
  286. package/text-input/TextInput.test.js +1712 -0
  287. package/text-input/types.d.ts +178 -0
  288. package/text-input/types.js +5 -0
  289. package/textarea/Textarea.d.ts +4 -0
  290. package/{dist/textarea → textarea}/Textarea.js +50 -142
  291. package/textarea/Textarea.stories.jsx +157 -0
  292. package/textarea/Textarea.test.js +437 -0
  293. package/textarea/types.d.ts +137 -0
  294. package/textarea/types.js +5 -0
  295. package/toggle-group/ToggleGroup.d.ts +4 -0
  296. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +36 -148
  297. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  298. package/toggle-group/ToggleGroup.test.js +156 -0
  299. package/toggle-group/types.d.ts +105 -0
  300. package/toggle-group/types.js +5 -0
  301. package/useTheme.d.ts +2 -0
  302. package/{dist/useTheme.js → useTheme.js} +2 -2
  303. package/useTranslatedLabels.d.ts +2 -0
  304. package/useTranslatedLabels.js +20 -0
  305. package/wizard/Wizard.d.ts +4 -0
  306. package/wizard/Wizard.js +292 -0
  307. package/wizard/Wizard.stories.tsx +214 -0
  308. package/wizard/Wizard.test.js +141 -0
  309. package/wizard/types.d.ts +64 -0
  310. package/wizard/types.js +5 -0
  311. package/README.md +0 -66
  312. package/babel.config.js +0 -7
  313. package/dist/BackgroundColorContext.js +0 -46
  314. package/dist/ThemeContext.js +0 -250
  315. package/dist/V3Select/V3Select.js +0 -549
  316. package/dist/V3Select/index.d.ts +0 -27
  317. package/dist/V3Textarea/V3Textarea.js +0 -264
  318. package/dist/V3Textarea/index.d.ts +0 -27
  319. package/dist/accordion/Accordion.js +0 -353
  320. package/dist/accordion/index.d.ts +0 -28
  321. package/dist/accordion-group/AccordionGroup.js +0 -186
  322. package/dist/accordion-group/index.d.ts +0 -16
  323. package/dist/alert/index.d.ts +0 -51
  324. package/dist/badge/Badge.js +0 -63
  325. package/dist/box/Box.js +0 -156
  326. package/dist/box/index.d.ts +0 -25
  327. package/dist/button/Button.stories.js +0 -27
  328. package/dist/button/index.d.ts +0 -24
  329. package/dist/card/Card.js +0 -254
  330. package/dist/card/index.d.ts +0 -22
  331. package/dist/checkbox/index.d.ts +0 -24
  332. package/dist/chip/Chip.js +0 -265
  333. package/dist/chip/index.d.ts +0 -22
  334. package/dist/date/Date.js +0 -379
  335. package/dist/date/index.d.ts +0 -27
  336. package/dist/date-input/index.d.ts +0 -95
  337. package/dist/dialog/Dialog.js +0 -218
  338. package/dist/dialog/index.d.ts +0 -18
  339. package/dist/dropdown/index.d.ts +0 -26
  340. package/dist/file-input/FileInput.js +0 -644
  341. package/dist/file-input/FileItem.js +0 -287
  342. package/dist/file-input/index.d.ts +0 -81
  343. package/dist/footer/Footer.js +0 -421
  344. package/dist/footer/index.d.ts +0 -25
  345. package/dist/header/Header.js +0 -470
  346. package/dist/header/index.d.ts +0 -25
  347. package/dist/heading/index.d.ts +0 -17
  348. package/dist/input-text/Icons.js +0 -22
  349. package/dist/input-text/InputText.js +0 -705
  350. package/dist/input-text/index.d.ts +0 -36
  351. package/dist/layout/ApplicationLayout.js +0 -327
  352. package/dist/link/Link.js +0 -237
  353. package/dist/link/index.d.ts +0 -23
  354. package/dist/main.d.ts +0 -40
  355. package/dist/number-input/NumberInput.js +0 -136
  356. package/dist/number-input/index.d.ts +0 -113
  357. package/dist/paginator/Paginator.js +0 -305
  358. package/dist/paginator/index.d.ts +0 -20
  359. package/dist/password-input/index.d.ts +0 -94
  360. package/dist/progress-bar/index.d.ts +0 -18
  361. package/dist/radio/Radio.js +0 -209
  362. package/dist/radio/index.d.ts +0 -23
  363. package/dist/resultsetTable/index.d.ts +0 -19
  364. package/dist/select/Select.js +0 -1137
  365. package/dist/select/index.d.ts +0 -131
  366. package/dist/sidenav/Sidenav.js +0 -179
  367. package/dist/sidenav/index.d.ts +0 -13
  368. package/dist/slider/index.d.ts +0 -29
  369. package/dist/spinner/Spinner.js +0 -381
  370. package/dist/spinner/index.d.ts +0 -17
  371. package/dist/switch/Switch.js +0 -222
  372. package/dist/switch/index.d.ts +0 -24
  373. package/dist/table/index.d.ts +0 -13
  374. package/dist/tabs/Tabs.js +0 -343
  375. package/dist/tabs/index.d.ts +0 -19
  376. package/dist/tag/Tag.js +0 -282
  377. package/dist/tag/index.d.ts +0 -24
  378. package/dist/text-input/index.d.ts +0 -135
  379. package/dist/textarea/index.d.ts +0 -117
  380. package/dist/toggle/Toggle.js +0 -220
  381. package/dist/toggle/index.d.ts +0 -21
  382. package/dist/toggle-group/index.d.ts +0 -21
  383. package/dist/upload/Upload.js +0 -205
  384. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  385. package/dist/upload/buttons-upload/Icons.js +0 -40
  386. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  387. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  388. package/dist/upload/file-upload/FileToUpload.js +0 -189
  389. package/dist/upload/file-upload/Icons.js +0 -66
  390. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  391. package/dist/upload/index.d.ts +0 -15
  392. package/dist/upload/transaction/Icons.js +0 -160
  393. package/dist/upload/transaction/Transaction.js +0 -148
  394. package/dist/upload/transactions/Transactions.js +0 -138
  395. package/dist/wizard/Icons.js +0 -65
  396. package/dist/wizard/Wizard.js +0 -405
  397. package/dist/wizard/index.d.ts +0 -18
  398. package/test/Accordion.test.js +0 -33
  399. package/test/AccordionGroup.test.js +0 -125
  400. package/test/Alert.test.js +0 -53
  401. package/test/Box.test.js +0 -10
  402. package/test/Button.test.js +0 -18
  403. package/test/Card.test.js +0 -30
  404. package/test/Checkbox.test.js +0 -45
  405. package/test/Chip.test.js +0 -25
  406. package/test/Date.test.js +0 -395
  407. package/test/DateInput.test.js +0 -242
  408. package/test/Dialog.test.js +0 -23
  409. package/test/Dropdown.test.js +0 -145
  410. package/test/FileInput.test.js +0 -201
  411. package/test/Footer.test.js +0 -94
  412. package/test/Header.test.js +0 -34
  413. package/test/Heading.test.js +0 -83
  414. package/test/InputText.test.js +0 -239
  415. package/test/Link.test.js +0 -43
  416. package/test/NumberInput.test.js +0 -259
  417. package/test/Paginator.test.js +0 -181
  418. package/test/PasswordInput.test.js +0 -83
  419. package/test/ProgressBar.test.js +0 -35
  420. package/test/Radio.test.js +0 -37
  421. package/test/ResultsetTable.test.js +0 -330
  422. package/test/Select.test.js +0 -928
  423. package/test/Sidenav.test.js +0 -45
  424. package/test/Slider.test.js +0 -74
  425. package/test/Spinner.test.js +0 -32
  426. package/test/Switch.test.js +0 -45
  427. package/test/Table.test.js +0 -36
  428. package/test/Tabs.test.js +0 -109
  429. package/test/Tag.test.js +0 -32
  430. package/test/TextInput.test.js +0 -731
  431. package/test/Textarea.test.js +0 -193
  432. package/test/ToggleGroup.test.js +0 -85
  433. package/test/Upload.test.js +0 -60
  434. package/test/V3Select.test.js +0 -212
  435. package/test/V3TextArea.test.js +0 -51
  436. package/test/Wizard.test.js +0 -130
  437. package/test/mocks/pngMock.js +0 -1
  438. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,660 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
17
+
18
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
+
20
+ var _react = _interopRequireWildcard(require("react"));
21
+
22
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
+
24
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
25
+
26
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
27
+
28
+ var _variables = require("../common/variables.js");
29
+
30
+ var _uuid = require("uuid");
31
+
32
+ var _utils = require("../common/utils.js");
33
+
34
+ var _Icons = _interopRequireDefault(require("./Icons"));
35
+
36
+ var _Listbox = _interopRequireDefault(require("./Listbox"));
37
+
38
+ var Popover = _interopRequireWildcard(require("@radix-ui/react-popover"));
39
+
40
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17;
41
+
42
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
43
+
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; }
45
+
46
+ var groupsHaveOptions = function groupsHaveOptions(innerOptions) {
47
+ return innerOptions[0].hasOwnProperty("options") ? innerOptions[0].options ? innerOptions.some(function (groupOption) {
48
+ return groupOption.options.length > 0;
49
+ }) : false : true;
50
+ };
51
+
52
+ var filteredGroupsHaveOptions = function filteredGroupsHaveOptions(filteredOptions) {
53
+ return filteredOptions !== null && filteredOptions !== void 0 && filteredOptions[0].options ? filteredOptions.some(function (groupOption) {
54
+ var _groupOption$options;
55
+
56
+ return ((_groupOption$options = groupOption.options) === null || _groupOption$options === void 0 ? void 0 : _groupOption$options.length) > 0;
57
+ }) : true;
58
+ };
59
+
60
+ var canOpenOptions = function canOpenOptions(options, disabled) {
61
+ return !disabled && (options === null || options === void 0 ? void 0 : options.length) > 0 && groupsHaveOptions(options);
62
+ };
63
+
64
+ var filterOptionsBySearchValue = function filterOptionsBySearchValue(options, searchValue) {
65
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
66
+ if (options[0].options) return options.map(function (optionGroup) {
67
+ var group = {
68
+ label: optionGroup.label,
69
+ options: optionGroup.options.filter(function (option) {
70
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
71
+ })
72
+ };
73
+ return group;
74
+ });else return options.filter(function (option) {
75
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
76
+ });
77
+ }
78
+ };
79
+
80
+ var getLastOptionIndex = function getLastOptionIndex(options, filteredOptions, searchable, optional, multiple) {
81
+ var last = 0;
82
+
83
+ var reducer = function reducer(acc, current) {
84
+ var _current$options;
85
+
86
+ return acc + ((_current$options = current.options) === null || _current$options === void 0 ? void 0 : _current$options.length);
87
+ };
88
+
89
+ if (searchable && filteredOptions.length > 0) filteredOptions[0].options ? last = filteredOptions.reduce(reducer, 0) - 1 : last = filteredOptions.length - 1;else if ((options === null || options === void 0 ? void 0 : options.length) > 0) options[0].options ? last = options.reduce(reducer, 0) - 1 : last = options.length - 1;
90
+ return optional && !multiple ? last + 1 : last;
91
+ };
92
+
93
+ var getSelectedOption = function getSelectedOption(value, options, multiple, optional, optionalItem) {
94
+ var selectedOption = multiple ? [] : {};
95
+ var singleSelectionIndex;
96
+
97
+ if (multiple) {
98
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
99
+ options.forEach(function (option) {
100
+ if (option.options) {
101
+ option.options.forEach(function (singleOption) {
102
+ if (value.includes(singleOption.value)) selectedOption.push(singleOption);
103
+ });
104
+ } else if (value.includes(option.value)) selectedOption.push(option);
105
+ });
106
+ }
107
+ } else {
108
+ if (optional && value === "") {
109
+ selectedOption = optionalItem;
110
+ singleSelectionIndex = 0;
111
+ } else if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
112
+ var group_index = 0;
113
+ options.some(function (option, index) {
114
+ if (option.options) {
115
+ option.options.some(function (singleOption) {
116
+ if (singleOption.value === value) {
117
+ selectedOption = singleOption;
118
+ singleSelectionIndex = optional ? group_index + 1 : group_index;
119
+ return true;
120
+ }
121
+
122
+ group_index++;
123
+ });
124
+ } else if (option.value === value) {
125
+ selectedOption = option;
126
+ singleSelectionIndex = optional ? index + 1 : index;
127
+ return true;
128
+ }
129
+ });
130
+ }
131
+ }
132
+
133
+ return {
134
+ selectedOption: selectedOption,
135
+ singleSelectionIndex: singleSelectionIndex
136
+ };
137
+ };
138
+
139
+ var notOptionalCheck = function notOptionalCheck(value, multiple, optional) {
140
+ return !optional && (multiple ? value.length === 0 : value === "");
141
+ };
142
+
143
+ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
144
+ var _selectedOption$label;
145
+
146
+ var label = _ref.label,
147
+ _ref$name = _ref.name,
148
+ name = _ref$name === void 0 ? "" : _ref$name,
149
+ defaultValue = _ref.defaultValue,
150
+ value = _ref.value,
151
+ options = _ref.options,
152
+ helperText = _ref.helperText,
153
+ _ref$placeholder = _ref.placeholder,
154
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
155
+ _ref$disabled = _ref.disabled,
156
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
157
+ _ref$optional = _ref.optional,
158
+ optional = _ref$optional === void 0 ? false : _ref$optional,
159
+ _ref$searchable = _ref.searchable,
160
+ searchable = _ref$searchable === void 0 ? false : _ref$searchable,
161
+ _ref$multiple = _ref.multiple,
162
+ multiple = _ref$multiple === void 0 ? false : _ref$multiple,
163
+ onChange = _ref.onChange,
164
+ onBlur = _ref.onBlur,
165
+ error = _ref.error,
166
+ margin = _ref.margin,
167
+ _ref$size = _ref.size,
168
+ size = _ref$size === void 0 ? "medium" : _ref$size,
169
+ _ref$tabIndex = _ref.tabIndex,
170
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
171
+
172
+ var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
173
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
174
+ selectId = _useState2[0];
175
+
176
+ var selectLabelId = "label-".concat(selectId);
177
+ var errorId = "error-".concat(selectId);
178
+ var optionsListId = "".concat(selectId, "-listbox");
179
+
180
+ var _useState3 = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : multiple ? [] : ""),
181
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
182
+ innerValue = _useState4[0],
183
+ setInnerValue = _useState4[1];
184
+
185
+ var _useState5 = (0, _react.useState)(""),
186
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
187
+ searchValue = _useState6[0],
188
+ setSearchValue = _useState6[1];
189
+
190
+ var _useState7 = (0, _react.useState)(-1),
191
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
192
+ visualFocusIndex = _useState8[0],
193
+ changeVisualFocusIndex = _useState8[1];
194
+
195
+ var _useState9 = (0, _react.useState)(false),
196
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
197
+ isOpen = _useState10[0],
198
+ changeIsOpen = _useState10[1];
199
+
200
+ var _useState11 = (0, _react.useState)(null),
201
+ _useState12 = (0, _slicedToArray2["default"])(_useState11, 2),
202
+ listboxStyles = _useState12[0],
203
+ setListboxStyles = _useState12[1];
204
+
205
+ var selectRef = (0, _react.useRef)(null);
206
+ var selectSearchInputRef = (0, _react.useRef)(null);
207
+ var colorsTheme = (0, _useTheme["default"])();
208
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
209
+ var optionalItem = {
210
+ label: placeholder,
211
+ value: ""
212
+ };
213
+ var filteredOptions = (0, _react.useMemo)(function () {
214
+ return filterOptionsBySearchValue(options, searchValue);
215
+ }, [options, searchValue]);
216
+ var lastOptionIndex = (0, _react.useMemo)(function () {
217
+ return getLastOptionIndex(options, filteredOptions, searchable, optional, multiple);
218
+ }, [options, filteredOptions, searchable, optional, multiple]);
219
+
220
+ var _useMemo = (0, _react.useMemo)(function () {
221
+ return getSelectedOption(value !== null && value !== void 0 ? value : innerValue, options, multiple, optional, optionalItem);
222
+ }, [value, innerValue, options, multiple, optional, optionalItem]),
223
+ selectedOption = _useMemo.selectedOption,
224
+ singleSelectionIndex = _useMemo.singleSelectionIndex;
225
+
226
+ var openOptions = function openOptions() {
227
+ if (!isOpen && canOpenOptions(options, disabled)) changeIsOpen(true);
228
+ };
229
+
230
+ var closeOptions = function closeOptions() {
231
+ if (isOpen) {
232
+ changeIsOpen(false);
233
+ changeVisualFocusIndex(-1);
234
+ }
235
+ };
236
+
237
+ var handleSelectChangeValue = function handleSelectChangeValue(newOption) {
238
+ var newValue;
239
+
240
+ if (multiple) {
241
+ if ((value !== null && value !== void 0 ? value : innerValue).includes(newOption.value)) newValue = (value !== null && value !== void 0 ? value : innerValue).filter(function (optionVal) {
242
+ return optionVal !== newOption.value;
243
+ });else newValue = [].concat((0, _toConsumableArray2["default"])(value !== null && value !== void 0 ? value : innerValue), [newOption.value]);
244
+ } else newValue = newOption.value;
245
+
246
+ value !== null && value !== void 0 ? value : setInnerValue(newValue);
247
+ notOptionalCheck(newValue, multiple, optional) ? onChange === null || onChange === void 0 ? void 0 : onChange({
248
+ value: newValue,
249
+ error: translatedLabels.formFields.requiredValueErrorMessage
250
+ }) : onChange === null || onChange === void 0 ? void 0 : onChange({
251
+ value: newValue
252
+ });
253
+ };
254
+
255
+ var handleSelectOnClick = function handleSelectOnClick() {
256
+ searchable && selectSearchInputRef.current.focus();
257
+
258
+ if (isOpen) {
259
+ closeOptions();
260
+ setSearchValue("");
261
+ } else openOptions();
262
+ };
263
+
264
+ var handleSelectOnFocus = function handleSelectOnFocus(event) {
265
+ if (!event.currentTarget.contains(event.relatedTarget)) searchable && selectSearchInputRef.current.focus();
266
+ };
267
+
268
+ var handleSelectOnBlur = function handleSelectOnBlur(event) {
269
+ // focus leaves container (outside, not to childs)
270
+ if (!event.currentTarget.contains(event.relatedTarget)) {
271
+ closeOptions();
272
+ setSearchValue("");
273
+ var currentValue = value !== null && value !== void 0 ? value : innerValue;
274
+ notOptionalCheck(currentValue, multiple, optional) ? onBlur === null || onBlur === void 0 ? void 0 : onBlur({
275
+ value: currentValue,
276
+ error: translatedLabels.formFields.requiredValueErrorMessage
277
+ }) : onBlur === null || onBlur === void 0 ? void 0 : onBlur({
278
+ value: currentValue
279
+ });
280
+ }
281
+ };
282
+
283
+ var handleSelectOnKeyDown = function handleSelectOnKeyDown(event) {
284
+ switch (event.keyCode) {
285
+ case 40:
286
+ // Arrow Down
287
+ event.preventDefault();
288
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
289
+ if (visualFocusIndex < lastOptionIndex) return visualFocusIndex + 1;else if (visualFocusIndex === lastOptionIndex) return 0;
290
+ });
291
+ openOptions();
292
+ break;
293
+
294
+ case 38:
295
+ // Arrow Up
296
+ event.preventDefault();
297
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
298
+ return visualFocusIndex === 0 || visualFocusIndex === -1 ? lastOptionIndex : visualFocusIndex - 1;
299
+ });
300
+ openOptions();
301
+ break;
302
+
303
+ case 27:
304
+ // Esc
305
+ event.preventDefault();
306
+ closeOptions();
307
+ setSearchValue("");
308
+ break;
309
+
310
+ case 13:
311
+ // Enter
312
+ if (isOpen && visualFocusIndex >= 0) {
313
+ var accLength = optional && !multiple ? 1 : 0;
314
+
315
+ if (searchable) {
316
+ if (filteredOptions.length > 0) {
317
+ if (optional && !multiple && visualFocusIndex === 0 && filteredGroupsHaveOptions(filteredOptions)) handleSelectChangeValue(optionalItem);else filteredOptions[0].options ? filteredGroupsHaveOptions(filteredOptions) && filteredOptions.some(function (groupOption) {
318
+ var groupLength = accLength + groupOption.options.length;
319
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
320
+ accLength = groupLength;
321
+ return groupLength > visualFocusIndex;
322
+ }) : handleSelectChangeValue(filteredOptions[visualFocusIndex - accLength]);
323
+ }
324
+ } else {
325
+ if (optional && !multiple && visualFocusIndex === 0) handleSelectChangeValue(optionalItem);else options[0].options ? options.some(function (groupOption) {
326
+ var groupLength = accLength + groupOption.options.length;
327
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
328
+ accLength = groupLength;
329
+ return groupLength > visualFocusIndex;
330
+ }) : handleSelectChangeValue(options[visualFocusIndex - accLength]);
331
+ }
332
+
333
+ !multiple && closeOptions();
334
+ setSearchValue("");
335
+ }
336
+
337
+ break;
338
+ }
339
+ };
340
+
341
+ var handleSearchIOnChange = function handleSearchIOnChange(event) {
342
+ setSearchValue(event.target.value);
343
+ changeVisualFocusIndex(-1);
344
+ openOptions();
345
+ };
346
+
347
+ var handleClearOptionsActionOnClick = function handleClearOptionsActionOnClick(event) {
348
+ event.stopPropagation();
349
+ value !== null && value !== void 0 ? value : setInnerValue([]);
350
+ !optional ? onChange === null || onChange === void 0 ? void 0 : onChange({
351
+ value: [],
352
+ error: translatedLabels.formFields.requiredValueErrorMessage
353
+ }) : onChange === null || onChange === void 0 ? void 0 : onChange({
354
+ value: []
355
+ });
356
+ };
357
+
358
+ var handleClearSearchActionOnClick = function handleClearSearchActionOnClick(event) {
359
+ event.stopPropagation();
360
+ setSearchValue("");
361
+ };
362
+
363
+ var handleOptionOnClick = (0, _react.useCallback)(function (option) {
364
+ handleSelectChangeValue(option);
365
+ !multiple && closeOptions();
366
+ setSearchValue("");
367
+ }, [handleSelectChangeValue, closeOptions, multiple]);
368
+
369
+ var handleListboxResize = function handleListboxResize() {
370
+ var _selectRef$current;
371
+
372
+ var rect = selectRef === null || selectRef === void 0 ? void 0 : (_selectRef$current = selectRef.current) === null || _selectRef$current === void 0 ? void 0 : _selectRef$current.getBoundingClientRect();
373
+ setListboxStyles({
374
+ width: rect === null || rect === void 0 ? void 0 : rect.width
375
+ });
376
+ };
377
+
378
+ (0, _react.useEffect)(function () {
379
+ handleListboxResize();
380
+ window.addEventListener("resize", handleListboxResize);
381
+ return function () {
382
+ window.removeEventListener("resize", handleListboxResize);
383
+ };
384
+ }, [setListboxStyles]);
385
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
386
+ theme: colorsTheme.select
387
+ }, /*#__PURE__*/_react["default"].createElement(SelectContainer, {
388
+ margin: margin,
389
+ size: size,
390
+ ref: ref
391
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
392
+ id: selectLabelId,
393
+ disabled: disabled,
394
+ onClick: function onClick() {
395
+ selectRef.current.focus();
396
+ },
397
+ helperText: helperText
398
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, translatedLabels.formFields.optionalLabel)), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
399
+ disabled: disabled
400
+ }, helperText), /*#__PURE__*/_react["default"].createElement(Popover.Root, {
401
+ open: isOpen
402
+ }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
403
+ asChild: true
404
+ }, /*#__PURE__*/_react["default"].createElement(Select, {
405
+ id: selectId,
406
+ disabled: disabled,
407
+ error: error,
408
+ onBlur: handleSelectOnBlur,
409
+ onClick: handleSelectOnClick,
410
+ onFocus: handleSelectOnFocus,
411
+ onKeyDown: handleSelectOnKeyDown,
412
+ ref: selectRef,
413
+ tabIndex: tabIndex,
414
+ role: "combobox",
415
+ "aria-controls": optionsListId,
416
+ "aria-disabled": disabled,
417
+ "aria-expanded": isOpen,
418
+ "aria-haspopup": "listbox",
419
+ "aria-labelledby": label ? selectLabelId : undefined,
420
+ "aria-activedescendant": visualFocusIndex >= 0 ? "option-".concat(visualFocusIndex) : undefined,
421
+ "aria-invalid": error ? "true" : "false",
422
+ "aria-errormessage": error ? errorId : undefined,
423
+ "aria-required": !disabled && !optional
424
+ }, multiple && selectedOption.length > 0 && /*#__PURE__*/_react["default"].createElement(SelectionIndicator, null, /*#__PURE__*/_react["default"].createElement(SelectionNumber, {
425
+ disabled: disabled
426
+ }, selectedOption.length), /*#__PURE__*/_react["default"].createElement(ClearOptionsAction, {
427
+ disabled: disabled,
428
+ onMouseDown: function onMouseDown(event) {
429
+ // Avoid input to lose focus when pressed
430
+ event.preventDefault();
431
+ },
432
+ onClick: handleClearOptionsActionOnClick,
433
+ tabIndex: -1,
434
+ title: translatedLabels.select.actionClearSelectionTitle,
435
+ "aria-label": translatedLabels.select.actionClearSelectionTitle
436
+ }, _Icons["default"].clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
437
+ name: name,
438
+ value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(",") : value !== null && value !== void 0 ? value : innerValue,
439
+ readOnly: true,
440
+ "aria-hidden": "true"
441
+ }), searchable && /*#__PURE__*/_react["default"].createElement(SearchInput, {
442
+ value: searchValue,
443
+ disabled: disabled,
444
+ onChange: handleSearchIOnChange,
445
+ ref: selectSearchInputRef,
446
+ autoComplete: "nope",
447
+ autoCorrect: "nope",
448
+ size: 1
449
+ }), (!searchable || searchValue === "") && (multiple ? /*#__PURE__*/_react["default"].createElement(SelectedOption, {
450
+ disabled: disabled,
451
+ atBackground: (value !== null && value !== void 0 ? value : innerValue).length === 0 || searchable && isOpen
452
+ }, /*#__PURE__*/_react["default"].createElement(SelectedOptionLabel, null, selectedOption.map(function (option) {
453
+ return option.label;
454
+ }).join(", ")), selectedOption.length === 0 && placeholder) : /*#__PURE__*/_react["default"].createElement(SelectedOption, {
455
+ disabled: disabled,
456
+ atBackground: !(value !== null && value !== void 0 ? value : innerValue) || searchable && isOpen
457
+ }, /*#__PURE__*/_react["default"].createElement(SelectedOptionLabel, null, (_selectedOption$label = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) !== null && _selectedOption$label !== void 0 ? _selectedOption$label : placeholder)))), !disabled && error && /*#__PURE__*/_react["default"].createElement(ErrorIcon, null, _Icons["default"].error), searchable && searchValue.length > 0 && /*#__PURE__*/_react["default"].createElement(ClearSearchAction, {
458
+ onMouseDown: function onMouseDown(event) {
459
+ // Avoid input to lose focus
460
+ event.preventDefault();
461
+ },
462
+ onClick: handleClearSearchActionOnClick,
463
+ tabIndex: -1,
464
+ title: translatedLabels.select.actionClearSearchTitle,
465
+ "aria-label": translatedLabels.select.actionClearSearchTitle
466
+ }, _Icons["default"].clear), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
467
+ disabled: disabled
468
+ }, isOpen ? _Icons["default"].arrowUp : _Icons["default"].arrowDown))), /*#__PURE__*/_react["default"].createElement(Popover.Content, {
469
+ sideOffset: 4,
470
+ onOpenAutoFocus: function onOpenAutoFocus(event) {
471
+ // Avoid select to lose focus when the list is opened
472
+ event.preventDefault();
473
+ },
474
+ onCloseAutoFocus: function onCloseAutoFocus(event) {
475
+ // Avoid select to lose focus when the list is closed
476
+ event.preventDefault();
477
+ }
478
+ }, /*#__PURE__*/_react["default"].createElement(_Listbox["default"], {
479
+ id: optionsListId,
480
+ currentValue: value !== null && value !== void 0 ? value : innerValue,
481
+ options: searchable ? filteredOptions : options,
482
+ visualFocusIndex: visualFocusIndex,
483
+ lastOptionIndex: lastOptionIndex,
484
+ multiple: multiple,
485
+ optional: optional,
486
+ optionalItem: optionalItem,
487
+ searchable: searchable,
488
+ handleOptionOnClick: handleOptionOnClick,
489
+ styles: listboxStyles
490
+ }))), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
491
+ id: errorId,
492
+ "aria-live": error ? "assertive" : "off"
493
+ }, error)));
494
+ });
495
+
496
+ var sizes = {
497
+ small: "240px",
498
+ medium: "360px",
499
+ large: "480px",
500
+ fillParent: "100%"
501
+ };
502
+
503
+ var calculateWidth = function calculateWidth(margin, size) {
504
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
505
+ };
506
+
507
+ var SelectContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n box-sizing: border-box;\n\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
508
+ return calculateWidth(props.margin, props.size);
509
+ }, function (props) {
510
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
511
+ }, function (props) {
512
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
513
+ }, function (props) {
514
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
515
+ }, function (props) {
516
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
517
+ }, function (props) {
518
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
519
+ });
520
+
521
+ var Label = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n cursor: default;\n ", "\n"])), function (props) {
522
+ return props.disabled ? props.theme.disabledColor : props.theme.labelFontColor;
523
+ }, function (props) {
524
+ return props.theme.fontFamily;
525
+ }, function (props) {
526
+ return props.theme.labelFontSize;
527
+ }, function (props) {
528
+ return props.theme.labelFontStyle;
529
+ }, function (props) {
530
+ return props.theme.labelFontWeight;
531
+ }, function (props) {
532
+ return props.theme.labelLineHeight;
533
+ }, function (props) {
534
+ return !props.helperText && "margin-bottom: 0.25rem";
535
+ });
536
+
537
+ var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
538
+ return props.theme.optionalLabelFontWeight;
539
+ });
540
+
541
+ var HelperText = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-bottom: 0.25rem;\n"])), function (props) {
542
+ return props.disabled ? props.theme.disabledColor : props.theme.helperTextFontColor;
543
+ }, function (props) {
544
+ return props.theme.fontFamily;
545
+ }, function (props) {
546
+ return props.theme.helperTextFontSize;
547
+ }, function (props) {
548
+ return props.theme.helperTextFontStyle;
549
+ }, function (props) {
550
+ return props.theme.helperTextFontWeight;
551
+ }, function (props) {
552
+ return props.theme.helperTextLineHeight;
553
+ });
554
+
555
+ var Select = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n position: relative;\n align-items: center;\n height: calc(2.5rem - 2px);\n padding: 0 0.5rem;\n outline: none;\n ", ";\n box-shadow: 0 0 0 2px transparent;\n border-radius: 4px;\n border: 1px solid\n ", ";\n ", "\n ", ";\n\n ", ";\n"])), function (props) {
556
+ return props.disabled && "background-color: ".concat(props.theme.disabledInputBackgroundColor);
557
+ }, function (props) {
558
+ return props.disabled ? props.theme.disabledInputBorderColor : props.theme.enabledInputBorderColor;
559
+ }, function (props) {
560
+ return props.error && !props.disabled && "border-color: transparent;\n box-shadow: 0 0 0 2px ".concat(props.theme.errorInputBorderColor, ";\n ");
561
+ }, function (props) {
562
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
563
+ }, function (props) {
564
+ return !props.disabled && "\n &:hover {\n border-color: ".concat(props.error ? "transparent" : props.theme.hoverInputBorderColor, ";\n ").concat(props.error && "box-shadow: 0 0 0 2px ".concat(props.theme.hoverInputErrorBorderColor, ";"), "\n }\n &:focus-within {\n border-color: transparent;\n box-shadow: 0 0 0 2px ").concat(props.theme.focusInputBorderColor, ";\n }\n ");
565
+ });
566
+
567
+ var SelectionIndicator = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n border: 1px solid ", ";\n border-radius: 2px;\n max-height: 22px;\n width: 46px;\n"])), function (props) {
568
+ return props.theme.selectionIndicatorBorderColor;
569
+ });
570
+
571
+ var SelectionNumber = _styledComponents["default"].span(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 22px;\n height: 22px;\n user-select: none;\n ", ";\n border-right: 1px solid ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n ", "\n"])), function (props) {
572
+ return !props.disabled && "background-color: ".concat(props.theme.selectionIndicatorBackgroundColor);
573
+ }, function (props) {
574
+ return props.theme.selectionIndicatorBorderColor;
575
+ }, function (props) {
576
+ return props.disabled ? props.theme.disabledColor : props.theme.selectionIndicatorFontColor;
577
+ }, function (props) {
578
+ return props.theme.fontFamily;
579
+ }, function (props) {
580
+ return props.theme.selectionIndicatorFontSize;
581
+ }, function (props) {
582
+ return props.theme.selectionIndicatorFontStyle;
583
+ }, function (props) {
584
+ return props.theme.selectionIndicatorFontWeight;
585
+ }, function (props) {
586
+ return props.disabled ? "cursor: not-allowed;" : "cursor: default;";
587
+ });
588
+
589
+ var ClearOptionsAction = _styledComponents["default"].button(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n width: 23px;\n height: 22px;\n border: none;\n padding: 0.25rem;\n ", "\n background-color: ", ";\n color: ", ";\n\n :focus-visible {\n outline: none;\n }\n ", "\n\n svg {\n line-height: 18px;\n }\n"])), function (props) {
590
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
591
+ }, function (props) {
592
+ return props.disabled ? "transparent" : props.theme.enabledSelectionIndicatorActionBackgroundColor;
593
+ }, function (props) {
594
+ return props.disabled ? props.theme.disabledColor : props.theme.enabledSelectionIndicatorActionIconColor;
595
+ }, function (props) {
596
+ return !props.disabled && "\n &:hover {\n background-color: ".concat(props.theme.hoverSelectionIndicatorActionBackgroundColor, ";\n color: ").concat(props.theme.hoverSelectionIndicatorActionIconColor, ";\n }\n &:active {\n background-color: ").concat(props.theme.activeSelectionIndicatorActionBackgroundColor, ";\n color: ").concat(props.theme.activeSelectionIndicatorActionIconColor, ";\n }\n ");
597
+ });
598
+
599
+ var SearchableValueContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n width: 100%;\n"])));
600
+
601
+ var SelectedOption = _styledComponents["default"].span(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n grid-area: 1 / 1 / 1 / 1;\n display: inline-flex;\n align-items: center;\n height: calc(2.5rem - 2px);\n padding: 0 0.5rem;\n user-select: none;\n overflow: hidden;\n\n color: ", ";\n\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
602
+ if (props.disabled) return props.theme.disabledColor;else if (props.atBackground) return props.theme.placeholderFontColor;else return props.theme.valueFontColor;
603
+ }, function (props) {
604
+ return props.theme.fontFamily;
605
+ }, function (props) {
606
+ return props.theme.valueFontSize;
607
+ }, function (props) {
608
+ return props.theme.valueFontStyle;
609
+ }, function (props) {
610
+ return props.theme.valueFontWeight;
611
+ });
612
+
613
+ var SelectedOptionLabel = _styledComponents["default"].span(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n"])));
614
+
615
+ var ValueInput = _styledComponents["default"].input(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
616
+
617
+ var SearchInput = _styledComponents["default"].input(_templateObject13 || (_templateObject13 = (0, _taggedTemplateLiteral2["default"])(["\n grid-area: 1 / 1 / 1 / 1;\n height: calc(2.5rem - 2px);\n background: none;\n border: none;\n outline: none;\n padding: 0 0.5rem;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: 1.5em;\n"])), function (props) {
618
+ return props.disabled ? props.theme.disabledColor : props.theme.valueFontColor;
619
+ }, function (props) {
620
+ return props.theme.fontFamily;
621
+ }, function (props) {
622
+ return props.theme.valueFontSize;
623
+ }, function (props) {
624
+ return props.theme.valueFontStyle;
625
+ }, function (props) {
626
+ return props.theme.valueFontWeight;
627
+ });
628
+
629
+ var ErrorIcon = _styledComponents["default"].span(_templateObject14 || (_templateObject14 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n padding: 3px;\n height: 18px;\n width: 18px;\n margin-left: 0.25rem;\n pointer-events: none;\n color: ", ";\n\n svg {\n line-height: 18px;\n font-size: 1.25rem;\n }\n"])), function (props) {
630
+ return props.theme.errorIconColor;
631
+ });
632
+
633
+ var Error = _styledComponents["default"].span(_templateObject15 || (_templateObject15 = (0, _taggedTemplateLiteral2["default"])(["\n min-height: 1.5em;\n color: ", ";\n font-family: ", ";\n font-size: 0.75rem;\n font-weight: 400;\n line-height: 1.5em;\n margin-top: 0.25rem;\n"])), function (props) {
634
+ return props.theme.errorMessageColor;
635
+ }, function (props) {
636
+ return props.theme.fontFamily;
637
+ });
638
+
639
+ var CollapseIndicator = _styledComponents["default"].span(_templateObject16 || (_templateObject16 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 16px;\n width: 16px;\n padding: 4px;\n margin-left: 0.25rem;\n color: ", ";\n"])), function (props) {
640
+ return props.disabled ? props.theme.disabledColor : props.theme.collapseIndicatorColor;
641
+ });
642
+
643
+ var ClearSearchAction = _styledComponents["default"].button(_templateObject17 || (_templateObject17 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n font-size: 1rem;\n font-family: ", ";\n border: 1px solid transparent;\n border-radius: 2px;\n padding: 3px;\n margin-left: 0.25rem;\n background-color: ", ";\n color: ", ";\n\n cursor: pointer;\n &:hover {\n background-color: ", ";\n color: ", ";\n }\n &:active {\n background-color: ", ";\n color: ", ";\n }\n svg {\n line-height: 18px;\n }\n"])), function (props) {
644
+ return props.theme.fontFamily;
645
+ }, function (props) {
646
+ return props.theme.actionBackgroundColor;
647
+ }, function (props) {
648
+ return props.theme.actionIconColor;
649
+ }, function (props) {
650
+ return props.theme.hoverActionBackgroundColor;
651
+ }, function (props) {
652
+ return props.theme.hoverActionIconColor;
653
+ }, function (props) {
654
+ return props.theme.activeActionBackgroundColor;
655
+ }, function (props) {
656
+ return props.theme.activeActionIconColor;
657
+ });
658
+
659
+ var _default = DxcSelect;
660
+ exports["default"] = _default;