@dxc-technology/halstack-react 0.0.0-fed0950 → 0.0.0-ff43881

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 (435) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +15 -0
  4. package/ThemeContext.js +243 -0
  5. package/V3Select/V3Select.js +455 -0
  6. package/V3Select/index.d.ts +27 -0
  7. package/V3Textarea/V3Textarea.js +260 -0
  8. package/V3Textarea/index.d.ts +27 -0
  9. package/accordion/Accordion.d.ts +4 -0
  10. package/accordion/Accordion.js +247 -0
  11. package/accordion/Accordion.stories.tsx +307 -0
  12. package/accordion/types.d.ts +64 -0
  13. package/accordion/types.js +5 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +170 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  17. package/accordion-group/types.d.ts +68 -0
  18. package/accordion-group/types.js +5 -0
  19. package/alert/Alert.d.ts +4 -0
  20. package/alert/Alert.js +290 -0
  21. package/alert/Alert.stories.tsx +170 -0
  22. package/alert/types.d.ts +49 -0
  23. package/alert/types.js +5 -0
  24. package/badge/Badge.d.ts +4 -0
  25. package/badge/Badge.js +59 -0
  26. package/badge/types.d.ts +4 -0
  27. package/badge/types.js +5 -0
  28. package/bleed/Bleed.d.ts +3 -0
  29. package/bleed/Bleed.js +84 -0
  30. package/bleed/Bleed.stories.tsx +342 -0
  31. package/bleed/types.d.ts +13 -0
  32. package/bleed/types.js +5 -0
  33. package/box/Box.d.ts +4 -0
  34. package/box/Box.js +126 -0
  35. package/box/Box.stories.tsx +132 -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/button/Button.js +171 -0
  40. package/button/Button.stories.tsx +274 -0
  41. package/button/types.d.ts +53 -0
  42. package/button/types.js +5 -0
  43. package/card/Card.d.ts +4 -0
  44. package/card/Card.js +164 -0
  45. package/card/Card.stories.tsx +201 -0
  46. package/card/ice-cream.jpg +0 -0
  47. package/card/types.d.ts +67 -0
  48. package/card/types.js +5 -0
  49. package/checkbox/Checkbox.d.ts +4 -0
  50. package/checkbox/Checkbox.js +253 -0
  51. package/checkbox/Checkbox.stories.tsx +192 -0
  52. package/checkbox/types.d.ts +60 -0
  53. package/checkbox/types.js +5 -0
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +161 -0
  56. package/chip/Chip.stories.tsx +119 -0
  57. package/chip/types.d.ts +45 -0
  58. package/chip/types.js +5 -0
  59. package/{dist/common → common}/OpenSans.css +0 -0
  60. package/common/RequiredComponent.js +32 -0
  61. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  62. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  63. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  64. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  65. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  68. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  71. package/{dist/common → common}/utils.js +0 -0
  72. package/common/variables.js +1611 -0
  73. package/{dist/date → date}/Date.js +121 -90
  74. package/date/index.d.ts +27 -0
  75. package/date-input/DateInput.d.ts +4 -0
  76. package/date-input/DateInput.js +358 -0
  77. package/date-input/DateInput.stories.tsx +138 -0
  78. package/date-input/types.d.ts +100 -0
  79. package/date-input/types.js +5 -0
  80. package/dialog/Dialog.d.ts +4 -0
  81. package/dialog/Dialog.js +166 -0
  82. package/dialog/Dialog.stories.tsx +212 -0
  83. package/dialog/types.d.ts +43 -0
  84. package/dialog/types.js +5 -0
  85. package/dropdown/Dropdown.d.ts +4 -0
  86. package/dropdown/Dropdown.js +395 -0
  87. package/dropdown/Dropdown.stories.tsx +249 -0
  88. package/dropdown/types.d.ts +80 -0
  89. package/dropdown/types.js +5 -0
  90. package/file-input/FileInput.d.ts +4 -0
  91. package/file-input/FileInput.js +590 -0
  92. package/file-input/FileInput.stories.tsx +507 -0
  93. package/file-input/FileItem.d.ts +14 -0
  94. package/file-input/FileItem.js +184 -0
  95. package/file-input/types.d.ts +112 -0
  96. package/file-input/types.js +5 -0
  97. package/footer/Footer.d.ts +4 -0
  98. package/footer/Footer.js +258 -0
  99. package/footer/Footer.stories.tsx +130 -0
  100. package/footer/Icons.d.ts +2 -0
  101. package/footer/Icons.js +77 -0
  102. package/footer/types.d.ts +65 -0
  103. package/footer/types.js +5 -0
  104. package/header/Header.d.ts +7 -0
  105. package/header/Header.js +324 -0
  106. package/header/Header.stories.tsx +162 -0
  107. package/header/Icons.d.ts +2 -0
  108. package/header/Icons.js +34 -0
  109. package/header/types.d.ts +47 -0
  110. package/header/types.js +5 -0
  111. package/heading/Heading.d.ts +4 -0
  112. package/heading/Heading.js +159 -0
  113. package/heading/Heading.stories.tsx +54 -0
  114. package/heading/types.d.ts +33 -0
  115. package/heading/types.js +5 -0
  116. package/input-text/Icons.js +22 -0
  117. package/input-text/InputText.js +611 -0
  118. package/input-text/index.d.ts +36 -0
  119. package/inset/Inset.d.ts +3 -0
  120. package/inset/Inset.js +84 -0
  121. package/inset/Inset.stories.tsx +229 -0
  122. package/inset/types.d.ts +13 -0
  123. package/inset/types.js +5 -0
  124. package/layout/ApplicationLayout.d.ts +10 -0
  125. package/layout/ApplicationLayout.js +231 -0
  126. package/layout/ApplicationLayout.stories.tsx +171 -0
  127. package/layout/Icons.js +55 -0
  128. package/layout/types.d.ts +57 -0
  129. package/layout/types.js +5 -0
  130. package/link/Link.d.ts +3 -0
  131. package/link/Link.js +153 -0
  132. package/link/Link.stories.tsx +151 -0
  133. package/link/types.d.ts +70 -0
  134. package/link/types.js +5 -0
  135. package/list/List.d.ts +4 -0
  136. package/list/List.js +47 -0
  137. package/list/List.stories.tsx +95 -0
  138. package/list/types.d.ts +7 -0
  139. package/list/types.js +5 -0
  140. package/main.d.ts +51 -0
  141. package/{dist/main.js → main.js} +197 -41
  142. package/number-input/NumberInput.d.ts +4 -0
  143. package/number-input/NumberInput.js +83 -0
  144. package/number-input/NumberInput.stories.tsx +115 -0
  145. package/number-input/NumberInputContext.d.ts +4 -0
  146. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +6 -2
  147. package/number-input/numberInputContextTypes.d.ts +19 -0
  148. package/number-input/numberInputContextTypes.js +5 -0
  149. package/number-input/types.d.ts +117 -0
  150. package/number-input/types.js +5 -0
  151. package/package.json +44 -24
  152. package/paginator/Icons.js +66 -0
  153. package/paginator/Paginator.d.ts +4 -0
  154. package/paginator/Paginator.js +192 -0
  155. package/paginator/Paginator.stories.tsx +63 -0
  156. package/paginator/types.d.ts +38 -0
  157. package/paginator/types.js +5 -0
  158. package/password-input/PasswordInput.d.ts +4 -0
  159. package/password-input/PasswordInput.js +163 -0
  160. package/password-input/PasswordInput.stories.tsx +131 -0
  161. package/password-input/types.d.ts +107 -0
  162. package/password-input/types.js +5 -0
  163. package/progress-bar/ProgressBar.d.ts +4 -0
  164. package/progress-bar/ProgressBar.js +170 -0
  165. package/progress-bar/ProgressBar.stories.jsx +58 -0
  166. package/progress-bar/types.d.ts +37 -0
  167. package/progress-bar/types.js +5 -0
  168. package/radio/Radio.d.ts +4 -0
  169. package/radio/Radio.js +174 -0
  170. package/radio/Radio.stories.tsx +192 -0
  171. package/radio/types.d.ts +54 -0
  172. package/radio/types.js +5 -0
  173. package/radio-group/Radio.d.ts +4 -0
  174. package/radio-group/Radio.js +140 -0
  175. package/radio-group/RadioGroup.d.ts +4 -0
  176. package/radio-group/RadioGroup.js +273 -0
  177. package/radio-group/RadioGroup.stories.tsx +79 -0
  178. package/radio-group/RadioGroup.test.js +248 -0
  179. package/radio-group/types.d.ts +36 -0
  180. package/radio-group/types.js +5 -0
  181. package/resultsetTable/ResultsetTable.d.ts +4 -0
  182. package/resultsetTable/ResultsetTable.js +254 -0
  183. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  184. package/resultsetTable/types.d.ts +67 -0
  185. package/resultsetTable/types.js +5 -0
  186. package/row/Row.d.ts +3 -0
  187. package/row/Row.js +127 -0
  188. package/row/Row.stories.tsx +237 -0
  189. package/row/types.d.ts +10 -0
  190. package/row/types.js +5 -0
  191. package/select/Select.d.ts +4 -0
  192. package/select/Select.js +863 -0
  193. package/select/Select.stories.tsx +572 -0
  194. package/select/types.d.ts +170 -0
  195. package/select/types.js +5 -0
  196. package/sidenav/Sidenav.d.ts +9 -0
  197. package/sidenav/Sidenav.js +136 -0
  198. package/sidenav/Sidenav.stories.tsx +182 -0
  199. package/sidenav/types.d.ts +50 -0
  200. package/sidenav/types.js +5 -0
  201. package/slider/Slider.d.ts +4 -0
  202. package/slider/Slider.js +317 -0
  203. package/slider/Slider.stories.tsx +177 -0
  204. package/slider/types.d.ts +78 -0
  205. package/slider/types.js +5 -0
  206. package/spinner/Spinner.d.ts +4 -0
  207. package/spinner/Spinner.js +250 -0
  208. package/spinner/Spinner.stories.jsx +103 -0
  209. package/spinner/types.d.ts +32 -0
  210. package/spinner/types.js +5 -0
  211. package/stack/Stack.d.ts +3 -0
  212. package/stack/Stack.js +97 -0
  213. package/stack/Stack.stories.tsx +164 -0
  214. package/stack/types.d.ts +9 -0
  215. package/stack/types.js +5 -0
  216. package/switch/Switch.d.ts +4 -0
  217. package/switch/Switch.js +179 -0
  218. package/switch/Switch.stories.tsx +160 -0
  219. package/switch/types.d.ts +58 -0
  220. package/switch/types.js +5 -0
  221. package/table/Table.d.ts +4 -0
  222. package/table/Table.js +118 -0
  223. package/table/Table.stories.jsx +277 -0
  224. package/table/types.d.ts +21 -0
  225. package/table/types.js +5 -0
  226. package/tabs/Tabs.d.ts +4 -0
  227. package/tabs/Tabs.js +213 -0
  228. package/tabs/Tabs.stories.tsx +120 -0
  229. package/tabs/types.d.ts +78 -0
  230. package/tabs/types.js +5 -0
  231. package/tag/Tag.d.ts +4 -0
  232. package/tag/Tag.js +188 -0
  233. package/tag/Tag.stories.tsx +138 -0
  234. package/tag/types.d.ts +69 -0
  235. package/tag/types.js +5 -0
  236. package/text/Text.d.ts +7 -0
  237. package/text/Text.js +30 -0
  238. package/text/Text.stories.tsx +19 -0
  239. package/text-input/TextInput.d.ts +4 -0
  240. package/text-input/TextInput.js +794 -0
  241. package/text-input/TextInput.stories.tsx +456 -0
  242. package/text-input/types.d.ts +159 -0
  243. package/text-input/types.js +5 -0
  244. package/textarea/Textarea.d.ts +4 -0
  245. package/textarea/Textarea.js +284 -0
  246. package/textarea/Textarea.stories.jsx +136 -0
  247. package/textarea/types.d.ts +130 -0
  248. package/textarea/types.js +5 -0
  249. package/toggle-group/ToggleGroup.d.ts +4 -0
  250. package/toggle-group/ToggleGroup.js +214 -0
  251. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  252. package/toggle-group/types.d.ts +97 -0
  253. package/toggle-group/types.js +5 -0
  254. package/{dist/upload → upload}/Upload.js +23 -22
  255. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  256. package/upload/buttons-upload/Icons.js +40 -0
  257. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  258. package/upload/dragAndDropArea/Icons.js +39 -0
  259. package/upload/file-upload/FileToUpload.js +115 -0
  260. package/upload/file-upload/Icons.js +66 -0
  261. package/upload/files-upload/FilesToUpload.js +109 -0
  262. package/upload/index.d.ts +15 -0
  263. package/upload/transaction/Icons.js +160 -0
  264. package/upload/transaction/Transaction.js +104 -0
  265. package/upload/transactions/Transactions.js +94 -0
  266. package/useTheme.d.ts +2 -0
  267. package/useTheme.js +22 -0
  268. package/wizard/Wizard.d.ts +4 -0
  269. package/wizard/Wizard.js +281 -0
  270. package/wizard/Wizard.stories.tsx +224 -0
  271. package/wizard/types.d.ts +60 -0
  272. package/wizard/types.js +5 -0
  273. package/babel.config.js +0 -4
  274. package/dist/accordion/Accordion.js +0 -264
  275. package/dist/accordion/Accordion.stories.js +0 -207
  276. package/dist/accordion/readme.md +0 -96
  277. package/dist/alert/Alert.js +0 -302
  278. package/dist/alert/Alert.stories.js +0 -158
  279. package/dist/alert/close.svg +0 -4
  280. package/dist/alert/error.svg +0 -4
  281. package/dist/alert/info.svg +0 -4
  282. package/dist/alert/readme.md +0 -43
  283. package/dist/alert/success.svg +0 -4
  284. package/dist/alert/warning.svg +0 -4
  285. package/dist/box/Box.js +0 -136
  286. package/dist/button/Button.js +0 -187
  287. package/dist/button/Button.stories.js +0 -224
  288. package/dist/button/readme.md +0 -93
  289. package/dist/card/Card.js +0 -246
  290. package/dist/checkbox/Checkbox.js +0 -221
  291. package/dist/checkbox/Checkbox.stories.js +0 -144
  292. package/dist/checkbox/readme.md +0 -116
  293. package/dist/chip/Chip.js +0 -170
  294. package/dist/common/RequiredComponent.js +0 -50
  295. package/dist/common/services/example-service.js +0 -10
  296. package/dist/common/services/example-service.test.js +0 -12
  297. package/dist/common/variables.js +0 -77
  298. package/dist/date/Date.stories.js +0 -205
  299. package/dist/date/calendar.svg +0 -1
  300. package/dist/date/calendar_dark.svg +0 -1
  301. package/dist/date/readme.md +0 -73
  302. package/dist/dialog/Dialog.js +0 -164
  303. package/dist/dialog/Dialog.stories.js +0 -217
  304. package/dist/dialog/readme.md +0 -32
  305. package/dist/dropdown/Dropdown.js +0 -412
  306. package/dist/dropdown/Dropdown.stories.js +0 -249
  307. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  308. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  309. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  310. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  311. package/dist/dropdown/readme.md +0 -69
  312. package/dist/footer/Footer.js +0 -341
  313. package/dist/footer/Footer.stories.js +0 -94
  314. package/dist/footer/dxc_logo_wht.png +0 -0
  315. package/dist/footer/readme.md +0 -41
  316. package/dist/header/Header.js +0 -343
  317. package/dist/header/Header.stories.js +0 -176
  318. package/dist/header/close_icon.svg +0 -1
  319. package/dist/header/dxc_logo_black.png +0 -0
  320. package/dist/header/dxc_logo_white.png +0 -0
  321. package/dist/header/hamb_menu_black.svg +0 -1
  322. package/dist/header/hamb_menu_white.svg +0 -1
  323. package/dist/header/readme.md +0 -33
  324. package/dist/heading/Heading.js +0 -159
  325. package/dist/input-text/InputText.js +0 -510
  326. package/dist/input-text/InputText.stories.js +0 -209
  327. package/dist/input-text/error.svg +0 -1
  328. package/dist/input-text/readme.md +0 -91
  329. package/dist/link/Link.js +0 -129
  330. package/dist/link/readme.md +0 -51
  331. package/dist/paginator/Paginator.js +0 -178
  332. package/dist/paginator/images/next.svg +0 -3
  333. package/dist/paginator/images/nextPage.svg +0 -3
  334. package/dist/paginator/images/previous.svg +0 -3
  335. package/dist/paginator/images/previousPage.svg +0 -3
  336. package/dist/paginator/readme.md +0 -50
  337. package/dist/progress-bar/ProgressBar.js +0 -189
  338. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  339. package/dist/progress-bar/readme.md +0 -63
  340. package/dist/radio/Radio.js +0 -204
  341. package/dist/radio/Radio.stories.js +0 -166
  342. package/dist/radio/readme.md +0 -70
  343. package/dist/resultsetTable/ResultsetTable.js +0 -334
  344. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  345. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  346. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  347. package/dist/select/Select.js +0 -425
  348. package/dist/select/Select.stories.js +0 -235
  349. package/dist/select/readme.md +0 -72
  350. package/dist/sidenav/Sidenav.js +0 -217
  351. package/dist/sidenav/arrow_icon.svg +0 -3
  352. package/dist/slider/Slider.js +0 -268
  353. package/dist/slider/Slider.stories.js +0 -241
  354. package/dist/slider/readme.md +0 -64
  355. package/dist/spinner/Spinner.js +0 -196
  356. package/dist/spinner/Spinner.stories.js +0 -183
  357. package/dist/spinner/readme.md +0 -65
  358. package/dist/switch/Switch.js +0 -219
  359. package/dist/switch/Switch.stories.js +0 -134
  360. package/dist/switch/readme.md +0 -133
  361. package/dist/table/Table.js +0 -84
  362. package/dist/tabs/Tabs.js +0 -183
  363. package/dist/tabs/Tabs.stories.js +0 -130
  364. package/dist/tabs/readme.md +0 -78
  365. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  366. package/dist/tabs-for-sections/readme.md +0 -78
  367. package/dist/tag/Tag.js +0 -217
  368. package/dist/textarea/Textarea.js +0 -226
  369. package/dist/toggle/Toggle.js +0 -223
  370. package/dist/toggle/Toggle.stories.js +0 -297
  371. package/dist/toggle/readme.md +0 -80
  372. package/dist/upload/Upload.stories.js +0 -72
  373. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  374. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  375. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  376. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  377. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  378. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  379. package/dist/upload/file-upload/FileToUpload.js +0 -158
  380. package/dist/upload/file-upload/audio-icon.svg +0 -4
  381. package/dist/upload/file-upload/close.svg +0 -4
  382. package/dist/upload/file-upload/file-icon.svg +0 -4
  383. package/dist/upload/file-upload/video-icon.svg +0 -4
  384. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  385. package/dist/upload/readme.md +0 -37
  386. package/dist/upload/transaction/Transaction.js +0 -155
  387. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  388. package/dist/upload/transaction/audio-icon.svg +0 -4
  389. package/dist/upload/transaction/error-icon.svg +0 -4
  390. package/dist/upload/transaction/file-icon-err.svg +0 -4
  391. package/dist/upload/transaction/file-icon.svg +0 -4
  392. package/dist/upload/transaction/image-icon-err.svg +0 -4
  393. package/dist/upload/transaction/image-icon.svg +0 -4
  394. package/dist/upload/transaction/success-icon.svg +0 -4
  395. package/dist/upload/transaction/video-icon-err.svg +0 -4
  396. package/dist/upload/transaction/video-icon.svg +0 -4
  397. package/dist/upload/transactions/Transactions.js +0 -120
  398. package/dist/wizard/Wizard.js +0 -310
  399. package/dist/wizard/invalid_icon.svg +0 -6
  400. package/dist/wizard/valid_icon.svg +0 -6
  401. package/dist/wizard/validation-wrong.svg +0 -6
  402. package/test/Accordion.test.js +0 -33
  403. package/test/Alert.test.js +0 -53
  404. package/test/Box.test.js +0 -10
  405. package/test/Button.test.js +0 -18
  406. package/test/Card.test.js +0 -30
  407. package/test/Checkbox.test.js +0 -45
  408. package/test/Chip.test.js +0 -25
  409. package/test/Date.test.js +0 -393
  410. package/test/Dialog.test.js +0 -23
  411. package/test/Dropdown.test.js +0 -130
  412. package/test/Footer.test.js +0 -99
  413. package/test/Header.test.js +0 -39
  414. package/test/Heading.test.js +0 -35
  415. package/test/InputText.test.js +0 -236
  416. package/test/Link.test.js +0 -25
  417. package/test/Paginator.test.js +0 -165
  418. package/test/ProgressBar.test.js +0 -35
  419. package/test/Radio.test.js +0 -37
  420. package/test/ResultsetTable.test.js +0 -282
  421. package/test/Select.test.js +0 -191
  422. package/test/Sidenav.test.js +0 -87
  423. package/test/Slider.test.js +0 -65
  424. package/test/Spinner.test.js +0 -27
  425. package/test/Switch.test.js +0 -45
  426. package/test/Table.test.js +0 -36
  427. package/test/Tabs.test.js +0 -88
  428. package/test/TabsForSections.test.js +0 -34
  429. package/test/Tag.test.js +0 -32
  430. package/test/TextArea.test.js +0 -52
  431. package/test/Toggle.test.js +0 -43
  432. package/test/Upload.test.js +0 -60
  433. package/test/Wizard.test.js +0 -130
  434. package/test/mocks/pngMock.js +0 -1
  435. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,863 @@
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 _variables = require("../common/variables.js");
27
+
28
+ var _uuid = require("uuid");
29
+
30
+ var _utils = require("../common/utils.js");
31
+
32
+ var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox"));
33
+
34
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18, _templateObject19, _templateObject20, _templateObject21, _templateObject22, _templateObject23, _templateObject24, _templateObject25, _templateObject26, _templateObject27, _templateObject28;
35
+
36
+ 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); }
37
+
38
+ 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; }
39
+
40
+ var selectIcons = {
41
+ error: /*#__PURE__*/_react["default"].createElement("svg", {
42
+ role: "img",
43
+ xmlns: "http://www.w3.org/2000/svg",
44
+ height: "24px",
45
+ viewBox: "0 0 24 24",
46
+ width: "24px",
47
+ fill: "currentColor"
48
+ }, /*#__PURE__*/_react["default"].createElement("path", {
49
+ d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"
50
+ })),
51
+ arrowUp: /*#__PURE__*/_react["default"].createElement("svg", {
52
+ role: "img",
53
+ xmlns: "http://www.w3.org/2000/svg",
54
+ height: "24px",
55
+ viewBox: "0 0 24 24",
56
+ width: "24px",
57
+ fill: "currentColor"
58
+ }, /*#__PURE__*/_react["default"].createElement("path", {
59
+ d: "M0 0h24v24H0V0z",
60
+ fill: "none"
61
+ }), /*#__PURE__*/_react["default"].createElement("path", {
62
+ d: "M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6 1.41 1.41z"
63
+ })),
64
+ arrowDown: /*#__PURE__*/_react["default"].createElement("svg", {
65
+ role: "img",
66
+ xmlns: "http://www.w3.org/2000/svg",
67
+ height: "24px",
68
+ viewBox: "0 0 24 24",
69
+ width: "24px",
70
+ fill: "currentColor"
71
+ }, /*#__PURE__*/_react["default"].createElement("path", {
72
+ d: "M0 0h24v24H0V0z",
73
+ fill: "none"
74
+ }), /*#__PURE__*/_react["default"].createElement("path", {
75
+ d: "M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z"
76
+ })),
77
+ clear: /*#__PURE__*/_react["default"].createElement("svg", {
78
+ role: "img",
79
+ xmlns: "http://www.w3.org/2000/svg",
80
+ width: "24",
81
+ height: "24",
82
+ viewBox: "0 0 24 24",
83
+ fill: "currentColor"
84
+ }, /*#__PURE__*/_react["default"].createElement("path", {
85
+ d: "M0 0h24v24H0V0z",
86
+ fill: "none"
87
+ }), /*#__PURE__*/_react["default"].createElement("path", {
88
+ d: "M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"
89
+ })),
90
+ selected: /*#__PURE__*/_react["default"].createElement("svg", {
91
+ role: "img",
92
+ xmlns: "http://www.w3.org/2000/svg",
93
+ height: "24px",
94
+ viewBox: "0 0 24 24",
95
+ width: "24px",
96
+ fill: "currentColor"
97
+ }, /*#__PURE__*/_react["default"].createElement("path", {
98
+ d: "M0 0h24v24H0z",
99
+ fill: "none"
100
+ }), /*#__PURE__*/_react["default"].createElement("path", {
101
+ d: "M9 16.2L4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4L9 16.2z"
102
+ })),
103
+ searchOff: /*#__PURE__*/_react["default"].createElement("svg", {
104
+ role: "img",
105
+ xmlns: "http://www.w3.org/2000/svg",
106
+ height: "24px",
107
+ viewBox: "0 0 24 24",
108
+ width: "24px",
109
+ fill: "currentColor"
110
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("rect", {
111
+ fill: "none",
112
+ height: "24",
113
+ width: "24"
114
+ })), /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
115
+ d: "M15.5,14h-0.79l-0.28-0.27C15.41,12.59,16,11.11,16,9.5C16,5.91,13.09,3,9.5,3C6.08,3,3.28,5.64,3.03,9h2.02 C5.3,6.75,7.18,5,9.5,5C11.99,5,14,7.01,14,9.5S11.99,14,9.5,14c-0.17,0-0.33-0.03-0.5-0.05v2.02C9.17,15.99,9.33,16,9.5,16 c1.61,0,3.09-0.59,4.23-1.57L14,14.71v0.79l5,4.99L20.49,19L15.5,14z"
116
+ }), /*#__PURE__*/_react["default"].createElement("polygon", {
117
+ points: "6.47,10.82 4,13.29 1.53,10.82 0.82,11.53 3.29,14 0.82,16.47 1.53,17.18 4,14.71 6.47,17.18 7.18,16.47 4.71,14 7.18,11.53"
118
+ }))))
119
+ };
120
+
121
+ var getNotOptionalErrorMessage = function getNotOptionalErrorMessage() {
122
+ return "This field is required. Please, enter a value.";
123
+ };
124
+
125
+ var filterOptionsBySearchValue = function filterOptionsBySearchValue(options, searchValue) {
126
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
127
+ if (options[0].options) return options.map(function (optionGroup) {
128
+ var group = {
129
+ label: optionGroup.label,
130
+ options: optionGroup.options.filter(function (option) {
131
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
132
+ })
133
+ };
134
+ return group;
135
+ });else return options.filter(function (option) {
136
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
137
+ });
138
+ }
139
+ };
140
+
141
+ var getLastOptionIndex = function getLastOptionIndex(options, filteredOptions, searchable, optional, multiple) {
142
+ var last = 0;
143
+
144
+ var reducer = function reducer(acc, current) {
145
+ var _current$options;
146
+
147
+ return acc + ((_current$options = current.options) === null || _current$options === void 0 ? void 0 : _current$options.length);
148
+ };
149
+
150
+ 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;
151
+ return optional && !multiple ? last + 1 : last;
152
+ };
153
+
154
+ var getSelectedOption = function getSelectedOption(options, multiple, optional, optionalEmptyOption, value, innerValue) {
155
+ var val = value !== null && value !== void 0 ? value : innerValue;
156
+ var selectedOption = multiple ? [] : {};
157
+ var singleSelectionIndex;
158
+
159
+ if (multiple) {
160
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
161
+ options.forEach(function (option) {
162
+ if (option.options) {
163
+ option.options.forEach(function (singleOption) {
164
+ if (val.includes(singleOption.value)) selectedOption.push(singleOption);
165
+ });
166
+ } else if (val.includes(option.value)) selectedOption.push(option);
167
+ });
168
+ }
169
+ } else {
170
+ if (optional && val === "") {
171
+ selectedOption = optionalEmptyOption;
172
+ singleSelectionIndex = 0;
173
+ } else if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
174
+ var group_index = 0;
175
+ options.some(function (option, index) {
176
+ if (option.options) {
177
+ option.options.some(function (singleOption) {
178
+ if (singleOption.value === val) {
179
+ selectedOption = singleOption;
180
+ singleSelectionIndex = optional ? group_index + 1 : group_index;
181
+ return true;
182
+ }
183
+
184
+ group_index++;
185
+ });
186
+ } else if (option.value === val) {
187
+ selectedOption = option;
188
+ singleSelectionIndex = optional ? index + 1 : index;
189
+ return true;
190
+ }
191
+ });
192
+ }
193
+ }
194
+
195
+ return {
196
+ selectedOption: selectedOption,
197
+ singleSelectionIndex: singleSelectionIndex
198
+ };
199
+ };
200
+
201
+ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
202
+ var _selectedOption$label;
203
+
204
+ var label = _ref.label,
205
+ _ref$name = _ref.name,
206
+ name = _ref$name === void 0 ? "" : _ref$name,
207
+ value = _ref.value,
208
+ options = _ref.options,
209
+ helperText = _ref.helperText,
210
+ _ref$placeholder = _ref.placeholder,
211
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
212
+ _ref$disabled = _ref.disabled,
213
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
214
+ _ref$optional = _ref.optional,
215
+ optional = _ref$optional === void 0 ? false : _ref$optional,
216
+ _ref$searchable = _ref.searchable,
217
+ searchable = _ref$searchable === void 0 ? false : _ref$searchable,
218
+ _ref$multiple = _ref.multiple,
219
+ multiple = _ref$multiple === void 0 ? false : _ref$multiple,
220
+ onChange = _ref.onChange,
221
+ onBlur = _ref.onBlur,
222
+ error = _ref.error,
223
+ margin = _ref.margin,
224
+ _ref$size = _ref.size,
225
+ size = _ref$size === void 0 ? "medium" : _ref$size,
226
+ _ref$tabIndex = _ref.tabIndex,
227
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
228
+
229
+ var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
230
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
231
+ selectId = _useState2[0];
232
+
233
+ var selectLabelId = "label-".concat(selectId);
234
+ var optionsListId = "".concat(selectId, "-listbox");
235
+
236
+ var _useState3 = (0, _react.useState)(multiple ? [] : ""),
237
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
238
+ innerValue = _useState4[0],
239
+ setInnerValue = _useState4[1];
240
+
241
+ var _useState5 = (0, _react.useState)(""),
242
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
243
+ searchValue = _useState6[0],
244
+ setSearchValue = _useState6[1];
245
+
246
+ var _useState7 = (0, _react.useState)(-1),
247
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
248
+ visualFocusIndex = _useState8[0],
249
+ changeVisualFocusIndex = _useState8[1];
250
+
251
+ var _useState9 = (0, _react.useState)(false),
252
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
253
+ isOpen = _useState10[0],
254
+ changeIsOpen = _useState10[1];
255
+
256
+ var selectContainerRef = (0, _react.useRef)(null);
257
+ var selectSearchInputRef = (0, _react.useRef)(null);
258
+ var selectOptionsListRef = (0, _react.useRef)(null);
259
+ var colorsTheme = (0, _useTheme["default"])();
260
+ var optionalEmptyOption = {
261
+ label: placeholder,
262
+ value: ""
263
+ };
264
+ var filteredOptions = (0, _react.useMemo)(function () {
265
+ return filterOptionsBySearchValue(options, searchValue);
266
+ }, [options, searchValue]);
267
+ var lastOptionIndex = (0, _react.useMemo)(function () {
268
+ return getLastOptionIndex(options, filteredOptions, searchable, optional, multiple);
269
+ }, [searchable, optional, multiple, filteredOptions, options]);
270
+
271
+ var _useMemo = (0, _react.useMemo)(function () {
272
+ return getSelectedOption(options, multiple, optional, optionalEmptyOption, value, innerValue);
273
+ }, [options, multiple, optional, value, innerValue]),
274
+ selectedOption = _useMemo.selectedOption,
275
+ singleSelectionIndex = _useMemo.singleSelectionIndex;
276
+
277
+ var notOptionalCheck = function notOptionalCheck(value) {
278
+ return value === "" && !optional;
279
+ };
280
+
281
+ var notOptionalMultipleCheck = function notOptionalMultipleCheck() {
282
+ return (value !== null && value !== void 0 ? value : innerValue).length === 0 && !optional;
283
+ };
284
+
285
+ var canBeOpenOptions = function canBeOpenOptions() {
286
+ return !disabled && (options === null || options === void 0 ? void 0 : options.length) > 0 && groupsHaveOptions();
287
+ };
288
+
289
+ var groupsHaveOptions = function groupsHaveOptions() {
290
+ return options[0].hasOwnProperty("options") ? options[0].options ? options.some(function (groupOption) {
291
+ return groupOption.options.length > 0;
292
+ }) : false : true;
293
+ };
294
+
295
+ var filteredGroupsHaveOptions = function filteredGroupsHaveOptions() {
296
+ return filteredOptions !== null && filteredOptions !== void 0 && filteredOptions[0].options ? filteredOptions.some(function (groupOption) {
297
+ var _groupOption$options;
298
+
299
+ return ((_groupOption$options = groupOption.options) === null || _groupOption$options === void 0 ? void 0 : _groupOption$options.length) > 0;
300
+ }) : true;
301
+ };
302
+
303
+ var openOptions = function openOptions() {
304
+ if (!isOpen && canBeOpenOptions()) changeIsOpen(true);
305
+ };
306
+
307
+ var closeOptions = function closeOptions() {
308
+ if (isOpen) {
309
+ changeIsOpen(false);
310
+ changeVisualFocusIndex(-1);
311
+ }
312
+ };
313
+
314
+ var handleSelectChangeValue = function handleSelectChangeValue(newOption) {
315
+ if (multiple) {
316
+ var _res, _res2;
317
+
318
+ var res;
319
+ if ((value !== null && value !== void 0 ? value : innerValue).includes(newOption.value)) value ? res = value.filter(function (optionVal) {
320
+ return optionVal !== newOption.value;
321
+ }) : setInnerValue(function (previous) {
322
+ return previous.filter(function (optionVal) {
323
+ return optionVal !== newOption.value;
324
+ });
325
+ });else value ? res = [].concat((0, _toConsumableArray2["default"])(value), [newOption.value]) : setInnerValue(function (previous) {
326
+ return [].concat((0, _toConsumableArray2["default"])(previous), [newOption.value]);
327
+ });
328
+ if (notOptionalMultipleCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
329
+ value: (_res = res) !== null && _res !== void 0 ? _res : innerValue,
330
+ error: getNotOptionalErrorMessage()
331
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
332
+ value: (_res2 = res) !== null && _res2 !== void 0 ? _res2 : innerValue,
333
+ error: null
334
+ });
335
+ } else {
336
+ value !== null && value !== void 0 ? value : setInnerValue(newOption.value);
337
+ if (notOptionalCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
338
+ value: newOption.value,
339
+ error: getNotOptionalErrorMessage()
340
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
341
+ value: newOption.value,
342
+ error: null
343
+ });
344
+ }
345
+ };
346
+
347
+ var handleSelectOnClick = function handleSelectOnClick() {
348
+ searchable && selectSearchInputRef.current.focus();
349
+
350
+ if (isOpen) {
351
+ closeOptions();
352
+ setSearchValue("");
353
+ } else openOptions();
354
+ };
355
+
356
+ var handleSelectOnFocus = function handleSelectOnFocus(event) {
357
+ if (!event.currentTarget.contains(event.relatedTarget)) searchable && selectSearchInputRef.current.focus();
358
+ };
359
+
360
+ var handleSelectOnBlur = function handleSelectOnBlur(event) {
361
+ // focus leaves container (outside, not to childs)
362
+ if (!event.currentTarget.contains(event.relatedTarget)) {
363
+ closeOptions();
364
+ setSearchValue("");
365
+ if (notOptionalCheck(value !== null && value !== void 0 ? value : innerValue)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
366
+ value: value !== null && value !== void 0 ? value : innerValue,
367
+ error: getNotOptionalErrorMessage()
368
+ });else onBlur === null || onBlur === void 0 ? void 0 : onBlur({
369
+ value: value !== null && value !== void 0 ? value : innerValue,
370
+ error: null
371
+ });
372
+ }
373
+ };
374
+
375
+ var handleSelectOnKeyDown = function handleSelectOnKeyDown(event) {
376
+ switch (event.keyCode) {
377
+ case 40:
378
+ // Arrow Down
379
+ event.preventDefault();
380
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
381
+ if (visualFocusIndex < lastOptionIndex) return visualFocusIndex + 1;else if (visualFocusIndex === lastOptionIndex) return 0;
382
+ });
383
+ openOptions();
384
+ break;
385
+
386
+ case 38:
387
+ // Arrow Up
388
+ event.preventDefault();
389
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
390
+ return visualFocusIndex === 0 || visualFocusIndex === -1 ? lastOptionIndex : visualFocusIndex - 1;
391
+ });
392
+ openOptions();
393
+ break;
394
+
395
+ case 27:
396
+ // Esc
397
+ event.preventDefault();
398
+ closeOptions();
399
+ setSearchValue("");
400
+ break;
401
+
402
+ case 13:
403
+ // Enter
404
+ if (isOpen && visualFocusIndex >= 0) {
405
+ var accLength = optional && !multiple ? 1 : 0;
406
+
407
+ if (searchable) {
408
+ if (filteredOptions.length > 0) {
409
+ if (optional && !multiple && visualFocusIndex === 0 && filteredGroupsHaveOptions()) handleSelectChangeValue(optionalEmptyOption);else filteredOptions[0].options ? filteredGroupsHaveOptions() && filteredOptions.some(function (groupOption) {
410
+ var groupLength = accLength + groupOption.options.length;
411
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
412
+ accLength = groupLength;
413
+ return groupLength > visualFocusIndex;
414
+ }) : handleSelectChangeValue(filteredOptions[visualFocusIndex - accLength]);
415
+ }
416
+ } else {
417
+ if (optional && !multiple && visualFocusIndex === 0) handleSelectChangeValue(optionalEmptyOption);else options[0].options ? options.some(function (groupOption) {
418
+ var groupLength = accLength + groupOption.options.length;
419
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
420
+ accLength = groupLength;
421
+ return groupLength > visualFocusIndex;
422
+ }) : handleSelectChangeValue(options[visualFocusIndex - accLength]);
423
+ }
424
+
425
+ !multiple && closeOptions();
426
+ setSearchValue("");
427
+ }
428
+
429
+ break;
430
+ }
431
+ };
432
+
433
+ var handleSearchIOnChange = function handleSearchIOnChange(event) {
434
+ setSearchValue(event.target.value);
435
+ changeVisualFocusIndex(-1);
436
+ openOptions();
437
+ };
438
+
439
+ var handleClearOptionsActionOnClick = function handleClearOptionsActionOnClick(event) {
440
+ event.stopPropagation();
441
+ value !== null && value !== void 0 ? value : setInnerValue([]);
442
+ onChange === null || onChange === void 0 ? void 0 : onChange({
443
+ value: [],
444
+ error: getNotOptionalErrorMessage()
445
+ });
446
+ };
447
+
448
+ var handleClearSearchActionOnClick = function handleClearSearchActionOnClick(event) {
449
+ event.stopPropagation();
450
+ setSearchValue("");
451
+ };
452
+
453
+ (0, _react.useLayoutEffect)(function () {
454
+ if (isOpen && singleSelectionIndex) {
455
+ var _listEl$scrollTo;
456
+
457
+ var listEl = selectOptionsListRef === null || selectOptionsListRef === void 0 ? void 0 : selectOptionsListRef.current;
458
+ var selectedListOptionEl = listEl === null || listEl === void 0 ? void 0 : listEl.querySelector("[aria-selected='true']");
459
+ listEl === null || listEl === void 0 ? void 0 : (_listEl$scrollTo = listEl.scrollTo) === null || _listEl$scrollTo === void 0 ? void 0 : _listEl$scrollTo.call(listEl, {
460
+ top: (selectedListOptionEl === null || selectedListOptionEl === void 0 ? void 0 : selectedListOptionEl.offsetTop) - (listEl === null || listEl === void 0 ? void 0 : listEl.clientHeight) / 2
461
+ });
462
+ }
463
+ }, [isOpen]);
464
+ (0, _react.useLayoutEffect)(function () {
465
+ var _selectOptionsListRef, _visualFocusedOptionE;
466
+
467
+ var visualFocusedOptionEl = selectOptionsListRef === null || selectOptionsListRef === void 0 ? void 0 : (_selectOptionsListRef = selectOptionsListRef.current) === null || _selectOptionsListRef === void 0 ? void 0 : _selectOptionsListRef.querySelectorAll("[role='option']")[visualFocusIndex];
468
+ visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
469
+ block: "nearest",
470
+ inline: "start"
471
+ });
472
+ }, [visualFocusIndex]);
473
+
474
+ var Option = function Option(_ref2) {
475
+ var option = _ref2.option,
476
+ index = _ref2.index,
477
+ _ref2$isGroupedOption = _ref2.isGroupedOption,
478
+ isGroupedOption = _ref2$isGroupedOption === void 0 ? false : _ref2$isGroupedOption;
479
+ var isSelected = multiple ? (value !== null && value !== void 0 ? value : innerValue).includes(option.value) : (value !== null && value !== void 0 ? value : innerValue) === option.value;
480
+ var isLastOption = index === lastOptionIndex;
481
+ return /*#__PURE__*/_react["default"].createElement(OptionItem, {
482
+ id: "option-".concat(index),
483
+ onClick: function onClick() {
484
+ handleSelectChangeValue(option);
485
+ !multiple && closeOptions();
486
+ setSearchValue("");
487
+ },
488
+ visualFocused: visualFocusIndex === index,
489
+ selected: isSelected,
490
+ role: "option",
491
+ "aria-selected": isSelected
492
+ }, /*#__PURE__*/_react["default"].createElement(StyledOption, {
493
+ visualFocused: visualFocusIndex === index,
494
+ selected: isSelected,
495
+ last: isLastOption,
496
+ grouped: isGroupedOption,
497
+ multiple: multiple
498
+ }, multiple && /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
499
+ tabIndex: -1,
500
+ checked: isSelected
501
+ }), option.icon && /*#__PURE__*/_react["default"].createElement(OptionIcon, {
502
+ grouped: isGroupedOption,
503
+ multiple: multiple,
504
+ role: !(typeof option.icon === "string") && "img"
505
+ }, typeof option.icon === "string" ? /*#__PURE__*/_react["default"].createElement(OptionIconImg, {
506
+ src: option.icon
507
+ }) : option.icon), /*#__PURE__*/_react["default"].createElement(OptionContent, {
508
+ grouped: isGroupedOption,
509
+ hasIcon: option.icon,
510
+ multiple: multiple
511
+ }, /*#__PURE__*/_react["default"].createElement(OptionLabel, null, option.label), !multiple && isSelected && /*#__PURE__*/_react["default"].createElement(OptionSelectedIndicator, null, selectIcons.selected))));
512
+ };
513
+
514
+ var globalIndex = optional && !multiple ? 0 : -1; // index for options, starting from 0 to options.length -1
515
+
516
+ var mapOptionFunc = function mapOptionFunc(option, mapIndex) {
517
+ if (option.options) {
518
+ var groupId = "group-".concat(mapIndex);
519
+ return option.options.length > 0 && /*#__PURE__*/_react["default"].createElement("li", null, /*#__PURE__*/_react["default"].createElement(GroupList, {
520
+ role: "group",
521
+ "aria-labelledby": groupId
522
+ }, /*#__PURE__*/_react["default"].createElement(GroupLabel, {
523
+ role: "presentation",
524
+ id: groupId
525
+ }, option.label), option.options.map(function (singleOption) {
526
+ globalIndex++;
527
+ return /*#__PURE__*/_react["default"].createElement(Option, {
528
+ option: singleOption,
529
+ index: globalIndex,
530
+ isGroupedOption: true
531
+ });
532
+ })));
533
+ } else {
534
+ globalIndex++;
535
+ return /*#__PURE__*/_react["default"].createElement(Option, {
536
+ key: "option-".concat(option.value),
537
+ option: option,
538
+ index: globalIndex
539
+ });
540
+ }
541
+ };
542
+
543
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
544
+ theme: colorsTheme.select
545
+ }, /*#__PURE__*/_react["default"].createElement(SelectContainer, {
546
+ margin: margin,
547
+ size: size,
548
+ ref: ref
549
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
550
+ id: selectLabelId,
551
+ disabled: disabled,
552
+ onClick: function onClick() {
553
+ selectContainerRef.current.focus();
554
+ },
555
+ helperText: helperText
556
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
557
+ disabled: disabled
558
+ }, helperText), /*#__PURE__*/_react["default"].createElement(Select, {
559
+ id: selectId,
560
+ disabled: disabled,
561
+ error: error,
562
+ onBlur: handleSelectOnBlur,
563
+ onClick: handleSelectOnClick,
564
+ onFocus: handleSelectOnFocus,
565
+ onKeyDown: handleSelectOnKeyDown,
566
+ ref: selectContainerRef,
567
+ tabIndex: tabIndex,
568
+ role: "combobox",
569
+ "aria-controls": optionsListId,
570
+ "aria-expanded": isOpen,
571
+ "aria-haspopup": "listbox",
572
+ "aria-labelledby": selectLabelId,
573
+ "aria-activedescendant": visualFocusIndex >= 0 ? "option-".concat(visualFocusIndex) : undefined,
574
+ "aria-invalid": error ? "true" : "false",
575
+ "aria-required": !optional
576
+ }, multiple && selectedOption.length > 0 && /*#__PURE__*/_react["default"].createElement(SelectionIndicator, null, /*#__PURE__*/_react["default"].createElement(SelectionNumber, {
577
+ disabled: disabled
578
+ }, selectedOption.length), /*#__PURE__*/_react["default"].createElement(ClearOptionsAction, {
579
+ disabled: disabled,
580
+ onMouseDown: function onMouseDown(event) {
581
+ // Avoid input to lose focus when pressed
582
+ event.preventDefault();
583
+ },
584
+ onClick: handleClearOptionsActionOnClick,
585
+ tabIndex: -1,
586
+ title: "Clear selection",
587
+ "aria-label": "Clear selection"
588
+ }, selectIcons.clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
589
+ name: name,
590
+ value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(", ") : value !== null && value !== void 0 ? value : innerValue,
591
+ readOnly: true,
592
+ "aria-hidden": "true"
593
+ }), searchable && /*#__PURE__*/_react["default"].createElement(SearchInput, {
594
+ value: searchValue,
595
+ disabled: disabled,
596
+ onChange: handleSearchIOnChange,
597
+ ref: selectSearchInputRef,
598
+ autoComplete: "off",
599
+ autoCorrect: "off",
600
+ size: "1"
601
+ }), (!searchable || searchValue === "") && (multiple ? /*#__PURE__*/_react["default"].createElement(SelectedOption, {
602
+ disabled: disabled,
603
+ atBackground: (value !== null && value !== void 0 ? value : innerValue).length === 0 || searchable && isOpen
604
+ }, /*#__PURE__*/_react["default"].createElement(OptionLabel, null, selectedOption.map(function (option) {
605
+ return option.label;
606
+ }).join(", ")), selectedOption.length === 0 && placeholder) : /*#__PURE__*/_react["default"].createElement(SelectedOption, {
607
+ disabled: disabled,
608
+ atBackground: !(value !== null && value !== void 0 ? value : innerValue) || searchable && isOpen
609
+ }, /*#__PURE__*/_react["default"].createElement(OptionLabel, 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, selectIcons.error), searchable && searchValue.length > 0 && /*#__PURE__*/_react["default"].createElement(ClearSearchAction, {
610
+ onMouseDown: function onMouseDown(event) {
611
+ // Avoid input to lose focus
612
+ event.preventDefault();
613
+ },
614
+ onClick: handleClearSearchActionOnClick,
615
+ tabIndex: -1,
616
+ title: "Clear search",
617
+ "aria-label": "Clear search"
618
+ }, selectIcons.clear), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
619
+ disabled: disabled
620
+ }, isOpen ? selectIcons.arrowUp : selectIcons.arrowDown), isOpen && /*#__PURE__*/_react["default"].createElement(OptionsList, {
621
+ id: optionsListId,
622
+ onClick: function onClick(event) {
623
+ event.stopPropagation();
624
+ },
625
+ onMouseDown: function onMouseDown(event) {
626
+ event.preventDefault();
627
+ },
628
+ ref: selectOptionsListRef,
629
+ role: "listbox",
630
+ "aria-multiselectable": multiple
631
+ }, searchable && (filteredOptions.length === 0 || !filteredGroupsHaveOptions()) ? /*#__PURE__*/_react["default"].createElement(OptionsSystemMessage, null, /*#__PURE__*/_react["default"].createElement(NoMatchesFoundIcon, null, selectIcons.searchOff), "No matches found") : optional && !multiple && /*#__PURE__*/_react["default"].createElement(Option, {
632
+ option: optionalEmptyOption,
633
+ index: 0
634
+ }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, null, error)));
635
+ });
636
+
637
+ var sizes = {
638
+ small: "240px",
639
+ medium: "360px",
640
+ large: "480px",
641
+ fillParent: "100%"
642
+ };
643
+
644
+ var calculateWidth = function calculateWidth(margin, size) {
645
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
646
+ };
647
+
648
+ 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) {
649
+ return calculateWidth(props.margin, props.size);
650
+ }, function (props) {
651
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
652
+ }, function (props) {
653
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
654
+ }, function (props) {
655
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
656
+ }, function (props) {
657
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
658
+ }, function (props) {
659
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
660
+ });
661
+
662
+ 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) {
663
+ return props.disabled ? props.theme.disabledColor : props.theme.labelFontColor;
664
+ }, function (props) {
665
+ return props.theme.fontFamily;
666
+ }, function (props) {
667
+ return props.theme.labelFontSize;
668
+ }, function (props) {
669
+ return props.theme.labelFontStyle;
670
+ }, function (props) {
671
+ return props.theme.labelFontWeight;
672
+ }, function (props) {
673
+ return props.theme.labelLineHeight;
674
+ }, function (props) {
675
+ return !props.helperText && "margin-bottom: 0.25rem";
676
+ });
677
+
678
+ var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
679
+ return props.theme.optionalLabelFontWeight;
680
+ });
681
+
682
+ 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) {
683
+ return props.disabled ? props.theme.disabledColor : props.theme.helperTextFontColor;
684
+ }, function (props) {
685
+ return props.theme.fontFamily;
686
+ }, function (props) {
687
+ return props.theme.helperTextFontSize;
688
+ }, function (props) {
689
+ return props.theme.helperTextFontStyle;
690
+ }, function (props) {
691
+ return props.theme.helperTextFontWeight;
692
+ }, function (props) {
693
+ return props.theme.helperTextLineHeight;
694
+ });
695
+
696
+ 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) {
697
+ return props.disabled && "background-color: ".concat(props.theme.disabledInputBackgroundColor);
698
+ }, function (props) {
699
+ return props.disabled ? props.theme.disabledInputBorderColor : props.theme.enabledInputBorderColor;
700
+ }, function (props) {
701
+ return props.error && !props.disabled && "border-color: transparent;\n box-shadow: 0 0 0 2px ".concat(props.theme.errorInputBorderColor, ";\n ");
702
+ }, function (props) {
703
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
704
+ }, function (props) {
705
+ 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 ");
706
+ });
707
+
708
+ 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) {
709
+ return props.theme.selectionIndicatorBorderColor;
710
+ });
711
+
712
+ 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) {
713
+ return !props.disabled && "background-color: ".concat(props.theme.selectionIndicatorBackgroundColor);
714
+ }, function (props) {
715
+ return props.theme.selectionIndicatorBorderColor;
716
+ }, function (props) {
717
+ return props.disabled ? props.theme.disabledColor : props.theme.selectionIndicatorFontColor;
718
+ }, function (props) {
719
+ return props.theme.fontFamily;
720
+ }, function (props) {
721
+ return props.theme.selectionIndicatorFontSize;
722
+ }, function (props) {
723
+ return props.theme.selectionIndicatorFontStyle;
724
+ }, function (props) {
725
+ return props.theme.selectionIndicatorFontWeight;
726
+ }, function (props) {
727
+ return props.disabled ? "cursor: not-allowed;" : "cursor: default;";
728
+ });
729
+
730
+ 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 font-size: 1rem;\n font-family: ", ";\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) {
731
+ return props.theme.fontFamily;
732
+ }, function (props) {
733
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
734
+ }, function (props) {
735
+ return props.disabled ? "transparent" : props.theme.enabledSelectionIndicatorActionBackgroundColor;
736
+ }, function (props) {
737
+ return props.disabled ? props.theme.disabledColor : props.theme.enabledSelectionIndicatorActionIconColor;
738
+ }, function (props) {
739
+ 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 ");
740
+ });
741
+
742
+ var SearchableValueContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n width: 100%;\n"])));
743
+
744
+ 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) {
745
+ if (props.disabled) return props.theme.disabledColor;else if (props.atBackground) return props.theme.placeholderFontColor;else return props.theme.valueFontColor;
746
+ }, function (props) {
747
+ return props.theme.fontFamily;
748
+ }, function (props) {
749
+ return props.theme.valueFontSize;
750
+ }, function (props) {
751
+ return props.theme.valueFontStyle;
752
+ }, function (props) {
753
+ return props.theme.valueFontWeight;
754
+ });
755
+
756
+ var ValueInput = _styledComponents["default"].input(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
757
+
758
+ var SearchInput = _styledComponents["default"].input(_templateObject12 || (_templateObject12 = (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) {
759
+ return props.disabled ? props.theme.disabledColor : props.theme.valueFontColor;
760
+ }, function (props) {
761
+ return props.theme.fontFamily;
762
+ }, function (props) {
763
+ return props.theme.valueFontSize;
764
+ }, function (props) {
765
+ return props.theme.valueFontStyle;
766
+ }, function (props) {
767
+ return props.theme.valueFontWeight;
768
+ });
769
+
770
+ var ErrorIcon = _styledComponents["default"].span(_templateObject13 || (_templateObject13 = (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) {
771
+ return props.theme.errorIconColor;
772
+ });
773
+
774
+ var Error = _styledComponents["default"].span(_templateObject14 || (_templateObject14 = (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) {
775
+ return props.theme.errorMessageColor;
776
+ }, function (props) {
777
+ return props.theme.fontFamily;
778
+ });
779
+
780
+ var CollapseIndicator = _styledComponents["default"].span(_templateObject15 || (_templateObject15 = (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) {
781
+ return props.disabled ? props.theme.disabledColor : props.theme.collapseIndicatorColor;
782
+ });
783
+
784
+ var ClearSearchAction = _styledComponents["default"].button(_templateObject16 || (_templateObject16 = (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) {
785
+ return props.theme.fontFamily;
786
+ }, function (props) {
787
+ return props.theme.actionBackgroundColor;
788
+ }, function (props) {
789
+ return props.theme.actionIconColor;
790
+ }, function (props) {
791
+ return props.theme.hoverActionBackgroundColor;
792
+ }, function (props) {
793
+ return props.theme.hoverActionIconColor;
794
+ }, function (props) {
795
+ return props.theme.activeActionBackgroundColor;
796
+ }, function (props) {
797
+ return props.theme.activeActionIconColor;
798
+ });
799
+
800
+ var OptionsList = _styledComponents["default"].ul(_templateObject17 || (_templateObject17 = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n z-index: 1;\n max-height: 304px;\n overflow-y: auto;\n top: calc(100% + 4px);\n left: 0;\n margin: 0;\n padding: 0.25rem 0;\n width: 100%;\n background-color: ", ";\n border: 1px solid ", ";\n border-radius: 0.25rem;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n cursor: default;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
801
+ return props.theme.listDialogBackgroundColor;
802
+ }, function (props) {
803
+ return props.theme.listDialogBorderColor;
804
+ }, function (props) {
805
+ return props.theme.listOptionFontColor;
806
+ }, function (props) {
807
+ return props.theme.fontFamily;
808
+ }, function (props) {
809
+ return props.theme.listOptionFontSize;
810
+ }, function (props) {
811
+ return props.theme.listOptionFontStyle;
812
+ }, function (props) {
813
+ return props.theme.listOptionFontWeight;
814
+ });
815
+
816
+ var OptionsSystemMessage = _styledComponents["default"].span(_templateObject18 || (_templateObject18 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 4px 16px;\n color: ", ";\n font-size: 0.875rem;\n line-height: 1.715em;\n"])), function (props) {
817
+ return props.theme.systemMessageFontColor;
818
+ });
819
+
820
+ var NoMatchesFoundIcon = _styledComponents["default"].span(_templateObject19 || (_templateObject19 = (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-right: 0.25rem;\n"])));
821
+
822
+ var GroupList = _styledComponents["default"].ul(_templateObject20 || (_templateObject20 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0;\n"])));
823
+
824
+ var GroupLabel = _styledComponents["default"].li(_templateObject21 || (_templateObject21 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 4px 16px;\n font-weight: ", ";\n line-height: 1.715em;\n"])), function (props) {
825
+ return props.theme.listGroupLabelFontWeight;
826
+ });
827
+
828
+ var OptionItem = _styledComponents["default"].li(_templateObject22 || (_templateObject22 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0 0.5rem;\n box-shadow: inset 0 0 0 2px transparent;\n ", "\n ", ";\n line-height: 1.715em;\n cursor: pointer;\n\n &:hover {\n ", ";\n }\n &:active {\n ", ";\n }\n"])), function (props) {
829
+ return props.visualFocused && "box-shadow: inset 0 0 0 2px ".concat(props.theme.focusListOptionBorderColor, ";");
830
+ }, function (props) {
831
+ return props.selected && "background-color: ".concat(props.theme.selectedListOptionBackgroundColor);
832
+ }, function (props) {
833
+ return props.selected ? "background-color: ".concat(props.theme.selectedHoverListOptionBackgroundColor, ";") : "background-color: ".concat(props.theme.unselectedHoverListOptionBackgroundColor, ";");
834
+ }, function (props) {
835
+ return props.selected ? "background-color: ".concat(props.theme.selectedActiveListOptionBackgroundColor, ";") : "background-color: ".concat(props.theme.unselectedActiveListOptionBackgroundColor, ";");
836
+ });
837
+
838
+ var StyledOption = _styledComponents["default"].span(_templateObject23 || (_templateObject23 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 0.25rem 0.5rem 0.188rem 0;\n min-height: 24px;\n ", "\n ", ";\n"])), function (props) {
839
+ return props.grouped && props.multiple && "padding-left: 16px;";
840
+ }, function (props) {
841
+ return props.last || props.visualFocused || props.selected ? "border-bottom: 1px solid transparent" : "border-bottom: 1px solid ".concat(props.theme.listOptionDividerColor);
842
+ });
843
+
844
+ var OptionContent = _styledComponents["default"].span(_templateObject24 || (_templateObject24 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n width: 100%;\n overflow: hidden;\n ", "\n"])), function (props) {
845
+ return props.grouped && !props.multiple && !props.hasIcon ? "padding-left: 16px;" : "padding-left: 8px;";
846
+ });
847
+
848
+ var OptionIcon = _styledComponents["default"].span(_templateObject25 || (_templateObject25 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 24px;\n width: 24px;\n ", "\n color: ", ";\n"])), function (props) {
849
+ return props.grouped && !props.multiple ? "padding-left: 16px;" : "padding-left: 8px;";
850
+ }, function (props) {
851
+ return props.theme.listOptionIconColor;
852
+ });
853
+
854
+ var OptionIconImg = _styledComponents["default"].img(_templateObject26 || (_templateObject26 = (0, _taggedTemplateLiteral2["default"])(["\n width: 16px;\n height: 16px;\n"])));
855
+
856
+ var OptionLabel = _styledComponents["default"].span(_templateObject27 || (_templateObject27 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n"])));
857
+
858
+ var OptionSelectedIndicator = _styledComponents["default"].span(_templateObject28 || (_templateObject28 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 16px;\n width: 16px;\n margin-left: 4px;\n color: ", ";\n"])), function (props) {
859
+ return props.theme.selectedListOptionIconColor;
860
+ });
861
+
862
+ var _default = DxcSelect;
863
+ exports["default"] = _default;