@dxc-technology/halstack-react 0.0.0-bfdc357 → 0.0.0-c023f9a

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 (535) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1246 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +1 -1
  9. package/accordion/Accordion.js +103 -193
  10. package/accordion/Accordion.stories.tsx +241 -0
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +12 -23
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +3 -3
  17. package/accordion-group/AccordionGroup.js +39 -108
  18. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +94 -0
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +18 -23
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +41 -128
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +75 -0
  40. package/alert/types.d.ts +6 -6
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +4 -0
  44. package/badge/Badge.js +142 -40
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +54 -0
  49. package/badge/types.js +5 -0
  50. package/bleed/Bleed.d.ts +3 -0
  51. package/bleed/Bleed.js +43 -0
  52. package/bleed/Bleed.stories.tsx +342 -0
  53. package/bleed/types.d.ts +37 -0
  54. package/bleed/types.js +5 -0
  55. package/box/Box.accessibility.test.d.ts +1 -0
  56. package/box/Box.accessibility.test.js +33 -0
  57. package/box/Box.d.ts +1 -1
  58. package/box/Box.js +31 -82
  59. package/box/Box.stories.tsx +38 -51
  60. package/box/Box.test.d.ts +1 -0
  61. package/box/Box.test.js +13 -0
  62. package/box/types.d.ts +3 -14
  63. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  64. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  65. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  66. package/breadcrumbs/Breadcrumbs.js +79 -0
  67. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  68. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  69. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  70. package/breadcrumbs/Item.d.ts +4 -0
  71. package/breadcrumbs/Item.js +52 -0
  72. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  73. package/breadcrumbs/dropdownTheme.js +62 -0
  74. package/breadcrumbs/types.d.ts +16 -0
  75. package/breadcrumbs/types.js +5 -0
  76. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  77. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  78. package/bulleted-list/BulletedList.d.ts +7 -0
  79. package/bulleted-list/BulletedList.js +92 -0
  80. package/bulleted-list/BulletedList.stories.tsx +115 -0
  81. package/bulleted-list/types.d.ts +38 -0
  82. package/bulleted-list/types.js +5 -0
  83. package/button/Button.accessibility.test.d.ts +1 -0
  84. package/button/Button.accessibility.test.js +127 -0
  85. package/button/Button.d.ts +1 -1
  86. package/button/Button.js +65 -121
  87. package/button/Button.stories.tsx +155 -106
  88. package/button/Button.test.d.ts +1 -0
  89. package/button/Button.test.js +38 -0
  90. package/button/types.d.ts +14 -14
  91. package/card/Card.accessibility.test.d.ts +1 -0
  92. package/card/Card.accessibility.test.js +36 -0
  93. package/card/Card.d.ts +1 -1
  94. package/card/Card.js +60 -103
  95. package/card/Card.stories.tsx +171 -0
  96. package/card/Card.test.d.ts +1 -0
  97. package/card/Card.test.js +39 -0
  98. package/card/types.d.ts +8 -15
  99. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  100. package/checkbox/Checkbox.accessibility.test.js +87 -0
  101. package/checkbox/Checkbox.d.ts +2 -2
  102. package/checkbox/Checkbox.js +141 -182
  103. package/checkbox/Checkbox.stories.tsx +166 -136
  104. package/checkbox/Checkbox.test.d.ts +1 -0
  105. package/checkbox/Checkbox.test.js +199 -0
  106. package/checkbox/types.d.ts +20 -8
  107. package/chip/Chip.accessibility.test.d.ts +1 -0
  108. package/chip/Chip.accessibility.test.js +67 -0
  109. package/chip/Chip.d.ts +4 -0
  110. package/chip/Chip.js +51 -146
  111. package/chip/Chip.stories.tsx +109 -31
  112. package/chip/Chip.test.d.ts +1 -0
  113. package/chip/Chip.test.js +41 -0
  114. package/chip/types.d.ts +45 -0
  115. package/chip/types.js +5 -0
  116. package/common/coreTokens.d.ts +237 -0
  117. package/common/coreTokens.js +184 -0
  118. package/common/utils.d.ts +1 -0
  119. package/common/utils.js +6 -12
  120. package/common/variables.d.ts +1392 -0
  121. package/common/variables.js +1084 -1397
  122. package/container/Container.d.ts +4 -0
  123. package/container/Container.js +194 -0
  124. package/container/Container.stories.tsx +214 -0
  125. package/container/types.d.ts +74 -0
  126. package/container/types.js +5 -0
  127. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  128. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  129. package/contextual-menu/ContextualMenu.d.ts +5 -0
  130. package/contextual-menu/ContextualMenu.js +88 -0
  131. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  132. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  133. package/contextual-menu/ContextualMenu.test.js +205 -0
  134. package/contextual-menu/GroupItem.d.ts +4 -0
  135. package/contextual-menu/GroupItem.js +67 -0
  136. package/contextual-menu/ItemAction.d.ts +4 -0
  137. package/contextual-menu/ItemAction.js +51 -0
  138. package/contextual-menu/MenuItem.d.ts +4 -0
  139. package/contextual-menu/MenuItem.js +29 -0
  140. package/contextual-menu/SingleItem.d.ts +4 -0
  141. package/contextual-menu/SingleItem.js +38 -0
  142. package/contextual-menu/types.d.ts +58 -0
  143. package/contextual-menu/types.js +5 -0
  144. package/date-input/Calendar.d.ts +4 -0
  145. package/date-input/Calendar.js +214 -0
  146. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  147. package/date-input/DateInput.accessibility.test.js +230 -0
  148. package/date-input/DateInput.js +174 -313
  149. package/date-input/DateInput.stories.tsx +210 -56
  150. package/date-input/DateInput.test.d.ts +1 -0
  151. package/date-input/DateInput.test.js +809 -0
  152. package/date-input/DatePicker.d.ts +4 -0
  153. package/date-input/DatePicker.js +121 -0
  154. package/date-input/YearPicker.d.ts +4 -0
  155. package/date-input/YearPicker.js +100 -0
  156. package/date-input/types.d.ts +86 -22
  157. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  158. package/dialog/Dialog.accessibility.test.js +69 -0
  159. package/dialog/Dialog.d.ts +1 -1
  160. package/dialog/Dialog.js +57 -129
  161. package/dialog/Dialog.stories.tsx +325 -167
  162. package/dialog/Dialog.test.d.ts +1 -0
  163. package/dialog/Dialog.test.js +371 -0
  164. package/dialog/types.d.ts +18 -25
  165. package/divider/Divider.accessibility.test.d.ts +1 -0
  166. package/divider/Divider.accessibility.test.js +33 -0
  167. package/divider/Divider.d.ts +4 -0
  168. package/divider/Divider.js +36 -0
  169. package/divider/Divider.stories.tsx +223 -0
  170. package/divider/Divider.test.d.ts +1 -0
  171. package/divider/Divider.test.js +38 -0
  172. package/divider/types.d.ts +21 -0
  173. package/divider/types.js +5 -0
  174. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  175. package/dropdown/Dropdown.accessibility.test.js +184 -0
  176. package/dropdown/Dropdown.d.ts +1 -1
  177. package/dropdown/Dropdown.js +233 -330
  178. package/dropdown/Dropdown.stories.tsx +427 -0
  179. package/dropdown/Dropdown.test.d.ts +1 -0
  180. package/dropdown/Dropdown.test.js +629 -0
  181. package/dropdown/DropdownMenu.d.ts +4 -0
  182. package/dropdown/DropdownMenu.js +63 -0
  183. package/dropdown/DropdownMenuItem.d.ts +4 -0
  184. package/dropdown/DropdownMenuItem.js +71 -0
  185. package/dropdown/types.d.ts +38 -31
  186. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  187. package/file-input/FileInput.accessibility.test.js +167 -0
  188. package/file-input/FileInput.d.ts +2 -2
  189. package/file-input/FileInput.js +271 -342
  190. package/file-input/FileInput.stories.tsx +618 -0
  191. package/file-input/FileInput.test.d.ts +1 -0
  192. package/file-input/FileInput.test.js +404 -0
  193. package/file-input/FileItem.d.ts +4 -14
  194. package/file-input/FileItem.js +64 -121
  195. package/file-input/types.d.ts +53 -11
  196. package/flex/Flex.d.ts +4 -0
  197. package/flex/Flex.js +57 -0
  198. package/flex/Flex.stories.tsx +112 -0
  199. package/flex/types.d.ts +97 -0
  200. package/flex/types.js +5 -0
  201. package/footer/Footer.accessibility.test.d.ts +1 -0
  202. package/footer/Footer.accessibility.test.js +125 -0
  203. package/footer/Footer.d.ts +1 -1
  204. package/footer/Footer.js +74 -200
  205. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +96 -39
  206. package/footer/Footer.test.d.ts +1 -0
  207. package/footer/Footer.test.js +85 -0
  208. package/footer/Icons.d.ts +3 -0
  209. package/footer/Icons.js +54 -23
  210. package/footer/types.d.ts +40 -37
  211. package/grid/Grid.d.ts +7 -0
  212. package/grid/Grid.js +76 -0
  213. package/grid/Grid.stories.tsx +219 -0
  214. package/grid/types.d.ts +115 -0
  215. package/grid/types.js +5 -0
  216. package/header/Header.accessibility.test.d.ts +1 -0
  217. package/header/Header.accessibility.test.js +94 -0
  218. package/header/Header.d.ts +4 -3
  219. package/header/Header.js +105 -219
  220. package/header/Header.stories.tsx +168 -63
  221. package/header/Header.test.d.ts +1 -0
  222. package/header/Header.test.js +66 -0
  223. package/header/Icons.d.ts +2 -0
  224. package/header/Icons.js +5 -15
  225. package/header/types.d.ts +6 -18
  226. package/heading/Heading.accessibility.test.d.ts +1 -0
  227. package/heading/Heading.accessibility.test.js +33 -0
  228. package/heading/Heading.js +11 -33
  229. package/heading/Heading.stories.tsx +54 -0
  230. package/heading/Heading.test.d.ts +1 -0
  231. package/heading/Heading.test.js +156 -0
  232. package/heading/types.d.ts +7 -7
  233. package/icon/Icon.accessibility.test.d.ts +1 -0
  234. package/icon/Icon.accessibility.test.js +30 -0
  235. package/icon/Icon.d.ts +4 -0
  236. package/icon/Icon.js +33 -0
  237. package/icon/Icon.stories.tsx +28 -0
  238. package/icon/types.d.ts +4 -0
  239. package/icon/types.js +5 -0
  240. package/image/Image.accessibility.test.d.ts +1 -0
  241. package/image/Image.accessibility.test.js +56 -0
  242. package/image/Image.d.ts +4 -0
  243. package/image/Image.js +70 -0
  244. package/image/Image.stories.tsx +129 -0
  245. package/image/types.d.ts +72 -0
  246. package/image/types.js +5 -0
  247. package/inset/Inset.d.ts +3 -0
  248. package/inset/Inset.js +43 -0
  249. package/inset/Inset.stories.tsx +230 -0
  250. package/inset/types.d.ts +37 -0
  251. package/inset/types.js +5 -0
  252. package/layout/ApplicationLayout.d.ts +20 -0
  253. package/layout/ApplicationLayout.js +88 -186
  254. package/layout/ApplicationLayout.stories.tsx +162 -0
  255. package/layout/Icons.d.ts +7 -0
  256. package/layout/Icons.js +41 -48
  257. package/layout/types.d.ts +41 -0
  258. package/layout/types.js +5 -0
  259. package/link/Link.accessibility.test.d.ts +1 -0
  260. package/link/Link.accessibility.test.js +108 -0
  261. package/link/Link.d.ts +3 -2
  262. package/link/Link.js +65 -109
  263. package/link/Link.stories.tsx +161 -54
  264. package/link/Link.test.d.ts +1 -0
  265. package/link/Link.test.js +63 -0
  266. package/link/types.d.ts +15 -35
  267. package/main.d.ts +20 -14
  268. package/main.js +99 -98
  269. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  270. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  271. package/nav-tabs/NavTabs.d.ts +7 -0
  272. package/nav-tabs/NavTabs.js +93 -0
  273. package/nav-tabs/NavTabs.stories.tsx +279 -0
  274. package/nav-tabs/NavTabs.test.d.ts +1 -0
  275. package/nav-tabs/NavTabs.test.js +77 -0
  276. package/nav-tabs/NavTabsContext.d.ts +3 -0
  277. package/nav-tabs/NavTabsContext.js +8 -0
  278. package/nav-tabs/Tab.d.ts +4 -0
  279. package/nav-tabs/Tab.js +117 -0
  280. package/nav-tabs/types.d.ts +52 -0
  281. package/nav-tabs/types.js +5 -0
  282. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  283. package/number-input/NumberInput.accessibility.test.js +228 -0
  284. package/number-input/NumberInput.js +48 -48
  285. package/number-input/NumberInput.stories.tsx +44 -28
  286. package/number-input/NumberInput.test.d.ts +1 -0
  287. package/number-input/NumberInput.test.js +989 -0
  288. package/number-input/NumberInputContext.d.ts +3 -0
  289. package/number-input/NumberInputContext.js +3 -11
  290. package/number-input/types.d.ts +34 -15
  291. package/package.json +53 -52
  292. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  293. package/paginator/Paginator.accessibility.test.js +79 -0
  294. package/paginator/Paginator.js +47 -107
  295. package/paginator/Paginator.stories.tsx +24 -0
  296. package/paginator/Paginator.test.d.ts +1 -0
  297. package/paginator/Paginator.test.js +335 -0
  298. package/paginator/types.d.ts +3 -3
  299. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  300. package/paragraph/Paragraph.accessibility.test.js +28 -0
  301. package/paragraph/Paragraph.d.ts +5 -0
  302. package/paragraph/Paragraph.js +22 -0
  303. package/paragraph/Paragraph.stories.tsx +27 -0
  304. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  305. package/password-input/PasswordInput.accessibility.test.js +153 -0
  306. package/password-input/PasswordInput.js +61 -126
  307. package/password-input/PasswordInput.stories.tsx +3 -35
  308. package/password-input/PasswordInput.test.d.ts +1 -0
  309. package/password-input/PasswordInput.test.js +198 -0
  310. package/password-input/types.d.ts +35 -24
  311. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  312. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  313. package/progress-bar/ProgressBar.js +69 -93
  314. package/progress-bar/ProgressBar.stories.tsx +93 -0
  315. package/progress-bar/ProgressBar.test.d.ts +1 -0
  316. package/progress-bar/ProgressBar.test.js +93 -0
  317. package/progress-bar/types.d.ts +3 -3
  318. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  319. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  320. package/quick-nav/QuickNav.d.ts +4 -0
  321. package/quick-nav/QuickNav.js +94 -0
  322. package/quick-nav/QuickNav.stories.tsx +356 -0
  323. package/quick-nav/types.d.ts +21 -0
  324. package/quick-nav/types.js +5 -0
  325. package/radio-group/Radio.d.ts +4 -0
  326. package/radio-group/Radio.js +121 -0
  327. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  328. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  329. package/radio-group/RadioGroup.d.ts +4 -0
  330. package/radio-group/RadioGroup.js +233 -0
  331. package/radio-group/RadioGroup.stories.tsx +214 -0
  332. package/radio-group/RadioGroup.test.d.ts +1 -0
  333. package/radio-group/RadioGroup.test.js +754 -0
  334. package/radio-group/types.d.ts +114 -0
  335. package/radio-group/types.js +5 -0
  336. package/resultset-table/Icons.d.ts +7 -0
  337. package/resultset-table/Icons.js +47 -0
  338. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  339. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  340. package/resultset-table/ResultsetTable.d.ts +7 -0
  341. package/resultset-table/ResultsetTable.js +171 -0
  342. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  343. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  344. package/resultset-table/ResultsetTable.test.js +380 -0
  345. package/resultset-table/types.d.ts +100 -0
  346. package/resultset-table/types.js +5 -0
  347. package/select/Listbox.d.ts +4 -0
  348. package/select/Listbox.js +151 -0
  349. package/select/Option.d.ts +4 -0
  350. package/select/Option.js +89 -0
  351. package/select/Select.accessibility.test.d.ts +1 -0
  352. package/select/Select.accessibility.test.js +228 -0
  353. package/select/Select.d.ts +4 -0
  354. package/select/Select.js +248 -513
  355. package/select/Select.stories.tsx +602 -255
  356. package/select/Select.test.d.ts +1 -0
  357. package/select/Select.test.js +2268 -0
  358. package/select/types.d.ts +209 -0
  359. package/select/types.js +5 -0
  360. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  361. package/sidenav/Sidenav.accessibility.test.js +59 -0
  362. package/sidenav/Sidenav.d.ts +6 -5
  363. package/sidenav/Sidenav.js +137 -72
  364. package/sidenav/Sidenav.stories.tsx +277 -0
  365. package/sidenav/Sidenav.test.d.ts +1 -0
  366. package/sidenav/Sidenav.test.js +37 -0
  367. package/sidenav/SidenavContext.d.ts +5 -0
  368. package/sidenav/SidenavContext.js +13 -0
  369. package/sidenav/types.d.ts +52 -26
  370. package/slider/Slider.accessibility.test.d.ts +1 -0
  371. package/slider/Slider.accessibility.test.js +104 -0
  372. package/slider/Slider.d.ts +2 -2
  373. package/slider/Slider.js +149 -183
  374. package/slider/Slider.stories.tsx +68 -65
  375. package/slider/Slider.test.d.ts +1 -0
  376. package/slider/Slider.test.js +257 -0
  377. package/slider/types.d.ts +11 -3
  378. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  379. package/spinner/Spinner.accessibility.test.js +96 -0
  380. package/spinner/Spinner.js +35 -75
  381. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  382. package/spinner/Spinner.test.d.ts +1 -0
  383. package/spinner/Spinner.test.js +55 -0
  384. package/spinner/types.d.ts +3 -3
  385. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  386. package/status-light/StatusLight.accessibility.test.js +157 -0
  387. package/status-light/StatusLight.d.ts +4 -0
  388. package/status-light/StatusLight.js +51 -0
  389. package/status-light/StatusLight.stories.tsx +74 -0
  390. package/status-light/StatusLight.test.d.ts +1 -0
  391. package/status-light/StatusLight.test.js +25 -0
  392. package/status-light/types.d.ts +17 -0
  393. package/status-light/types.js +5 -0
  394. package/switch/Switch.accessibility.test.d.ts +1 -0
  395. package/switch/Switch.accessibility.test.js +98 -0
  396. package/switch/Switch.d.ts +2 -2
  397. package/switch/Switch.js +147 -115
  398. package/switch/Switch.stories.tsx +57 -68
  399. package/switch/Switch.test.d.ts +1 -0
  400. package/switch/Switch.test.js +180 -0
  401. package/switch/types.d.ts +13 -5
  402. package/table/DropdownTheme.js +62 -0
  403. package/table/Table.accessibility.test.d.ts +1 -0
  404. package/table/Table.accessibility.test.js +93 -0
  405. package/table/Table.d.ts +6 -2
  406. package/table/Table.js +80 -37
  407. package/table/Table.stories.tsx +663 -0
  408. package/table/Table.test.d.ts +1 -0
  409. package/table/Table.test.js +112 -0
  410. package/table/types.d.ts +34 -6
  411. package/tabs/Tab.d.ts +4 -0
  412. package/tabs/Tab.js +117 -0
  413. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  414. package/tabs/Tabs.accessibility.test.js +56 -0
  415. package/tabs/Tabs.d.ts +1 -1
  416. package/tabs/Tabs.js +307 -145
  417. package/tabs/Tabs.stories.tsx +230 -0
  418. package/tabs/Tabs.test.d.ts +1 -0
  419. package/tabs/Tabs.test.js +276 -0
  420. package/tabs/types.d.ts +48 -27
  421. package/tag/Tag.accessibility.test.d.ts +1 -0
  422. package/tag/Tag.accessibility.test.js +69 -0
  423. package/tag/Tag.d.ts +1 -1
  424. package/tag/Tag.js +44 -86
  425. package/tag/Tag.stories.tsx +37 -30
  426. package/tag/Tag.test.d.ts +1 -0
  427. package/tag/Tag.test.js +41 -0
  428. package/tag/types.d.ts +25 -16
  429. package/text-input/Suggestion.d.ts +4 -0
  430. package/text-input/Suggestion.js +67 -0
  431. package/text-input/Suggestions.d.ts +4 -0
  432. package/text-input/Suggestions.js +94 -0
  433. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  434. package/text-input/TextInput.accessibility.test.js +321 -0
  435. package/text-input/TextInput.d.ts +4 -0
  436. package/text-input/TextInput.js +336 -592
  437. package/text-input/TextInput.stories.tsx +474 -0
  438. package/text-input/TextInput.test.d.ts +1 -0
  439. package/text-input/TextInput.test.js +1756 -0
  440. package/text-input/types.d.ts +205 -0
  441. package/text-input/types.js +5 -0
  442. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  443. package/textarea/Textarea.accessibility.test.js +155 -0
  444. package/textarea/Textarea.d.ts +4 -0
  445. package/textarea/Textarea.js +98 -183
  446. package/textarea/Textarea.stories.tsx +174 -0
  447. package/textarea/Textarea.test.d.ts +1 -0
  448. package/textarea/Textarea.test.js +406 -0
  449. package/textarea/types.d.ts +141 -0
  450. package/textarea/types.js +5 -0
  451. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  452. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  453. package/toggle-group/ToggleGroup.d.ts +4 -0
  454. package/toggle-group/ToggleGroup.js +99 -143
  455. package/toggle-group/ToggleGroup.stories.tsx +79 -39
  456. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  457. package/toggle-group/ToggleGroup.test.js +137 -0
  458. package/toggle-group/types.d.ts +114 -0
  459. package/toggle-group/types.js +5 -0
  460. package/typography/Typography.accessibility.test.d.ts +1 -0
  461. package/typography/Typography.accessibility.test.js +339 -0
  462. package/typography/Typography.d.ts +4 -0
  463. package/typography/Typography.js +23 -0
  464. package/typography/Typography.stories.tsx +198 -0
  465. package/typography/types.d.ts +18 -0
  466. package/typography/types.js +5 -0
  467. package/useTheme.d.ts +1145 -0
  468. package/useTheme.js +4 -11
  469. package/useTranslatedLabels.d.ts +85 -0
  470. package/useTranslatedLabels.js +14 -0
  471. package/utils/BaseTypography.d.ts +21 -0
  472. package/utils/BaseTypography.js +94 -0
  473. package/utils/FocusLock.d.ts +13 -0
  474. package/utils/FocusLock.js +124 -0
  475. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  476. package/wizard/Wizard.accessibility.test.js +55 -0
  477. package/wizard/Wizard.d.ts +1 -1
  478. package/wizard/Wizard.js +122 -114
  479. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +67 -19
  480. package/wizard/Wizard.test.d.ts +1 -0
  481. package/wizard/Wizard.test.js +114 -0
  482. package/wizard/types.d.ts +15 -15
  483. package/ThemeContext.js +0 -246
  484. package/V3Select/V3Select.js +0 -455
  485. package/V3Select/index.d.ts +0 -27
  486. package/V3Textarea/V3Textarea.js +0 -260
  487. package/V3Textarea/index.d.ts +0 -27
  488. package/chip/index.d.ts +0 -22
  489. package/common/OpenSans.css +0 -81
  490. package/common/RequiredComponent.js +0 -32
  491. package/common/fonts/OpenSans-Bold.ttf +0 -0
  492. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  493. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  494. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  495. package/common/fonts/OpenSans-Italic.ttf +0 -0
  496. package/common/fonts/OpenSans-Light.ttf +0 -0
  497. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  498. package/common/fonts/OpenSans-Regular.ttf +0 -0
  499. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  500. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  501. package/date/Date.js +0 -373
  502. package/date/index.d.ts +0 -27
  503. package/input-text/Icons.js +0 -22
  504. package/input-text/InputText.js +0 -611
  505. package/input-text/index.d.ts +0 -36
  506. package/paginator/Icons.js +0 -66
  507. package/progress-bar/ProgressBar.stories.jsx +0 -58
  508. package/radio/Radio.d.ts +0 -4
  509. package/radio/Radio.js +0 -174
  510. package/radio/Radio.stories.tsx +0 -192
  511. package/radio/types.d.ts +0 -54
  512. package/resultsetTable/ResultsetTable.js +0 -274
  513. package/resultsetTable/index.d.ts +0 -19
  514. package/select/index.d.ts +0 -131
  515. package/table/Table.stories.jsx +0 -276
  516. package/text-input/index.d.ts +0 -135
  517. package/textarea/Textarea.stories.jsx +0 -135
  518. package/textarea/index.d.ts +0 -117
  519. package/toggle/Toggle.js +0 -186
  520. package/toggle/index.d.ts +0 -21
  521. package/toggle-group/index.d.ts +0 -21
  522. package/upload/Upload.js +0 -201
  523. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  524. package/upload/buttons-upload/Icons.js +0 -40
  525. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  526. package/upload/dragAndDropArea/Icons.js +0 -39
  527. package/upload/file-upload/FileToUpload.js +0 -115
  528. package/upload/file-upload/Icons.js +0 -66
  529. package/upload/files-upload/FilesToUpload.js +0 -109
  530. package/upload/index.d.ts +0 -15
  531. package/upload/transaction/Icons.js +0 -160
  532. package/upload/transaction/Transaction.js +0 -104
  533. package/upload/transactions/Transactions.js +0 -94
  534. package/wizard/Icons.js +0 -65
  535. /package/{radio → action-icon}/types.js +0 -0
