@dxc-technology/halstack-react 0.0.0-9253572 → 0.0.0-9282b45

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 (364) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +7 -6
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +129 -237
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +69 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +68 -105
  13. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  14. package/accordion-group/AccordionGroup.test.js +126 -0
  15. package/accordion-group/types.d.ts +79 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +44 -154
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +15 -17
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +37 -77
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +44 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +4 -0
  44. package/button/Button.js +63 -145
  45. package/button/Button.stories.tsx +283 -0
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +53 -0
  48. package/button/types.js +5 -0
  49. package/card/Card.d.ts +4 -0
  50. package/card/Card.js +44 -137
  51. package/card/Card.stories.tsx +201 -0
  52. package/card/Card.test.js +50 -0
  53. package/card/ice-cream.jpg +0 -0
  54. package/card/types.d.ts +68 -0
  55. package/card/types.js +5 -0
  56. package/checkbox/Checkbox.d.ts +4 -0
  57. package/checkbox/Checkbox.js +106 -156
  58. package/checkbox/Checkbox.stories.tsx +188 -0
  59. package/checkbox/Checkbox.test.js +155 -0
  60. package/checkbox/types.d.ts +64 -0
  61. package/checkbox/types.js +5 -0
  62. package/chip/Chip.d.ts +4 -0
  63. package/chip/Chip.js +26 -130
  64. package/chip/Chip.stories.tsx +119 -0
  65. package/chip/Chip.test.js +56 -0
  66. package/chip/types.d.ts +45 -0
  67. package/chip/types.js +5 -0
  68. package/common/RequiredComponent.js +3 -11
  69. package/common/variables.js +322 -381
  70. package/date-input/DateInput.d.ts +4 -0
  71. package/date-input/DateInput.js +83 -111
  72. package/date-input/DateInput.stories.tsx +138 -0
  73. package/date-input/DateInput.test.js +479 -0
  74. package/date-input/types.d.ts +107 -0
  75. package/date-input/types.js +5 -0
  76. package/dialog/Dialog.d.ts +4 -0
  77. package/dialog/Dialog.js +60 -116
  78. package/dialog/Dialog.stories.tsx +267 -0
  79. package/dialog/Dialog.test.js +70 -0
  80. package/dialog/types.d.ts +44 -0
  81. package/dialog/types.js +5 -0
  82. package/dropdown/Dropdown.d.ts +4 -0
  83. package/dropdown/Dropdown.js +243 -399
  84. package/dropdown/Dropdown.stories.tsx +312 -0
  85. package/dropdown/Dropdown.test.js +590 -0
  86. package/dropdown/DropdownMenu.d.ts +4 -0
  87. package/dropdown/DropdownMenu.js +80 -0
  88. package/dropdown/DropdownMenuItem.d.ts +4 -0
  89. package/dropdown/DropdownMenuItem.js +92 -0
  90. package/dropdown/types.d.ts +100 -0
  91. package/dropdown/types.js +5 -0
  92. package/file-input/FileInput.d.ts +4 -0
  93. package/file-input/FileInput.js +200 -251
  94. package/file-input/FileInput.stories.tsx +507 -0
  95. package/file-input/FileInput.test.js +457 -0
  96. package/file-input/FileItem.d.ts +14 -0
  97. package/file-input/FileItem.js +44 -145
  98. package/file-input/types.d.ts +112 -0
  99. package/file-input/types.js +5 -0
  100. package/flex/Flex.d.ts +4 -0
  101. package/flex/Flex.js +69 -0
  102. package/flex/Flex.stories.tsx +103 -0
  103. package/flex/types.d.ts +32 -0
  104. package/flex/types.js +5 -0
  105. package/footer/Footer.d.ts +4 -0
  106. package/footer/Footer.js +50 -286
  107. package/footer/Footer.stories.tsx +137 -0
  108. package/footer/Footer.test.js +109 -0
  109. package/footer/Icons.d.ts +2 -0
  110. package/footer/Icons.js +16 -16
  111. package/footer/types.d.ts +66 -0
  112. package/footer/types.js +5 -0
  113. package/header/Header.d.ts +7 -0
  114. package/header/Header.js +131 -296
  115. package/header/Header.stories.tsx +172 -0
  116. package/header/Header.test.js +79 -0
  117. package/header/Icons.d.ts +2 -0
  118. package/header/Icons.js +9 -34
  119. package/header/types.d.ts +48 -0
  120. package/header/types.js +5 -0
  121. package/heading/Heading.d.ts +4 -0
  122. package/heading/Heading.js +25 -96
  123. package/heading/Heading.stories.tsx +54 -0
  124. package/heading/Heading.test.js +186 -0
  125. package/heading/types.d.ts +33 -0
  126. package/heading/types.js +5 -0
  127. package/inset/Inset.d.ts +3 -0
  128. package/inset/Inset.js +51 -0
  129. package/inset/Inset.stories.tsx +229 -0
  130. package/inset/types.d.ts +37 -0
  131. package/inset/types.js +5 -0
  132. package/layout/ApplicationLayout.d.ts +20 -0
  133. package/layout/ApplicationLayout.js +76 -232
  134. package/layout/ApplicationLayout.stories.tsx +162 -0
  135. package/layout/Icons.d.ts +5 -0
  136. package/layout/Icons.js +19 -8
  137. package/layout/SidenavContext.d.ts +5 -0
  138. package/layout/SidenavContext.js +19 -0
  139. package/layout/types.d.ts +42 -0
  140. package/layout/types.js +5 -0
  141. package/link/Link.d.ts +4 -0
  142. package/link/Link.js +64 -165
  143. package/link/Link.stories.tsx +193 -0
  144. package/link/Link.test.js +83 -0
  145. package/link/types.d.ts +54 -0
  146. package/link/types.js +5 -0
  147. package/main.d.ts +44 -40
  148. package/main.js +114 -104
  149. package/number-input/NumberInput.d.ts +4 -0
  150. package/number-input/NumberInput.js +21 -81
  151. package/number-input/NumberInput.stories.tsx +115 -0
  152. package/number-input/NumberInput.test.js +506 -0
  153. package/number-input/NumberInputContext.d.ts +4 -0
  154. package/number-input/NumberInputContext.js +5 -2
  155. package/number-input/numberInputContextTypes.d.ts +19 -0
  156. package/number-input/numberInputContextTypes.js +5 -0
  157. package/number-input/types.d.ts +124 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +30 -23
  160. package/paginator/Icons.js +9 -9
  161. package/paginator/Paginator.d.ts +4 -0
  162. package/paginator/Paginator.js +32 -166
  163. package/paginator/Paginator.stories.tsx +63 -0
  164. package/paginator/Paginator.test.js +308 -0
  165. package/paginator/types.d.ts +38 -0
  166. package/paginator/types.js +5 -0
  167. package/paragraph/Paragraph.d.ts +6 -0
  168. package/paragraph/Paragraph.js +38 -0
  169. package/paragraph/Paragraph.stories.tsx +44 -0
  170. package/password-input/PasswordInput.d.ts +4 -0
  171. package/password-input/PasswordInput.js +44 -79
  172. package/password-input/PasswordInput.stories.tsx +131 -0
  173. package/password-input/PasswordInput.test.js +181 -0
  174. package/password-input/types.d.ts +110 -0
  175. package/password-input/types.js +5 -0
  176. package/progress-bar/ProgressBar.d.ts +4 -0
  177. package/progress-bar/ProgressBar.js +72 -138
  178. package/progress-bar/ProgressBar.stories.jsx +60 -0
  179. package/progress-bar/ProgressBar.test.js +110 -0
  180. package/progress-bar/types.d.ts +36 -0
  181. package/progress-bar/types.js +5 -0
  182. package/quick-nav/QuickNav.d.ts +4 -0
  183. package/quick-nav/QuickNav.js +117 -0
  184. package/quick-nav/QuickNav.stories.tsx +342 -0
  185. package/quick-nav/types.d.ts +21 -0
  186. package/quick-nav/types.js +5 -0
  187. package/radio-group/Radio.d.ts +4 -0
  188. package/radio-group/Radio.js +156 -0
  189. package/radio-group/RadioGroup.d.ts +4 -0
  190. package/radio-group/RadioGroup.js +283 -0
  191. package/radio-group/RadioGroup.stories.tsx +101 -0
  192. package/radio-group/RadioGroup.test.js +722 -0
  193. package/radio-group/types.d.ts +114 -0
  194. package/radio-group/types.js +5 -0
  195. package/resultsetTable/ResultsetTable.d.ts +4 -0
  196. package/resultsetTable/ResultsetTable.js +43 -147
  197. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  198. package/resultsetTable/ResultsetTable.test.js +348 -0
  199. package/resultsetTable/types.d.ts +67 -0
  200. package/resultsetTable/types.js +5 -0
  201. package/select/Icons.d.ts +10 -0
  202. package/select/Icons.js +93 -0
  203. package/select/Listbox.d.ts +4 -0
  204. package/select/Listbox.js +198 -0
  205. package/select/Option.d.ts +4 -0
  206. package/select/Option.js +110 -0
  207. package/select/Select.d.ts +4 -0
  208. package/select/Select.js +231 -724
  209. package/select/Select.stories.tsx +627 -0
  210. package/select/Select.test.js +2233 -0
  211. package/select/types.d.ts +210 -0
  212. package/select/types.js +5 -0
  213. package/sidenav/Sidenav.d.ts +10 -0
  214. package/sidenav/Sidenav.js +194 -105
  215. package/sidenav/Sidenav.stories.tsx +180 -0
  216. package/sidenav/Sidenav.test.js +44 -0
  217. package/sidenav/types.d.ts +73 -0
  218. package/sidenav/types.js +5 -0
  219. package/slider/Slider.d.ts +4 -0
  220. package/slider/Slider.js +162 -224
  221. package/slider/Slider.stories.tsx +183 -0
  222. package/slider/Slider.test.js +250 -0
  223. package/slider/types.d.ts +82 -0
  224. package/slider/types.js +5 -0
  225. package/spinner/Spinner.d.ts +4 -0
  226. package/spinner/Spinner.js +46 -177
  227. package/spinner/Spinner.stories.jsx +103 -0
  228. package/spinner/Spinner.test.js +64 -0
  229. package/spinner/types.d.ts +32 -0
  230. package/spinner/types.js +5 -0
  231. package/switch/Switch.d.ts +4 -0
  232. package/switch/Switch.js +158 -119
  233. package/switch/Switch.stories.tsx +138 -0
  234. package/switch/Switch.test.js +225 -0
  235. package/switch/types.d.ts +61 -0
  236. package/switch/types.js +5 -0
  237. package/table/Table.d.ts +4 -0
  238. package/table/Table.js +12 -26
  239. package/table/Table.stories.jsx +277 -0
  240. package/table/Table.test.js +26 -0
  241. package/table/types.d.ts +21 -0
  242. package/table/types.js +5 -0
  243. package/tabs/Tab.d.ts +4 -0
  244. package/tabs/Tab.js +135 -0
  245. package/tabs/Tabs.d.ts +4 -0
  246. package/tabs/Tabs.js +353 -229
  247. package/tabs/Tabs.stories.tsx +186 -0
  248. package/tabs/Tabs.test.js +351 -0
  249. package/tabs/types.d.ts +92 -0
  250. package/tabs/types.js +5 -0
  251. package/tabs-nav/NavTabs.d.ts +8 -0
  252. package/tabs-nav/NavTabs.js +125 -0
  253. package/tabs-nav/NavTabs.stories.tsx +170 -0
  254. package/tabs-nav/NavTabs.test.js +82 -0
  255. package/tabs-nav/Tab.d.ts +4 -0
  256. package/tabs-nav/Tab.js +130 -0
  257. package/tabs-nav/types.d.ts +53 -0
  258. package/tabs-nav/types.js +5 -0
  259. package/tag/Tag.d.ts +4 -0
  260. package/tag/Tag.js +45 -144
  261. package/tag/Tag.stories.tsx +142 -0
  262. package/tag/Tag.test.js +60 -0
  263. package/tag/types.d.ts +69 -0
  264. package/tag/types.js +5 -0
  265. package/text-input/Icons.d.ts +8 -0
  266. package/text-input/Icons.js +60 -0
  267. package/text-input/Suggestion.d.ts +4 -0
  268. package/text-input/Suggestion.js +57 -0
  269. package/text-input/Suggestions.d.ts +4 -0
  270. package/text-input/Suggestions.js +134 -0
  271. package/text-input/TextInput.d.ts +4 -0
  272. package/text-input/TextInput.js +256 -575
  273. package/text-input/TextInput.stories.tsx +481 -0
  274. package/text-input/TextInput.test.js +1714 -0
  275. package/text-input/types.d.ts +197 -0
  276. package/text-input/types.js +5 -0
  277. package/textarea/Textarea.d.ts +4 -0
  278. package/textarea/Textarea.js +50 -142
  279. package/textarea/Textarea.stories.jsx +157 -0
  280. package/textarea/Textarea.test.js +437 -0
  281. package/textarea/types.d.ts +137 -0
  282. package/textarea/types.js +5 -0
  283. package/toggle-group/ToggleGroup.d.ts +4 -0
  284. package/toggle-group/ToggleGroup.js +36 -148
  285. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  286. package/toggle-group/ToggleGroup.test.js +156 -0
  287. package/toggle-group/types.d.ts +105 -0
  288. package/toggle-group/types.js +5 -0
  289. package/typography/Typography.d.ts +4 -0
  290. package/typography/Typography.js +131 -0
  291. package/typography/Typography.stories.tsx +198 -0
  292. package/typography/types.d.ts +18 -0
  293. package/typography/types.js +5 -0
  294. package/useTheme.d.ts +2 -0
  295. package/useTheme.js +2 -2
  296. package/useTranslatedLabels.d.ts +2 -0
  297. package/useTranslatedLabels.js +20 -0
  298. package/wizard/Wizard.d.ts +4 -0
  299. package/wizard/Wizard.js +132 -252
  300. package/wizard/Wizard.stories.tsx +233 -0
  301. package/wizard/Wizard.test.js +141 -0
  302. package/wizard/types.d.ts +65 -0
  303. package/wizard/types.js +5 -0
  304. package/ThemeContext.js +0 -250
  305. package/V3Select/V3Select.js +0 -549
  306. package/V3Select/index.d.ts +0 -27
  307. package/V3Textarea/V3Textarea.js +0 -264
  308. package/V3Textarea/index.d.ts +0 -27
  309. package/accordion/index.d.ts +0 -28
  310. package/accordion-group/index.d.ts +0 -16
  311. package/alert/index.d.ts +0 -51
  312. package/box/index.d.ts +0 -25
  313. package/button/Button.stories.js +0 -27
  314. package/button/index.d.ts +0 -24
  315. package/card/index.d.ts +0 -22
  316. package/checkbox/index.d.ts +0 -24
  317. package/chip/index.d.ts +0 -22
  318. package/date/Date.js +0 -379
  319. package/date/index.d.ts +0 -27
  320. package/date-input/index.d.ts +0 -95
  321. package/dialog/index.d.ts +0 -18
  322. package/dropdown/index.d.ts +0 -26
  323. package/file-input/index.d.ts +0 -81
  324. package/footer/index.d.ts +0 -25
  325. package/header/index.d.ts +0 -25
  326. package/heading/index.d.ts +0 -17
  327. package/input-text/Icons.js +0 -22
  328. package/input-text/InputText.js +0 -705
  329. package/input-text/index.d.ts +0 -36
  330. package/link/index.d.ts +0 -23
  331. package/number-input/index.d.ts +0 -113
  332. package/paginator/index.d.ts +0 -20
  333. package/password-input/index.d.ts +0 -94
  334. package/progress-bar/index.d.ts +0 -18
  335. package/radio/Radio.js +0 -209
  336. package/radio/index.d.ts +0 -23
  337. package/resultsetTable/index.d.ts +0 -19
  338. package/select/index.d.ts +0 -131
  339. package/sidenav/index.d.ts +0 -13
  340. package/slider/index.d.ts +0 -29
  341. package/spinner/index.d.ts +0 -17
  342. package/switch/index.d.ts +0 -24
  343. package/table/index.d.ts +0 -13
  344. package/tabs/index.d.ts +0 -19
  345. package/tag/index.d.ts +0 -24
  346. package/text-input/index.d.ts +0 -135
  347. package/textarea/index.d.ts +0 -117
  348. package/toggle/Toggle.js +0 -220
  349. package/toggle/index.d.ts +0 -21
  350. package/toggle-group/index.d.ts +0 -21
  351. package/upload/Upload.js +0 -205
  352. package/upload/buttons-upload/ButtonsUpload.js +0 -135
  353. package/upload/buttons-upload/Icons.js +0 -40
  354. package/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  355. package/upload/dragAndDropArea/Icons.js +0 -39
  356. package/upload/file-upload/FileToUpload.js +0 -189
  357. package/upload/file-upload/Icons.js +0 -66
  358. package/upload/files-upload/FilesToUpload.js +0 -123
  359. package/upload/index.d.ts +0 -15
  360. package/upload/transaction/Icons.js +0 -160
  361. package/upload/transaction/Transaction.js +0 -148
  362. package/upload/transactions/Transactions.js +0 -138
  363. package/wizard/Icons.js +0 -65
  364. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,180 @@
