@dxc-technology/halstack-react 0.0.0-f4755a1 → 0.0.0-f4dcdd7

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 (534) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1244 -0
  4. package/HalstackContext.js +306 -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 +102 -192
  10. package/accordion/Accordion.stories.tsx +83 -142
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +11 -22
  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 +38 -107
  18. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  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 +17 -22
  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 +40 -127
  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 +5 -5
  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/bleed/Bleed.d.ts +3 -0
  50. package/bleed/Bleed.js +43 -0
  51. package/bleed/Bleed.stories.tsx +342 -0
  52. package/bleed/types.d.ts +37 -0
  53. package/box/Box.accessibility.test.d.ts +1 -0
  54. package/box/Box.accessibility.test.js +33 -0
  55. package/box/Box.d.ts +1 -1
  56. package/box/Box.js +30 -81
  57. package/box/Box.stories.tsx +38 -51
  58. package/box/Box.test.d.ts +1 -0
  59. package/box/Box.test.js +13 -0
  60. package/box/types.d.ts +3 -14
  61. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  62. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  63. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  64. package/breadcrumbs/Breadcrumbs.js +79 -0
  65. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  66. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  67. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  68. package/breadcrumbs/Item.d.ts +4 -0
  69. package/breadcrumbs/Item.js +52 -0
  70. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  71. package/breadcrumbs/dropdownTheme.js +62 -0
  72. package/breadcrumbs/types.d.ts +16 -0
  73. package/breadcrumbs/types.js +5 -0
  74. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  75. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  76. package/bulleted-list/BulletedList.d.ts +7 -0
  77. package/bulleted-list/BulletedList.js +92 -0
  78. package/bulleted-list/BulletedList.stories.tsx +115 -0
  79. package/bulleted-list/types.d.ts +38 -0
  80. package/bulleted-list/types.js +5 -0
  81. package/button/Button.accessibility.test.d.ts +1 -0
  82. package/button/Button.accessibility.test.js +127 -0
  83. package/button/Button.d.ts +1 -1
  84. package/button/Button.js +64 -122
  85. package/button/Button.stories.tsx +155 -106
  86. package/button/Button.test.d.ts +1 -0
  87. package/button/Button.test.js +38 -0
  88. package/button/types.d.ts +12 -12
  89. package/card/Card.accessibility.test.d.ts +1 -0
  90. package/card/Card.accessibility.test.js +36 -0
  91. package/card/Card.d.ts +1 -1
  92. package/card/Card.js +59 -102
  93. package/card/Card.stories.tsx +13 -43
  94. package/card/Card.test.d.ts +1 -0
  95. package/card/Card.test.js +39 -0
  96. package/card/types.d.ts +6 -11
  97. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  98. package/checkbox/Checkbox.accessibility.test.js +87 -0
  99. package/checkbox/Checkbox.d.ts +2 -2
  100. package/checkbox/Checkbox.js +140 -181
  101. package/checkbox/Checkbox.stories.tsx +166 -136
  102. package/checkbox/Checkbox.test.d.ts +1 -0
  103. package/checkbox/Checkbox.test.js +199 -0
  104. package/checkbox/types.d.ts +18 -6
  105. package/chip/Chip.accessibility.test.d.ts +1 -0
  106. package/chip/Chip.accessibility.test.js +69 -0
  107. package/chip/Chip.d.ts +1 -1
  108. package/chip/Chip.js +45 -129
  109. package/chip/Chip.stories.tsx +142 -32
  110. package/chip/Chip.test.d.ts +1 -0
  111. package/chip/Chip.test.js +41 -0
  112. package/chip/types.d.ts +38 -23
  113. package/common/coreTokens.d.ts +237 -0
  114. package/common/coreTokens.js +184 -0
  115. package/common/fonts.css +2 -0
  116. package/common/utils.d.ts +1 -0
  117. package/common/utils.js +6 -12
  118. package/common/variables.d.ts +1390 -0
  119. package/common/variables.js +1078 -1421
  120. package/container/Container.d.ts +4 -0
  121. package/container/Container.js +194 -0
  122. package/container/Container.stories.tsx +214 -0
  123. package/container/types.d.ts +74 -0
  124. package/container/types.js +5 -0
  125. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  126. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  127. package/contextual-menu/ContextualMenu.d.ts +5 -0
  128. package/contextual-menu/ContextualMenu.js +88 -0
  129. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  130. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  131. package/contextual-menu/ContextualMenu.test.js +205 -0
  132. package/contextual-menu/GroupItem.d.ts +4 -0
  133. package/contextual-menu/GroupItem.js +67 -0
  134. package/contextual-menu/ItemAction.d.ts +4 -0
  135. package/contextual-menu/ItemAction.js +51 -0
  136. package/contextual-menu/MenuItem.d.ts +4 -0
  137. package/contextual-menu/MenuItem.js +29 -0
  138. package/contextual-menu/SingleItem.d.ts +4 -0
  139. package/contextual-menu/SingleItem.js +38 -0
  140. package/contextual-menu/types.d.ts +58 -0
  141. package/contextual-menu/types.js +5 -0
  142. package/date-input/Calendar.d.ts +4 -0
  143. package/date-input/Calendar.js +214 -0
  144. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  145. package/date-input/DateInput.accessibility.test.js +230 -0
  146. package/date-input/DateInput.js +172 -308
  147. package/date-input/DateInput.stories.tsx +210 -56
  148. package/date-input/DateInput.test.d.ts +1 -0
  149. package/date-input/DateInput.test.js +809 -0
  150. package/date-input/DatePicker.d.ts +4 -0
  151. package/date-input/DatePicker.js +121 -0
  152. package/date-input/YearPicker.d.ts +4 -0
  153. package/date-input/YearPicker.js +100 -0
  154. package/date-input/types.d.ts +86 -22
  155. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  156. package/dialog/Dialog.accessibility.test.js +69 -0
  157. package/dialog/Dialog.d.ts +1 -1
  158. package/dialog/Dialog.js +56 -129
  159. package/dialog/Dialog.stories.tsx +325 -167
  160. package/dialog/Dialog.test.d.ts +1 -0
  161. package/dialog/Dialog.test.js +371 -0
  162. package/dialog/types.d.ts +18 -25
  163. package/divider/Divider.accessibility.test.d.ts +1 -0
  164. package/divider/Divider.accessibility.test.js +33 -0
  165. package/divider/Divider.d.ts +4 -0
  166. package/divider/Divider.js +36 -0
  167. package/divider/Divider.stories.tsx +223 -0
  168. package/divider/Divider.test.d.ts +1 -0
  169. package/divider/Divider.test.js +38 -0
  170. package/divider/types.d.ts +21 -0
  171. package/divider/types.js +5 -0
  172. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  173. package/dropdown/Dropdown.accessibility.test.js +184 -0
  174. package/dropdown/Dropdown.d.ts +1 -1
  175. package/dropdown/Dropdown.js +232 -329
  176. package/dropdown/Dropdown.stories.tsx +244 -64
  177. package/dropdown/Dropdown.test.d.ts +1 -0
  178. package/dropdown/Dropdown.test.js +629 -0
  179. package/dropdown/DropdownMenu.d.ts +4 -0
  180. package/dropdown/DropdownMenu.js +63 -0
  181. package/dropdown/DropdownMenuItem.d.ts +4 -0
  182. package/dropdown/DropdownMenuItem.js +71 -0
  183. package/dropdown/types.d.ts +37 -30
  184. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  185. package/file-input/FileInput.accessibility.test.js +167 -0
  186. package/file-input/FileInput.d.ts +2 -2
  187. package/file-input/FileInput.js +245 -395
  188. package/file-input/FileInput.stories.tsx +123 -11
  189. package/file-input/FileInput.test.d.ts +1 -0
  190. package/file-input/FileInput.test.js +404 -0
  191. package/file-input/FileItem.d.ts +4 -14
  192. package/file-input/FileItem.js +61 -120
  193. package/file-input/types.d.ts +25 -8
  194. package/flex/Flex.d.ts +4 -0
  195. package/flex/Flex.js +57 -0
  196. package/flex/Flex.stories.tsx +112 -0
  197. package/flex/types.d.ts +97 -0
  198. package/flex/types.js +5 -0
  199. package/footer/Footer.accessibility.test.d.ts +1 -0
  200. package/footer/Footer.accessibility.test.js +125 -0
  201. package/footer/Footer.d.ts +1 -1
  202. package/footer/Footer.js +73 -193
  203. package/footer/Footer.stories.tsx +99 -21
  204. package/footer/Footer.test.d.ts +1 -0
  205. package/footer/Footer.test.js +85 -0
  206. package/footer/Icons.d.ts +3 -2
  207. package/footer/Icons.js +54 -23
  208. package/footer/types.d.ts +26 -27
  209. package/grid/Grid.d.ts +7 -0
  210. package/grid/Grid.js +76 -0
  211. package/grid/Grid.stories.tsx +219 -0
  212. package/grid/types.d.ts +115 -0
  213. package/grid/types.js +5 -0
  214. package/header/Header.accessibility.test.d.ts +1 -0
  215. package/header/Header.accessibility.test.js +94 -0
  216. package/header/Header.d.ts +4 -3
  217. package/header/Header.js +104 -218
  218. package/header/Header.stories.tsx +168 -63
  219. package/header/Header.test.d.ts +1 -0
  220. package/header/Header.test.js +66 -0
  221. package/header/Icons.d.ts +2 -2
  222. package/header/Icons.js +5 -15
  223. package/header/types.d.ts +7 -21
  224. package/heading/Heading.accessibility.test.d.ts +1 -0
  225. package/heading/Heading.accessibility.test.js +33 -0
  226. package/heading/Heading.js +10 -32
  227. package/heading/Heading.stories.tsx +3 -2
  228. package/heading/Heading.test.d.ts +1 -0
  229. package/heading/Heading.test.js +156 -0
  230. package/heading/types.d.ts +7 -7
  231. package/icon/Icon.accessibility.test.d.ts +1 -0
  232. package/icon/Icon.accessibility.test.js +30 -0
  233. package/icon/Icon.d.ts +4 -0
  234. package/icon/Icon.js +33 -0
  235. package/icon/Icon.stories.tsx +28 -0
  236. package/icon/types.d.ts +4 -0
  237. package/icon/types.js +5 -0
  238. package/image/Image.accessibility.test.d.ts +1 -0
  239. package/image/Image.accessibility.test.js +56 -0
  240. package/image/Image.d.ts +4 -0
  241. package/image/Image.js +70 -0
  242. package/image/Image.stories.tsx +129 -0
  243. package/image/types.d.ts +72 -0
  244. package/image/types.js +5 -0
  245. package/inset/Inset.d.ts +3 -0
  246. package/inset/Inset.js +43 -0
  247. package/inset/Inset.stories.tsx +230 -0
  248. package/inset/types.d.ts +37 -0
  249. package/inset/types.js +5 -0
  250. package/layout/ApplicationLayout.d.ts +16 -6
  251. package/layout/ApplicationLayout.js +88 -176
  252. package/layout/ApplicationLayout.stories.tsx +85 -94
  253. package/layout/Icons.d.ts +7 -0
  254. package/layout/Icons.js +41 -48
  255. package/layout/types.d.ts +19 -35
  256. package/link/Link.accessibility.test.d.ts +1 -0
  257. package/link/Link.accessibility.test.js +108 -0
  258. package/link/Link.d.ts +3 -2
  259. package/link/Link.js +64 -108
  260. package/link/Link.stories.tsx +161 -54
  261. package/link/Link.test.d.ts +1 -0
  262. package/link/Link.test.js +63 -0
  263. package/link/types.d.ts +15 -35
  264. package/main.d.ts +21 -18
  265. package/main.js +90 -120
  266. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  267. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  268. package/nav-tabs/NavTabs.d.ts +7 -0
  269. package/nav-tabs/NavTabs.js +108 -0
  270. package/nav-tabs/NavTabs.stories.tsx +294 -0
  271. package/nav-tabs/NavTabs.test.d.ts +1 -0
  272. package/nav-tabs/NavTabs.test.js +77 -0
  273. package/nav-tabs/NavTabsContext.d.ts +3 -0
  274. package/nav-tabs/NavTabsContext.js +8 -0
  275. package/nav-tabs/Tab.d.ts +4 -0
  276. package/nav-tabs/Tab.js +117 -0
  277. package/nav-tabs/types.d.ts +52 -0
  278. package/nav-tabs/types.js +5 -0
  279. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  280. package/number-input/NumberInput.accessibility.test.js +228 -0
  281. package/number-input/NumberInput.js +47 -44
  282. package/number-input/NumberInput.stories.tsx +44 -28
  283. package/number-input/NumberInput.test.d.ts +1 -0
  284. package/number-input/NumberInput.test.js +989 -0
  285. package/number-input/NumberInputContext.d.ts +3 -4
  286. package/number-input/NumberInputContext.js +3 -14
  287. package/number-input/types.d.ts +34 -15
  288. package/package.json +55 -54
  289. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  290. package/paginator/Paginator.accessibility.test.js +79 -0
  291. package/paginator/Paginator.js +46 -100
  292. package/paginator/Paginator.stories.tsx +24 -0
  293. package/paginator/Paginator.test.d.ts +1 -0
  294. package/paginator/Paginator.test.js +335 -0
  295. package/paginator/types.d.ts +3 -3
  296. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  297. package/paragraph/Paragraph.accessibility.test.js +28 -0
  298. package/paragraph/Paragraph.d.ts +5 -0
  299. package/paragraph/Paragraph.js +22 -0
  300. package/paragraph/Paragraph.stories.tsx +27 -0
  301. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  302. package/password-input/PasswordInput.accessibility.test.js +153 -0
  303. package/password-input/PasswordInput.js +58 -124
  304. package/password-input/PasswordInput.stories.tsx +3 -35
  305. package/password-input/PasswordInput.test.d.ts +1 -0
  306. package/password-input/PasswordInput.test.js +198 -0
  307. package/password-input/types.d.ts +21 -17
  308. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  309. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  310. package/progress-bar/ProgressBar.js +68 -92
  311. package/progress-bar/ProgressBar.stories.tsx +93 -0
  312. package/progress-bar/ProgressBar.test.d.ts +1 -0
  313. package/progress-bar/ProgressBar.test.js +93 -0
  314. package/progress-bar/types.d.ts +3 -3
  315. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  316. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  317. package/quick-nav/QuickNav.d.ts +4 -0
  318. package/quick-nav/QuickNav.js +94 -0
  319. package/quick-nav/QuickNav.stories.tsx +356 -0
  320. package/quick-nav/types.d.ts +21 -0
  321. package/quick-nav/types.js +5 -0
  322. package/radio-group/Radio.d.ts +1 -1
  323. package/radio-group/Radio.js +77 -65
  324. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  325. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  326. package/radio-group/RadioGroup.js +156 -89
  327. package/radio-group/RadioGroup.stories.tsx +178 -20
  328. package/radio-group/RadioGroup.test.d.ts +1 -0
  329. package/radio-group/RadioGroup.test.js +754 -0
  330. package/radio-group/types.d.ts +93 -16
  331. package/resultset-table/Icons.d.ts +7 -0
  332. package/resultset-table/Icons.js +47 -0
  333. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  334. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  335. package/resultset-table/ResultsetTable.d.ts +7 -0
  336. package/resultset-table/ResultsetTable.js +171 -0
  337. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +173 -36
  338. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  339. package/resultset-table/ResultsetTable.test.js +380 -0
  340. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  341. package/resultset-table/types.js +5 -0
  342. package/select/Listbox.d.ts +4 -0
  343. package/select/Listbox.js +151 -0
  344. package/select/Option.d.ts +4 -0
  345. package/select/Option.js +89 -0
  346. package/select/Select.accessibility.test.d.ts +1 -0
  347. package/select/Select.accessibility.test.js +228 -0
  348. package/select/Select.js +239 -502
  349. package/select/Select.stories.tsx +602 -255
  350. package/select/Select.test.d.ts +1 -0
  351. package/select/Select.test.js +2268 -0
  352. package/select/types.d.ts +65 -26
  353. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  354. package/sidenav/Sidenav.accessibility.test.js +59 -0
  355. package/sidenav/Sidenav.d.ts +6 -5
  356. package/sidenav/Sidenav.js +136 -71
  357. package/sidenav/Sidenav.stories.tsx +246 -134
  358. package/sidenav/Sidenav.test.d.ts +1 -0
  359. package/sidenav/Sidenav.test.js +37 -0
  360. package/sidenav/SidenavContext.d.ts +5 -0
  361. package/sidenav/SidenavContext.js +13 -0
  362. package/sidenav/types.d.ts +52 -26
  363. package/slider/Slider.accessibility.test.d.ts +1 -0
  364. package/slider/Slider.accessibility.test.js +104 -0
  365. package/slider/Slider.d.ts +2 -2
  366. package/slider/Slider.js +147 -181
  367. package/slider/Slider.stories.tsx +68 -65
  368. package/slider/Slider.test.d.ts +1 -0
  369. package/slider/Slider.test.js +257 -0
  370. package/slider/types.d.ts +11 -3
  371. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  372. package/spinner/Spinner.accessibility.test.js +96 -0
  373. package/spinner/Spinner.js +34 -74
  374. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  375. package/spinner/Spinner.test.d.ts +1 -0
  376. package/spinner/Spinner.test.js +55 -0
  377. package/spinner/types.d.ts +3 -3
  378. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  379. package/status-light/StatusLight.accessibility.test.js +157 -0
  380. package/status-light/StatusLight.d.ts +4 -0
  381. package/status-light/StatusLight.js +51 -0
  382. package/status-light/StatusLight.stories.tsx +74 -0
  383. package/status-light/StatusLight.test.d.ts +1 -0
  384. package/status-light/StatusLight.test.js +25 -0
  385. package/status-light/types.d.ts +17 -0
  386. package/status-light/types.js +5 -0
  387. package/switch/Switch.accessibility.test.d.ts +1 -0
  388. package/switch/Switch.accessibility.test.js +98 -0
  389. package/switch/Switch.d.ts +2 -2
  390. package/switch/Switch.js +146 -114
  391. package/switch/Switch.stories.tsx +57 -68
  392. package/switch/Switch.test.d.ts +1 -0
  393. package/switch/Switch.test.js +180 -0
  394. package/switch/types.d.ts +13 -5
  395. package/table/DropdownTheme.js +62 -0
  396. package/table/Table.accessibility.test.d.ts +1 -0
  397. package/table/Table.accessibility.test.js +93 -0
  398. package/table/Table.d.ts +6 -2
  399. package/table/Table.js +78 -35
  400. package/table/Table.stories.tsx +663 -0
  401. package/table/Table.test.d.ts +1 -0
  402. package/table/Table.test.js +112 -0
  403. package/table/types.d.ts +34 -6
  404. package/tabs/Tab.d.ts +4 -0
  405. package/tabs/Tab.js +117 -0
  406. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  407. package/tabs/Tabs.accessibility.test.js +56 -0
  408. package/tabs/Tabs.d.ts +1 -1
  409. package/tabs/Tabs.js +306 -146
  410. package/tabs/Tabs.stories.tsx +127 -18
  411. package/tabs/Tabs.test.d.ts +1 -0
  412. package/tabs/Tabs.test.js +276 -0
  413. package/tabs/types.d.ts +46 -24
  414. package/tag/Tag.accessibility.test.d.ts +1 -0
  415. package/tag/Tag.accessibility.test.js +69 -0
  416. package/tag/Tag.d.ts +1 -1
  417. package/tag/Tag.js +43 -85
  418. package/tag/Tag.stories.tsx +37 -30
  419. package/tag/Tag.test.d.ts +1 -0
  420. package/tag/Tag.test.js +41 -0
  421. package/tag/types.d.ts +25 -16
  422. package/text-input/Suggestion.d.ts +4 -0
  423. package/text-input/Suggestion.js +67 -0
  424. package/text-input/Suggestions.d.ts +4 -0
  425. package/text-input/Suggestions.js +94 -0
  426. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  427. package/text-input/TextInput.accessibility.test.js +321 -0
  428. package/text-input/TextInput.js +329 -546
  429. package/text-input/TextInput.stories.tsx +290 -272
  430. package/text-input/TextInput.test.d.ts +1 -0
  431. package/text-input/TextInput.test.js +1756 -0
  432. package/text-input/types.d.ts +71 -25
  433. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  434. package/textarea/Textarea.accessibility.test.js +155 -0
  435. package/textarea/Textarea.js +85 -137
  436. package/textarea/Textarea.stories.tsx +174 -0
  437. package/textarea/Textarea.test.d.ts +1 -0
  438. package/textarea/Textarea.test.js +406 -0
  439. package/textarea/types.d.ts +27 -16
  440. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  441. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  442. package/toggle-group/ToggleGroup.d.ts +2 -2
  443. package/toggle-group/ToggleGroup.js +92 -107
  444. package/toggle-group/ToggleGroup.stories.tsx +56 -11
  445. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  446. package/toggle-group/ToggleGroup.test.js +137 -0
  447. package/toggle-group/types.d.ts +36 -19
  448. package/typography/Typography.accessibility.test.d.ts +1 -0
  449. package/typography/Typography.accessibility.test.js +339 -0
  450. package/typography/Typography.d.ts +4 -0
  451. package/typography/Typography.js +23 -0
  452. package/typography/Typography.stories.tsx +198 -0
  453. package/typography/types.d.ts +18 -0
  454. package/typography/types.js +5 -0
  455. package/useTheme.d.ts +1142 -1
  456. package/useTheme.js +4 -11
  457. package/useTranslatedLabels.d.ts +85 -0
  458. package/useTranslatedLabels.js +14 -0
  459. package/utils/BaseTypography.d.ts +21 -0
  460. package/utils/BaseTypography.js +94 -0
  461. package/utils/FocusLock.d.ts +13 -0
  462. package/utils/FocusLock.js +124 -0
  463. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  464. package/wizard/Wizard.accessibility.test.js +55 -0
  465. package/wizard/Wizard.d.ts +1 -1
  466. package/wizard/Wizard.js +78 -120
  467. package/wizard/Wizard.stories.tsx +67 -19
  468. package/wizard/Wizard.test.d.ts +1 -0
  469. package/wizard/Wizard.test.js +114 -0
  470. package/wizard/types.d.ts +14 -10
  471. package/ThemeContext.d.ts +0 -15
  472. package/ThemeContext.js +0 -243
  473. package/V3Select/V3Select.js +0 -455
  474. package/V3Select/index.d.ts +0 -27
  475. package/V3Textarea/V3Textarea.js +0 -260
  476. package/V3Textarea/index.d.ts +0 -27
  477. package/card/ice-cream.jpg +0 -0
  478. package/common/OpenSans.css +0 -81
  479. package/common/RequiredComponent.js +0 -32
  480. package/common/fonts/OpenSans-Bold.ttf +0 -0
  481. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  482. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  483. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  484. package/common/fonts/OpenSans-Italic.ttf +0 -0
  485. package/common/fonts/OpenSans-Light.ttf +0 -0
  486. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  487. package/common/fonts/OpenSans-Regular.ttf +0 -0
  488. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  489. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  490. package/date/Date.js +0 -373
  491. package/date/index.d.ts +0 -27
  492. package/input-text/Icons.js +0 -22
  493. package/input-text/InputText.js +0 -611
  494. package/input-text/index.d.ts +0 -36
  495. package/list/List.d.ts +0 -8
  496. package/list/List.js +0 -47
  497. package/list/List.stories.tsx +0 -95
  498. package/number-input/numberInputContextTypes.d.ts +0 -19
  499. package/paginator/Icons.js +0 -66
  500. package/progress-bar/ProgressBar.stories.jsx +0 -58
  501. package/radio/Radio.d.ts +0 -4
  502. package/radio/Radio.js +0 -174
  503. package/radio/Radio.stories.tsx +0 -192
  504. package/radio/types.d.ts +0 -54
  505. package/resultsetTable/ResultsetTable.d.ts +0 -4
  506. package/resultsetTable/ResultsetTable.js +0 -251
  507. package/row/Row.d.ts +0 -11
  508. package/row/Row.js +0 -127
  509. package/row/Row.stories.tsx +0 -239
  510. package/stack/Stack.d.ts +0 -10
  511. package/stack/Stack.js +0 -97
  512. package/stack/Stack.stories.tsx +0 -166
  513. package/table/Table.stories.jsx +0 -276
  514. package/text/Text.d.ts +0 -7
  515. package/text/Text.js +0 -30
  516. package/text/Text.stories.tsx +0 -19
  517. package/textarea/Textarea.stories.jsx +0 -135
  518. package/toggle/Toggle.js +0 -186
  519. package/toggle/index.d.ts +0 -21
  520. package/upload/Upload.js +0 -201
  521. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  522. package/upload/buttons-upload/Icons.js +0 -40
  523. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  524. package/upload/dragAndDropArea/Icons.js +0 -39
  525. package/upload/file-upload/FileToUpload.js +0 -115
  526. package/upload/file-upload/Icons.js +0 -66
  527. package/upload/files-upload/FilesToUpload.js +0 -109
  528. package/upload/index.d.ts +0 -15
  529. package/upload/transaction/Icons.js +0 -160
  530. package/upload/transaction/Transaction.js +0 -104
  531. package/upload/transactions/Transactions.js +0 -94
  532. /package/{radio → action-icon}/types.js +0 -0
  533. /package/{resultsetTable → badge}/types.js +0 -0
  534. /package/{number-input/numberInputContextTypes.js → bleed/types.js} +0 -0
