@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
@@ -0,0 +1,356 @@
1
+ import React from "react";
2
+ import styled from "styled-components";
3
+ import DxcQuickNav from "./QuickNav";
4
+ import DxcHeading from "../heading/Heading";
5
+ import DxcParagraph from "../paragraph/Paragraph";
6
+ import Title from "../../.storybook/components/Title";
7
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
8
+ import { HalstackProvider } from "../HalstackContext";
9
+
10
+ export default {
11
+ title: "Quick Nav",
12
+ component: DxcQuickNav,
13
+ };
14
+
15
+ const opinionatedTheme = {
16
+ quickNav: {
17
+ fontColor: "#666666",
18
+ accentColor: "#9a6bb2",
19
+ },
20
+ };
21
+
22
+ const defaultLinks = [
23
+ {
24
+ label: "Overview",
25
+ },
26
+ {
27
+ label: "Principles",
28
+ links: [{ label: "Color" }, { label: "Spacing" }, { label: "Typography" }],
29
+ },
30
+ {
31
+ label: "Components",
32
+ links: [
33
+ {
34
+ label: "Accordion",
35
+ },
36
+ {
37
+ label: "Button",
38
+ },
39
+ ],
40
+ },
41
+ ];
42
+
43
+ const links = [
44
+ {
45
+ label: "Overview",
46
+ links: [
47
+ {
48
+ label: "Introduction",
49
+ },
50
+ ],
51
+ },
52
+ {
53
+ label: "Components",
54
+ links: [
55
+ {
56
+ label: "Introduction",
57
+ },
58
+ {
59
+ label: "Accordion",
60
+ },
61
+ ],
62
+ },
63
+ {
64
+ label: "Principles very very very very very very very very long",
65
+ links: [
66
+ { label: "Color very very very very very very very very long" },
67
+ { label: "Spacingveryveryveryveryveryveryveryverylong" },
68
+ { label: "Typography" },
69
+ ],
70
+ },
71
+ {
72
+ label: "Componentsveryveryveryveryveryveryveryverylong",
73
+ links: [
74
+ {
75
+ label: "Accordion",
76
+ },
77
+ ],
78
+ },
79
+ ];
80
+
81
+ export const Chromatic = () => (
82
+ <>
83
+ <ExampleContainer>
84
+ <Title title="Default" level={4} />
85
+ <QuickNavContainer>
86
+ <DxcQuickNav links={defaultLinks} />
87
+ </QuickNavContainer>
88
+ </ExampleContainer>
89
+ <ExampleContainer>
90
+ <Title title="Text overflow" level={4} />
91
+ <QuickNavContainer>
92
+ <DxcQuickNav links={links} />
93
+ </QuickNavContainer>
94
+ </ExampleContainer>
95
+ <ExampleContainer pseudoState="pseudo-hover">
96
+ <Title title="Link hovered" level={4} />
97
+ <QuickNavContainer>
98
+ <DxcQuickNav links={links} />
99
+ </QuickNavContainer>
100
+ </ExampleContainer>
101
+ <ExampleContainer pseudoState="pseudo-focus">
102
+ <Title title="Link focus" level={4} />
103
+ <QuickNavContainer>
104
+ <DxcQuickNav links={links} />
105
+ </QuickNavContainer>
106
+ </ExampleContainer>
107
+ <ExampleContainer>
108
+ <Title title="QuickNav with content" level={4} />
109
+ <Container>
110
+ <ContentContainer>
111
+ <Content id="overview">
112
+ <DxcHeading level={1} text="Overview" margin={{ bottom: "small" }} />
113
+ <DxcParagraph>
114
+ Halstack is the DXC Technology's open source design system for insurance products and digital experiences.
115
+ Our system provides all the tools and resources needed to create superior, beautiful but above all,
116
+ functional user experiences. Halstack is the DXC Technology's open source design system for insurance
117
+ products and digital experiences. Our system provides all the tools and resources needed to create
118
+ superior, beautiful but above all, functional user experiences.Halstack is the DXC Technology's open
119
+ source design system for insurance products and digital experiences. Our system provides all the tools and
120
+ resources needed to create superior, beautiful but above all, functional user experiences.Halstack is the
121
+ DXC Technology's open source design system for insurance products and digital experiences. Our system
122
+ provides all the tools and resources needed to create superior, beautiful but above all, functional user
123
+ experiences.Halstack is the DXC Technology's open source design system for insurance products and digital
124
+ experiences. Our system provides all the tools and resources needed to create superior, beautiful but
125
+ above all, functional user experiences.Halstack is the DXC Technology's open source design system for
126
+ insurance products and digital experiences. Our system provides all the tools and resources needed to
127
+ create superior, beautiful but above all, functional user experiences.Halstack is the DXC Technology's
128
+ open source design system for insurance products and digital experiences. Our system provides all the
129
+ tools and resources needed to create superior, beautiful but above all, functional user experiences.
130
+ </DxcParagraph>
131
+ <Content id="overview-introduction">
132
+ <DxcHeading level={2} text="Introduction" margin={{ top: "xsmall", bottom: "xsmall" }} />
133
+ <DxcParagraph>
134
+ Design principles Halstack design principles are the fundamental part of DXC Technology's approach to
135
+ provide guidance for development teams in order to deliver delightful and consistent user experiences to
136
+ our customers: Balance Consistency Visual hierarchy All our components, design tokens, accessibility
137
+ guidelines, responsive design techniques, and layout proposals have been carefully curated by DXC design
138
+ and engineering teams with the objective of creating a unique visual language and ecosystem for our
139
+ applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
140
+ design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
141
+ to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
142
+ design new features, or help us improve the project documentation. If you're interested, definitely
143
+ check out our contribution guidelines.Design principles Halstack design principles are the fundamental
144
+ part of DXC Technology's approach to provide guidance for development teams in order to deliver
145
+ delightful and consistent user experiences to our customers: Balance Consistency Visual hierarchy All
146
+ our components, design tokens, accessibility guidelines, responsive design techniques, and layout
147
+ proposals have been carefully curated by DXC design and engineering teams with the objective of creating
148
+ a unique visual language and ecosystem for our applications. This is the DXC way of creating User
149
+ Experiences. Open Source Halstack is an open source design system, this means that we work towards DXC
150
+ Technology bussines needs, but it is open for anyone to use and contribute back to. We are charmed to
151
+ receive external contributions to help us find bugs, design new features, or help us improve the project
152
+ documentation. If you're interested, definitely check out our contribution guidelines.Design principles
153
+ Halstack design principles are the fundamental part of DXC Technology's approach to provide guidance for
154
+ development teams in order to deliver delightful and consistent user experiences to our customers:
155
+ Balance Consistency Visual hierarchy All our components, design tokens, accessibility guidelines,
156
+ responsive design techniques, and layout proposals have been carefully curated by DXC design and
157
+ engineering teams with the objective of creating a unique visual language and ecosystem for our
158
+ applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
159
+ design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
160
+ to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
161
+ design new features, or help us improve the project documentation. If you're interested, definitely
162
+ check out our contribution guidelines.
163
+ </DxcParagraph>
164
+ </Content>
165
+ </Content>
166
+ <Content id="components">
167
+ <DxcHeading level={1} text="Components" margin={{ top: "small", bottom: "xsmall" }} />
168
+ <Content id="components-introduction">
169
+ <DxcHeading level={2} text="Introduction" margin={{ top: "xsmall", bottom: "xsmall" }} />
170
+ <DxcParagraph>
171
+ Design principles Halstack design principles are the fundamental part of DXC Technology's approach to
172
+ provide guidance for development teams in order to deliver delightful and consistent user experiences to
173
+ our customers: Balance Consistency Visual hierarchy All our components, design tokens, accessibility
174
+ guidelines, responsive design techniques, and layout proposals have been carefully curated by DXC design
175
+ and engineering teams with the objective of creating a unique visual language and ecosystem for our
176
+ applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
177
+ design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
178
+ to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
179
+ design new features, or help us improve the project documentation. If you're interested, definitely
180
+ check out our contribution guidelines.Design principles Halstack design principles are the fundamental
181
+ part of DXC Technology's approach to provide guidance for development teams in order to deliver
182
+ delightful and consistent user experiences to our customers: Balance Consistency Visual hierarchy All
183
+ our components, design tokens, accessibility guidelines, responsive design techniques, and layout
184
+ proposals have been carefully curated by DXC design and engineering teams with the objective of creating
185
+ a unique visual language and ecosystem for our applications. This is the DXC way of creating User
186
+ Experiences. Open Source Halstack is an open source design system, this means that we work towards DXC
187
+ Technology bussines needs, but it is open for anyone to use and contribute back to. We are charmed to
188
+ receive external contributions to help us find bugs, design new features, or help us improve the project
189
+ documentation. If you're interested, definitely check out our contribution guidelines.Design principles
190
+ Halstack design principles are the fundamental part of DXC Technology's approach to provide guidance for
191
+ development teams in order to deliver delightful and consistent user experiences to our customers:
192
+ Balance Consistency Visual hierarchy All our components, design tokens, accessibility guidelines,
193
+ responsive design techniques, and layout proposals have been carefully curated by DXC design and
194
+ engineering teams with the objective of creating a unique visual language and ecosystem for our
195
+ applications. This is the DXC way of creating User Experiences. Open Source Halstack is an open source
196
+ design system, this means that we work towards DXC Technology bussines needs, but it is open for anyone
197
+ to use and contribute back to. We are charmed to receive external contributions to help us find bugs,
198
+ design new features, or help us improve the project documentation. If you're interested, definitely
199
+ check out our contribution guidelines.
200
+ </DxcParagraph>
201
+ </Content>
202
+ <Content id="components-accordion">
203
+ <DxcHeading level={2} text="Accordion" margin={{ top: "xsmall", bottom: "xsmall" }} />
204
+ <DxcParagraph>
205
+ Accordions are used to group similar content and hide or show it depending on user needs or preferences.
206
+ Accordions give users more granular control over the interface and help digest content in stages, rather
207
+ than all at once.
208
+ </DxcParagraph>
209
+ </Content>
210
+ </Content>
211
+ <Content id="principles-very-very-very-very-very-very-very-very-long">
212
+ <DxcHeading level={1} text="Principles" margin={{ top: "small", bottom: "xsmall" }} />
213
+ <Content id="principles-very-very-very-very-very-very-very-very-long-color-very-very-very-very-very-very-very-very-long">
214
+ <DxcHeading level={2} text="Color" margin={{ top: "xsmall", bottom: "xsmall" }} />
215
+ <DxcParagraph>
216
+ The color palette is an essential asset as a communication resource of our design system. Halstack color
217
+ palette brings a unified consistency and helps in guiding the user's perception order. Our color palette
218
+ is based in the HSL model . All our color families are calculated using the lightness value of the
219
+ standard DXC palette colors. Color Tokens Halstack uses tokens to manage color. Appart from a
220
+ multi-purpose greyscale family, purple and blue are the core color families used in our set of
221
+ components. Additional families as red, green and yellow help as feedback role-based color palettes and
222
+ must not be used outside this context.The color palette is an essential asset as a communication
223
+ resource of our design system. Halstack color palette brings a unified consistency and helps in guiding
224
+ the user's perception order. Our color palette is based in the HSL model . All our color families are
225
+ calculated using the lightness value of the standard DXC palette colors. Color Tokens Halstack uses
226
+ tokens to manage color. Appart from a multi-purpose greyscale family, purple and blue are the core color
227
+ families used in our set of components. Additional families as red, green and yellow help as feedback
228
+ role-based color palettes and must not be used outside this context.The color palette is an essential
229
+ asset as a communication resource of our design system. Halstack color palette brings a unified
230
+ consistency and helps in guiding the user's perception order. Our color palette is based in the HSL
231
+ model . All our color families are calculated using the lightness value of the standard DXC palette
232
+ colors. Color Tokens Halstack uses tokens to manage color. Appart from a multi-purpose greyscale family,
233
+ purple and blue are the core color families used in our set of components. Additional families as red,
234
+ green and yellow help as feedback role-based color palettes and must not be used outside this
235
+ context.The color palette is an essential asset as a communication resource of our design system.
236
+ Halstack color palette brings a unified consistency and helps in guiding the user's perception order.
237
+ Our color palette is based in the HSL model . All our color families are calculated using the lightness
238
+ value of the standard DXC palette colors. Color Tokens Halstack uses tokens to manage color. Appart from
239
+ a multi-purpose greyscale family, purple and blue are the core color families used in our set of
240
+ components. Additional families as red, green and yellow help as feedback role-based color palettes and
241
+ must not be used outside this context.The color palette is an essential asset as a communication
242
+ resource of our design system. Halstack color palette brings a unified consistency and helps in guiding
243
+ the user's perception order. Our color palette is based in the HSL model . All our color families are
244
+ calculated using the lightness value of the standard DXC palette colors. Color Tokens Halstack uses
245
+ tokens to manage color. Appart from a multi-purpose greyscale family, purple and blue are the core color
246
+ families used in our set of components. Additional families as red, green and yellow help as feedback
247
+ role-based color palettes and must not be used outside this context.
248
+ </DxcParagraph>
249
+ </Content>
250
+ <Content id="principles-very-very-very-very-very-very-very-very-long-spacingveryveryveryveryveryveryveryverylong">
251
+ <DxcHeading level={2} text="Spacing" margin={{ top: "xsmall", bottom: "xsmall" }} />
252
+ <DxcParagraph>
253
+ In the search of consistent alignment between the elements we provide a spacing scale based on a root
254
+ values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and consistent,
255
+ yet distinct enough, steps between them.In the search of consistent alignment between the elements we
256
+ provide a spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are easily
257
+ multiplied, they provide flexible and consistent, yet distinct enough, steps between them.In the search
258
+ of consistent alignment between the elements we provide a spacing scale based on a root values of 8px
259
+ and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and consistent, yet distinct
260
+ enough, steps between them.In the search of consistent alignment between the elements we provide a
261
+ spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they
262
+ provide flexible and consistent, yet distinct enough, steps between them.In the search of consistent
263
+ alignment between the elements we provide a spacing scale based on a root values of 8px and 4px. The
264
+ numbers 4 and 8 are easily multiplied, they provide flexible and consistent, yet distinct enough, steps
265
+ between them.In the search of consistent alignment between the elements we provide a spacing scale based
266
+ on a root values of 8px and 4px. The numbers 4 and 8 are easily multiplied, they provide flexible and
267
+ consistent, yet distinct enough, steps between them.In the search of consistent alignment between the
268
+ elements we provide a spacing scale based on a root values of 8px and 4px. The numbers 4 and 8 are
269
+ easily multiplied, they provide flexible and consistent, yet distinct enough, steps between them.
270
+ </DxcParagraph>
271
+ </Content>
272
+ <Content id="principles-very-very-very-very-very-very-very-very-long-typography">
273
+ <DxcHeading level={2} text="Typography" margin={{ top: "xsmall", bottom: "xsmall" }} />
274
+ <DxcParagraph>
275
+ Our selected typography helps in structuring our user's experience based on the visual impact that it
276
+ has on the user interface content. It defines what is the first noticeable piece of information or data
277
+ based on the font shape, size, color, or type and it highlights some pieces of text over the rest. Some
278
+ typographic elements used in Halstack Design System include headers, body, taglines, captions, and
279
+ labels. Make sure you include all the different typographic variants in order to enhance the
280
+ application's content structure, including the Heading component which defines different levels of page
281
+ and section titles.Our selected typography helps in structuring our user's experience based on the
282
+ visual impact that it has on the user interface content. It defines what is the first noticeable piece
283
+ of information or data based on the font shape, size, color, or type and it highlights some pieces of
284
+ text over the rest. Some typographic elements used in Halstack Design System include headers, body,
285
+ taglines, captions, and labels. Make sure you include all the different typographic variants in order to
286
+ enhance the application's content structure, including the Heading component which defines different
287
+ levels of page and section titles.Our selected typography helps in structuring our user's experience
288
+ based on the visual impact that it has on the user interface content. It defines what is the first
289
+ noticeable piece of information or data based on the font shape, size, color, or type and it highlights
290
+ some pieces of text over the rest. Some typographic elements used in Halstack Design System include
291
+ headers, body, taglines, captions, and labels. Make sure you include all the different typographic
292
+ variants in order to enhance the application's content structure, including the Heading component which
293
+ defines different levels of page and section titles.Our selected typography helps in structuring our
294
+ user's experience based on the visual impact that it has on the user interface content. It defines what
295
+ is the first noticeable piece of information or data based on the font shape, size, color, or type and
296
+ it highlights some pieces of text over the rest. Some typographic elements used in Halstack Design
297
+ System include headers, body, taglines, captions, and labels. Make sure you include all the different
298
+ typographic variants in order to enhance the application's content structure, including the Heading
299
+ component which defines different levels of page and section titles.Our selected typography helps in
300
+ structuring our user's experience based on the visual impact that it has on the user interface content.
301
+ It defines what is the first noticeable piece of information or data based on the font shape, size,
302
+ color, or type and it highlights some pieces of text over the rest. Some typographic elements used in
303
+ Halstack Design System include headers, body, taglines, captions, and labels. Make sure you include all
304
+ the different typographic variants in order to enhance the application's content structure, including
305
+ the Heading component which defines different levels of page and section titles.
306
+ </DxcParagraph>
307
+ </Content>
308
+ </Content>
309
+ <Content id="componentsveryveryveryveryveryveryveryverylong">
310
+ <DxcHeading level={1} text="Components" margin={{ top: "small", bottom: "xsmall" }} />
311
+ <Content id="componentsveryveryveryveryveryveryveryverylong-accordion">
312
+ <DxcHeading level={2} text="Accordion" margin={{ top: "xsmall", bottom: "xsmall" }} />
313
+ <DxcParagraph>
314
+ Accordions are used to group similar content and hide or show it depending on user needs or preferences.
315
+ Accordions give users more granular control over the interface and help digest content in stages, rather
316
+ than all at once.
317
+ </DxcParagraph>
318
+ </Content>
319
+ </Content>
320
+ </ContentContainer>
321
+ <QuickNavContainer>
322
+ <DxcQuickNav title="Sections" links={links} />
323
+ </QuickNavContainer>
324
+ </Container>
325
+ </ExampleContainer>
326
+ <Title title="Opinionated theme" level={2} />
327
+ <ExampleContainer>
328
+ <HalstackProvider theme={opinionatedTheme}>
329
+ <DxcQuickNav links={defaultLinks} />
330
+ </HalstackProvider>
331
+ </ExampleContainer>
332
+ </>
333
+ );
334
+
335
+ const Container = styled.div`
336
+ display: flex;
337
+ flex-direction: row;
338
+ width: 100%;
339
+ `;
340
+
341
+ const ContentContainer = styled.div`
342
+ display: flex;
343
+ flex-direction: column;
344
+ padding: 60px;
345
+ margin: 0 auto;
346
+ width: 800px;
347
+ `;
348
+
349
+ const Content = styled.div``;
350
+
351
+ const QuickNavContainer = styled.div`
352
+ max-height: calc(100vh - 100px);
353
+ position: sticky;
354
+ top: 100px;
355
+ width: 300px;
356
+ `;
@@ -0,0 +1,21 @@
1
+ type Link = {
2
+ /**
3
+ * Label to be shown in the link.
4
+ */
5
+ label: string;
6
+ /**
7
+ * Sublinks of the link.
8
+ */
9
+ links?: Link[];
10
+ };
11
+ type Props = {
12
+ /**
13
+ * Title of the quick nav component.
14
+ */
15
+ title?: string;
16
+ /**
17
+ * Links to be shown inside the quick nav component.
18
+ */
19
+ links: Link[];
20
+ };
21
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -1,4 +1,4 @@
1
1
  import React from "react";