package/useTheme.js CHANGED
@@ -1,22 +1,15 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports["default"] = void 0;
9
-
10
8
  var _react = require("react");
11
-
12
- var _variables = require("./common/variables.js");
13
-
14
- var _ThemeContext = _interopRequireDefault(require("./ThemeContext.js"));
15
-
9
+ var _variables = require("./common/variables");
10
+ var _HalstackContext = _interopRequireDefault(require("./HalstackContext"));
16
11
  var useTheme = function useTheme() {
17
- var colorsTheme = (0, _react.useContext)(_ThemeContext["default"]);
12
+ var colorsTheme = (0, _react.useContext)(_HalstackContext["default"]);
18
13
  return colorsTheme || _variables.componentTokens;
19
14
  };
20
-
21
- var _default = useTheme;
22
- exports["default"] = _default;
15
+ var _default = exports["default"] = useTheme;
@@ -0,0 +1,85 @@
1
+ declare const useTranslatedLabels: () => {
2
+ formFields?: Partial<{
3
+ optionalLabel: string;
4
+ requiredSelectionErrorMessage: string;
5
+ requiredValueErrorMessage: string;
6
+ formatRequestedErrorMessage: string;
7
+ lengthErrorMessage: (minLength?: number, maxLength?: number) => string;
8
+ logoAlternativeText: string;
9
+ }>;
10
+ applicationLayout?: Partial<{
11
+ visibilityToggleTitle: string;
12
+ }>;
13
+ alert?: Partial<{
14
+ infoTitleText: string;
15
+ successTitleText: string;
16
+ warningTitleText: string;
17
+ errorTitleText: string;
18
+ }>;
19
+ dateInput?: Partial<{
20
+ invalidDateErrorMessage: string;
21
+ }>;
22
+ dialog?: Partial<{
23
+ closeIconAriaLabel: string;
24
+ }>;
25
+ fileInput?: Partial<{
26
+ fileSizeGreaterThanErrorMessage: string;
27
+ fileSizeLessThanErrorMessage: string;
28
+ multipleButtonLabelDefault: string;
29
+ singleButtonLabelDefault: string;
30
+ dropAreaButtonLabelDefault: string;
31
+ multipleDropAreaLabelDefault: string;
32
+ singleDropAreaLabelDefault: string;
33
+ deleteFileActionTitle: string;
34
+ }>;
35
+ footer?: Partial<{
36
+ copyrightText: (year: number) => string;
37
+ }>;
38
+ header?: Partial<{
39
+ closeIcon: string;
40
+ hamburguerTitle: string;
41
+ }>;
42
+ numberInput?: Partial<{
43
+ valueGreaterThanOrEqualToErrorMessage: (value: number) => string;
44
+ valueLessThanOrEqualToErrorMessage: (value: number) => string;
45
+ decrementValueTitle: string;
46
+ incrementValueTitle: string;
47
+ }>;
48
+ paginator?: Partial<{
49
+ itemsPerPageText: string;
50
+ minToMaxOfText: (minNumberOfItems: number, maxNumberOfItems: number, totalItems: number) => string;
51
+ goToPageText: string;
52
+ pageOfText: (pageNumber: number, totalPagesNumber: number) => string;
53
+ }>;
54
+ passwordInput?: Partial<{
55
+ inputShowPasswordTitle: string;
56
+ inputHidePasswordTitle: string;
57
+ }>;
58
+ quickNav?: Partial<{
59
+ contentTitle: string;
60
+ }>;
61
+ radioGroup?: Partial<{
62
+ optionalItemLabelDefault: string;
63
+ }>;
64
+ select?: Partial<{
65
+ noMatchesErrorMessage: string;
66
+ actionClearSelectionTitle: string;
67
+ actionClearSearchTitle: string;
68
+ }>;
69
+ tabs?: Partial<{
70
+ scrollLeft: string;
71
+ scrollRight: string;
72
+ }>;
73
+ textInput?: Partial<{
74
+ clearFieldActionTitle: string;
75
+ searchingMessage: string;
76
+ fetchingDataErrorMessage: string;
77
+ }>;
78
+ calendar?: Partial<{
79
+ daysShort: string[];
80
+ months: string[];
81
+ previousMonthTitle: string;
82
+ nextMonthTitle: string;
83
+ }>;
84
+ };
85
+ export default useTranslatedLabels;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+ var _react = require("react");
8
+ var _variables = require("./common/variables");
9
+ var _HalstackContext = require("./HalstackContext");
10
+ var useTranslatedLabels = function useTranslatedLabels() {
11
+ var labels = (0, _react.useContext)(_HalstackContext.HalstackLanguageContext);
12
+ return labels || _variables.defaultTranslatedComponentLabels;
13
+ };
14
+ var _default = exports["default"] = useTranslatedLabels;
@@ -0,0 +1,21 @@
1
+ import React from "react";
2
+ type TypographyContextProps = {
3
+ as?: keyof HTMLElementTagNameMap;
4
+ display?: string;
5
+ fontFamily?: string;
6
+ fontSize?: string;
7
+ fontStyle?: string;
8
+ fontWeight?: string;
9
+ letterSpacing?: string;
10
+ lineHeight?: string;
11
+ textAlign?: string;
12
+ color?: string;
13
+ textDecoration?: string;
14
+ textOverflow?: string;
15
+ whiteSpace?: string;
16
+ };
17
+ type BaseTypographyProps = TypographyContextProps & {
18
+ children: React.ReactNode;
19
+ };
20
+ declare const BaseTypography: ({ as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace, children, }: BaseTypographyProps) => JSX.Element;
21
+ export default BaseTypography;
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
12
+ var _templateObject;
13
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
14
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
15
+ var TypographyContext = /*#__PURE__*/_react["default"].createContext(null);
16
+ var BaseTypography = function BaseTypography(_ref) {
17
+ var as = _ref.as,
18
+ display = _ref.display,
19
+ fontFamily = _ref.fontFamily,
20
+ fontSize = _ref.fontSize,
21
+ fontStyle = _ref.fontStyle,
22
+ fontWeight = _ref.fontWeight,
23
+ letterSpacing = _ref.letterSpacing,
24
+ lineHeight = _ref.lineHeight,
25
+ textAlign = _ref.textAlign,
26
+ color = _ref.color,
27
+ textDecoration = _ref.textDecoration,
28
+ textOverflow = _ref.textOverflow,
29
+ whiteSpace = _ref.whiteSpace,
30
+ children = _ref.children;
31
+ var componentContext = (0, _react.useContext)(TypographyContext);
32
+ var contextValue = (0, _react.useMemo)(function () {
33
+ var _ref2, _ref3, _ref4, _ref5, _ref6, _ref7, _ref8, _ref9, _ref10, _ref11, _ref12, _ref13, _ref14;
34
+ return {
35
+ as: (_ref2 = as !== null && as !== void 0 ? as : componentContext === null || componentContext === void 0 ? void 0 : componentContext.as) !== null && _ref2 !== void 0 ? _ref2 : "span",
36
+ display: (_ref3 = display !== null && display !== void 0 ? display : componentContext === null || componentContext === void 0 ? void 0 : componentContext.display) !== null && _ref3 !== void 0 ? _ref3 : "inline",
37
+ fontFamily: (_ref4 = fontFamily !== null && fontFamily !== void 0 ? fontFamily : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontFamily) !== null && _ref4 !== void 0 ? _ref4 : "Open Sans, sans-serif",
38
+ fontSize: (_ref5 = fontSize !== null && fontSize !== void 0 ? fontSize : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontSize) !== null && _ref5 !== void 0 ? _ref5 : "1rem",
39
+ fontStyle: (_ref6 = fontStyle !== null && fontStyle !== void 0 ? fontStyle : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontStyle) !== null && _ref6 !== void 0 ? _ref6 : "normal",
40
+ fontWeight: (_ref7 = fontWeight !== null && fontWeight !== void 0 ? fontWeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.fontWeight) !== null && _ref7 !== void 0 ? _ref7 : "400",
41
+ letterSpacing: (_ref8 = letterSpacing !== null && letterSpacing !== void 0 ? letterSpacing : componentContext === null || componentContext === void 0 ? void 0 : componentContext.letterSpacing) !== null && _ref8 !== void 0 ? _ref8 : "0em",
42
+ lineHeight: (_ref9 = lineHeight !== null && lineHeight !== void 0 ? lineHeight : componentContext === null || componentContext === void 0 ? void 0 : componentContext.lineHeight) !== null && _ref9 !== void 0 ? _ref9 : "1.5em",
43
+ textAlign: (_ref10 = textAlign !== null && textAlign !== void 0 ? textAlign : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textAlign) !== null && _ref10 !== void 0 ? _ref10 : "left",
44
+ color: (_ref11 = color !== null && color !== void 0 ? color : componentContext === null || componentContext === void 0 ? void 0 : componentContext.color) !== null && _ref11 !== void 0 ? _ref11 : "#000000",
45
+ textDecoration: (_ref12 = textDecoration !== null && textDecoration !== void 0 ? textDecoration : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textDecoration) !== null && _ref12 !== void 0 ? _ref12 : "none",
46
+ textOverflow: (_ref13 = textOverflow !== null && textOverflow !== void 0 ? textOverflow : componentContext === null || componentContext === void 0 ? void 0 : componentContext.textOverflow) !== null && _ref13 !== void 0 ? _ref13 : "unset",
47
+ whiteSpace: (_ref14 = whiteSpace !== null && whiteSpace !== void 0 ? whiteSpace : componentContext === null || componentContext === void 0 ? void 0 : componentContext.whiteSpace) !== null && _ref14 !== void 0 ? _ref14 : "normal"
48
+ };
49
+ }, [as, display, fontFamily, fontSize, fontStyle, fontWeight, letterSpacing, lineHeight, textAlign, color, textDecoration, textOverflow, whiteSpace]);
50
+ return /*#__PURE__*/_react["default"].createElement(TypographyContext.Provider, {
51
+ value: contextValue
52
+ }, /*#__PURE__*/_react["default"].createElement(StyledTypography, contextValue, children));
53
+ };
54
+ var StyledTypography = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n text-align: ", ";\n text-decoration: ", ";\n text-overflow: ", ";\n white-space: ", ";\n overflow: ", ";\n margin: 0;\n"])), function (_ref15) {
55
+ var display = _ref15.display;
56
+ return display;
57
+ }, function (_ref16) {
58
+ var color = _ref16.color;
59
+ return color;
60
+ }, function (_ref17) {
61
+ var fontFamily = _ref17.fontFamily;
62
+ return fontFamily;
63
+ }, function (_ref18) {
64
+ var fontSize = _ref18.fontSize;
65
+ return fontSize;
66
+ }, function (_ref19) {
67
+ var fontStyle = _ref19.fontStyle;
68
+ return fontStyle;
69
+ }, function (_ref20) {
70
+ var fontWeight = _ref20.fontWeight;
71
+ return fontWeight;
72
+ }, function (_ref21) {
73
+ var letterSpacing = _ref21.letterSpacing;
74
+ return letterSpacing;
75
+ }, function (_ref22) {
76
+ var lineHeight = _ref22.lineHeight;
77
+ return lineHeight;
78
+ }, function (_ref23) {
79
+ var textAlign = _ref23.textAlign;
80
+ return textAlign;
81
+ }, function (_ref24) {
82
+ var textDecoration = _ref24.textDecoration;
83
+ return textDecoration;
84
+ }, function (_ref25) {
85
+ var textOverflow = _ref25.textOverflow;
86
+ return textOverflow;
87
+ }, function (_ref26) {
88
+ var whiteSpace = _ref26.whiteSpace;
89
+ return whiteSpace;
90
+ }, function (_ref27) {
91
+ var textOverflow = _ref27.textOverflow;
92
+ return textOverflow !== "unset" ? "hidden" : "visible";
93
+ });
94
+ var _default = exports["default"] = BaseTypography;
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ /**
3
+ * Traps the focus inside the children of the component. It will focus the first focusable element when the component is mounted.
4
+ * When the focus is on the last focusable element and the user tries to focus the next element, it will focus the first element.
5
+ * When the focus is on the first focusable element and the user tries to focus the previous element, it will focus the last element.
6
+ * The focus can't be moved outside the children unless the children are removed from the DOM (for example, a Dialog, a Modal, etc).
7
+ * @param children: React.ReactNode
8
+ * @returns
9
+ */
10
+ declare const FocusLock: ({ children }: {
11
+ children: React.ReactNode;
12
+ }) => JSX.Element;
13
+ export default FocusLock;
@@ -0,0 +1,124 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
12
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
13
+ var not = {
14
+ negTabIndex: ':not([tabindex^="-"])',
15
+ disabled: ":not(:disabled)"
16
+ };
17
+ var focusableQuery = ["a[href]".concat(not.negTabIndex), "area[href]".concat(not.negTabIndex), "input:not([type=\"hidden\"])".concat(not.negTabIndex).concat(not.disabled), "select".concat(not.negTabIndex).concat(not.disabled), "textarea".concat(not.negTabIndex).concat(not.disabled), "button".concat(not.negTabIndex).concat(not.disabled), "details > summary:first-of-type".concat(not.negTabIndex), "iframe".concat(not.negTabIndex), "audio[controls]".concat(not.negTabIndex), "video[controls]".concat(not.negTabIndex), "[contenteditable]".concat(not.negTabIndex), "[tabindex]".concat(not.negTabIndex).concat(not.disabled)].join(",");
18
+ var getFocusableElements = function getFocusableElements(container) {
19
+ return Array.prototype.slice.call(container.querySelectorAll(focusableQuery)).filter(function (element) {
20
+ return element.getAttribute("aria-hidden") !== "true" && window.getComputedStyle(element).display !== "none" && window.getComputedStyle(element).visibility !== "hidden";
21
+ });
22
+ };
23
+
24
+ /**
25
+ * This function will try to focus the element and return true if it was able to receive the focus.
26
+ * Even if the element is focusable (passes any of the conditions of our selector), there is the possibility
27
+ * that the element may not be focusable at all.
28
+ * @param element: HTMLElement
29
+ * @returns
30
+ */
31
+ var attemptFocus = function attemptFocus(element) {
32
+ element === null || element === void 0 ? void 0 : element.focus();
33
+ return document.activeElement === element;
34
+ };
35
+
36
+ /**
37
+ * @param element: HTMLElement
38
+ * @returns boolean: true if element is contained inside a Radix Portal, false otherwise.
39
+ */
40
+ var radixPortalContains = function radixPortalContains(activeElement) {
41
+ var radixPortals = document.querySelectorAll("[data-radix-portal]");
42
+ var radixPoppers = document.querySelectorAll("[data-radix-popper-content-wrapper]");
43
+ return Array.prototype.slice.call(radixPortals).some(function (portal) {
44
+ return portal.contains(activeElement);
45
+ }) || Array.prototype.slice.call(radixPoppers).some(function (popper) {
46
+ return popper.contains(activeElement);
47
+ });
48
+ };
49
+
50
+ /**
51
+ * Custom hook that returns an array of focusable elements inside a container.
52
+ * @param ref: React.MutableRefObject<HTMLDivElement>
53
+ * @returns
54
+ */
55
+ var useFocusableElements = function useFocusableElements(ref) {
56
+ var _useState = (0, _react.useState)(),
57
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
58
+ focusableElements = _useState2[0],
59
+ setFocusableElements = _useState2[1];
60
+ (0, _react.useEffect)(function () {
61
+ if (ref.current != null) {
62
+ setFocusableElements(getFocusableElements(ref.current));
63
+ var observer = new MutationObserver(function () {
64
+ setFocusableElements(getFocusableElements(ref.current));
65
+ });
66
+ observer.observe(ref.current, {
67
+ childList: true,
68
+ subtree: true,
69
+ attributes: true
70
+ });
71
+ return function () {
72
+ observer.disconnect();
73
+ };
74
+ }
75
+ }, []);
76
+ return focusableElements;
77
+ };
78
+
79
+ /**
80
+ * Traps the focus inside the children of the component. It will focus the first focusable element when the component is mounted.
81
+ * When the focus is on the last focusable element and the user tries to focus the next element, it will focus the first element.
82
+ * When the focus is on the first focusable element and the user tries to focus the previous element, it will focus the last element.
83
+ * The focus can't be moved outside the children unless the children are removed from the DOM (for example, a Dialog, a Modal, etc).
84
+ * @param children: React.ReactNode
85
+ * @returns
86
+ */
87
+ var FocusLock = function FocusLock(_ref) {
88
+ var children = _ref.children;
89
+ var childrenContainerRef = (0, _react.useRef)();
90
+ var focusableElements = useFocusableElements(childrenContainerRef);
91
+ var focusFirst = (0, _react.useCallback)(function () {
92
+ var _childrenContainerRef;
93
+ if ((focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) === 0) (_childrenContainerRef = childrenContainerRef.current) === null || _childrenContainerRef === void 0 ? void 0 : _childrenContainerRef.focus();else if ((focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) > 0) focusableElements.some(function (element) {
94
+ return attemptFocus(element);
95
+ });
96
+ }, [focusableElements]);
97
+ var focusLast = function focusLast() {
98
+ focusableElements.reverse().some(function (element) {
99
+ return attemptFocus(element);
100
+ });
101
+ };
102
+ var focusLock = function focusLock(event) {
103
+ if (event.key === "Tab") focusableElements.length === 0 && event.preventDefault();
104
+ };
105
+ (0, _react.useEffect)(function () {
106
+ var _childrenContainerRef2;
107
+ if (!((_childrenContainerRef2 = childrenContainerRef.current) !== null && _childrenContainerRef2 !== void 0 && _childrenContainerRef2.contains(document.activeElement)) && !radixPortalContains(document.activeElement)) focusFirst();
108
+ }, [focusFirst]);
109
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("div", {
110
+ onFocus: focusLast,
111
+ tabIndex: 0
112
+ }), /*#__PURE__*/_react["default"].createElement("div", {
113
+ onKeyDown: focusLock,
114
+ ref: childrenContainerRef,
115
+ tabIndex: (focusableElements === null || focusableElements === void 0 ? void 0 : focusableElements.length) === 0 ? 0 : -1,
116
+ style: {
117
+ outline: "none"
118
+ }
119
+ }, children), /*#__PURE__*/_react["default"].createElement("div", {
120
+ onFocus: focusFirst,
121
+ tabIndex: 0
122
+ }));
123
+ };
124
+ var _default = exports["default"] = FocusLock;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _Wizard = _interopRequireDefault(require("./Wizard"));
10
+ var favoriteSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ viewBox: "0 0 24 24",
12
+ fill: "currentColor"
13
+ }, /*#__PURE__*/_react["default"].createElement("path", {
14
+ d: "M0 0h24v24H0z",
15
+ fill: "none"
16
+ }), /*#__PURE__*/_react["default"].createElement("path", {
17
+ d: "M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z"
18
+ }));
19
+ describe("Wizard component accessibility tests", function () {
20
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
21
+ var _render, container, results;
22
+ return _regenerator["default"].wrap(function _callee$(_context) {
23
+ while (1) switch (_context.prev = _context.next) {
24
+ case 0:
25
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Wizard["default"], {
26
+ steps: [{
27
+ label: "first-step",
28
+ description: "Description",
29
+ icon: favoriteSVG
30
+ }, {
31
+ label: "second-step",
32
+ description: "Description"
33
+ }, {
34
+ label: "valid-step",
35
+ valid: true
36
+ }, {
37
+ label: "disabled-step",
38
+ disabled: true
39
+ }],
40
+ mode: "vertical",
41
+ defaultCurrentStep: 1,
42
+ margin: "medium"
43
+ })), container = _render.container;
44
+ _context.next = 3;
45
+ return (0, _axeHelper.axe)(container);
46
+ case 3:
47
+ results = _context.sent;
48
+ expect(results).toHaveNoViolations();
49
+ case 5:
50
+ case "end":
51
+ return _context.stop();
52
+ }
53
+ }, _callee);
54
+ })));
55
+ });
@@ -1,4 +1,4 @@
1
1
  /// <reference types="react" />
2
2
  import WizardPropsType from "./types";
3
- declare const DxcWizard: ({ mode, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
3
+ declare const DxcWizard: ({ mode, defaultCurrentStep, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
4
4
  export default DxcWizard;