package/layout/Icons.js CHANGED
@@ -1,55 +1,48 @@
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
- exports.twitterLogo = exports.linkedinLogo = exports.facebookLogo = void 0;
9
-
7
+ exports["default"] = void 0;
10
8
  var _react = _interopRequireDefault(require("react"));
11
-
12
- var facebookLogo = /*#__PURE__*/_react["default"].createElement("svg", {
13
- version: "1.1",
14
- id: "Capa_1",
15
- x: "0px",
16
- y: "0px",
17
- width: "438.536px",
18
- height: "438.536px",
19
- viewBox: "0 0 438.536 438.536",
20
- fill: "#FFFFFF"
21
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
22
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
23
- })));
24
-
25
- exports.facebookLogo = facebookLogo;
26
-
27
- var twitterLogo = /*#__PURE__*/_react["default"].createElement("svg", {
28
- version: "1.1",
29
- id: "Capa_1",
30
- x: "0px",
31
- y: "0px",
32
- width: "438.536px",
33
- height: "438.536px",
34
- viewBox: "0 0 438.536 438.536",
35
- fill: "#FFFFFF"
36
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
37
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M335.471,168.735c0.191,1.713,0.288,4.278,0.288,7.71 c0,15.989-2.334,32.025-6.995,48.104c-4.661,16.087-11.8,31.504-21.416,46.254c-9.606,14.749-21.074,27.791-34.396,39.115 c-13.325,11.32-29.311,20.365-47.968,27.117c-18.648,6.762-38.637,10.143-59.953,10.143c-33.116,0-63.76-8.952-91.931-26.836 c4.568,0.568,9.329,0.855,14.275,0.855c27.6,0,52.439-8.565,74.519-25.7c-12.941-0.185-24.506-4.179-34.688-11.991 c-10.185-7.803-17.273-17.699-21.271-29.691c4.947,0.76,8.658,1.137,11.132,1.137c4.187,0,9.042-0.76,14.56-2.279 c-13.894-2.669-25.598-9.562-35.115-20.697c-9.519-11.136-14.277-23.84-14.277-38.114v-0.571 c10.085,4.755,19.602,7.229,28.549,7.422c-17.321-11.613-25.981-28.265-25.981-49.963c0-10.66,2.758-20.747,8.278-30.264 c15.035,18.464,33.311,33.213,54.816,44.252c21.507,11.038,44.54,17.227,69.092,18.558c-0.95-3.616-1.427-8.186-1.427-13.704 c0-16.562,5.853-30.692,17.56-42.399c11.703-11.706,25.837-17.561,42.394-17.561c17.515,0,32.079,6.283,43.688,18.846 c13.134-2.474,25.892-7.33,38.26-14.56c-4.757,14.652-13.613,25.788-26.55,33.402c12.368-1.716,23.88-4.95,34.537-9.708 C357.458,149.793,347.462,160.166,335.471,168.735z"
38
- })));
39
-
40
- exports.twitterLogo = twitterLogo;
41
-
42
- var linkedinLogo = /*#__PURE__*/_react["default"].createElement("svg", {
43
- version: "1.1",
44
- id: "Capa_1",
45
- x: "0px",
46
- y: "0px",
47
- width: "438.536px",
48
- height: "438.536px",
49
- viewBox: "0 0 438.536 438.536",
50
- fill: "#FFFFFF"
51
- }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
52
- d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
53
- })));
54
-
55
- exports.linkedinLogo = linkedinLogo;
9
+ var layoutIcons = {
10
+ facebookLogo: /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "#FFFFFF"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402 c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401 c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ }))),
21
+ xLogo: /*#__PURE__*/_react["default"].createElement("svg", {
22
+ width: "256",
23
+ height: "256",
24
+ viewBox: "0 0 256 256",
25
+ fill: "none",
26
+ xmlns: "http://www.w3.org/2000/svg"
27
+ }, /*#__PURE__*/_react["default"].createElement("rect", {
28
+ width: "256",
29
+ height: "256",
30
+ rx: "40",
31
+ fill: "white"
32
+ }), /*#__PURE__*/_react["default"].createElement("path", {
33
+ d: "M140.192 118.205L187.848 64H176.556L135.158 111.056L102.117 64H64L113.975 135.163L64 192H75.2914L118.982 142.296L153.883 192H192L140.192 118.205ZM124.722 135.787L119.65 128.697L79.3634 72.3294H96.7094L129.232 117.837L134.282 124.927L176.551 184.076H159.205L124.722 135.787Z",
34
+ fill: "#0F1419"
35
+ })),
36
+ linkedinLogo: /*#__PURE__*/_react["default"].createElement("svg", {
37
+ version: "1.1",
38
+ x: "0px",
39
+ y: "0px",
40
+ width: "438.536px",
41
+ height: "438.536px",
42
+ viewBox: "0 0 438.536 438.536",
43
+ fill: "#FFFFFF"
44
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
45
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123 C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126 h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225 C438.532,59.576,430.49,40.204,414.41,24.123z M133.618,367.157H67.666V169.016h65.952V367.157z M127.626,132.332 c-6.851,6.567-15.893,9.851-27.124,9.851h-0.288c-10.848,0-19.648-3.284-26.407-9.851c-6.76-6.567-10.138-14.703-10.138-24.41 c0-9.897,3.476-18.083,10.421-24.556c6.95-6.471,15.942-9.708,26.98-9.708c11.039,0,19.89,3.237,26.553,9.708 c6.661,6.473,10.088,14.659,10.277,24.556C137.899,117.625,134.477,125.761,127.626,132.332z M370.873,367.157h-65.952v-105.92 c0-29.879-11.036-44.823-33.116-44.823c-8.374,0-15.42,2.331-21.128,6.995c-5.715,4.661-9.996,10.324-12.847,16.991 c-1.335,3.422-1.999,8.75-1.999,15.981v110.775h-65.952c0.571-119.529,0.571-185.579,0-198.142h65.952v27.974 c13.867-21.681,33.558-32.544,59.101-32.544c22.84,0,41.21,7.52,55.104,22.554c13.895,15.037,20.841,37.214,20.841,66.519v113.64 H370.873z"
46
+ })))
47
+ };
48
+ var _default = exports["default"] = layoutIcons;
package/layout/types.d.ts CHANGED
@@ -1,57 +1,41 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Padding = {
4
- top?: Space;
5
- bottom?: Space;
6
- left?: Space;
7
- right?: Space;
8
- };
9
- declare type ChildrenType = AppLayoutHeaderPropsType | AppLayoutMainPropsType | AppLayoutFooterPropsType | AppLayoutSidenavPropsType;
10
- export declare type AppLayoutHeaderPropsType = {
2
+ export type AppLayoutMainPropsType = {
11
3
  /**
12
- * Everything between this tags will be displayed as a header, at the top of the screen.
13
- * This is optional and if it is not specified, the DxcHeader will be shown by default.
4
+ * Everything between the tags will be displayed as the content of the main part of the application.
14
5
  */
15
- children?: React.ReactNode;
6
+ children: React.ReactNode;
16
7
  };
17
- export declare type AppLayoutMainPropsType = {
8
+ export type AppLayoutSidenavPropsType = {
18
9
  /**
19
- * Everything between the tags will be displayed as the content of the main part of the application.
10
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
20
11
  */
21
12
  children: React.ReactNode;
22
- };
23
- export declare type AppLayoutFooterPropsType = {
24
13
  /**
25
- * Everything between the tags will be displayed as a footer, at the bottom of the screen.
26
- * This is optional and if it is not specified, the DxcFooter will be shown by default.
14
+ * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
27
15
  */
28
- children?: React.ReactNode;
16
+ title?: React.ReactNode;
29
17
  };
30
- export declare type AppLayoutSidenavPropsType = {
18
+ type AppLayoutPropsType = {
31
19
  /**
32
- * Size of the padding to be applied to the custom area ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
33
- * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
20
+ * Text to be placed next to the hamburger button that toggles the
21
+ * visibility of the sidenav.
34
22
  */
35
- padding?: Space | Padding;
23
+ visibilityToggleLabel?: string;
36
24
  /**
37
- * The area inside the sidenav. This area can be used to render custom content.
25
+ * Header content.
38
26
  */
39
- children: React.ReactNode;
27
+ header?: React.ReactNode;
40
28
  /**
41
- * If false, the arrow button is hidden.
42
- * In lower resolutions the arrow will be always displayed.
29
+ * Sidenav content
43
30
  */
44
- displayArrow?: boolean;
31
+ sidenav?: React.ReactNode;
45
32
  /**
46
- * Default action over the content of the page, overlay the content or push to the right ('push' | 'overlay').
47
- * In lower resolutions the mode will always be overlay.
33
+ * Footer content
48
34
  */
49
- mode: "push" | "overlay";
50
- };
51
- declare type AppLayoutPropsType = {
35
+ footer?: React.ReactNode;
52
36
  /**
53
- * The area inside the sidenav. This area can be used to render custom content.
37
+ * Use the DxcApplicationLayout.Main provided to render main content.
54
38
  */
55
- children: React.ReactElement<ChildrenType> | React.ReactElement<ChildrenType>[];
39
+ children: React.ReactElement<AppLayoutMainPropsType>;
56
40
  };
57
41
  export default AppLayoutPropsType;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,108 @@
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 _Link = _interopRequireDefault(require("./Link"));
10
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
11
+ var icon = /*#__PURE__*/_react["default"].createElement("svg", {
12
+ viewBox: "0 0 24 24",
13
+ enableBackground: "new 0 0 24 24",
14
+ fill: "currentColor"
15
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("rect", {
16
+ fill: "none",
17
+ width: "24",
18
+ height: "24"
19
+ })), /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
20
+ d: "M19,9.3V4h-3v2.6L12,3L2,12h3v8h5v-6h4v6h5v-8h3L19,9.3z M10,10c0-1.1,0.9-2,2-2s2,0.9,2,2H10z"
21
+ })));
22
+ describe("Link component accessibility tests", function () {
23
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
24
+ var _render, container, results;
25
+ return _regenerator["default"].wrap(function _callee$(_context) {
26
+ while (1) switch (_context.prev = _context.next) {
27
+ case 0:
28
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
29
+ href: "https://www.google.com",
30
+ icon: icon,
31
+ iconPosition: "before",
32
+ margin: "medium"
33
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
34
+ href: "https://www.google.com",
35
+ icon: icon,
36
+ iconPosition: "after",
37
+ margin: "medium"
38
+ }, "Link"))), container = _render.container;
39
+ _context.next = 3;
40
+ return (0, _axeHelper.axe)(container);
41
+ case 3:
42
+ results = _context.sent;
43
+ expect(results).toHaveNoViolations();
44
+ case 5:
45
+ case "end":
46
+ return _context.stop();
47
+ }
48
+ }, _callee);
49
+ })));
50
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
51
+ var _render2, container, results;
52
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
53
+ while (1) switch (_context2.prev = _context2.next) {
54
+ case 0:
55
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
56
+ href: "https://www.google.com",
57
+ icon: icon,
58
+ iconPosition: "before",
59
+ margin: "medium",
60
+ disabled: true
61
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
62
+ href: "https://www.google.com",
63
+ icon: icon,
64
+ iconPosition: "after",
65
+ margin: "medium",
66
+ disabled: true
67
+ }, "Link"))), container = _render2.container;
68
+ _context2.next = 3;
69
+ return (0, _axeHelper.axe)(container);
70
+ case 3:
71
+ results = _context2.sent;
72
+ expect(results).toHaveNoViolations();
73
+ case 5:
74
+ case "end":
75
+ return _context2.stop();
76
+ }
77
+ }, _callee2);
78
+ })));
79
+ it("Should not have basic accessibility issues for new-window mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
80
+ var _render3, container, results;
81
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
82
+ while (1) switch (_context3.prev = _context3.next) {
83
+ case 0:
84
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
85
+ href: "https://www.google.com",
86
+ icon: icon,
87
+ iconPosition: "before",
88
+ margin: "medium",
89
+ newWindow: true
90
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
91
+ href: "https://www.google.com",
92
+ icon: icon,
93
+ iconPosition: "after",
94
+ margin: "medium",
95
+ newWindow: true
96
+ }, "Link"))), container = _render3.container;
97
+ _context3.next = 3;
98
+ return (0, _axeHelper.axe)(container);
99
+ case 3:
100
+ results = _context3.sent;
101
+ expect(results).toHaveNoViolations();
102
+ case 5:
103
+ case "end":
104
+ return _context3.stop();
105
+ }
106
+ }, _callee3);
107
+ })));
108
+ });
package/link/Link.d.ts CHANGED
@@ -1,3 +1,4 @@
1
- import Overload from "./types";
2
- declare const DxcLink: Overload;
1
+ import React from "react";
2
+ import { LinkProps } from "./types";
3
+ declare const DxcLink: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
3
4
  export default DxcLink;