2
2
  import { RadioProps } from "./types";
3
- declare const _default: React.MemoExoticComponent<({ option, currentValue, onChange, disabledRadioGroup, error, first }: RadioProps) => JSX.Element>;
3
+ declare const _default: React.MemoExoticComponent<({ label, checked, onClick, error, disabled, focused, readOnly, tabIndex, }: RadioProps) => JSX.Element>;
4
4
  export default _default;
@@ -1,96 +1,100 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = 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
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
-
16
11
  var _react = _interopRequireWildcard(require("react"));
17
-
18
12
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
-
20
- var _uuid = require("uuid");
21
-
22
13
  var _useTheme = _interopRequireDefault(require("../useTheme"));
23
-
14
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
24
15
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
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 || _typeof(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
-
16
+ 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); }
17
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
30
18
  var DxcRadio = function DxcRadio(_ref) {
31
- var option = _ref.option,
32
- currentValue = _ref.currentValue,
33
- onChange = _ref.onChange,
34
- disabledRadioGroup = _ref.disabledRadioGroup,
35
- error = _ref.error,
36
- _ref$first = _ref.first,
37
- first = _ref$first === void 0 ? false : _ref$first;
38
-
39
- var _useState = (0, _react.useState)("radio-".concat((0, _uuid.v4)())),
40
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
41
- radioLabelId = _useState2[0];
42
-
43
- var radioRef = (0, _react.useRef)(null);
19
+ var label = _ref.label,
20
+ checked = _ref.checked,
21
+ onClick = _ref.onClick,
22
+ error = _ref.error,
23
+ disabled = _ref.disabled,
24
+ focused = _ref.focused,
25
+ readOnly = _ref.readOnly,
26
+ tabIndex = _ref.tabIndex;
27
+ var radioLabelId = "radio-".concat((0, _react.useId)());
28
+ var ref = (0, _react.useRef)(null);
44
29
  var colorsTheme = (0, _useTheme["default"])();
45
- var checked = option.value === currentValue;
46
- var disabled = disabledRadioGroup || option.disabled;
47
-
48
- var handleRadioOnClick = function handleRadioOnClick() {
49
- onChange(option.value);
30
+ var handleOnClick = function handleOnClick() {
31
+ var _ref$current;
32
+ onClick();
33
+ document.activeElement !== (ref === null || ref === void 0 ? void 0 : ref.current) && (ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.focus());
50
34
  };
51
-
52
- var handleLabelOnClick = function handleLabelOnClick() {
53
- var _radioRef$current;
54
-
55
- onChange(option.value);
56
- radioRef === null || radioRef === void 0 ? void 0 : (_radioRef$current = radioRef.current) === null || _radioRef$current === void 0 ? void 0 : _radioRef$current.focus();
57
- };
58
-
35
+ var _useState = (0, _react.useState)(true),
36
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
37
+ firstUpdate = _useState2[0],
38
+ setFirstUpdate = _useState2[1];
39
+ (0, _react.useEffect)(function () {
40
+ var _ref$current2;
41
+ // Don't apply in the first render
42
+ if (firstUpdate) {
43
+ setFirstUpdate(false);
44
+ return;
45
+ }
46
+ focused && (ref === null || ref === void 0 ? void 0 : (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.focus());
47
+ }, [focused]);
59
48
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
60
49
  theme: colorsTheme.radioGroup
61
- }, /*#__PURE__*/_react["default"].createElement(RadioContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInputContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInput, {
50
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], null, /*#__PURE__*/_react["default"].createElement(RadioContainer, {
51
+ error: error,
62
52
  disabled: disabled,
53
+ readOnly: readOnly,
54
+ onClick: disabled ? undefined : handleOnClick
55
+ }, /*#__PURE__*/_react["default"].createElement(RadioInputContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInput, {
63
56
  error: error,
64
- onClick: handleRadioOnClick,
57
+ disabled: disabled,
58
+ readOnly: readOnly,
65
59
  role: "radio",
66
60
  "aria-checked": checked,
61
+ "aria-disabled": disabled,
67
62
  "aria-labelledby": radioLabelId,
68
- tabIndex: (checked || first) && !disabled ? 0 : -1,
69
- ref: radioRef
63
+ tabIndex: disabled ? -1 : focused ? tabIndex : -1,
64
+ ref: ref
70
65
  }, checked && /*#__PURE__*/_react["default"].createElement(Dot, {
66
+ disabled: disabled,
67
+ readOnly: readOnly,
71
68
  error: error
72
69
  }))), /*#__PURE__*/_react["default"].createElement(Label, {
73
70
  id: radioLabelId,
74
- onClick: handleLabelOnClick,
75
71
  disabled: disabled
76
- }, option.label)));
72
+ }, label))));
77
73
  };
