@dxc-technology/halstack-react 0.0.0-fc652e4 → 0.0.0-fdc49d2

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 (440) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +248 -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 +170 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +133 -0
  15. package/accordion-group/types.d.ts +68 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +44 -157
  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 +59 -0
  25. package/badge/types.d.ts +4 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +84 -0
  29. package/bleed/Bleed.stories.tsx +342 -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/{dist/box → box}/Box.js +15 -45
  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 +27 -94
  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/{dist/card → card}/Card.js +34 -124
  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 +24 -77
  53. package/checkbox/Checkbox.stories.tsx +192 -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 +351 -345
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/date-input/DateInput.js +354 -0
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +492 -0
  81. package/date-input/types.d.ts +104 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/{dist/dialog → dialog}/Dialog.js +24 -76
  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 -208
  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 +590 -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 +184 -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 +258 -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/footer/Icons.js +77 -0
  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 +324 -0
  113. package/header/Header.stories.tsx +162 -0
  114. package/header/Header.test.js +63 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/header/Icons.js +34 -0
  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 +31 -90
  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/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +84 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +13 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +10 -0
  131. package/layout/ApplicationLayout.js +231 -0
  132. package/layout/ApplicationLayout.stories.tsx +171 -0
  133. package/layout/Icons.js +55 -0
  134. package/layout/types.d.ts +57 -0
  135. package/layout/types.js +5 -0
  136. package/link/Link.d.ts +3 -0
  137. package/{dist/link → link}/Link.js +23 -111
  138. package/link/Link.stories.tsx +151 -0
  139. package/link/Link.test.js +91 -0
  140. package/link/types.d.ts +70 -0
  141. package/link/types.js +5 -0
  142. package/list/List.d.ts +4 -0
  143. package/list/List.js +47 -0
  144. package/list/List.stories.tsx +95 -0
  145. package/list/types.d.ts +7 -0
  146. package/list/types.js +5 -0
  147. package/main.d.ts +47 -0
  148. package/{dist/main.js → main.js} +135 -99
  149. package/number-input/NumberInput.d.ts +4 -0
  150. package/number-input/NumberInput.js +76 -0
  151. package/number-input/NumberInput.stories.tsx +115 -0
  152. package/number-input/NumberInput.test.js +508 -0
  153. package/number-input/NumberInputContext.d.ts +4 -0
  154. package/{dist/number/NumberContext.js → number-input/NumberInputContext.js} +6 -3
  155. package/number-input/numberInputContextTypes.d.ts +19 -0
  156. package/number-input/numberInputContextTypes.js +5 -0
  157. package/number-input/types.d.ts +121 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +34 -24
  160. package/paginator/Icons.js +66 -0
  161. package/paginator/Paginator.d.ts +4 -0
  162. package/paginator/Paginator.js +192 -0
  163. package/paginator/Paginator.stories.tsx +63 -0
  164. package/paginator/Paginator.test.js +266 -0
  165. package/paginator/types.d.ts +38 -0
  166. package/paginator/types.js +5 -0
  167. package/password-input/PasswordInput.d.ts +4 -0
  168. package/{dist/password/Password.js → password-input/PasswordInput.js} +46 -83
  169. package/password-input/PasswordInput.stories.tsx +131 -0
  170. package/password-input/PasswordInput.test.js +183 -0
  171. package/password-input/types.d.ts +107 -0
  172. package/password-input/types.js +5 -0
  173. package/progress-bar/ProgressBar.d.ts +4 -0
  174. package/{dist/progress-bar → progress-bar}/ProgressBar.js +22 -94
  175. package/progress-bar/ProgressBar.stories.jsx +58 -0
  176. package/progress-bar/ProgressBar.test.js +65 -0
  177. package/progress-bar/types.d.ts +37 -0
  178. package/progress-bar/types.js +5 -0
  179. package/quick-nav/QuickNav.d.ts +4 -0
  180. package/quick-nav/QuickNav.js +60 -0
  181. package/quick-nav/QuickNav.stories.tsx +237 -0
  182. package/quick-nav/types.d.ts +25 -0
  183. package/quick-nav/types.js +5 -0
  184. package/radio/Radio.d.ts +4 -0
  185. package/{dist/radio → radio}/Radio.js +17 -52
  186. package/radio/Radio.stories.tsx +192 -0
  187. package/radio/Radio.test.js +71 -0
  188. package/radio/types.d.ts +54 -0
  189. package/radio/types.js +5 -0
  190. package/radio-group/Radio.d.ts +4 -0
  191. package/radio-group/Radio.js +141 -0
  192. package/radio-group/RadioGroup.d.ts +4 -0
  193. package/radio-group/RadioGroup.js +280 -0
  194. package/radio-group/RadioGroup.stories.tsx +100 -0
  195. package/radio-group/RadioGroup.test.js +695 -0
  196. package/radio-group/types.d.ts +114 -0
  197. package/radio-group/types.js +5 -0
  198. package/resultsetTable/ResultsetTable.d.ts +4 -0
  199. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  200. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  201. package/resultsetTable/ResultsetTable.test.js +306 -0
  202. package/resultsetTable/types.d.ts +67 -0
  203. package/resultsetTable/types.js +5 -0
  204. package/row/Row.d.ts +3 -0
  205. package/row/Row.js +127 -0
  206. package/row/Row.stories.tsx +237 -0
  207. package/row/types.d.ts +28 -0
  208. package/row/types.js +5 -0
  209. package/select/Icons.d.ts +10 -0
  210. package/select/Icons.js +93 -0
  211. package/select/Option.d.ts +4 -0
  212. package/select/Option.js +110 -0
  213. package/select/Select.d.ts +4 -0
  214. package/select/Select.js +740 -0
  215. package/select/Select.stories.tsx +582 -0
  216. package/select/Select.test.js +2016 -0
  217. package/select/types.d.ts +191 -0
  218. package/select/types.js +5 -0
  219. package/sidenav/Sidenav.d.ts +9 -0
  220. package/sidenav/Sidenav.js +136 -0
  221. package/sidenav/Sidenav.stories.tsx +182 -0
  222. package/sidenav/Sidenav.test.js +56 -0
  223. package/sidenav/types.d.ts +50 -0
  224. package/sidenav/types.js +5 -0
  225. package/slider/Slider.d.ts +4 -0
  226. package/slider/Slider.js +317 -0
  227. package/slider/Slider.stories.tsx +177 -0
  228. package/slider/Slider.test.js +129 -0
  229. package/slider/types.d.ts +78 -0
  230. package/slider/types.js +5 -0
  231. package/spinner/Spinner.d.ts +4 -0
  232. package/spinner/Spinner.js +250 -0
  233. package/spinner/Spinner.stories.jsx +103 -0
  234. package/spinner/Spinner.test.js +64 -0
  235. package/spinner/types.d.ts +32 -0
  236. package/spinner/types.js +5 -0
  237. package/stack/Stack.d.ts +3 -0
  238. package/stack/Stack.js +97 -0
  239. package/stack/Stack.stories.tsx +164 -0
  240. package/stack/types.d.ts +24 -0
  241. package/stack/types.js +5 -0
  242. package/switch/Switch.d.ts +4 -0
  243. package/{dist/switch → switch}/Switch.js +45 -75
  244. package/switch/Switch.stories.tsx +160 -0
  245. package/switch/Switch.test.js +98 -0
  246. package/switch/types.d.ts +62 -0
  247. package/switch/types.js +5 -0
  248. package/table/Table.d.ts +4 -0
  249. package/{dist/table → table}/Table.js +12 -26
  250. package/table/Table.stories.jsx +277 -0
  251. package/table/Table.test.js +26 -0
  252. package/table/types.d.ts +21 -0
  253. package/table/types.js +5 -0
  254. package/tabs/Tabs.d.ts +4 -0
  255. package/tabs/Tabs.js +213 -0
  256. package/tabs/Tabs.stories.tsx +120 -0
  257. package/tabs/Tabs.test.js +123 -0
  258. package/tabs/types.d.ts +78 -0
  259. package/tabs/types.js +5 -0
  260. package/tag/Tag.d.ts +4 -0
  261. package/tag/Tag.js +186 -0
  262. package/tag/Tag.stories.tsx +142 -0
  263. package/tag/Tag.test.js +60 -0
  264. package/tag/types.d.ts +69 -0
  265. package/tag/types.js +5 -0
  266. package/text/Text.d.ts +7 -0
  267. package/text/Text.js +30 -0
  268. package/text/Text.stories.tsx +19 -0
  269. package/text-input/TextInput.d.ts +4 -0
  270. package/text-input/TextInput.js +798 -0
  271. package/text-input/TextInput.stories.tsx +474 -0
  272. package/text-input/TextInput.test.js +1725 -0
  273. package/text-input/types.d.ts +163 -0
  274. package/text-input/types.js +5 -0
  275. package/textarea/Textarea.d.ts +4 -0
  276. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +95 -155
  277. package/textarea/Textarea.stories.jsx +157 -0
  278. package/textarea/Textarea.test.js +437 -0
  279. package/textarea/types.d.ts +134 -0
  280. package/textarea/types.js +5 -0
  281. package/toggle-group/ToggleGroup.d.ts +4 -0
  282. package/toggle-group/ToggleGroup.js +214 -0
  283. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  284. package/toggle-group/ToggleGroup.test.js +125 -0
  285. package/toggle-group/types.d.ts +97 -0
  286. package/toggle-group/types.js +5 -0
  287. package/useTheme.d.ts +2 -0
  288. package/{dist/useTheme.js → useTheme.js} +1 -1
  289. package/wizard/Wizard.d.ts +4 -0
  290. package/wizard/Wizard.js +286 -0
  291. package/wizard/Wizard.stories.tsx +214 -0
  292. package/wizard/Wizard.test.js +141 -0
  293. package/wizard/types.d.ts +64 -0
  294. package/wizard/types.js +5 -0
  295. package/README.md +0 -66
  296. package/babel.config.js +0 -8
  297. package/dist/BackgroundColorContext.js +0 -46
  298. package/dist/ThemeContext.js +0 -241
  299. package/dist/accordion/Accordion.js +0 -353
  300. package/dist/accordion-group/AccordionGroup.js +0 -188
  301. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  302. package/dist/accordion-group/readme.md +0 -70
  303. package/dist/badge/Badge.js +0 -63
  304. package/dist/checkbox/Checkbox.stories.js +0 -144
  305. package/dist/checkbox/readme.md +0 -116
  306. package/dist/chip/Chip.js +0 -265
  307. package/dist/date/Date.js +0 -381
  308. package/dist/date/Date.stories.js +0 -205
  309. package/dist/date/readme.md +0 -73
  310. package/dist/footer/Footer.js +0 -395
  311. package/dist/footer/Footer.stories.js +0 -94
  312. package/dist/footer/dxc_logo.svg +0 -15
  313. package/dist/footer/readme.md +0 -41
  314. package/dist/header/Header.js +0 -403
  315. package/dist/header/Header.stories.js +0 -176
  316. package/dist/header/close_icon.svg +0 -1
  317. package/dist/header/dxc_logo_black.svg +0 -8
  318. package/dist/header/hamb_menu_black.svg +0 -1
  319. package/dist/header/hamb_menu_white.svg +0 -1
  320. package/dist/header/readme.md +0 -33
  321. package/dist/input-text/InputText.js +0 -707
  322. package/dist/input-text/InputText.stories.js +0 -209
  323. package/dist/input-text/error.svg +0 -1
  324. package/dist/input-text/readme.md +0 -91
  325. package/dist/layout/ApplicationLayout.js +0 -331
  326. package/dist/layout/facebook.svg +0 -45
  327. package/dist/layout/linkedin.svg +0 -50
  328. package/dist/layout/twitter.svg +0 -53
  329. package/dist/link/readme.md +0 -51
  330. package/dist/new-date/NewDate.js +0 -403
  331. package/dist/new-input-text/NewInputText.js +0 -961
  332. package/dist/number/Number.js +0 -138
  333. package/dist/paginator/Paginator.js +0 -289
  334. package/dist/paginator/images/next.svg +0 -3
  335. package/dist/paginator/images/nextPage.svg +0 -3
  336. package/dist/paginator/images/previous.svg +0 -3
  337. package/dist/paginator/images/previousPage.svg +0 -3
  338. package/dist/paginator/readme.md +0 -50
  339. package/dist/password/styles.css +0 -3
  340. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  341. package/dist/progress-bar/readme.md +0 -63
  342. package/dist/radio/Radio.stories.js +0 -166
  343. package/dist/radio/readme.md +0 -70
  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 -585
  348. package/dist/select/Select.stories.js +0 -235
  349. package/dist/select/readme.md +0 -72
  350. package/dist/sidenav/Sidenav.js +0 -177
  351. package/dist/slider/Slider.js +0 -319
  352. package/dist/slider/Slider.stories.js +0 -241
  353. package/dist/slider/readme.md +0 -64
  354. package/dist/spinner/Spinner.js +0 -218
  355. package/dist/spinner/Spinner.stories.js +0 -183
  356. package/dist/spinner/readme.md +0 -65
  357. package/dist/switch/Switch.stories.js +0 -134
  358. package/dist/switch/readme.md +0 -133
  359. package/dist/tabs/Tabs.js +0 -343
  360. package/dist/tabs/Tabs.stories.js +0 -130
  361. package/dist/tabs/readme.md +0 -78
  362. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  363. package/dist/tabs-for-sections/readme.md +0 -78
  364. package/dist/tag/Tag.js +0 -288
  365. package/dist/textarea/Textarea.js +0 -264
  366. package/dist/toggle/Toggle.js +0 -220
  367. package/dist/toggle/Toggle.stories.js +0 -297
  368. package/dist/toggle/readme.md +0 -80
  369. package/dist/toggle-group/ToggleGroup.js +0 -223
  370. package/dist/upload/Upload.js +0 -205
  371. package/dist/upload/Upload.stories.js +0 -72
  372. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  373. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  374. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  375. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  376. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  377. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  378. package/dist/upload/file-upload/FileToUpload.js +0 -184
  379. package/dist/upload/file-upload/audio-icon.svg +0 -4
  380. package/dist/upload/file-upload/close.svg +0 -4
  381. package/dist/upload/file-upload/file-icon.svg +0 -4
  382. package/dist/upload/file-upload/video-icon.svg +0 -4
  383. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  384. package/dist/upload/readme.md +0 -37
  385. package/dist/upload/transaction/Transaction.js +0 -175
  386. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  387. package/dist/upload/transaction/audio-icon.svg +0 -4
  388. package/dist/upload/transaction/error-icon.svg +0 -4
  389. package/dist/upload/transaction/file-icon-err.svg +0 -4
  390. package/dist/upload/transaction/file-icon.svg +0 -4
  391. package/dist/upload/transaction/image-icon-err.svg +0 -4
  392. package/dist/upload/transaction/image-icon.svg +0 -4
  393. package/dist/upload/transaction/success-icon.svg +0 -4
  394. package/dist/upload/transaction/video-icon-err.svg +0 -4
  395. package/dist/upload/transaction/video-icon.svg +0 -4
  396. package/dist/upload/transactions/Transactions.js +0 -138
  397. package/dist/wizard/Wizard.js +0 -411
  398. package/dist/wizard/invalid_icon.svg +0 -5
  399. package/dist/wizard/valid_icon.svg +0 -5
  400. package/dist/wizard/validation-wrong.svg +0 -6
  401. package/test/Accordion.test.js +0 -33
  402. package/test/AccordionGroup.test.js +0 -125
  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 -145
  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 -240
  416. package/test/Link.test.js +0 -43
  417. package/test/NewDate.test.js +0 -203
  418. package/test/NewInputText.test.js +0 -817
  419. package/test/NewTextarea.test.js +0 -201
  420. package/test/Number.test.js +0 -241
  421. package/test/Paginator.test.js +0 -177
  422. package/test/Password.test.js +0 -76
  423. package/test/ProgressBar.test.js +0 -35
  424. package/test/Radio.test.js +0 -37
  425. package/test/ResultsetTable.test.js +0 -330
  426. package/test/Select.test.js +0 -189
  427. package/test/Sidenav.test.js +0 -45
  428. package/test/Slider.test.js +0 -82
  429. package/test/Spinner.test.js +0 -27
  430. package/test/Switch.test.js +0 -45
  431. package/test/Table.test.js +0 -36
  432. package/test/Tabs.test.js +0 -109
  433. package/test/TabsForSections.test.js +0 -34
  434. package/test/Tag.test.js +0 -32
  435. package/test/TextArea.test.js +0 -52
  436. package/test/ToggleGroup.test.js +0 -81
  437. package/test/Upload.test.js +0 -60
  438. package/test/Wizard.test.js +0 -130
  439. package/test/mocks/pngMock.js +0 -1
  440. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,740 @@
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 _Option = _interopRequireDefault(require("../select/Option"));
33
+
34
+ var _Icons = _interopRequireDefault(require("./Icons"));
35
+
36
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13, _templateObject14, _templateObject15, _templateObject16, _templateObject17, _templateObject18, _templateObject19, _templateObject20, _templateObject21, _templateObject22;
37
+
38
+ 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); }
39
+
40
+ 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; }
41
+
42
+ var getNotOptionalErrorMessage = function getNotOptionalErrorMessage() {
43
+ return "This field is required. Please, enter a value.";
44
+ };
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 filterOptionsBySearchValue = function filterOptionsBySearchValue(options, searchValue) {
61
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
62
+ if (options[0].options) return options.map(function (optionGroup) {
63
+ var group = {
64
+ label: optionGroup.label,
65
+ options: optionGroup.options.filter(function (option) {
66
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
67
+ })
68
+ };
69
+ return group;
70
+ });else return options.filter(function (option) {
71
+ return option.label.toUpperCase().includes(searchValue.toUpperCase());
72
+ });
73
+ }
74
+ };
75
+
76
+ var getLastOptionIndex = function getLastOptionIndex(options, filteredOptions, searchable, optional, multiple) {
77
+ var last = 0;
78
+
79
+ var reducer = function reducer(acc, current) {
80
+ var _current$options;
81
+
82
+ return acc + ((_current$options = current.options) === null || _current$options === void 0 ? void 0 : _current$options.length);
83
+ };
84
+
85
+ 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;
86
+ return optional && !multiple ? last + 1 : last;
87
+ };
88
+
89
+ var getSelectedOption = function getSelectedOption(value, options, multiple, optional, optionalItem) {
90
+ var selectedOption = multiple ? [] : {};
91
+ var singleSelectionIndex;
92
+
93
+ if (multiple) {
94
+ if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
95
+ options.forEach(function (option) {
96
+ if (option.options) {
97
+ option.options.forEach(function (singleOption) {
98
+ if (value.includes(singleOption.value)) selectedOption.push(singleOption);
99
+ });
100
+ } else if (value.includes(option.value)) selectedOption.push(option);
101
+ });
102
+ }
103
+ } else {
104
+ if (optional && value === "") {
105
+ selectedOption = optionalItem;
106
+ singleSelectionIndex = 0;
107
+ } else if ((options === null || options === void 0 ? void 0 : options.length) > 0) {
108
+ var group_index = 0;
109
+ options.some(function (option, index) {
110
+ if (option.options) {
111
+ option.options.some(function (singleOption) {
112
+ if (singleOption.value === value) {
113
+ selectedOption = singleOption;
114
+ singleSelectionIndex = optional ? group_index + 1 : group_index;
115
+ return true;
116
+ }
117
+
118
+ group_index++;
119
+ });
120
+ } else if (option.value === value) {
121
+ selectedOption = option;
122
+ singleSelectionIndex = optional ? index + 1 : index;
123
+ return true;
124
+ }
125
+ });
126
+ }
127
+ }
128
+
129
+ return {
130
+ selectedOption: selectedOption,
131
+ singleSelectionIndex: singleSelectionIndex
132
+ };
133
+ };
134
+
135
+ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
136
+ var _selectedOption$label;
137
+
138
+ var label = _ref.label,
139
+ _ref$name = _ref.name,
140
+ name = _ref$name === void 0 ? "" : _ref$name,
141
+ defaultValue = _ref.defaultValue,
142
+ value = _ref.value,
143
+ options = _ref.options,
144
+ helperText = _ref.helperText,
145
+ _ref$placeholder = _ref.placeholder,
146
+ placeholder = _ref$placeholder === void 0 ? "" : _ref$placeholder,
147
+ _ref$disabled = _ref.disabled,
148
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
149
+ _ref$optional = _ref.optional,
150
+ optional = _ref$optional === void 0 ? false : _ref$optional,
151
+ _ref$searchable = _ref.searchable,
152
+ searchable = _ref$searchable === void 0 ? false : _ref$searchable,
153
+ _ref$multiple = _ref.multiple,
154
+ multiple = _ref$multiple === void 0 ? false : _ref$multiple,
155
+ onChange = _ref.onChange,
156
+ onBlur = _ref.onBlur,
157
+ error = _ref.error,
158
+ margin = _ref.margin,
159
+ _ref$size = _ref.size,
160
+ size = _ref$size === void 0 ? "medium" : _ref$size,
161
+ _ref$tabIndex = _ref.tabIndex,
162
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
163
+
164
+ var _useState = (0, _react.useState)("select-".concat((0, _uuid.v4)())),
165
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
166
+ selectId = _useState2[0];
167
+
168
+ var selectLabelId = "label-".concat(selectId);
169
+ var errorId = "error-".concat(selectId);
170
+ var optionsListId = "".concat(selectId, "-listbox");
171
+
172
+ var _useState3 = (0, _react.useState)(defaultValue !== null && defaultValue !== void 0 ? defaultValue : multiple ? [] : ""),
173
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
174
+ innerValue = _useState4[0],
175
+ setInnerValue = _useState4[1];
176
+
177
+ var _useState5 = (0, _react.useState)(""),
178
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
179
+ searchValue = _useState6[0],
180
+ setSearchValue = _useState6[1];
181
+
182
+ var _useState7 = (0, _react.useState)(-1),
183
+ _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
184
+ visualFocusIndex = _useState8[0],
185
+ changeVisualFocusIndex = _useState8[1];
186
+
187
+ var _useState9 = (0, _react.useState)(false),
188
+ _useState10 = (0, _slicedToArray2["default"])(_useState9, 2),
189
+ isOpen = _useState10[0],
190
+ changeIsOpen = _useState10[1];
191
+
192
+ var selectContainerRef = (0, _react.useRef)(null);
193
+ var selectSearchInputRef = (0, _react.useRef)(null);
194
+ var selectOptionsListRef = (0, _react.useRef)(null);
195
+ var colorsTheme = (0, _useTheme["default"])();
196
+ var optionalItem = {
197
+ label: placeholder,
198
+ value: ""
199
+ };
200
+ var filteredOptions = (0, _react.useMemo)(function () {
201
+ return filterOptionsBySearchValue(options, searchValue);
202
+ }, [options, searchValue]);
203
+ var lastOptionIndex = (0, _react.useMemo)(function () {
204
+ return getLastOptionIndex(options, filteredOptions, searchable, optional, multiple);
205
+ }, [options, filteredOptions, searchable, optional, multiple, filteredOptions]);
206
+
207
+ var _useMemo = (0, _react.useMemo)(function () {
208
+ return getSelectedOption(value !== null && value !== void 0 ? value : innerValue, options, multiple, optional, optionalItem);
209
+ }, [value, innerValue, options, multiple, optional, optionalItem]),
210
+ selectedOption = _useMemo.selectedOption,
211
+ singleSelectionIndex = _useMemo.singleSelectionIndex;
212
+
213
+ var notOptionalCheck = function notOptionalCheck(value) {
214
+ return value === "" && !optional;
215
+ };
216
+
217
+ var notOptionalMultipleCheck = function notOptionalMultipleCheck() {
218
+ return (value !== null && value !== void 0 ? value : innerValue).length === 0 && !optional;
219
+ };
220
+
221
+ var canBeOpenOptions = function canBeOpenOptions() {
222
+ return !disabled && (options === null || options === void 0 ? void 0 : options.length) > 0 && groupsHaveOptions(options);
223
+ };
224
+
225
+ var openOptions = function openOptions() {
226
+ if (!isOpen && canBeOpenOptions()) changeIsOpen(true);
227
+ };
228
+
229
+ var closeOptions = function closeOptions() {
230
+ if (isOpen) {
231
+ changeIsOpen(false);
232
+ changeVisualFocusIndex(-1);
233
+ }
234
+ };
235
+
236
+ var handleSelectChangeValue = function handleSelectChangeValue(newOption) {
237
+ if (multiple) {
238
+ var _res, _res2;
239
+
240
+ var res;
241
+ if ((value !== null && value !== void 0 ? value : innerValue).includes(newOption.value)) value ? res = value.filter(function (optionVal) {
242
+ return optionVal !== newOption.value;
243
+ }) : setInnerValue(function (previous) {
244
+ return previous.filter(function (optionVal) {
245
+ return optionVal !== newOption.value;
246
+ });
247
+ });else value ? res = [].concat((0, _toConsumableArray2["default"])(value), [newOption.value]) : setInnerValue(function (previous) {
248
+ return [].concat((0, _toConsumableArray2["default"])(previous), [newOption.value]);
249
+ });
250
+ if (notOptionalMultipleCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
251
+ value: (_res = res) !== null && _res !== void 0 ? _res : innerValue,
252
+ error: getNotOptionalErrorMessage()
253
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
254
+ value: (_res2 = res) !== null && _res2 !== void 0 ? _res2 : innerValue,
255
+ error: null
256
+ });
257
+ } else {
258
+ value !== null && value !== void 0 ? value : setInnerValue(newOption.value);
259
+ if (notOptionalCheck(newOption.value)) onChange === null || onChange === void 0 ? void 0 : onChange({
260
+ value: newOption.value,
261
+ error: getNotOptionalErrorMessage()
262
+ });else onChange === null || onChange === void 0 ? void 0 : onChange({
263
+ value: newOption.value,
264
+ error: null
265
+ });
266
+ }
267
+ };
268
+
269
+ var handleSelectOnClick = function handleSelectOnClick() {
270
+ searchable && selectSearchInputRef.current.focus();
271
+
272
+ if (isOpen) {
273
+ closeOptions();
274
+ setSearchValue("");
275
+ } else openOptions();
276
+ };
277
+
278
+ var handleSelectOnFocus = function handleSelectOnFocus(event) {
279
+ if (!event.currentTarget.contains(event.relatedTarget)) searchable && selectSearchInputRef.current.focus();
280
+ };
281
+
282
+ var handleSelectOnBlur = function handleSelectOnBlur(event) {
283
+ // focus leaves container (outside, not to childs)
284
+ if (!event.currentTarget.contains(event.relatedTarget)) {
285
+ closeOptions();
286
+ setSearchValue("");
287
+ if (notOptionalCheck(value !== null && value !== void 0 ? value : innerValue)) onBlur === null || onBlur === void 0 ? void 0 : onBlur({
288
+ value: value !== null && value !== void 0 ? value : innerValue,
289
+ error: getNotOptionalErrorMessage()
290
+ });else onBlur === null || onBlur === void 0 ? void 0 : onBlur({
291
+ value: value !== null && value !== void 0 ? value : innerValue,
292
+ error: null
293
+ });
294
+ }
295
+ };
296
+
297
+ var handleSelectOnKeyDown = function handleSelectOnKeyDown(event) {
298
+ switch (event.keyCode) {
299
+ case 40:
300
+ // Arrow Down
301
+ event.preventDefault();
302
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
303
+ if (visualFocusIndex < lastOptionIndex) return visualFocusIndex + 1;else if (visualFocusIndex === lastOptionIndex) return 0;
304
+ });
305
+ openOptions();
306
+ break;
307
+
308
+ case 38:
309
+ // Arrow Up
310
+ event.preventDefault();
311
+ singleSelectionIndex !== undefined && (!isOpen || visualFocusIndex === -1 && singleSelectionIndex > -1 && singleSelectionIndex <= lastOptionIndex) ? changeVisualFocusIndex(singleSelectionIndex) : changeVisualFocusIndex(function (visualFocusIndex) {
312
+ return visualFocusIndex === 0 || visualFocusIndex === -1 ? lastOptionIndex : visualFocusIndex - 1;
313
+ });
314
+ openOptions();
315
+ break;
316
+
317
+ case 27:
318
+ // Esc
319
+ event.preventDefault();
320
+ closeOptions();
321
+ setSearchValue("");
322
+ break;
323
+
324
+ case 13:
325
+ // Enter
326
+ if (isOpen && visualFocusIndex >= 0) {
327
+ var accLength = optional && !multiple ? 1 : 0;
328
+
329
+ if (searchable) {
330
+ if (filteredOptions.length > 0) {
331
+ if (optional && !multiple && visualFocusIndex === 0 && filteredGroupsHaveOptions(filteredOptions)) handleSelectChangeValue(optionalItem);else filteredOptions[0].options ? filteredGroupsHaveOptions(filteredOptions) && filteredOptions.some(function (groupOption) {
332
+ var groupLength = accLength + groupOption.options.length;
333
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
334
+ accLength = groupLength;
335
+ return groupLength > visualFocusIndex;
336
+ }) : handleSelectChangeValue(filteredOptions[visualFocusIndex - accLength]);
337
+ }
338
+ } else {
339
+ if (optional && !multiple && visualFocusIndex === 0) handleSelectChangeValue(optionalItem);else options[0].options ? options.some(function (groupOption) {
340
+ var groupLength = accLength + groupOption.options.length;
341
+ groupLength > visualFocusIndex && handleSelectChangeValue(groupOption.options[visualFocusIndex - accLength]);
342
+ accLength = groupLength;
343
+ return groupLength > visualFocusIndex;
344
+ }) : handleSelectChangeValue(options[visualFocusIndex - accLength]);
345
+ }
346
+
347
+ !multiple && closeOptions();
348
+ setSearchValue("");
349
+ }
350
+
351
+ break;
352
+ }
353
+ };
354
+
355
+ var handleSearchIOnChange = function handleSearchIOnChange(event) {
356
+ setSearchValue(event.target.value);
357
+ changeVisualFocusIndex(-1);
358
+ openOptions();
359
+ };
360
+
361
+ var handleClearOptionsActionOnClick = function handleClearOptionsActionOnClick(event) {
362
+ event.stopPropagation();
363
+ value !== null && value !== void 0 ? value : setInnerValue([]);
364
+ onChange === null || onChange === void 0 ? void 0 : onChange({
365
+ value: [],
366
+ error: getNotOptionalErrorMessage()
367
+ });
368
+ };
369
+
370
+ var handleClearSearchActionOnClick = function handleClearSearchActionOnClick(event) {
371
+ event.stopPropagation();
372
+ setSearchValue("");
373
+ };
374
+
375
+ var handleOptionOnClick = (0, _react.useCallback)(function (option) {
376
+ handleSelectChangeValue(option);
377
+ !multiple && closeOptions();
378
+ setSearchValue("");
379
+ }, [handleSelectChangeValue, closeOptions, multiple]);
380
+ (0, _react.useLayoutEffect)(function () {
381
+ if (isOpen && singleSelectionIndex) {
382
+ var _listEl$scrollTo;
383
+
384
+ var listEl = selectOptionsListRef === null || selectOptionsListRef === void 0 ? void 0 : selectOptionsListRef.current;
385
+ var selectedListOptionEl = listEl === null || listEl === void 0 ? void 0 : listEl.querySelector("[aria-selected='true']");
386
+ listEl === null || listEl === void 0 ? void 0 : (_listEl$scrollTo = listEl.scrollTo) === null || _listEl$scrollTo === void 0 ? void 0 : _listEl$scrollTo.call(listEl, {
387
+ top: (selectedListOptionEl === null || selectedListOptionEl === void 0 ? void 0 : selectedListOptionEl.offsetTop) - (listEl === null || listEl === void 0 ? void 0 : listEl.clientHeight) / 2
388
+ });
389
+ }
390
+ }, [isOpen]);
391
+ (0, _react.useLayoutEffect)(function () {
392
+ var _selectOptionsListRef, _visualFocusedOptionE;
393
+
394
+ var visualFocusedOptionEl = selectOptionsListRef === null || selectOptionsListRef === void 0 ? void 0 : (_selectOptionsListRef = selectOptionsListRef.current) === null || _selectOptionsListRef === void 0 ? void 0 : _selectOptionsListRef.querySelectorAll("[role='option']")[visualFocusIndex];
395
+ visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
396
+ block: "nearest",
397
+ inline: "start"
398
+ });
399
+ }, [visualFocusIndex]);
400
+ var globalIndex = optional && !multiple ? 0 : -1; // index for options, starting from 0 to options.length -1
401
+
402
+ var mapOptionFunc = function mapOptionFunc(option, mapIndex) {
403
+ if (option.options) {
404
+ var groupId = "group-".concat(mapIndex);
405
+ return option.options.length > 0 && /*#__PURE__*/_react["default"].createElement("li", null, /*#__PURE__*/_react["default"].createElement(GroupList, {
406
+ role: "group",
407
+ "aria-labelledby": groupId
408
+ }, /*#__PURE__*/_react["default"].createElement(GroupLabel, {
409
+ role: "presentation",
410
+ id: groupId
411
+ }, option.label), option.options.map(function (singleOption) {
412
+ globalIndex++;
413
+ return /*#__PURE__*/_react["default"].createElement(_Option["default"], {
414
+ id: "option-".concat(globalIndex),
415
+ option: singleOption,
416
+ onClick: handleOptionOnClick,
417
+ multiple: multiple,
418
+ visualFocused: visualFocusIndex === globalIndex,
419
+ isGroupedOption: true,
420
+ isLastOption: lastOptionIndex === globalIndex,
421
+ isSelected: multiple ? (value !== null && value !== void 0 ? value : innerValue).includes(singleOption.value) : (value !== null && value !== void 0 ? value : innerValue) === singleOption.value
422
+ });
423
+ })));
424
+ } else {
425
+ globalIndex++;
426
+ return /*#__PURE__*/_react["default"].createElement(_Option["default"], {
427
+ key: "option-".concat(option.value),
428
+ id: "option-".concat(globalIndex),
429
+ option: option,
430
+ onClick: handleOptionOnClick,
431
+ multiple: multiple,
432
+ visualFocused: visualFocusIndex === globalIndex,
433
+ isGroupedOption: false,
434
+ isLastOption: lastOptionIndex === globalIndex,
435
+ isSelected: multiple ? (value !== null && value !== void 0 ? value : innerValue).includes(option.value) : (value !== null && value !== void 0 ? value : innerValue) === option.value
436
+ });
437
+ }
438
+ };
439
+
440
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
441
+ theme: colorsTheme.select
442
+ }, /*#__PURE__*/_react["default"].createElement(SelectContainer, {
443
+ margin: margin,
444
+ size: size,
445
+ ref: ref
446
+ }, label && /*#__PURE__*/_react["default"].createElement(Label, {
447
+ id: selectLabelId,
448
+ disabled: disabled,
449
+ onClick: function onClick() {
450
+ selectContainerRef.current.focus();
451
+ },
452
+ helperText: helperText
453
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(OptionalLabel, null, "(Optional)")), helperText && /*#__PURE__*/_react["default"].createElement(HelperText, {
454
+ disabled: disabled
455
+ }, helperText), /*#__PURE__*/_react["default"].createElement(Select, {
456
+ id: selectId,
457
+ disabled: disabled,
458
+ error: error,
459
+ onBlur: handleSelectOnBlur,
460
+ onClick: handleSelectOnClick,
461
+ onFocus: handleSelectOnFocus,
462
+ onKeyDown: handleSelectOnKeyDown,
463
+ ref: selectContainerRef,
464
+ tabIndex: tabIndex,
465
+ role: "combobox",
466
+ "aria-controls": optionsListId,
467
+ "aria-disabled": disabled,
468
+ "aria-expanded": isOpen,
469
+ "aria-haspopup": "listbox",
470
+ "aria-labelledby": selectLabelId,
471
+ "aria-activedescendant": visualFocusIndex >= 0 ? "option-".concat(visualFocusIndex) : undefined,
472
+ "aria-invalid": error ? "true" : "false",
473
+ "aria-errormessage": error ? errorId : undefined,
474
+ "aria-required": !disabled && !optional
475
+ }, multiple && selectedOption.length > 0 && /*#__PURE__*/_react["default"].createElement(SelectionIndicator, null, /*#__PURE__*/_react["default"].createElement(SelectionNumber, {
476
+ disabled: disabled
477
+ }, selectedOption.length), /*#__PURE__*/_react["default"].createElement(ClearOptionsAction, {
478
+ disabled: disabled,
479
+ onMouseDown: function onMouseDown(event) {
480
+ // Avoid input to lose focus when pressed
481
+ event.preventDefault();
482
+ },
483
+ onClick: handleClearOptionsActionOnClick,
484
+ tabIndex: -1,
485
+ title: "Clear selection",
486
+ "aria-label": "Clear selection"
487
+ }, _Icons["default"].clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
488
+ name: name,
489
+ value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(",") : value !== null && value !== void 0 ? value : innerValue,
490
+ readOnly: true,
491
+ "aria-hidden": "true"
492
+ }), searchable && /*#__PURE__*/_react["default"].createElement(SearchInput, {
493
+ value: searchValue,
494
+ disabled: disabled,
495
+ onChange: handleSearchIOnChange,
496
+ ref: selectSearchInputRef,
497
+ autoComplete: "nope",
498
+ autoCorrect: "nope",
499
+ size: "1"
500
+ }), (!searchable || searchValue === "") && (multiple ? /*#__PURE__*/_react["default"].createElement(SelectedOption, {
501
+ disabled: disabled,
502
+ atBackground: (value !== null && value !== void 0 ? value : innerValue).length === 0 || searchable && isOpen
503
+ }, /*#__PURE__*/_react["default"].createElement(OptionLabel, null, selectedOption.map(function (option) {
504
+ return option.label;
505
+ }).join(", ")), selectedOption.length === 0 && placeholder) : /*#__PURE__*/_react["default"].createElement(SelectedOption, {
506
+ disabled: disabled,
507
+ atBackground: !(value !== null && value !== void 0 ? value : innerValue) || searchable && isOpen
508
+ }, /*#__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, _Icons["default"].error), searchable && searchValue.length > 0 && /*#__PURE__*/_react["default"].createElement(ClearSearchAction, {
509
+ onMouseDown: function onMouseDown(event) {
510
+ // Avoid input to lose focus
511
+ event.preventDefault();
512
+ },
513
+ onClick: handleClearSearchActionOnClick,
514
+ tabIndex: -1,
515
+ title: "Clear search",
516
+ "aria-label": "Clear search"
517
+ }, _Icons["default"].clear), /*#__PURE__*/_react["default"].createElement(CollapseIndicator, {
518
+ disabled: disabled
519
+ }, isOpen ? _Icons["default"].arrowUp : _Icons["default"].arrowDown), isOpen && /*#__PURE__*/_react["default"].createElement(OptionsList, {
520
+ id: optionsListId,
521
+ onClick: function onClick(event) {
522
+ event.stopPropagation();
523
+ },
524
+ onMouseDown: function onMouseDown(event) {
525
+ event.preventDefault();
526
+ },
527
+ ref: selectOptionsListRef,
528
+ role: "listbox",
529
+ "aria-multiselectable": multiple,
530
+ "aria-orientation": "vertical"
531
+ }, searchable && (filteredOptions.length === 0 || !filteredGroupsHaveOptions(filteredOptions)) ? /*#__PURE__*/_react["default"].createElement(OptionsSystemMessage, null, /*#__PURE__*/_react["default"].createElement(NoMatchesFoundIcon, null, _Icons["default"].searchOff), "No matches found") : optional && !multiple && /*#__PURE__*/_react["default"].createElement(_Option["default"], {
532
+ id: "option-".concat(0),
533
+ option: optionalItem,
534
+ onClick: handleOptionOnClick,
535
+ multiple: multiple,
536
+ visualFocused: visualFocusIndex === 0,
537
+ isGroupedOption: false,
538
+ isLastOption: lastOptionIndex === 0,
539
+ isSelected: multiple ? (value !== null && value !== void 0 ? value : innerValue).includes(optionalItem.value) : (value !== null && value !== void 0 ? value : innerValue) === optionalItem.value
540
+ }), searchable ? filteredOptions.map(mapOptionFunc) : options.map(mapOptionFunc))), !disabled && typeof error === "string" && /*#__PURE__*/_react["default"].createElement(Error, {
541
+ id: errorId,
542
+ "aria-live": error ? "assertive" : "off"
543
+ }, error)));
544
+ });
545
+
546
+ var sizes = {
547
+ small: "240px",
548
+ medium: "360px",
549
+ large: "480px",
550
+ fillParent: "100%"
551
+ };
552
+
553
+ var calculateWidth = function calculateWidth(margin, size) {
554
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
555
+ };
556
+
557
+ 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) {
558
+ return calculateWidth(props.margin, props.size);
559
+ }, function (props) {
560
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
561
+ }, function (props) {
562
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
563
+ }, function (props) {
564
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
565
+ }, function (props) {
566
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
567
+ }, function (props) {
568
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
569
+ });
570
+
571
+ 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) {
572
+ return props.disabled ? props.theme.disabledColor : props.theme.labelFontColor;
573
+ }, function (props) {
574
+ return props.theme.fontFamily;
575
+ }, function (props) {
576
+ return props.theme.labelFontSize;
577
+ }, function (props) {
578
+ return props.theme.labelFontStyle;
579
+ }, function (props) {
580
+ return props.theme.labelFontWeight;
581
+ }, function (props) {
582
+ return props.theme.labelLineHeight;
583
+ }, function (props) {
584
+ return !props.helperText && "margin-bottom: 0.25rem";
585
+ });
586
+
587
+ var OptionalLabel = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-weight: ", ";\n"])), function (props) {
588
+ return props.theme.optionalLabelFontWeight;
589
+ });
590
+
591
+ 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) {
592
+ return props.disabled ? props.theme.disabledColor : props.theme.helperTextFontColor;
593
+ }, function (props) {
594
+ return props.theme.fontFamily;
595
+ }, function (props) {
596
+ return props.theme.helperTextFontSize;
597
+ }, function (props) {
598
+ return props.theme.helperTextFontStyle;
599
+ }, function (props) {
600
+ return props.theme.helperTextFontWeight;
601
+ }, function (props) {
602
+ return props.theme.helperTextLineHeight;
603
+ });
604
+
605
+ 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) {
606
+ return props.disabled && "background-color: ".concat(props.theme.disabledInputBackgroundColor);
607
+ }, function (props) {
608
+ return props.disabled ? props.theme.disabledInputBorderColor : props.theme.enabledInputBorderColor;
609
+ }, function (props) {
610
+ return props.error && !props.disabled && "border-color: transparent;\n box-shadow: 0 0 0 2px ".concat(props.theme.errorInputBorderColor, ";\n ");
611
+ }, function (props) {
612
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
613
+ }, function (props) {
614
+ 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 ");
615
+ });
616
+
617
+ 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) {
618
+ return props.theme.selectionIndicatorBorderColor;
619
+ });
620
+
621
+ 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) {
622
+ return !props.disabled && "background-color: ".concat(props.theme.selectionIndicatorBackgroundColor);
623
+ }, function (props) {
624
+ return props.theme.selectionIndicatorBorderColor;
625
+ }, function (props) {
626
+ return props.disabled ? props.theme.disabledColor : props.theme.selectionIndicatorFontColor;
627
+ }, function (props) {
628
+ return props.theme.fontFamily;
629
+ }, function (props) {
630
+ return props.theme.selectionIndicatorFontSize;
631
+ }, function (props) {
632
+ return props.theme.selectionIndicatorFontStyle;
633
+ }, function (props) {
634
+ return props.theme.selectionIndicatorFontWeight;
635
+ }, function (props) {
636
+ return props.disabled ? "cursor: not-allowed;" : "cursor: default;";
637
+ });
638
+
639
+ 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) {
640
+ return props.theme.fontFamily;
641
+ }, function (props) {
642
+ return props.disabled ? "cursor: not-allowed;" : "cursor: pointer;";
643
+ }, function (props) {
644
+ return props.disabled ? "transparent" : props.theme.enabledSelectionIndicatorActionBackgroundColor;
645
+ }, function (props) {
646
+ return props.disabled ? props.theme.disabledColor : props.theme.enabledSelectionIndicatorActionIconColor;
647
+ }, function (props) {
648
+ 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 ");
649
+ });
650
+
651
+ var SearchableValueContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: grid;\n width: 100%;\n"])));
652
+
653
+ 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) {
654
+ if (props.disabled) return props.theme.disabledColor;else if (props.atBackground) return props.theme.placeholderFontColor;else return props.theme.valueFontColor;
655
+ }, function (props) {
656
+ return props.theme.fontFamily;
657
+ }, function (props) {
658
+ return props.theme.valueFontSize;
659
+ }, function (props) {
660
+ return props.theme.valueFontStyle;
661
+ }, function (props) {
662
+ return props.theme.valueFontWeight;
663
+ });
664
+
665
+ var ValueInput = _styledComponents["default"].input(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
666
+
667
+ 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) {
668
+ return props.disabled ? props.theme.disabledColor : props.theme.valueFontColor;
669
+ }, function (props) {
670
+ return props.theme.fontFamily;
671
+ }, function (props) {
672
+ return props.theme.valueFontSize;
673
+ }, function (props) {
674
+ return props.theme.valueFontStyle;
675
+ }, function (props) {
676
+ return props.theme.valueFontWeight;
677
+ });
678
+
679
+ 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) {
680
+ return props.theme.errorIconColor;
681
+ });
682
+
683
+ 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) {
684
+ return props.theme.errorMessageColor;
685
+ }, function (props) {
686
+ return props.theme.fontFamily;
687
+ });
688
+
689
+ 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) {
690
+ return props.disabled ? props.theme.disabledColor : props.theme.collapseIndicatorColor;
691
+ });
692
+
693
+ 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) {
694
+ return props.theme.fontFamily;
695
+ }, function (props) {
696
+ return props.theme.actionBackgroundColor;
697
+ }, function (props) {
698
+ return props.theme.actionIconColor;
699
+ }, function (props) {
700
+ return props.theme.hoverActionBackgroundColor;
701
+ }, function (props) {
702
+ return props.theme.hoverActionIconColor;
703
+ }, function (props) {
704
+ return props.theme.activeActionBackgroundColor;
705
+ }, function (props) {
706
+ return props.theme.activeActionIconColor;
707
+ });
708
+
709
+ 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) {
710
+ return props.theme.listDialogBackgroundColor;
711
+ }, function (props) {
712
+ return props.theme.listDialogBorderColor;
713
+ }, function (props) {
714
+ return props.theme.listOptionFontColor;
715
+ }, function (props) {
716
+ return props.theme.fontFamily;
717
+ }, function (props) {
718
+ return props.theme.listOptionFontSize;
719
+ }, function (props) {
720
+ return props.theme.listOptionFontStyle;
721
+ }, function (props) {
722
+ return props.theme.listOptionFontWeight;
723
+ });
724
+
725
+ 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) {
726
+ return props.theme.systemMessageFontColor;
727
+ });
728
+
729
+ 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"])));
730
+
731
+ var GroupList = _styledComponents["default"].ul(_templateObject20 || (_templateObject20 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0;\n"])));
732
+
733
+ 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) {
734
+ return props.theme.listGroupLabelFontWeight;
735
+ });
736
+
737
+ var OptionLabel = _styledComponents["default"].span(_templateObject22 || (_templateObject22 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n"])));
738
+
739
+ var _default = DxcSelect;
740
+ exports["default"] = _default;