package/link/Link.js CHANGED
@@ -1,83 +1,72 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
9
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
-
16
- var _react = _interopRequireDefault(require("react"));
17
-
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+ var _react = _interopRequireWildcard(require("react"));
18
14
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _variables = require("../common/variables.js");
21
-
15
+ var _variables = require("../common/variables");
22
16
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
-
24
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6;
25
-
26
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
27
-
28
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
-
30
- var DxcLink = function DxcLink(_ref) {
31
- var _ref$inheritColor = _ref.inheritColor,
32
- inheritColor = _ref$inheritColor === void 0 ? false : _ref$inheritColor,
33
- _ref$disabled = _ref.disabled,
34
- disabled = _ref$disabled === void 0 ? false : _ref$disabled,
35
- iconSrc = _ref.iconSrc,
36
- icon = _ref.icon,
37
- _ref$iconPosition = _ref.iconPosition,
38
- iconPosition = _ref$iconPosition === void 0 ? "before" : _ref$iconPosition,
39
- _ref$href = _ref.href,
40
- href = _ref$href === void 0 ? "" : _ref$href,
41
- _ref$newWindow = _ref.newWindow,
42
- newWindow = _ref$newWindow === void 0 ? false : _ref$newWindow,
43
- onClick = _ref.onClick,
44
- _ref$text = _ref.text,
45
- text = _ref$text === void 0 ? "" : _ref$text,
46
- margin = _ref.margin,
47
- _ref$tabIndex = _ref.tabIndex,
48
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
49
- var colorsTheme = (0, _useTheme["default"])();
50
-
51
- var linkContent = /*#__PURE__*/_react["default"].createElement(LinkText, {
52
- iconPosition: iconPosition
53
- }, text, icon ? /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
17
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
18
+ var _templateObject, _templateObject2;
19
+ var _excluded = ["inheritColor", "disabled", "icon", "iconPosition", "href", "newWindow", "onClick", "margin", "tabIndex", "children"];
20
+ 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); }
21
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(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; }
22
+ var LinkContent = /*#__PURE__*/_react["default"].memo(function (_ref) {
23
+ var iconPosition = _ref.iconPosition,
24
+ icon = _ref.icon,
25
+ children = _ref.children;
26
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
54
27
  iconPosition: iconPosition
55
- }, (0, _typeof2["default"])(icon) === "object" ? icon : /*#__PURE__*/_react["default"].createElement(icon)) : iconSrc && /*#__PURE__*/_react["default"].createElement(LinkIcon, {
56
- src: iconSrc,
57
- iconPosition: iconPosition
58
- }));
59
-
28
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
29
+ icon: icon
30
+ }) : icon), iconPosition === "before" && children);
31
+ });
32
+ var DxcLink = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
33
+ var _ref2$inheritColor = _ref2.inheritColor,
34
+ inheritColor = _ref2$inheritColor === void 0 ? false : _ref2$inheritColor,
35
+ _ref2$disabled = _ref2.disabled,
36
+ disabled = _ref2$disabled === void 0 ? false : _ref2$disabled,
37
+ icon = _ref2.icon,
38
+ _ref2$iconPosition = _ref2.iconPosition,
39
+ iconPosition = _ref2$iconPosition === void 0 ? "before" : _ref2$iconPosition,
40
+ _ref2$href = _ref2.href,
41
+ href = _ref2$href === void 0 ? "" : _ref2$href,
42
+ _ref2$newWindow = _ref2.newWindow,
43
+ newWindow = _ref2$newWindow === void 0 ? false : _ref2$newWindow,
44
+ onClick = _ref2.onClick,
45
+ margin = _ref2.margin,
46
+ _ref2$tabIndex = _ref2.tabIndex,
47
+ tabIndex = _ref2$tabIndex === void 0 ? 0 : _ref2$tabIndex,
48
+ children = _ref2.children,
49
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
50
+ var colorsTheme = (0, _useTheme["default"])();
60
51
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
61
52
  theme: colorsTheme.link