78
-
79
- var RadioContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n"])));
80
-
81
- var RadioInputContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
82
-
83
- var RadioInput = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n width: 18px;\n height: 18px;\n border: 2px solid\n ", ";\n border-radius: 50%;\n box-shadow: 0 0 0 2px transparent;\n\n ", "\n"])), function (props) {
84
- return props.disabled ? props.theme.disabledRadioInputColor : props.error ? props.theme.errorRadioInputColor : props.theme.radioInputColor;
74
+ var getRadioInputStateColor = function getRadioInputStateColor(props, state) {
75
+ switch (state) {
76
+ case "enabled":
77
+ return props.disabled ? props.theme.disabledRadioInputColor : props.error ? props.theme.errorRadioInputColor : props.readOnly ? props.theme.readOnlyRadioInputColor : props.theme.radioInputColor;
78
+ case "hover":
79
+ return props.error ? props.theme.hoverErrorRadioInputColor : props.readOnly ? props.theme.hoverReadOnlyRadioInputColor : props.theme.hoverRadioInputColor;
80
+ case "active":
81
+ return props.error ? props.theme.activeErrorRadioInputColor : props.readOnly ? props.theme.activeReadOnlyRadioInputColor : props.theme.activeRadioInputColor;
82
+ }
83
+ };
84
+ var RadioInputContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
85
+ var RadioInput = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 2px solid ", ";\n border-radius: 50%;\n\n &:focus {\n outline: 2px solid ", ";\n outline-offset: 1px;\n }\n ", "\n"])), function (props) {
86
+ return getRadioInputStateColor(props, "enabled");
87
+ }, function (props) {
88
+ return props.theme.focusBorderColor;
85
89
  }, function (props) {
86
- return !props.disabled ? "\n &:focus {\n outline: 2px solid ".concat(props.theme.focusBorderColor, ";\n outline-offset: 1px;\n }\n &:focus-visible {\n outline: 2px solid ").concat(props.theme.focusBorderColor, ";\n outline-offset: 1px;\n }\n &:hover {\n cursor: pointer;\n border-color: ").concat(props.error ? props.theme.hoverErrorRadioInputColor : props.theme.hoverInputColor, ";\n & > span {\n background-color: ").concat(props.error ? props.theme.hoverErrorRadioInputColor : props.theme.hoverInputColor, ";\n }\n }\n &:active {\n cursor: pointer;\n border-color: ").concat(props.error ? props.theme.activeErrorInputColor : props.theme.activeInputColor, ";\n & > span {\n background-color: ").concat(props.error ? props.theme.activeErrorInputColor : props.theme.activeInputColor, ";\n }\n }\n ") : "\n & > span {\n background-color: ".concat(props.theme.disabledRadioInputColor, ";\n }\n cursor: not-allowed;\n pointer-events: none;\n :focus-visible {\n outline: none;\n }\n ");
90
+ return props.disabled && "pointer-events: none;";
87
91
  });
