@dxc-technology/halstack-react 0.0.0-ab6ca72 → 0.0.0-abdd3b9

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 (595) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +169 -0
  9. package/accordion/Accordion.stories.tsx +251 -0
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +57 -0
  12. package/accordion/types.js +5 -0
  13. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +101 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  17. package/accordion-group/AccordionGroup.test.js +98 -0
  18. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  19. package/accordion-group/AccordionGroupAccordion.js +31 -0
  20. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  21. package/accordion-group/AccordionGroupContext.js +8 -0
  22. package/accordion-group/types.d.ts +67 -0
  23. package/accordion-group/types.js +5 -0
  24. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  25. package/action-icon/ActionIcon.d.ts +4 -0
  26. package/action-icon/ActionIcon.js +48 -0
  27. package/action-icon/ActionIcon.stories.tsx +41 -0
  28. package/action-icon/ActionIcon.test.js +64 -0
  29. package/action-icon/types.d.ts +26 -0
  30. package/action-icon/types.js +5 -0
  31. package/alert/Alert.accessibility.test.js +95 -0
  32. package/alert/Alert.d.ts +4 -0
  33. package/alert/Alert.js +200 -0
  34. package/alert/Alert.stories.tsx +198 -0
  35. package/alert/Alert.test.js +75 -0
  36. package/alert/types.d.ts +49 -0
  37. package/alert/types.js +5 -0
  38. package/badge/Badge.accessibility.test.js +129 -0
  39. package/badge/Badge.d.ts +4 -0
  40. package/badge/Badge.js +161 -0
  41. package/badge/Badge.stories.tsx +210 -0
  42. package/badge/Badge.test.js +30 -0
  43. package/badge/types.d.ts +54 -0
  44. package/badge/types.js +5 -0
  45. package/bleed/Bleed.d.ts +3 -0
  46. package/bleed/Bleed.js +43 -0
  47. package/bleed/Bleed.stories.tsx +342 -0
  48. package/bleed/types.d.ts +37 -0
  49. package/bleed/types.js +5 -0
  50. package/box/Box.accessibility.test.js +33 -0
  51. package/box/Box.d.ts +4 -0
  52. package/box/Box.js +75 -0
  53. package/box/Box.stories.tsx +119 -0
  54. package/box/Box.test.js +13 -0
  55. package/box/types.d.ts +32 -0
  56. package/box/types.js +5 -0
  57. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  58. package/bulleted-list/BulletedList.d.ts +7 -0
  59. package/bulleted-list/BulletedList.js +92 -0
  60. package/bulleted-list/BulletedList.stories.tsx +115 -0
  61. package/bulleted-list/types.d.ts +38 -0
  62. package/bulleted-list/types.js +5 -0
  63. package/button/Button.accessibility.test.js +127 -0
  64. package/button/Button.d.ts +4 -0
  65. package/button/Button.js +121 -0
  66. package/button/Button.stories.tsx +325 -0
  67. package/button/Button.test.js +38 -0
  68. package/button/types.d.ts +57 -0
  69. package/button/types.js +5 -0
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +4 -0
  72. package/card/Card.js +120 -0
  73. package/card/Card.stories.tsx +171 -0
  74. package/card/Card.test.js +39 -0
  75. package/card/types.d.ts +62 -0
  76. package/card/types.js +5 -0
  77. package/checkbox/Checkbox.accessibility.test.js +87 -0
  78. package/checkbox/Checkbox.d.ts +4 -0
  79. package/checkbox/Checkbox.js +215 -0
  80. package/checkbox/Checkbox.stories.tsx +222 -0
  81. package/checkbox/Checkbox.test.js +199 -0
  82. package/checkbox/types.d.ts +72 -0
  83. package/checkbox/types.js +5 -0
  84. package/chip/Chip.accessibility.test.js +67 -0
  85. package/chip/Chip.d.ts +4 -0
  86. package/chip/Chip.js +124 -0
  87. package/chip/Chip.stories.tsx +195 -0
  88. package/chip/Chip.test.js +41 -0
  89. package/chip/types.d.ts +45 -0
  90. package/chip/types.js +5 -0
  91. package/common/coreTokens.d.ts +237 -0
  92. package/common/coreTokens.js +184 -0
  93. package/common/utils.d.ts +1 -0
  94. package/common/utils.js +16 -0
  95. package/common/variables.d.ts +1395 -0
  96. package/common/variables.js +1267 -0
  97. package/container/Container.d.ts +4 -0
  98. package/container/Container.js +194 -0
  99. package/container/Container.stories.tsx +214 -0
  100. package/container/types.d.ts +74 -0
  101. package/container/types.js +5 -0
  102. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  103. package/contextual-menu/ContextualMenu.d.ts +7 -0
  104. package/contextual-menu/ContextualMenu.js +71 -0
  105. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  106. package/contextual-menu/ContextualMenu.test.js +71 -0
  107. package/contextual-menu/MenuItemAction.d.ts +4 -0
  108. package/contextual-menu/MenuItemAction.js +46 -0
  109. package/contextual-menu/types.d.ts +22 -0
  110. package/contextual-menu/types.js +5 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +216 -0
  114. package/date-input/DateInput.d.ts +4 -0
  115. package/date-input/DateInput.js +222 -0
  116. package/date-input/DateInput.stories.tsx +285 -0
  117. package/date-input/DateInput.test.js +808 -0
  118. package/date-input/DatePicker.d.ts +4 -0
  119. package/date-input/DatePicker.js +121 -0
  120. package/date-input/YearPicker.d.ts +4 -0
  121. package/date-input/YearPicker.js +100 -0
  122. package/date-input/types.d.ts +164 -0
  123. package/date-input/types.js +5 -0
  124. package/dialog/Dialog.accessibility.test.js +69 -0
  125. package/dialog/Dialog.d.ts +4 -0
  126. package/dialog/Dialog.js +104 -0
  127. package/dialog/Dialog.stories.tsx +365 -0
  128. package/dialog/Dialog.test.js +307 -0
  129. package/dialog/types.d.ts +36 -0
  130. package/dialog/types.js +5 -0
  131. package/divider/Divider.accessibility.test.js +33 -0
  132. package/divider/Divider.d.ts +4 -0
  133. package/divider/Divider.js +36 -0
  134. package/divider/Divider.stories.tsx +223 -0
  135. package/divider/Divider.test.js +38 -0
  136. package/divider/types.d.ts +21 -0
  137. package/divider/types.js +5 -0
  138. package/dropdown/Dropdown.accessibility.test.js +180 -0
  139. package/dropdown/Dropdown.d.ts +4 -0
  140. package/dropdown/Dropdown.js +319 -0
  141. package/dropdown/Dropdown.stories.tsx +427 -0
  142. package/dropdown/Dropdown.test.js +599 -0
  143. package/dropdown/DropdownMenu.d.ts +4 -0
  144. package/dropdown/DropdownMenu.js +63 -0
  145. package/dropdown/DropdownMenuItem.d.ts +4 -0
  146. package/dropdown/DropdownMenuItem.js +70 -0
  147. package/dropdown/types.d.ts +96 -0
  148. package/dropdown/types.js +5 -0
  149. package/file-input/FileInput.accessibility.test.js +160 -0
  150. package/file-input/FileInput.d.ts +4 -0
  151. package/file-input/FileInput.js +443 -0
  152. package/file-input/FileInput.stories.tsx +618 -0
  153. package/file-input/FileInput.test.js +382 -0
  154. package/file-input/FileItem.d.ts +4 -0
  155. package/file-input/FileItem.js +121 -0
  156. package/file-input/types.d.ts +129 -0
  157. package/file-input/types.js +5 -0
  158. package/flex/Flex.d.ts +4 -0
  159. package/flex/Flex.js +57 -0
  160. package/flex/Flex.stories.tsx +112 -0
  161. package/flex/types.d.ts +97 -0
  162. package/flex/types.js +5 -0
  163. package/footer/Footer.accessibility.test.js +117 -0
  164. package/footer/Footer.d.ts +4 -0
  165. package/footer/Footer.js +140 -0
  166. package/footer/Footer.stories.tsx +196 -0
  167. package/footer/Footer.test.js +85 -0
  168. package/footer/Icons.d.ts +3 -0
  169. package/footer/Icons.js +136 -0
  170. package/footer/types.d.ts +64 -0
  171. package/footer/types.js +5 -0
  172. package/grid/Grid.d.ts +7 -0
  173. package/grid/Grid.js +76 -0
  174. package/grid/Grid.stories.tsx +219 -0
  175. package/grid/types.d.ts +115 -0
  176. package/grid/types.js +5 -0
  177. package/header/Header.accessibility.test.js +84 -0
  178. package/header/Header.d.ts +8 -0
  179. package/header/Header.js +209 -0
  180. package/header/Header.stories.tsx +251 -0
  181. package/header/Header.test.js +66 -0
  182. package/header/Icons.d.ts +2 -0
  183. package/header/Icons.js +29 -0
  184. package/header/types.d.ts +33 -0
  185. package/header/types.js +5 -0
  186. package/heading/Heading.accessibility.test.js +33 -0
  187. package/heading/Heading.d.ts +4 -0
  188. package/heading/Heading.js +137 -0
  189. package/heading/Heading.stories.tsx +54 -0
  190. package/heading/Heading.test.js +169 -0
  191. package/heading/types.d.ts +33 -0
  192. package/heading/types.js +5 -0
  193. package/icon/Icon.accessibility.test.js +30 -0
  194. package/icon/Icon.d.ts +4 -0
  195. package/icon/Icon.js +33 -0
  196. package/icon/Icon.stories.tsx +28 -0
  197. package/icon/types.d.ts +4 -0
  198. package/icon/types.js +5 -0
  199. package/image/Image.accessibility.test.js +56 -0
  200. package/image/Image.d.ts +4 -0
  201. package/image/Image.js +70 -0
  202. package/image/Image.stories.tsx +129 -0
  203. package/image/types.d.ts +72 -0
  204. package/image/types.js +5 -0
  205. package/inset/Inset.d.ts +3 -0
  206. package/inset/Inset.js +43 -0
  207. package/inset/Inset.stories.tsx +230 -0
  208. package/inset/types.d.ts +37 -0
  209. package/inset/types.js +5 -0
  210. package/layout/ApplicationLayout.d.ts +20 -0
  211. package/layout/ApplicationLayout.js +134 -0
  212. package/layout/ApplicationLayout.stories.tsx +162 -0
  213. package/layout/Icons.d.ts +8 -0
  214. package/layout/Icons.js +56 -0
  215. package/layout/types.d.ts +41 -0
  216. package/layout/types.js +5 -0
  217. package/link/Link.accessibility.test.js +112 -0
  218. package/link/Link.d.ts +4 -0
  219. package/link/Link.js +117 -0
  220. package/link/Link.stories.tsx +253 -0
  221. package/link/Link.test.js +63 -0
  222. package/link/types.d.ts +54 -0
  223. package/link/types.js +5 -0
  224. package/main.d.ts +49 -0
  225. package/main.js +357 -0
  226. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  227. package/nav-tabs/NavTabs.d.ts +7 -0
  228. package/nav-tabs/NavTabs.js +93 -0
  229. package/nav-tabs/NavTabs.stories.tsx +279 -0
  230. package/nav-tabs/NavTabs.test.js +75 -0
  231. package/nav-tabs/NavTabsContext.d.ts +3 -0
  232. package/nav-tabs/NavTabsContext.js +8 -0
  233. package/nav-tabs/Tab.d.ts +4 -0
  234. package/nav-tabs/Tab.js +117 -0
  235. package/nav-tabs/types.d.ts +52 -0
  236. package/nav-tabs/types.js +5 -0
  237. package/number-input/NumberInput.accessibility.test.js +228 -0
  238. package/number-input/NumberInput.d.ts +4 -0
  239. package/number-input/NumberInput.js +86 -0
  240. package/number-input/NumberInput.stories.tsx +131 -0
  241. package/number-input/NumberInput.test.js +989 -0
  242. package/number-input/NumberInputContext.d.ts +3 -0
  243. package/number-input/NumberInputContext.js +8 -0
  244. package/number-input/types.d.ts +136 -0
  245. package/number-input/types.js +5 -0
  246. package/package.json +65 -49
  247. package/paginator/Icons.d.ts +5 -0
  248. package/paginator/Icons.js +40 -0
  249. package/paginator/Paginator.accessibility.test.js +79 -0
  250. package/paginator/Paginator.d.ts +4 -0
  251. package/paginator/Paginator.js +135 -0
  252. package/paginator/Paginator.stories.tsx +87 -0
  253. package/paginator/Paginator.test.js +335 -0
  254. package/paginator/types.d.ts +38 -0
  255. package/paginator/types.js +5 -0
  256. package/paragraph/Paragraph.accessibility.test.js +28 -0
  257. package/paragraph/Paragraph.d.ts +5 -0
  258. package/paragraph/Paragraph.js +22 -0
  259. package/paragraph/Paragraph.stories.tsx +27 -0
  260. package/password-input/PasswordInput.accessibility.test.js +153 -0
  261. package/password-input/PasswordInput.d.ts +4 -0
  262. package/password-input/PasswordInput.js +96 -0
  263. package/password-input/PasswordInput.stories.tsx +99 -0
  264. package/password-input/PasswordInput.test.js +198 -0
  265. package/password-input/types.d.ts +111 -0
  266. package/password-input/types.js +5 -0
  267. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  268. package/progress-bar/ProgressBar.d.ts +4 -0
  269. package/progress-bar/ProgressBar.js +144 -0
  270. package/progress-bar/ProgressBar.stories.tsx +93 -0
  271. package/progress-bar/ProgressBar.test.js +93 -0
  272. package/progress-bar/types.d.ts +37 -0
  273. package/progress-bar/types.js +5 -0
  274. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  275. package/quick-nav/QuickNav.d.ts +4 -0
  276. package/quick-nav/QuickNav.js +94 -0
  277. package/quick-nav/QuickNav.stories.tsx +356 -0
  278. package/quick-nav/types.d.ts +21 -0
  279. package/quick-nav/types.js +5 -0
  280. package/radio-group/Radio.d.ts +4 -0
  281. package/radio-group/Radio.js +124 -0
  282. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  283. package/radio-group/RadioGroup.d.ts +4 -0
  284. package/radio-group/RadioGroup.js +235 -0
  285. package/radio-group/RadioGroup.stories.tsx +214 -0
  286. package/radio-group/RadioGroup.test.js +756 -0
  287. package/radio-group/types.d.ts +114 -0
  288. package/radio-group/types.js +5 -0
  289. package/resultset-table/Icons.d.ts +7 -0
  290. package/resultset-table/Icons.js +47 -0
  291. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  292. package/resultset-table/ResultsetTable.d.ts +7 -0
  293. package/resultset-table/ResultsetTable.js +170 -0
  294. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  295. package/resultset-table/ResultsetTable.test.js +381 -0
  296. package/resultset-table/types.d.ts +100 -0
  297. package/resultset-table/types.js +5 -0
  298. package/select/Icons.d.ts +10 -0
  299. package/select/Icons.js +89 -0
  300. package/select/Listbox.d.ts +4 -0
  301. package/select/Listbox.js +143 -0
  302. package/select/Option.d.ts +4 -0
  303. package/select/Option.js +87 -0
  304. package/select/Select.accessibility.test.js +217 -0
  305. package/select/Select.d.ts +4 -0
  306. package/select/Select.js +590 -0
  307. package/select/Select.stories.tsx +970 -0
  308. package/select/Select.test.js +2370 -0
  309. package/select/types.d.ts +209 -0
  310. package/select/types.js +5 -0
  311. package/sidenav/Sidenav.accessibility.test.js +59 -0
  312. package/sidenav/Sidenav.d.ts +10 -0
  313. package/sidenav/Sidenav.js +201 -0
  314. package/sidenav/Sidenav.stories.tsx +277 -0
  315. package/sidenav/Sidenav.test.js +37 -0
  316. package/sidenav/SidenavContext.d.ts +5 -0
  317. package/sidenav/SidenavContext.js +13 -0
  318. package/sidenav/types.d.ts +76 -0
  319. package/sidenav/types.js +5 -0
  320. package/slider/Slider.accessibility.test.js +104 -0
  321. package/slider/Slider.d.ts +4 -0
  322. package/slider/Slider.js +285 -0
  323. package/slider/Slider.test.js +254 -0
  324. package/slider/types.d.ts +86 -0
  325. package/slider/types.js +5 -0
  326. package/spinner/Spinner.accessibility.test.js +96 -0
  327. package/spinner/Spinner.d.ts +4 -0
  328. package/spinner/Spinner.js +206 -0
  329. package/spinner/Spinner.stories.tsx +129 -0
  330. package/spinner/Spinner.test.js +55 -0
  331. package/spinner/types.d.ts +32 -0
  332. package/spinner/types.js +5 -0
  333. package/status-light/StatusLight.accessibility.test.js +157 -0
  334. package/status-light/StatusLight.d.ts +4 -0
  335. package/status-light/StatusLight.js +51 -0
  336. package/status-light/StatusLight.stories.tsx +74 -0
  337. package/status-light/StatusLight.test.js +25 -0
  338. package/status-light/types.d.ts +17 -0
  339. package/status-light/types.js +5 -0
  340. package/switch/Switch.accessibility.test.js +89 -0
  341. package/switch/Switch.d.ts +4 -0
  342. package/switch/Switch.js +214 -0
  343. package/switch/Switch.stories.tsx +137 -0
  344. package/switch/Switch.test.js +180 -0
  345. package/switch/types.d.ts +66 -0
  346. package/switch/types.js +5 -0
  347. package/table/DropdownTheme.js +62 -0
  348. package/table/Table.accessibility.test.js +82 -0
  349. package/table/Table.d.ts +8 -0
  350. package/table/Table.js +161 -0
  351. package/table/Table.stories.tsx +651 -0
  352. package/table/Table.test.js +113 -0
  353. package/table/types.d.ts +49 -0
  354. package/table/types.js +5 -0
  355. package/tabs/Tab.d.ts +4 -0
  356. package/tabs/Tab.js +117 -0
  357. package/tabs/Tabs.accessibility.test.js +56 -0
  358. package/tabs/Tabs.d.ts +4 -0
  359. package/tabs/Tabs.js +373 -0
  360. package/tabs/Tabs.stories.tsx +224 -0
  361. package/tabs/Tabs.test.js +276 -0
  362. package/tabs/types.d.ts +92 -0
  363. package/tabs/types.js +5 -0
  364. package/tag/Tag.accessibility.test.js +69 -0
  365. package/tag/Tag.d.ts +4 -0
  366. package/tag/Tag.js +151 -0
  367. package/tag/Tag.stories.tsx +152 -0
  368. package/tag/Tag.test.js +41 -0
  369. package/tag/types.d.ts +69 -0
  370. package/tag/types.js +5 -0
  371. package/text-input/Suggestion.d.ts +4 -0
  372. package/text-input/Suggestion.js +67 -0
  373. package/text-input/Suggestions.d.ts +4 -0
  374. package/text-input/Suggestions.js +86 -0
  375. package/text-input/TextInput.accessibility.test.js +321 -0
  376. package/text-input/TextInput.d.ts +4 -0
  377. package/text-input/TextInput.js +567 -0
  378. package/text-input/TextInput.stories.tsx +465 -0
  379. package/text-input/TextInput.test.js +1756 -0
  380. package/text-input/types.d.ts +205 -0
  381. package/text-input/types.js +5 -0
  382. package/textarea/Textarea.accessibility.test.js +155 -0
  383. package/textarea/Textarea.d.ts +4 -0
  384. package/textarea/Textarea.js +234 -0
  385. package/textarea/Textarea.stories.tsx +174 -0
  386. package/textarea/Textarea.test.js +406 -0
  387. package/textarea/types.d.ts +141 -0
  388. package/textarea/types.js +5 -0
  389. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  390. package/toggle-group/ToggleGroup.d.ts +4 -0
  391. package/toggle-group/ToggleGroup.js +202 -0
  392. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  393. package/toggle-group/ToggleGroup.test.js +137 -0
  394. package/toggle-group/types.d.ts +114 -0
  395. package/toggle-group/types.js +5 -0
  396. package/typography/Typography.accessibility.test.js +339 -0
  397. package/typography/Typography.d.ts +4 -0
  398. package/typography/Typography.js +23 -0
  399. package/typography/Typography.stories.tsx +198 -0
  400. package/typography/types.d.ts +18 -0
  401. package/typography/types.js +5 -0
  402. package/useTheme.d.ts +1148 -0
  403. package/useTheme.js +15 -0
  404. package/useTranslatedLabels.d.ts +85 -0
  405. package/useTranslatedLabels.js +14 -0
  406. package/utils/BaseTypography.d.ts +21 -0
  407. package/utils/BaseTypography.js +94 -0
  408. package/utils/FocusLock.d.ts +13 -0
  409. package/utils/FocusLock.js +124 -0
  410. package/wizard/Wizard.accessibility.test.js +55 -0
  411. package/wizard/Wizard.d.ts +4 -0
  412. package/wizard/Wizard.js +247 -0
  413. package/wizard/Wizard.stories.tsx +272 -0
  414. package/wizard/Wizard.test.js +114 -0
  415. package/wizard/types.d.ts +64 -0
  416. package/wizard/types.js +5 -0
  417. package/babel.config.js +0 -4
  418. package/dist/ThemeContext.js +0 -15
  419. package/dist/accordion/Accordion.js +0 -242
  420. package/dist/accordion/Accordion.stories.js +0 -207
  421. package/dist/accordion/readme.md +0 -96
  422. package/dist/alert/Alert.js +0 -304
  423. package/dist/alert/Alert.stories.js +0 -158
  424. package/dist/alert/close.svg +0 -4
  425. package/dist/alert/error.svg +0 -4
  426. package/dist/alert/info.svg +0 -4
  427. package/dist/alert/readme.md +0 -43
  428. package/dist/alert/success.svg +0 -4
  429. package/dist/alert/warning.svg +0 -4
  430. package/dist/box/Box.js +0 -148
  431. package/dist/button/Button.js +0 -181
  432. package/dist/button/Button.stories.js +0 -224
  433. package/dist/button/readme.md +0 -93
  434. package/dist/card/Card.js +0 -217
  435. package/dist/checkbox/Checkbox.js +0 -224
  436. package/dist/checkbox/Checkbox.stories.js +0 -144
  437. package/dist/checkbox/readme.md +0 -116
  438. package/dist/chip/Chip.js +0 -171
  439. package/dist/common/OpenSans.css +0 -81
  440. package/dist/common/RequiredComponent.js +0 -46
  441. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  442. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  443. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  444. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  445. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  446. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  447. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  448. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  449. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  450. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  451. package/dist/common/services/example-service.js +0 -10
  452. package/dist/common/services/example-service.test.js +0 -12
  453. package/dist/common/utils.js +0 -42
  454. package/dist/common/variables.js +0 -397
  455. package/dist/date/Date.js +0 -357
  456. package/dist/date/Date.stories.js +0 -205
  457. package/dist/date/calendar.svg +0 -1
  458. package/dist/date/calendar_dark.svg +0 -1
  459. package/dist/date/readme.md +0 -73
  460. package/dist/dialog/Dialog.js +0 -197
  461. package/dist/dialog/Dialog.stories.js +0 -217
  462. package/dist/dialog/readme.md +0 -32
  463. package/dist/dropdown/Dropdown.js +0 -424
  464. package/dist/dropdown/Dropdown.stories.js +0 -249
  465. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  466. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  467. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  468. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  469. package/dist/dropdown/readme.md +0 -69
  470. package/dist/footer/Footer.js +0 -346
  471. package/dist/footer/Footer.stories.js +0 -94
  472. package/dist/footer/dxc_logo_wht.png +0 -0
  473. package/dist/footer/readme.md +0 -41
  474. package/dist/header/Header.js +0 -372
  475. package/dist/header/Header.stories.js +0 -176
  476. package/dist/header/close_icon.svg +0 -1
  477. package/dist/header/dxc_logo_black.png +0 -0
  478. package/dist/header/dxc_logo_white.png +0 -0
  479. package/dist/header/hamb_menu_black.svg +0 -1
  480. package/dist/header/hamb_menu_white.svg +0 -1
  481. package/dist/header/readme.md +0 -33
  482. package/dist/heading/Heading.js +0 -153
  483. package/dist/input-text/InputText.js +0 -519
  484. package/dist/input-text/InputText.stories.js +0 -209
  485. package/dist/input-text/error.svg +0 -1
  486. package/dist/input-text/readme.md +0 -91
  487. package/dist/link/Link.js +0 -136
  488. package/dist/link/readme.md +0 -51
  489. package/dist/main.js +0 -263
  490. package/dist/paginator/Paginator.js +0 -196
  491. package/dist/paginator/images/next.svg +0 -3
  492. package/dist/paginator/images/nextPage.svg +0 -3
  493. package/dist/paginator/images/previous.svg +0 -3
  494. package/dist/paginator/images/previousPage.svg +0 -3
  495. package/dist/paginator/readme.md +0 -50
  496. package/dist/progress-bar/ProgressBar.js +0 -185
  497. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  498. package/dist/progress-bar/readme.md +0 -63
  499. package/dist/radio/Radio.js +0 -187
  500. package/dist/radio/Radio.stories.js +0 -166
  501. package/dist/radio/readme.md +0 -70
  502. package/dist/resultsetTable/ResultsetTable.js +0 -334
  503. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  504. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  505. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  506. package/dist/select/Select.js +0 -445
  507. package/dist/select/Select.stories.js +0 -235
  508. package/dist/select/readme.md +0 -72
  509. package/dist/sidenav/Sidenav.js +0 -236
  510. package/dist/sidenav/arrow_icon.svg +0 -3
  511. package/dist/slider/Slider.js +0 -258
  512. package/dist/slider/Slider.stories.js +0 -241
  513. package/dist/slider/readme.md +0 -64
  514. package/dist/spinner/Spinner.js +0 -193
  515. package/dist/spinner/Spinner.stories.js +0 -183
  516. package/dist/spinner/readme.md +0 -65
  517. package/dist/switch/Switch.js +0 -199
  518. package/dist/switch/Switch.stories.js +0 -134
  519. package/dist/switch/readme.md +0 -133
  520. package/dist/table/Table.js +0 -87
  521. package/dist/tabs/Tabs.js +0 -170
  522. package/dist/tabs/Tabs.stories.js +0 -130
  523. package/dist/tabs/readme.md +0 -78
  524. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  525. package/dist/tabs-for-sections/readme.md +0 -78
  526. package/dist/tag/Tag.js +0 -217
  527. package/dist/textarea/Textarea.js +0 -227
  528. package/dist/toggle/Toggle.js +0 -223
  529. package/dist/toggle/Toggle.stories.js +0 -297
  530. package/dist/toggle/readme.md +0 -80
  531. package/dist/upload/Upload.js +0 -200
  532. package/dist/upload/Upload.stories.js +0 -72
  533. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  534. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  535. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  536. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  537. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  538. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  539. package/dist/upload/file-upload/FileToUpload.js +0 -158
  540. package/dist/upload/file-upload/audio-icon.svg +0 -4
  541. package/dist/upload/file-upload/close.svg +0 -4
  542. package/dist/upload/file-upload/file-icon.svg +0 -4
  543. package/dist/upload/file-upload/video-icon.svg +0 -4
  544. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  545. package/dist/upload/readme.md +0 -37
  546. package/dist/upload/transaction/Transaction.js +0 -155
  547. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  548. package/dist/upload/transaction/audio-icon.svg +0 -4
  549. package/dist/upload/transaction/error-icon.svg +0 -4
  550. package/dist/upload/transaction/file-icon-err.svg +0 -4
  551. package/dist/upload/transaction/file-icon.svg +0 -4
  552. package/dist/upload/transaction/image-icon-err.svg +0 -4
  553. package/dist/upload/transaction/image-icon.svg +0 -4
  554. package/dist/upload/transaction/success-icon.svg +0 -4
  555. package/dist/upload/transaction/video-icon-err.svg +0 -4
  556. package/dist/upload/transaction/video-icon.svg +0 -4
  557. package/dist/upload/transactions/Transactions.js +0 -120
  558. package/dist/wizard/Wizard.js +0 -320
  559. package/dist/wizard/invalid_icon.svg +0 -6
  560. package/dist/wizard/valid_icon.svg +0 -6
  561. package/dist/wizard/validation-wrong.svg +0 -6
  562. package/test/Accordion.test.js +0 -33
  563. package/test/Alert.test.js +0 -53
  564. package/test/Box.test.js +0 -10
  565. package/test/Button.test.js +0 -18
  566. package/test/Card.test.js +0 -30
  567. package/test/Checkbox.test.js +0 -45
  568. package/test/Chip.test.js +0 -25
  569. package/test/Date.test.js +0 -393
  570. package/test/Dialog.test.js +0 -23
  571. package/test/Dropdown.test.js +0 -130
  572. package/test/Footer.test.js +0 -99
  573. package/test/Header.test.js +0 -39
  574. package/test/Heading.test.js +0 -35
  575. package/test/InputText.test.js +0 -236
  576. package/test/Link.test.js +0 -25
  577. package/test/Paginator.test.js +0 -165
  578. package/test/ProgressBar.test.js +0 -35
  579. package/test/Radio.test.js +0 -37
  580. package/test/ResultsetTable.test.js +0 -282
  581. package/test/Select.test.js +0 -191
  582. package/test/Sidenav.test.js +0 -87
  583. package/test/Slider.test.js +0 -65
  584. package/test/Spinner.test.js +0 -27
  585. package/test/Switch.test.js +0 -45
  586. package/test/Table.test.js +0 -36
  587. package/test/Tabs.test.js +0 -88
  588. package/test/TabsForSections.test.js +0 -34
  589. package/test/Tag.test.js +0 -32
  590. package/test/TextArea.test.js +0 -52
  591. package/test/Toggle.test.js +0 -43
  592. package/test/Upload.test.js +0 -60
  593. package/test/Wizard.test.js +0 -130
  594. package/test/mocks/pngMock.js +0 -1
  595. package/test/mocks/svgMock.js +0 -1
package/useTheme.js ADDED
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _react = require("react");
9
+ var _variables = require("./common/variables");
10
+ var _HalstackContext = _interopRequireDefault(require("./HalstackContext"));
11
+ var useTheme = function useTheme() {
12
+ var colorsTheme = (0, _react.useContext)(_HalstackContext["default"]);
13
+ return colorsTheme || _variables.componentTokens;
14
+ };
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 && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
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 && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
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,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 _jestAxe = require("jest-axe");
9
+ var _Wizard = _interopRequireDefault(require("./Wizard.tsx"));
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, _jestAxe.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
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import WizardPropsType from "./types";
3
+ declare const DxcWizard: ({ mode, defaultCurrentStep, currentStep, onStepClick, steps, margin, tabIndex, }: WizardPropsType) => JSX.Element;
4
+ export default DxcWizard;