62
- }, /*#__PURE__*/_react["default"].createElement(DxcLinkContainer, {
63
- margin: margin
64
- }, onClick ? /*#__PURE__*/_react["default"].createElement(StyledButton, {
65
- type: "button",
66
- onClick: !disabled && onClick,
67
- margin: margin,
68
- disabled: disabled,
69
- inheritColor: inheritColor
70
- }, linkContent) : /*#__PURE__*/_react["default"].createElement(StyledLink, {
53
+ }, /*#__PURE__*/_react["default"].createElement(StyledLink, (0, _extends2["default"])({
54
+ as: href ? "a" : "button",
71
55
  tabIndex: tabIndex,
72
- href: !disabled && href,
73
- target: newWindow ? "_blank" : "_self",
74
- margin: margin,
56
+ onClick: !disabled ? onClick : undefined,
57
+ href: !disabled && href ? href : undefined,
58
+ target: href ? newWindow ? "_blank" : "_self" : undefined,
75
59
  disabled: disabled,
76
- inheritColor: inheritColor
77
- }, linkContent)));
78
- };
79
-
80
- var DxcLinkContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
60
+ inheritColor: inheritColor,
61
+ margin: margin,
62
+ ref: ref
63
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(LinkContent, {
64
+ iconPosition: iconPosition,
65
+ icon: icon,
66
+ children: children
67
+ })));
68
+ });
69
+ var StyledLink = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: baseline;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n text-decoration-color: transparent;\n width: fit-content;\n ", "\n ", "\n color: ", ";\n ", "\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
81
70
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
82
71
  }, function (props) {
83
72
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -87,36 +76,26 @@ var DxcLinkContainer = _styledComponents["default"].div(_templateObject || (_tem
87
76
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
88
77
  }, function (props) {
89
78
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
90
- });
91
-
92
- var StyledLink = _styledComponents["default"].a(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n ", "\n\n text-decoration-color: transparent;\n ", "\n\n &:visited {\n color: ", ";\n &:hover {\n ", "\n }\n }\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
93
- return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
94
- }, function (props) {
95
- return props.disabled ? "pointer-events: none;" : "";
96
- }, function (props) {
97
- return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
98
79
  }, function (props) {
99
- return !props.inheritColor ? props.theme.visitedFontColor : "";
100
- }, function (props) {
101
- return "color: ".concat(props.theme.visitedFontColor, ";\n border-bottom-color: ").concat(props.theme.visitedUnderlineColor, ";");
80
+ return props.theme.fontSize;
102
81
  }, function (props) {
103
- return "color: ".concat(props.theme.hoverFontColor, ";\n border-bottom-color: ").concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
82
+ return props.theme.fontWeight;
104
83
  }, function (props) {
105
- return props.theme.focusColor;
84
+ return props.theme.fontStyle;
106
85
  }, function (props) {
107
- return props.disabled && "outline: none";
86
+ return props.theme.fontFamily;
108
87
  }, function (props) {
109
- return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
110
- });
111
-
112
- var StyledButton = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n font-family: inherit;\n text-decoration-color: transparent;\n\n ", "\n ", "\n color: ", ";\n ", "\n\n &:hover {\n ", "\n }\n &:focus {\n border-radius: 2px;\n outline: 2px solid ", ";\n ", "\n }\n &:active {\n ", "\n }\n"])), function (props) {
113
88
  return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