1
+ import React from "react";
2
+ import DxcSidenav from "./Sidenav";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { userEvent, within } from "@storybook/testing-library";
6
+
7
+ export default {
8
+ title: "Sidenav",
9
+ component: DxcSidenav,
10
+ };
11
+
12
+ const iconSVG = (
13
+ <svg viewBox="0 0 24 24" fill="currentColor">
14
+ <path d="M0 0h24v24H0z" fill="none" />
15
+ <path d="M12 21.35l-1.45-1.32C5.4 15.36 2 12.28 2 8.5 2 5.42 4.42 3 7.5 3c1.74 0 3.41.81 4.5 2.09C13.09 3.81 14.76 3 16.5 3 19.58 3 22 5.42 22 8.5c0 3.78-3.4 6.86-8.55 11.54L12 21.35z" />
16
+ </svg>
17
+ );
18
+
19
+ const TitleComponent = () => {
20
+ return <DxcSidenav.Title>Dxc technology</DxcSidenav.Title>;
21
+ };
22
+
23
+ export const Chromatic = () => (
24
+ <>
25
+ <ExampleContainer>
26
+ <Title title="Default sidenav" theme="light" level={4} />
27
+ <DxcSidenav title={<TitleComponent />}>
28
+ <DxcSidenav.Section>
29
+ <p>
30
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
31
+ vitae lacinia libero.
32
+ </p>
33
+ </DxcSidenav.Section>
34
+ <DxcSidenav.Section>
35
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
36
+ <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
37
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
38
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
39
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
40
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
41
+ </DxcSidenav.Group>
42
+ </DxcSidenav.Section>
43
+ <DxcSidenav.Section>
44
+ <DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
45
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
46
+ <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
47
+ </DxcSidenav.Group>
48
+ <DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
49
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
50
+ <DxcSidenav.Group collapsable={false} title="Section Group">
51
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
52
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
53
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
54
+ </DxcSidenav.Group>
55
+ </DxcSidenav.Section>
56
+ </DxcSidenav>
57
+ </ExampleContainer>
58
+ </>
59
+ );
60
+
61
+ export const FocusedSidenav = () => (
62
+ <ExampleContainer pseudoState="pseudo-focus">
63
+ <Title title="Default sidenav" theme="light" level={4} />
64
+ <DxcSidenav title={<TitleComponent />}>
65
+ <DxcSidenav.Section>
66
+ <p>
67
+ Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse vitae
68
+ lacinia libero.
69
+ </p>
70
+ </DxcSidenav.Section>
71
+ <DxcSidenav.Section>
72
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
73
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
74
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
75
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
76
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
77
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
78
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
79
+ </DxcSidenav.Group>
80
+ </DxcSidenav.Section>
81
+ <DxcSidenav.Section>
82
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
83
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
84
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
85
+ </DxcSidenav.Group>
86
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
87
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
88
+ <DxcSidenav.Group collapsable={false} title="Section Group">
89
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
90
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
91
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
92
+ </DxcSidenav.Group>
93
+ </DxcSidenav.Section>
94
+ </DxcSidenav>
95
+ </ExampleContainer>
96
+ );
97
+
98
+ const CollapsedGroup = () => (
99
+ <>
100
+ <ExampleContainer>
101
+ <Title title="Default sidenav" theme="light" level={4} />
102
+ <DxcSidenav title={<TitleComponent />}>
103
+ <DxcSidenav.Section>
104
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group" icon={iconSVG}>
105
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
106
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
107
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
108
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
109
+ </DxcSidenav.Group>
110
+ </DxcSidenav.Section>
111
+ <DxcSidenav.Section>
112
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
113
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
114
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
115
+ </DxcSidenav.Group>
116
+ <DxcSidenav.Group collapsable={false} title="Section Group">
117
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
118
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
119
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
120
+ </DxcSidenav.Group>
121
+ </DxcSidenav.Section>
122
+ </DxcSidenav>
123
+ </ExampleContainer>
124
+ </>
125
+ );
126
+
127
+ const HoverSidenav = () => (
128
+ <ExampleContainer pseudoState="pseudo-hover">
129
+ <Title title="Default sidenav" theme="light" level={4} />
130
+ <DxcSidenav title={<TitleComponent />}>
131
+ <DxcSidenav.Section>
132
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
133
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
134
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
135
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
136
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
137
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
138
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
139
+ </DxcSidenav.Group>
140
+ </DxcSidenav.Section>
141
+ <DxcSidenav.Section>
142
+ <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
143
+ <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
144
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
145
+ </DxcSidenav.Group>
146
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
147
+ <DxcSidenav.Link>Single Link</DxcSidenav.Link>
148
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
149
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
150
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
151
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
152
+ </DxcSidenav.Group>
153
+
154
+ <DxcSidenav.Group collapsable={true} title="Collapsable Group">
155
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
156
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
157
+ <DxcSidenav.Link>Group Link</DxcSidenav.Link>
158
+ </DxcSidenav.Group>
159
+ </DxcSidenav.Section>
160
+ </DxcSidenav>
161
+ </ExampleContainer>
162
+ );
163
+
164
+ export const CollapseGroup = CollapsedGroup.bind({});
165
+ CollapseGroup.play = async ({ canvasElement }) => {
166
+ const canvas = within(canvasElement);
167
+ const collapsableGroups = canvas.getAllByText("Collapsable Group");
168
+ collapsableGroups.forEach((group) => {
169
+ userEvent.click(group);
170
+ });
171
+ };
172
+
173
+ export const CollapseHoverGroup = HoverSidenav.bind({});
174
+ CollapseHoverGroup.play = async ({ canvasElement }) => {
175
+ const canvas = within(canvasElement);
176
+ const collapsableGroups = canvas.getAllByText("Collapsable Group");
177
+ collapsableGroups.forEach((group) => {
178
+ userEvent.click(group);
179
+ });
180
+ };
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Sidenav = _interopRequireDefault(require("./Sidenav.tsx"));
10
+
11
+ describe("Sidenav component tests", function () {
12
+ test("Sidenav renders anchors and Section correctly", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement("p", null, "nav-content-test"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
14
+ href: "#"
15
+ }, "Link")))),
16
+ getByText = _render.getByText;
17
+
18
+ expect(getByText("nav-content-test")).toBeTruthy();
19
+ var link = getByText("Link");
20
+ expect(link.closest("a").getAttribute("href")).toBe("#");
21
+ });
22
+ test("Sidenav renders groups correctly", function () {
23
+ var sidenav = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Group, {
24
+ title: "Collapsable",
25
+ collapsable: true
26
+ }, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
27
+ href: "#"
28
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
29
+ href: "#"
30
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
31
+ href: "#"
32
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
33
+ href: "#"
34
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
35
+ href: "#"
36
+ }, "Lorem ipsum")))));
37
+ expect(sidenav.getByText("Collapsable")).toBeTruthy();
38
+ expect(sidenav.getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("true");
39
+
40
+ _react2.fireEvent.click(sidenav.getByText("Collapsable"));
41
+
42
+ expect(sidenav.getAllByRole("button")[0].getAttribute("aria-expanded")).toBe("false");
43
+ });
44
+ });
@@ -0,0 +1,73 @@
1
+ /// <reference types="react" />
2
+ declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ declare type SidenavPropsType = {
4
+ /**
5
+ * The area inside the sidenav. This area can be used to render the content inside the sidenav.
6
+ */
7
+ children: React.ReactNode;
8
+ /**
9
+ * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
10
+ */
11
+ title?: React.ReactNode;
12
+ };
13
+ export declare type SidenavTitlePropsType = {
14
+ /**
15
+ * The area inside the sidenav title. This area can be used to render custom content.
16
+ */
17
+ children: React.ReactNode;
18
+ };
19
+ export declare type SidenavSectionPropsType = {
20
+ /**
21
+ * The area inside the sidenav section. This area can be used to render sidenav groups, links and custom content.
22
+ */
23
+ children: React.ReactNode;
24
+ };
25
+ export declare type SidenavGroupPropsType = {
26
+ /**
27
+ * The area inside the sidenav group. This area can be used to render sidenav links.
28
+ */
29
+ children: React.ReactNode;
30
+ /**
31
+ * The title of the sidenav group.
32
+ */
33
+ title?: string;
34
+ /**
35
+ * If true the sidenav group title will be considered a button and the group will be collapsable.
36
+ */
37
+ collapsable?: boolean;
38
+ /**
39
+ * The icon to be displayed next to the title of the group.
40
+ */
41
+ icon?: string | SVG;
42
+ };
43
+ export declare type SidenavLinkPropsType = {
44
+ /**
45
+ * Value of the tabindex.
46
+ */
47
+ tabIndex?: number;
48
+ /**
49
+ * Page to be opened when the user clicks on the link.
50
+ */
51
+ href?: string;
52
+ /**
53
+ * If true, the page is opened in a new browser tab.
54
+ */
55
+ newWindow?: boolean;
56
+ /**
57
+ * Element or path used as the icon that will be placed to the left of the link text.
58
+ */
59
+ icon?: string | SVG;
60
+ /**
61
+ * If true, the link will be marked as selected. This can also affect the group if it is closed to indicate that one of its links is selected.
62
+ */
63
+ selected?: boolean;
64
+ /**
65
+ * The area inside the sidenav link.
66
+ */
67
+ children: string;
68
+ /**
69
+ * This function will be called when the user clicks the link.
70
+ */
71
+ onClick?: ($event: any) => void;
72
+ };
73
+ export default SidenavPropsType;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import SliderPropsType from "./types";
3
+ declare const DxcSlider: ({ label, name, defaultValue, value, helperText, minValue, maxValue, step, showLimitsValues, showInput, disabled, marks, onChange, onDragEnd, labelFormatCallback, margin, size, }: SliderPropsType) => JSX.Element;
4
+ export default DxcSlider;