@dxc-technology/halstack-react 0.0.0-957bfad → 0.0.0-95b5b84

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 (601) 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 +159 -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 +121 -0
  87. package/chip/Chip.stories.tsx +213 -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 +223 -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 +115 -0
  120. package/date-input/Icons.d.ts +6 -0
  121. package/date-input/Icons.js +58 -0
  122. package/date-input/YearPicker.d.ts +4 -0
  123. package/date-input/YearPicker.js +100 -0
  124. package/date-input/types.d.ts +164 -0
  125. package/date-input/types.js +5 -0
  126. package/dialog/Dialog.accessibility.test.js +69 -0
  127. package/dialog/Dialog.d.ts +4 -0
  128. package/dialog/Dialog.js +104 -0
  129. package/dialog/Dialog.stories.tsx +365 -0
  130. package/dialog/Dialog.test.js +307 -0
  131. package/dialog/types.d.ts +36 -0
  132. package/dialog/types.js +5 -0
  133. package/divider/Divider.accessibility.test.js +33 -0
  134. package/divider/Divider.d.ts +4 -0
  135. package/divider/Divider.js +36 -0
  136. package/divider/Divider.stories.tsx +223 -0
  137. package/divider/Divider.test.js +38 -0
  138. package/divider/types.d.ts +21 -0
  139. package/divider/types.js +5 -0
  140. package/dropdown/Dropdown.accessibility.test.js +180 -0
  141. package/dropdown/Dropdown.d.ts +4 -0
  142. package/dropdown/Dropdown.js +319 -0
  143. package/dropdown/Dropdown.stories.tsx +427 -0
  144. package/dropdown/Dropdown.test.js +599 -0
  145. package/dropdown/DropdownMenu.d.ts +4 -0
  146. package/dropdown/DropdownMenu.js +63 -0
  147. package/dropdown/DropdownMenuItem.d.ts +4 -0
  148. package/dropdown/DropdownMenuItem.js +70 -0
  149. package/dropdown/types.d.ts +96 -0
  150. package/dropdown/types.js +5 -0
  151. package/file-input/FileInput.accessibility.test.js +160 -0
  152. package/file-input/FileInput.d.ts +4 -0
  153. package/file-input/FileInput.js +479 -0
  154. package/file-input/FileInput.stories.tsx +618 -0
  155. package/file-input/FileInput.test.js +459 -0
  156. package/file-input/FileItem.d.ts +4 -0
  157. package/file-input/FileItem.js +135 -0
  158. package/file-input/types.d.ts +129 -0
  159. package/file-input/types.js +5 -0
  160. package/flex/Flex.d.ts +4 -0
  161. package/flex/Flex.js +57 -0
  162. package/flex/Flex.stories.tsx +112 -0
  163. package/flex/types.d.ts +97 -0
  164. package/flex/types.js +5 -0
  165. package/footer/Footer.accessibility.test.js +117 -0
  166. package/footer/Footer.d.ts +4 -0
  167. package/footer/Footer.js +138 -0
  168. package/footer/Footer.stories.tsx +170 -0
  169. package/footer/Footer.test.js +85 -0
  170. package/footer/Icons.d.ts +3 -0
  171. package/footer/Icons.js +136 -0
  172. package/footer/types.d.ts +64 -0
  173. package/footer/types.js +5 -0
  174. package/grid/Grid.d.ts +7 -0
  175. package/grid/Grid.js +76 -0
  176. package/grid/Grid.stories.tsx +219 -0
  177. package/grid/types.d.ts +115 -0
  178. package/grid/types.js +5 -0
  179. package/header/Header.accessibility.test.js +84 -0
  180. package/header/Header.d.ts +8 -0
  181. package/header/Header.js +220 -0
  182. package/header/Header.stories.tsx +251 -0
  183. package/header/Header.test.js +66 -0
  184. package/header/Icons.d.ts +2 -0
  185. package/header/Icons.js +29 -0
  186. package/header/types.d.ts +33 -0
  187. package/header/types.js +5 -0
  188. package/heading/Heading.accessibility.test.js +33 -0
  189. package/heading/Heading.d.ts +4 -0
  190. package/heading/Heading.js +137 -0
  191. package/heading/Heading.stories.tsx +54 -0
  192. package/heading/Heading.test.js +169 -0
  193. package/heading/types.d.ts +33 -0
  194. package/heading/types.js +5 -0
  195. package/icon/Icon.accessibility.test.js +30 -0
  196. package/icon/Icon.d.ts +4 -0
  197. package/icon/Icon.js +33 -0
  198. package/icon/Icon.stories.tsx +28 -0
  199. package/icon/types.d.ts +4 -0
  200. package/icon/types.js +5 -0
  201. package/image/Image.accessibility.test.js +56 -0
  202. package/image/Image.d.ts +4 -0
  203. package/image/Image.js +70 -0
  204. package/image/Image.stories.tsx +129 -0
  205. package/image/types.d.ts +72 -0
  206. package/image/types.js +5 -0
  207. package/inset/Inset.d.ts +3 -0
  208. package/inset/Inset.js +43 -0
  209. package/inset/Inset.stories.tsx +230 -0
  210. package/inset/types.d.ts +37 -0
  211. package/inset/types.js +5 -0
  212. package/layout/ApplicationLayout.d.ts +20 -0
  213. package/layout/ApplicationLayout.js +134 -0
  214. package/layout/ApplicationLayout.stories.tsx +162 -0
  215. package/layout/Icons.d.ts +8 -0
  216. package/layout/Icons.js +56 -0
  217. package/layout/types.d.ts +41 -0
  218. package/layout/types.js +5 -0
  219. package/link/Link.accessibility.test.js +112 -0
  220. package/link/Link.d.ts +4 -0
  221. package/link/Link.js +115 -0
  222. package/link/Link.stories.tsx +253 -0
  223. package/link/Link.test.js +63 -0
  224. package/link/types.d.ts +54 -0
  225. package/link/types.js +5 -0
  226. package/main.d.ts +49 -0
  227. package/main.js +357 -0
  228. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  229. package/nav-tabs/NavTabs.d.ts +7 -0
  230. package/nav-tabs/NavTabs.js +93 -0
  231. package/nav-tabs/NavTabs.stories.tsx +276 -0
  232. package/nav-tabs/NavTabs.test.js +76 -0
  233. package/nav-tabs/NavTabsContext.d.ts +3 -0
  234. package/nav-tabs/NavTabsContext.js +8 -0
  235. package/nav-tabs/Tab.d.ts +4 -0
  236. package/nav-tabs/Tab.js +118 -0
  237. package/nav-tabs/types.d.ts +52 -0
  238. package/nav-tabs/types.js +5 -0
  239. package/number-input/NumberInput.accessibility.test.js +228 -0
  240. package/number-input/NumberInput.d.ts +4 -0
  241. package/number-input/NumberInput.js +86 -0
  242. package/number-input/NumberInput.stories.tsx +131 -0
  243. package/number-input/NumberInput.test.js +989 -0
  244. package/number-input/NumberInputContext.d.ts +3 -0
  245. package/number-input/NumberInputContext.js +8 -0
  246. package/number-input/types.d.ts +136 -0
  247. package/number-input/types.js +5 -0
  248. package/package.json +65 -49
  249. package/paginator/Icons.d.ts +5 -0
  250. package/paginator/Icons.js +40 -0
  251. package/paginator/Paginator.accessibility.test.js +79 -0
  252. package/paginator/Paginator.d.ts +4 -0
  253. package/paginator/Paginator.js +135 -0
  254. package/paginator/Paginator.stories.tsx +87 -0
  255. package/paginator/Paginator.test.js +335 -0
  256. package/paginator/types.d.ts +38 -0
  257. package/paginator/types.js +5 -0
  258. package/paragraph/Paragraph.accessibility.test.js +28 -0
  259. package/paragraph/Paragraph.d.ts +5 -0
  260. package/paragraph/Paragraph.js +22 -0
  261. package/paragraph/Paragraph.stories.tsx +27 -0
  262. package/password-input/Icons.d.ts +6 -0
  263. package/password-input/Icons.js +35 -0
  264. package/password-input/PasswordInput.accessibility.test.js +153 -0
  265. package/password-input/PasswordInput.d.ts +4 -0
  266. package/password-input/PasswordInput.js +97 -0
  267. package/password-input/PasswordInput.stories.tsx +99 -0
  268. package/password-input/PasswordInput.test.js +198 -0
  269. package/password-input/types.d.ts +111 -0
  270. package/password-input/types.js +5 -0
  271. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  272. package/progress-bar/ProgressBar.d.ts +4 -0
  273. package/progress-bar/ProgressBar.js +144 -0
  274. package/progress-bar/ProgressBar.stories.tsx +93 -0
  275. package/progress-bar/ProgressBar.test.js +93 -0
  276. package/progress-bar/types.d.ts +37 -0
  277. package/progress-bar/types.js +5 -0
  278. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  279. package/quick-nav/QuickNav.d.ts +4 -0
  280. package/quick-nav/QuickNav.js +94 -0
  281. package/quick-nav/QuickNav.stories.tsx +356 -0
  282. package/quick-nav/types.d.ts +21 -0
  283. package/quick-nav/types.js +5 -0
  284. package/radio-group/Radio.d.ts +4 -0
  285. package/radio-group/Radio.js +124 -0
  286. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  287. package/radio-group/RadioGroup.d.ts +4 -0
  288. package/radio-group/RadioGroup.js +235 -0
  289. package/radio-group/RadioGroup.stories.tsx +214 -0
  290. package/radio-group/RadioGroup.test.js +756 -0
  291. package/radio-group/types.d.ts +114 -0
  292. package/radio-group/types.js +5 -0
  293. package/resultset-table/Icons.d.ts +7 -0
  294. package/resultset-table/Icons.js +47 -0
  295. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  296. package/resultset-table/ResultsetTable.d.ts +7 -0
  297. package/resultset-table/ResultsetTable.js +170 -0
  298. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  299. package/resultset-table/ResultsetTable.test.js +381 -0
  300. package/resultset-table/types.d.ts +100 -0
  301. package/resultset-table/types.js +5 -0
  302. package/select/Icons.d.ts +10 -0
  303. package/select/Icons.js +89 -0
  304. package/select/Listbox.d.ts +4 -0
  305. package/select/Listbox.js +143 -0
  306. package/select/Option.d.ts +4 -0
  307. package/select/Option.js +87 -0
  308. package/select/Select.accessibility.test.js +217 -0
  309. package/select/Select.d.ts +4 -0
  310. package/select/Select.js +590 -0
  311. package/select/Select.stories.tsx +970 -0
  312. package/select/Select.test.js +2370 -0
  313. package/select/types.d.ts +209 -0
  314. package/select/types.js +5 -0
  315. package/sidenav/Icons.d.ts +7 -0
  316. package/sidenav/Icons.js +47 -0
  317. package/sidenav/Sidenav.accessibility.test.js +59 -0
  318. package/sidenav/Sidenav.d.ts +10 -0
  319. package/sidenav/Sidenav.js +197 -0
  320. package/sidenav/Sidenav.stories.tsx +281 -0
  321. package/sidenav/Sidenav.test.js +37 -0
  322. package/sidenav/SidenavContext.d.ts +5 -0
  323. package/sidenav/SidenavContext.js +13 -0
  324. package/sidenav/types.d.ts +76 -0
  325. package/sidenav/types.js +5 -0
  326. package/slider/Slider.accessibility.test.js +104 -0
  327. package/slider/Slider.d.ts +4 -0
  328. package/slider/Slider.js +285 -0
  329. package/slider/Slider.test.js +254 -0
  330. package/slider/types.d.ts +86 -0
  331. package/slider/types.js +5 -0
  332. package/spinner/Spinner.accessibility.test.js +96 -0
  333. package/spinner/Spinner.d.ts +4 -0
  334. package/spinner/Spinner.js +206 -0
  335. package/spinner/Spinner.stories.tsx +129 -0
  336. package/spinner/Spinner.test.js +55 -0
  337. package/spinner/types.d.ts +32 -0
  338. package/spinner/types.js +5 -0
  339. package/status-light/StatusLight.accessibility.test.js +157 -0
  340. package/status-light/StatusLight.d.ts +4 -0
  341. package/status-light/StatusLight.js +51 -0
  342. package/status-light/StatusLight.stories.tsx +74 -0
  343. package/status-light/StatusLight.test.js +25 -0
  344. package/status-light/types.d.ts +17 -0
  345. package/status-light/types.js +5 -0
  346. package/switch/Switch.accessibility.test.js +89 -0
  347. package/switch/Switch.d.ts +4 -0
  348. package/switch/Switch.js +214 -0
  349. package/switch/Switch.stories.tsx +137 -0
  350. package/switch/Switch.test.js +180 -0
  351. package/switch/types.d.ts +66 -0
  352. package/switch/types.js +5 -0
  353. package/table/DropdownTheme.js +62 -0
  354. package/table/Table.accessibility.test.js +82 -0
  355. package/table/Table.d.ts +8 -0
  356. package/table/Table.js +161 -0
  357. package/table/Table.stories.tsx +651 -0
  358. package/table/Table.test.js +113 -0
  359. package/table/types.d.ts +49 -0
  360. package/table/types.js +5 -0
  361. package/tabs/Tab.d.ts +4 -0
  362. package/tabs/Tab.js +116 -0
  363. package/tabs/Tabs.accessibility.test.js +56 -0
  364. package/tabs/Tabs.d.ts +4 -0
  365. package/tabs/Tabs.js +384 -0
  366. package/tabs/Tabs.stories.tsx +226 -0
  367. package/tabs/Tabs.test.js +294 -0
  368. package/tabs/types.d.ts +92 -0
  369. package/tabs/types.js +5 -0
  370. package/tag/Tag.accessibility.test.js +69 -0
  371. package/tag/Tag.d.ts +4 -0
  372. package/tag/Tag.js +151 -0
  373. package/tag/Tag.stories.tsx +155 -0
  374. package/tag/Tag.test.js +49 -0
  375. package/tag/types.d.ts +69 -0
  376. package/tag/types.js +5 -0
  377. package/text-input/Suggestion.d.ts +4 -0
  378. package/text-input/Suggestion.js +67 -0
  379. package/text-input/Suggestions.d.ts +4 -0
  380. package/text-input/Suggestions.js +86 -0
  381. package/text-input/TextInput.accessibility.test.js +321 -0
  382. package/text-input/TextInput.d.ts +4 -0
  383. package/text-input/TextInput.js +567 -0
  384. package/text-input/TextInput.stories.tsx +465 -0
  385. package/text-input/TextInput.test.js +1756 -0
  386. package/text-input/types.d.ts +205 -0
  387. package/text-input/types.js +5 -0
  388. package/textarea/Textarea.accessibility.test.js +155 -0
  389. package/textarea/Textarea.d.ts +4 -0
  390. package/textarea/Textarea.js +234 -0
  391. package/textarea/Textarea.stories.tsx +174 -0
  392. package/textarea/Textarea.test.js +406 -0
  393. package/textarea/types.d.ts +141 -0
  394. package/textarea/types.js +5 -0
  395. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  396. package/toggle-group/ToggleGroup.d.ts +4 -0
  397. package/toggle-group/ToggleGroup.js +201 -0
  398. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  399. package/toggle-group/ToggleGroup.test.js +137 -0
  400. package/toggle-group/types.d.ts +114 -0
  401. package/toggle-group/types.js +5 -0
  402. package/typography/Typography.accessibility.test.js +339 -0
  403. package/typography/Typography.d.ts +4 -0
  404. package/typography/Typography.js +23 -0
  405. package/typography/Typography.stories.tsx +198 -0
  406. package/typography/types.d.ts +18 -0
  407. package/typography/types.js +5 -0
  408. package/useTheme.d.ts +1148 -0
  409. package/useTheme.js +15 -0
  410. package/useTranslatedLabels.d.ts +85 -0
  411. package/useTranslatedLabels.js +14 -0
  412. package/utils/BaseTypography.d.ts +21 -0
  413. package/utils/BaseTypography.js +94 -0
  414. package/utils/FocusLock.d.ts +13 -0
  415. package/utils/FocusLock.js +124 -0
  416. package/wizard/Wizard.accessibility.test.js +55 -0
  417. package/wizard/Wizard.d.ts +4 -0
  418. package/wizard/Wizard.js +250 -0
  419. package/wizard/Wizard.stories.tsx +253 -0
  420. package/wizard/Wizard.test.js +114 -0
  421. package/wizard/types.d.ts +64 -0
  422. package/wizard/types.js +5 -0
  423. package/babel.config.js +0 -4
  424. package/dist/ThemeContext.js +0 -15
  425. package/dist/accordion/Accordion.js +0 -264
  426. package/dist/accordion/Accordion.stories.js +0 -207
  427. package/dist/accordion/readme.md +0 -96
  428. package/dist/alert/Alert.js +0 -302
  429. package/dist/alert/Alert.stories.js +0 -158
  430. package/dist/alert/close.svg +0 -4
  431. package/dist/alert/error.svg +0 -4
  432. package/dist/alert/info.svg +0 -4
  433. package/dist/alert/readme.md +0 -43
  434. package/dist/alert/success.svg +0 -4
  435. package/dist/alert/warning.svg +0 -4
  436. package/dist/box/Box.js +0 -136
  437. package/dist/button/Button.js +0 -182
  438. package/dist/button/Button.stories.js +0 -224
  439. package/dist/button/readme.md +0 -93
  440. package/dist/card/Card.js +0 -246
  441. package/dist/checkbox/Checkbox.js +0 -224
  442. package/dist/checkbox/Checkbox.stories.js +0 -144
  443. package/dist/checkbox/readme.md +0 -116
  444. package/dist/chip/Chip.js +0 -170
  445. package/dist/common/OpenSans.css +0 -81
  446. package/dist/common/RequiredComponent.js +0 -50
  447. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  448. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  449. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  450. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  451. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  452. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  453. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  454. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  455. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  456. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  457. package/dist/common/services/example-service.js +0 -10
  458. package/dist/common/services/example-service.test.js +0 -12
  459. package/dist/common/utils.js +0 -42
  460. package/dist/common/variables.js +0 -145
  461. package/dist/date/Date.js +0 -342
  462. package/dist/date/Date.stories.js +0 -205
  463. package/dist/date/calendar.svg +0 -1
  464. package/dist/date/calendar_dark.svg +0 -1
  465. package/dist/date/readme.md +0 -73
  466. package/dist/dialog/Dialog.js +0 -193
  467. package/dist/dialog/Dialog.stories.js +0 -217
  468. package/dist/dialog/readme.md +0 -32
  469. package/dist/dropdown/Dropdown.js +0 -412
  470. package/dist/dropdown/Dropdown.stories.js +0 -249
  471. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  472. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  473. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  474. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  475. package/dist/dropdown/readme.md +0 -69
  476. package/dist/footer/Footer.js +0 -341
  477. package/dist/footer/Footer.stories.js +0 -94
  478. package/dist/footer/dxc_logo_wht.png +0 -0
  479. package/dist/footer/readme.md +0 -41
  480. package/dist/header/Header.js +0 -343
  481. package/dist/header/Header.stories.js +0 -176
  482. package/dist/header/close_icon.svg +0 -1
  483. package/dist/header/dxc_logo_black.png +0 -0
  484. package/dist/header/dxc_logo_white.png +0 -0
  485. package/dist/header/hamb_menu_black.svg +0 -1
  486. package/dist/header/hamb_menu_white.svg +0 -1
  487. package/dist/header/readme.md +0 -33
  488. package/dist/heading/Heading.js +0 -159
  489. package/dist/input-text/InputText.js +0 -517
  490. package/dist/input-text/InputText.stories.js +0 -209
  491. package/dist/input-text/error.svg +0 -1
  492. package/dist/input-text/readme.md +0 -91
  493. package/dist/link/Link.js +0 -129
  494. package/dist/link/readme.md +0 -51
  495. package/dist/main.js +0 -263
  496. package/dist/paginator/Paginator.js +0 -178
  497. package/dist/paginator/images/next.svg +0 -3
  498. package/dist/paginator/images/nextPage.svg +0 -3
  499. package/dist/paginator/images/previous.svg +0 -3
  500. package/dist/paginator/images/previousPage.svg +0 -3
  501. package/dist/paginator/readme.md +0 -50
  502. package/dist/progress-bar/ProgressBar.js +0 -189
  503. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  504. package/dist/progress-bar/readme.md +0 -63
  505. package/dist/radio/Radio.js +0 -204
  506. package/dist/radio/Radio.stories.js +0 -166
  507. package/dist/radio/readme.md +0 -70
  508. package/dist/resultsetTable/ResultsetTable.js +0 -334
  509. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  510. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  511. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  512. package/dist/select/Select.js +0 -425
  513. package/dist/select/Select.stories.js +0 -235
  514. package/dist/select/readme.md +0 -72
  515. package/dist/sidenav/Sidenav.js +0 -217
  516. package/dist/sidenav/arrow_icon.svg +0 -3
  517. package/dist/slider/Slider.js +0 -258
  518. package/dist/slider/Slider.stories.js +0 -241
  519. package/dist/slider/readme.md +0 -64
  520. package/dist/spinner/Spinner.js +0 -196
  521. package/dist/spinner/Spinner.stories.js +0 -183
  522. package/dist/spinner/readme.md +0 -65
  523. package/dist/switch/Switch.js +0 -219
  524. package/dist/switch/Switch.stories.js +0 -134
  525. package/dist/switch/readme.md +0 -133
  526. package/dist/table/Table.js +0 -84
  527. package/dist/tabs/Tabs.js +0 -183
  528. package/dist/tabs/Tabs.stories.js +0 -130
  529. package/dist/tabs/readme.md +0 -78
  530. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  531. package/dist/tabs-for-sections/readme.md +0 -78
  532. package/dist/tag/Tag.js +0 -217
  533. package/dist/textarea/Textarea.js +0 -226
  534. package/dist/toggle/Toggle.js +0 -223
  535. package/dist/toggle/Toggle.stories.js +0 -297
  536. package/dist/toggle/readme.md +0 -80
  537. package/dist/upload/Upload.js +0 -200
  538. package/dist/upload/Upload.stories.js +0 -72
  539. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  540. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  541. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  542. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  543. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  544. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  545. package/dist/upload/file-upload/FileToUpload.js +0 -158
  546. package/dist/upload/file-upload/audio-icon.svg +0 -4
  547. package/dist/upload/file-upload/close.svg +0 -4
  548. package/dist/upload/file-upload/file-icon.svg +0 -4
  549. package/dist/upload/file-upload/video-icon.svg +0 -4
  550. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  551. package/dist/upload/readme.md +0 -37
  552. package/dist/upload/transaction/Transaction.js +0 -155
  553. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  554. package/dist/upload/transaction/audio-icon.svg +0 -4
  555. package/dist/upload/transaction/error-icon.svg +0 -4
  556. package/dist/upload/transaction/file-icon-err.svg +0 -4
  557. package/dist/upload/transaction/file-icon.svg +0 -4
  558. package/dist/upload/transaction/image-icon-err.svg +0 -4
  559. package/dist/upload/transaction/image-icon.svg +0 -4
  560. package/dist/upload/transaction/success-icon.svg +0 -4
  561. package/dist/upload/transaction/video-icon-err.svg +0 -4
  562. package/dist/upload/transaction/video-icon.svg +0 -4
  563. package/dist/upload/transactions/Transactions.js +0 -120
  564. package/dist/wizard/Wizard.js +0 -310
  565. package/dist/wizard/invalid_icon.svg +0 -6
  566. package/dist/wizard/valid_icon.svg +0 -6
  567. package/dist/wizard/validation-wrong.svg +0 -6
  568. package/test/Accordion.test.js +0 -33
  569. package/test/Alert.test.js +0 -53
  570. package/test/Box.test.js +0 -10
  571. package/test/Button.test.js +0 -18
  572. package/test/Card.test.js +0 -30
  573. package/test/Checkbox.test.js +0 -45
  574. package/test/Chip.test.js +0 -25
  575. package/test/Date.test.js +0 -393
  576. package/test/Dialog.test.js +0 -23
  577. package/test/Dropdown.test.js +0 -130
  578. package/test/Footer.test.js +0 -99
  579. package/test/Header.test.js +0 -39
  580. package/test/Heading.test.js +0 -35
  581. package/test/InputText.test.js +0 -236
  582. package/test/Link.test.js +0 -25
  583. package/test/Paginator.test.js +0 -165
  584. package/test/ProgressBar.test.js +0 -35
  585. package/test/Radio.test.js +0 -37
  586. package/test/ResultsetTable.test.js +0 -282
  587. package/test/Select.test.js +0 -191
  588. package/test/Sidenav.test.js +0 -87
  589. package/test/Slider.test.js +0 -65
  590. package/test/Spinner.test.js +0 -27
  591. package/test/Switch.test.js +0 -45
  592. package/test/Table.test.js +0 -36
  593. package/test/Tabs.test.js +0 -88
  594. package/test/TabsForSections.test.js +0 -34
  595. package/test/Tag.test.js +0 -32
  596. package/test/TextArea.test.js +0 -52
  597. package/test/Toggle.test.js +0 -43
  598. package/test/Upload.test.js +0 -60
  599. package/test/Wizard.test.js +0 -130
  600. package/test/mocks/pngMock.js +0 -1
  601. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,134 @@
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 _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ var _Header = _interopRequireDefault(require("../header/Header"));
13
+ var _Footer = _interopRequireDefault(require("../footer/Footer"));
14
+ var _Sidenav = _interopRequireDefault(require("../sidenav/Sidenav"));
15
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
16
+ var _variables = require("../common/variables");
17
+ var _Icons = _interopRequireDefault(require("./Icons"));
18
+ var _SidenavContext = require("../sidenav/SidenavContext");
19
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
20
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
21
+ 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); }
22
+ 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; }
23
+ var year = new Date().getFullYear();
24
+ var Main = function Main(_ref) {
25
+ var children = _ref.children;
26
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, children);
27
+ };
28
+ var defaultHeader = function defaultHeader() {
29
+ return /*#__PURE__*/_react["default"].createElement(_Header["default"], {
30
+ underlined: true
31
+ });
32
+ };
33
+ var defaultFooter = function defaultFooter() {
34
+ return /*#__PURE__*/_react["default"].createElement(_Footer["default"], {
35
+ copyright: "\xA9 DXC Technology ".concat(year, "\u200B\u200B\u200B\u200B. All rights reserved."),
36
+ bottomLinks: [{
37
+ href: "https://www.linkedin.com/company/dxctechnology",
38
+ text: "Linkedin"
39
+ }, {
40
+ href: "https://x.com/dxctechnology",
41
+ text: "X"
42
+ }, {
43
+ href: "https://www.facebook.com/DXCTechnology/",
44
+ text: "Facebook"
45
+ }],
46
+ socialLinks: [{
47
+ href: "https://www.linkedin.com/company/dxctechnology",
48
+ logo: _Icons["default"].linkedinLogo,
49
+ title: "Linkedin"
50
+ }, {
51
+ href: "https://x.com/dxctechnology",
52
+ logo: _Icons["default"].xLogo,
53
+ title: "X"
54
+ }, {
55
+ href: "https://www.facebook.com/DXCTechnology/",
56
+ logo: _Icons["default"].facebookLogo,
57
+ title: "Facebook"
58
+ }]
59
+ });
60
+ };
61
+ var childTypeExists = function childTypeExists(children, childType) {
62
+ return children.find(function (child) {
63
+ return (child === null || child === void 0 ? void 0 : child.type) === childType;
64
+ });
65
+ };
66
+ var DxcApplicationLayout = function DxcApplicationLayout(_ref2) {
67
+ var _ref2$visibilityToggl = _ref2.visibilityToggleLabel,
68
+ visibilityToggleLabel = _ref2$visibilityToggl === void 0 ? "" : _ref2$visibilityToggl,
69
+ header = _ref2.header,
70
+ sidenav = _ref2.sidenav,
71
+ footer = _ref2.footer,
72
+ children = _ref2.children;
73
+ var _useState = (0, _react.useState)(false),
74
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
75
+ isSidenavVisibleResponsive = _useState2[0],
76
+ setIsSidenavVisibleResponsive = _useState2[1];
77
+ var _useState3 = (0, _react.useState)(false),
78
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
79
+ isResponsive = _useState4[0],
80
+ setIsResponsive = _useState4[1];
81
+ var ref = (0, _react.useRef)(null);
82
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
83
+ var childrenArray = _react["default"].Children.toArray(children);
84
+ var headerContent = header || defaultHeader();
85
+ var footerContent = footer || defaultFooter();
86
+ var main = childTypeExists(childrenArray, Main);
87
+ var handleResize = function handleResize() {
88
+ setIsResponsive(window.matchMedia("(max-width: ".concat(_variables.responsiveSizes.medium, "rem)")).matches);
89
+ };
90
+ var handleSidenavVisibility = function handleSidenavVisibility() {
91
+ setIsSidenavVisibleResponsive(function (isSidenavVisibleResponsive) {
92
+ return !isSidenavVisibleResponsive;
93
+ });
94
+ };
95
+ (0, _react.useEffect)(function () {
96
+ handleResize();
97
+ window.addEventListener("resize", handleResize);
98
+ return function () {
99
+ window.removeEventListener("resize", handleResize);
100
+ };
101
+ }, []);
102
+ (0, _react.useEffect)(function () {
103
+ !isResponsive && setIsSidenavVisibleResponsive(false);
104
+ }, [isResponsive]);
105
+ return /*#__PURE__*/_react["default"].createElement(ApplicationLayoutContainer, {
106
+ hasSidenav: sidenav ? true : false,
107
+ isSidenavVisible: isSidenavVisibleResponsive,
108
+ ref: ref
109
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, null, headerContent), sidenav && isResponsive && /*#__PURE__*/_react["default"].createElement(VisibilityToggle, null, /*#__PURE__*/_react["default"].createElement(HamburgerTrigger, {
110
+ onClick: handleSidenavVisibility,
111
+ "aria-label": visibilityToggleLabel ? undefined : translatedLabels.applicationLayout.visibilityToggleTitle,
112
+ title: translatedLabels.applicationLayout.visibilityToggleTitle
113
+ }, _Icons["default"].hamburgerIcon, visibilityToggleLabel)), /*#__PURE__*/_react["default"].createElement(BodyContainer, null, /*#__PURE__*/_react["default"].createElement(_SidenavContext.SidenavContextProvider, {
114
+ value: setIsSidenavVisibleResponsive
115
+ }, sidenav && (isResponsive ? isSidenavVisibleResponsive : true) && /*#__PURE__*/_react["default"].createElement(SidenavContainer, null, sidenav)), /*#__PURE__*/_react["default"].createElement(MainContainer, null, /*#__PURE__*/_react["default"].createElement(MainContentContainer, null, main), footerContent)));
116
+ };
117
+ var ApplicationLayoutContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n position: absolute;\n top: 64px;\n bottom: 0;\n left: 0;\n right: 0;\n display: flex;\n flex-direction: column;\n\n @media (max-width: ", "rem) {\n ", ";\n ", "\n }\n"])), _variables.responsiveSizes.medium, function (props) {
118
+ return props.hasSidenav && "top: 116px";
119
+ }, function (props) {
120
+ return props.isSidenavVisible && "overflow: hidden;";
121
+ });
122
+ var HeaderContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n z-index: 3;\n"])));
123
+ var VisibilityToggle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n position: fixed;\n top: 64px;\n left: 0;\n right: 0;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n padding: 4px 16px;\n width: 100%;\n background-color: #f2f2f2;\n user-select: none;\n z-index: 2;\n"])));
124
+ var HamburgerTrigger = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n gap: 10px;\n border: 0px solid transparent;\n border-radius: 2px;\n padding: 12px 4px;\n background-color: transparent;\n box-shadow: 0 0 0 2px transparent;\n font-family: Open Sans, sans-serif;\n font-weight: 600;\n font-size: 14px;\n color: #000;\n cursor: pointer;\n\n :active {\n background-color: #cccccc;\n }\n :focus,\n :focus-visible {\n outline: none;\n box-shadow: 0 0 0 2px #0095ff;\n }\n & > svg {\n height: 20px;\n width: 20px;\n }\n"])));
125
+ var BodyContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n flex: 1;\n"])));
126
+ var SidenavContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n position: sticky;\n top: 64px;\n display: flex;\n height: calc(100vh - 64px);\n z-index: 1;\n\n @media (max-width: ", "rem) {\n position: absolute;\n top: 0px;\n height: 100%;\n }\n"])), _variables.responsiveSizes.medium);
127
+ var MainContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n"])));
128
+ var MainContentContainer = _styledComponents["default"].main(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n flex: 1;\n background-color: #fff;\n"])));
129
+ DxcApplicationLayout.Header = _Header["default"];
130
+ DxcApplicationLayout.Main = Main;
131
+ DxcApplicationLayout.Footer = _Footer["default"];
132
+ DxcApplicationLayout.SideNav = _Sidenav["default"];
133
+ DxcApplicationLayout.useResponsiveSidenavVisibility = _SidenavContext.useResponsiveSidenavVisibility;
134
+ var _default = exports["default"] = DxcApplicationLayout;
@@ -0,0 +1,162 @@
1
+ import React from "react";
2
+ import DxcApplicationLayout from "./ApplicationLayout";
3
+ import Title from "../../.storybook/components/Title";
4
+ import { INITIAL_VIEWPORTS } from "@storybook/addon-viewport";
5
+
6
+ export default {
7
+ title: "Application Layout",
8
+ component: DxcApplicationLayout,
9
+ parameters: {
10
+ viewport: {
11
+ viewports: INITIAL_VIEWPORTS,
12
+ },
13
+ },
14
+ };
15
+
16
+ export const DefaultApplicationLayout = () => (
17
+ <>
18
+ <DxcApplicationLayout>
19
+ <DxcApplicationLayout.Main>
20
+ <Title title="Default application layout" theme="light" level={4} />
21
+ <p>Main Content</p>
22
+ <p>Main Content</p>
23
+ <p>Main Content</p>
24
+ <p>Main Content</p>
25
+ </DxcApplicationLayout.Main>
26
+ </DxcApplicationLayout>
27
+ </>
28
+ );
29
+
30
+ export const ApplicationLayoutWithDefaultSidenav = () => (
31
+ <>
32
+ <DxcApplicationLayout
33
+ sidenav={
34
+ <DxcApplicationLayout.SideNav
35
+ title={
36
+ <DxcApplicationLayout.SideNav.Title>
37
+ Application layout with push sidenav
38
+ </DxcApplicationLayout.SideNav.Title>
39
+ }
40
+ >
41
+ <DxcApplicationLayout.SideNav.Section>
42
+ <p>SideNav Content</p>
43
+ <p>SideNav Content</p>
44
+ <p>SideNav Content</p>
45
+ <p>SideNav Content</p>
46
+ <p>SideNav Content</p>
47
+ </DxcApplicationLayout.SideNav.Section>
48
+ </DxcApplicationLayout.SideNav>
49
+ }
50
+ >
51
+ <DxcApplicationLayout.Main>
52
+ <p>Main Content</p>
53
+ <p>Main Content</p>
54
+ <p>Main Content</p>
55
+ <p>Main Content</p>
56
+ </DxcApplicationLayout.Main>
57
+ </DxcApplicationLayout>
58
+ </>
59
+ );
60
+
61
+ export const ApplicationLayoutWithResponsiveSidenav = () => (
62
+ <>
63
+ <DxcApplicationLayout
64
+ visibilityToggleLabel="Example"
65
+ sidenav={
66
+ <DxcApplicationLayout.SideNav
67
+ title={
68
+ <DxcApplicationLayout.SideNav.Title>
69
+ Application layout with push sidenav
70
+ </DxcApplicationLayout.SideNav.Title>
71
+ }
72
+ >
73
+ <DxcApplicationLayout.SideNav.Section>
74
+ <p>SideNav Content</p>
75
+ <p>SideNav Content</p>
76
+ <p>SideNav Content</p>
77
+ <p>SideNav Content</p>
78
+ <p>SideNav Content</p>
79
+ </DxcApplicationLayout.SideNav.Section>
80
+ </DxcApplicationLayout.SideNav>
81
+ }
82
+ >
83
+ <DxcApplicationLayout.Main>
84
+ <p>Main Content</p>
85
+ <p>Main Content</p>
86
+ <p>Main Content</p>
87
+ <p>Main Content</p>
88
+ </DxcApplicationLayout.Main>
89
+ </DxcApplicationLayout>
90
+ </>
91
+ );
92
+
93
+ ApplicationLayoutWithResponsiveSidenav.parameters = {
94
+ viewport: {
95
+ defaultViewport: "pixel",
96
+ },
97
+ chromatic: { viewports: [540] },
98
+ };
99
+
100
+ export const ApplicationLayoutWithCustomHeader = () => (
101
+ <>
102
+ <DxcApplicationLayout
103
+ header={<p>Custom Header</p>}
104
+ sidenav={
105
+ <DxcApplicationLayout.SideNav
106
+ title={
107
+ <DxcApplicationLayout.SideNav.Title>
108
+ Application layout with push sidenav
109
+ </DxcApplicationLayout.SideNav.Title>
110
+ }
111
+ >
112
+ <DxcApplicationLayout.SideNav.Section>
113
+ <p>SideNav Content</p>
114
+ <p>SideNav Content</p>
115
+ <p>SideNav Content</p>
116
+ <p>SideNav Content</p>
117
+ <p>SideNav Content</p>
118
+ </DxcApplicationLayout.SideNav.Section>
119
+ </DxcApplicationLayout.SideNav>
120
+ }
121
+ >
122
+ <DxcApplicationLayout.Main>
123
+ <p>Main Content</p>
124
+ <p>Main Content</p>
125
+ <p>Main Content</p>
126
+ <p>Main Content</p>
127
+ </DxcApplicationLayout.Main>
128
+ </DxcApplicationLayout>
129
+ </>
130
+ );
131
+
132
+ export const ApplicationLayoutWithCustomFooter = () => (
133
+ <>
134
+ <DxcApplicationLayout
135
+ footer={<p>Custom Footer</p>}
136
+ sidenav={
137
+ <DxcApplicationLayout.SideNav
138
+ title={
139
+ <DxcApplicationLayout.SideNav.Title>
140
+ Application layout with push sidenav
141
+ </DxcApplicationLayout.SideNav.Title>
142
+ }
143
+ >
144
+ <DxcApplicationLayout.SideNav.Section>
145
+ <p>SideNav Content</p>
146
+ <p>SideNav Content</p>
147
+ <p>SideNav Content</p>
148
+ <p>SideNav Content</p>
149
+ <p>SideNav Content</p>
150
+ </DxcApplicationLayout.SideNav.Section>
151
+ </DxcApplicationLayout.SideNav>
152
+ }
153
+ >
154
+ <DxcApplicationLayout.Main>
155
+ <p>Main Content</p>
156
+ <p>Main Content</p>
157
+ <p>Main Content</p>
158
+ <p>Main Content</p>
159
+ </DxcApplicationLayout.Main>
160
+ </DxcApplicationLayout>
161
+ </>
162
+ );
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ declare const layoutIcons: {
3
+ facebookLogo: React.JSX.Element;
4
+ xLogo: React.JSX.Element;
5
+ linkedinLogo: React.JSX.Element;
6
+ hamburgerIcon: React.JSX.Element;
7
+ };
8
+ export default layoutIcons;
@@ -0,0 +1,56 @@
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 = _interopRequireDefault(require("react"));
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
+ hamburgerIcon: /*#__PURE__*/_react["default"].createElement("svg", {
48
+ xmlns: "http://www.w3.org/2000/svg",
49
+ height: "24",
50
+ width: "24",
51
+ viewBox: "0 0 24 24"
52
+ }, /*#__PURE__*/_react["default"].createElement("path", {
53
+ d: "M3 18V16H21V18ZM3 13V11H21V13ZM3 8V6H21V8Z"
54
+ }))
55
+ };
56
+ var _default = exports["default"] = layoutIcons;
@@ -0,0 +1,41 @@
1
+ /// <reference types="react" />
2
+ export type AppLayoutMainPropsType = {
3
+ /**
4
+ * Everything between the tags will be displayed as the content of the main part of the application.
5
+ */
6
+ children: React.ReactNode;
7
+ };
8
+ export type AppLayoutSidenavPropsType = {
9
+ /**
10
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
11
+ */
12
+ children: React.ReactNode;
13
+ /**
14
+ * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
15
+ */
16
+ title?: React.ReactNode;
17
+ };
18
+ type AppLayoutPropsType = {
19
+ /**
20
+ * Text to be placed next to the hamburger button that toggles the
21
+ * visibility of the sidenav.
22
+ */
23
+ visibilityToggleLabel?: string;
24
+ /**
25
+ * Header content.
26
+ */
27
+ header?: React.ReactNode;
28
+ /**
29
+ * Sidenav content
30
+ */
31
+ sidenav?: React.ReactNode;
32
+ /**
33
+ * Footer content
34
+ */
35
+ footer?: React.ReactNode;
36
+ /**
37
+ * Use the DxcApplicationLayout.Main provided to render main content.
38
+ */
39
+ children: React.ReactElement<AppLayoutMainPropsType>;
40
+ };
41
+ export default AppLayoutPropsType;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,112 @@
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 _Link = _interopRequireDefault(require("./Link.tsx"));
10
+ var _Flex = _interopRequireDefault(require("../flex/Flex.tsx"));
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", {
16
+ id: "Bounding_Box"
17
+ }, /*#__PURE__*/_react["default"].createElement("rect", {
18
+ fill: "none",
19
+ width: "24",
20
+ height: "24"
21
+ })), /*#__PURE__*/_react["default"].createElement("g", {
22
+ id: "Master"
23
+ }, /*#__PURE__*/_react["default"].createElement("path", {
24
+ 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"
25
+ })));
26
+ describe("Link component accessibility tests", function () {
27
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
28
+ var _render, container, results;
29
+ return _regenerator["default"].wrap(function _callee$(_context) {
30
+ while (1) switch (_context.prev = _context.next) {
31
+ case 0:
32
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
33
+ href: "https://www.google.com",
34
+ icon: icon,
35
+ iconPosition: "before",
36
+ margin: "medium"
37
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
38
+ href: "https://www.google.com",
39
+ icon: icon,
40
+ iconPosition: "after",
41
+ margin: "medium"
42
+ }, "Link"))), container = _render.container;
43
+ _context.next = 3;
44
+ return (0, _jestAxe.axe)(container);
45
+ case 3:
46
+ results = _context.sent;
47
+ expect(results).toHaveNoViolations();
48
+ case 5:
49
+ case "end":
50
+ return _context.stop();
51
+ }
52
+ }, _callee);
53
+ })));
54
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
55
+ var _render2, container, results;
56
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
57
+ while (1) switch (_context2.prev = _context2.next) {
58
+ case 0:
59
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
60
+ href: "https://www.google.com",
61
+ icon: icon,
62
+ iconPosition: "before",
63
+ margin: "medium",
64
+ disabled: true
65
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
66
+ href: "https://www.google.com",
67
+ icon: icon,
68
+ iconPosition: "after",
69
+ margin: "medium",
70
+ disabled: true
71
+ }, "Link"))), container = _render2.container;
72
+ _context2.next = 3;
73
+ return (0, _jestAxe.axe)(container);
74
+ case 3:
75
+ results = _context2.sent;
76
+ expect(results).toHaveNoViolations();
77
+ case 5:
78
+ case "end":
79
+ return _context2.stop();
80
+ }
81
+ }, _callee2);
82
+ })));
83
+ it("Should not have basic accessibility issues for new-window mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
84
+ var _render3, container, results;
85
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
86
+ while (1) switch (_context3.prev = _context3.next) {
87
+ case 0:
88
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(_Link["default"], {
89
+ href: "https://www.google.com",
90
+ icon: icon,
91
+ iconPosition: "before",
92
+ margin: "medium",
93
+ newWindow: true
94
+ }, "Link"), /*#__PURE__*/_react["default"].createElement(_Link["default"], {
95
+ href: "https://www.google.com",
96
+ icon: icon,
97
+ iconPosition: "after",
98
+ margin: "medium",
99
+ newWindow: true
100
+ }, "Link"))), container = _render3.container;
101
+ _context3.next = 3;
102
+ return (0, _jestAxe.axe)(container);
103
+ case 3:
104
+ results = _context3.sent;
105
+ expect(results).toHaveNoViolations();
106
+ case 5:
107
+ case "end":
108
+ return _context3.stop();
109
+ }
110
+ }, _callee3);
111
+ })));
112
+ });
package/link/Link.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { LinkProps } from "./types";
3
+ declare const DxcLink: React.ForwardRefExoticComponent<LinkProps & React.RefAttributes<HTMLAnchorElement>>;
4
+ export default DxcLink;
package/link/Link.js ADDED
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
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"));
14
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
15
+ var _variables = require("../common/variables");
16
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
17
+ var _templateObject, _templateObject2, _templateObject3;
18
+ var _excluded = ["inheritColor", "disabled", "icon", "iconPosition", "href", "newWindow", "onClick", "margin", "tabIndex", "children"];
19
+ 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); }
20
+ 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 && 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; }
21
+ var LinkContent = /*#__PURE__*/_react["default"].memo(function (_ref) {
22
+ var iconPosition = _ref.iconPosition,
23
+ icon = _ref.icon,
24
+ children = _ref.children;
25
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, iconPosition === "after" && children, icon && /*#__PURE__*/_react["default"].createElement(LinkIconContainer, {
26
+ iconPosition: iconPosition
27
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(LinkIcon, {
28
+ src: icon
29
+ }) : icon), iconPosition === "before" && children);
30
+ });
31
+ var DxcLink = /*#__PURE__*/(0, _react.forwardRef)(function (_ref2, ref) {
32
+ var _ref2$inheritColor = _ref2.inheritColor,
33
+ inheritColor = _ref2$inheritColor === void 0 ? false : _ref2$inheritColor,
34
+ _ref2$disabled = _ref2.disabled,
35
+ disabled = _ref2$disabled === void 0 ? false : _ref2$disabled,
36
+ icon = _ref2.icon,
37
+ _ref2$iconPosition = _ref2.iconPosition,
38
+ iconPosition = _ref2$iconPosition === void 0 ? "before" : _ref2$iconPosition,
39
+ _ref2$href = _ref2.href,
40
+ href = _ref2$href === void 0 ? "" : _ref2$href,
41
+ _ref2$newWindow = _ref2.newWindow,
42
+ newWindow = _ref2$newWindow === void 0 ? false : _ref2$newWindow,
43
+ onClick = _ref2.onClick,
44
+ margin = _ref2.margin,
45
+ _ref2$tabIndex = _ref2.tabIndex,
46
+ tabIndex = _ref2$tabIndex === void 0 ? 0 : _ref2$tabIndex,
47
+ children = _ref2.children,
48
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref2, _excluded);
49
+ var colorsTheme = (0, _useTheme["default"])();
50
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
51
+ theme: colorsTheme.link
52
+ }, /*#__PURE__*/_react["default"].createElement(StyledLink, (0, _extends2["default"])({
53
+ as: href ? "a" : "button",
54
+ tabIndex: tabIndex,
55
+ onClick: !disabled ? onClick : undefined,
56
+ href: !disabled && href ? href : undefined,
57
+ target: href ? newWindow ? "_blank" : "_self" : undefined,
58
+ disabled: disabled,
59
+ inheritColor: inheritColor,
60
+ margin: margin,
61
+ ref: ref
62
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(LinkContent, {
63
+ iconPosition: iconPosition,
64
+ icon: icon,
65
+ children: children
66
+ })));
67
+ });
68
+ 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) {
69
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
70
+ }, function (props) {
71
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
72
+ }, function (props) {
73
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
74
+ }, function (props) {
75
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
76
+ }, function (props) {
77
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
78
+ }, function (props) {
79
+ return props.theme.fontSize;
80
+ }, function (props) {
81
+ return props.theme.fontWeight;
82
+ }, function (props) {
83
+ return props.theme.fontStyle;
84
+ }, function (props) {
85
+ return props.theme.fontFamily;
86
+ }, function (props) {
87
+ return "padding-bottom: ".concat(props.theme.underlineSpacing, ";\n border-bottom: ").concat(props.theme.underlineThickness, " ").concat(props.theme.underlineStyle, " transparent;");
88
+ }, function (props) {
89
+ return props.disabled && "cursor: default;";
90
+ }, function (props) {
91
+ return props.inheritColor ? "inherit" : !props.disabled ? props.theme.fontColor : props.theme.disabledFontColor;
92
+ }, function (props) {
93
+ return props.disabled ? "pointer-events: none;" : "";
94
+ }, function (props) {
95
+ return !props.inheritColor && !props.disabled ? props.theme.visitedFontColor : "";
96
+ }, function (props) {
97
+ return "color: ".concat(props.theme.visitedFontColor, ";\n border-bottom-color: ").concat(props.theme.visitedUnderlineColor, ";");
98
+ }, function (props) {
99
+ return "color: ".concat(props.theme.hoverFontColor, ";\n border-bottom-color: ").concat(props.theme.hoverUnderlineColor, ";\n cursor: pointer;");
100
+ }, function (props) {
101
+ return props.theme.focusColor;
102
+ }, function (props) {
103
+ return props.disabled && "outline: none";
104
+ }, function (props) {
105
+ return "color: ".concat(props.theme.activeFontColor, " !important;\n border-bottom-color: ").concat(props.theme.activeUnderlineColor, " !important;");
106
+ });
107
+ var LinkIcon = _styledComponents["default"].img(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
108
+ var LinkIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n ", ";\n overflow: hidden;\n align-self: center;\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
109
+ return props.theme.iconSize;
110
+ }, function (props) {
111
+ return props.theme.iconSize;
112
+ }, function (props) {
113
+ return "".concat(props.iconPosition === "before" ? "margin-right" : "margin-left", ": ").concat(props.theme.iconSpacing);
114
+ });
115
+ var _default = exports["default"] = DxcLink;