88
-
89
- var Dot = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: 10px;\n width: 10px;\n background-color: ", ";\n border-radius: 50%;\n"])), function (props) {
90
- return props.error ? props.theme.errorRadioInputColor : props.theme.radioInputColor;
92
+ var Dot = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n height: 10px;\n width: 10px;\n border-radius: 50%;\n background-color: ", ";\n"])), function (props) {
93
+ return getRadioInputStateColor(props, "enabled");
91
94
  });
92
-
93
- var Label = _styledComponents["default"].label(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 0.5rem;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
95
+ var Label = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
96
+ return props.theme.radioInputLabelMargin;
97
+ }, function (props) {
94
98
  return props.theme.fontFamily;
95
99
  }, function (props) {
96
100
  return props.theme.radioInputLabelFontSize;
@@ -101,9 +105,17 @@ var Label = _styledComponents["default"].label(_templateObject5 || (_templateObj
101
105
  }, function (props) {
102
106
  return props.theme.radioInputLabelLineHeight;
103
107
  }, function (props) {
104
- return props.disabled && "color: ".concat(props.theme.disabledRadioInputLabelFontColor, "; pointer-events: none;");
108
+ return props.disabled ? "color: ".concat(props.theme.disabledRadioInputLabelFontColor, ";") : "color: ".concat(props.theme.radioInputLabelFontColor);
105
109
  });
106
-
107
- var _default = /*#__PURE__*/_react["default"].memo(DxcRadio);
108
-
109
- exports["default"] = _default;
110
+ var RadioContainer = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n\n &:hover {\n ", " {\n border-color: ", ";\n }\n ", " {\n background-color: ", ";\n }\n }\n &:active {\n ", " {\n border-color: ", ";\n }\n ", " {\n background-color: ", ";\n }\n }\n"])), function (props) {
111
+ return props.disabled ? "not-allowed" : props.readOnly ? "default" : "pointer";
112
+ }, RadioInput, function (props) {
113
+ return !props.disabled && getRadioInputStateColor(props, "hover");
114
+ }, Dot, function (props) {
115
+ return !props.disabled && getRadioInputStateColor(props, "hover");
116
+ }, RadioInput, function (props) {
117
+ return !props.disabled && getRadioInputStateColor(props, "active");
118
+ }, Dot, function (props) {
119
+ return !props.disabled && getRadioInputStateColor(props, "active");
120
+ });
121
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(DxcRadio);
@@ -0,0 +1 @@
1
+ export {};