114
89
  }, function (props) {
115
90
  return props.disabled && "cursor: default;";
116
91
  }, function (props) {
117
- return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledColor;
92
+ return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledFontColor;
118
93
  }, function (props) {
119
94
  return props.disabled ? "pointer-events: none;" : "";
95
+ }, function (props) {
96
+ return !props.inheritColor && !props.disabled ? props.theme.visitedFontColor : "";
97
+ }, function (props) {
98
+ return "color: ".concat(props.theme.visitedFontColor, ";\n border-bottom-color: ").concat(props.theme.visitedUnderlineColor, ";");
120
99
  }, function (props) {
121
100
  return "color: ".concat(props.theme.hoverFontColor, ";\n border-bottom-color: ").concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
122
101
  }, function (props) {
@@ -126,36 +105,13 @@ var StyledButton = _styledComponents["default"].button(_templateObject3 || (_tem
126
105
  }, function (props) {
127
106
  return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
128
107
  });
129
-
130
- var LinkText = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n font-family: ", ";\n display: inline-flex;\n flex-direction: ", ";\n justify-content: ", ";\n align-items: center;\n max-width: 100%;\n"])), function (props) {
131
- return props.theme.fontSize;
132
- }, function (props) {
133
- return props.theme.fontWeight;
134
- }, function (props) {
135
- return props.theme.fontStyle;
136
- }, function (props) {
137
- return props.theme.fontFamily;
138
- }, function (props) {
139
- return props.iconPosition === "after" ? "row" : "row-reverse";
140
- }, function (props) {
141
- return props.iconPosition === "after" ? "flex-start" : "flex-end";
142
- });
143
-
144
- var LinkIcon = _styledComponents["default"].img(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n"])), function (props) {
108
+ var LinkIconContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n font-size: ", ";\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
145
109
  return props.theme.iconSize;
146
110
  }, function (props) {
147
111
  return props.theme.iconSize;
148
112
  }, function (props) {
149
113
  return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
150
- });
151
-
152
- var LinkIconContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
153
- return props.theme.iconSize;
154
114
  }, function (props) {
155
115
  return props.theme.iconSize;
156
- }, function (props) {
157
- return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
158
116
  });
159
-
160
- var _default = DxcLink;
161
- exports["default"] = _default;
117
+ var _default = exports["default"] = DxcLink;