@dxc-technology/halstack-react 0.0.0-abf35d9 → 0.0.0-accd42b

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 (341) hide show
  1. package/README.md +46 -0
  2. package/dist/index.d.mts +6665 -0
  3. package/dist/index.d.ts +6665 -0
  4. package/dist/index.js +14521 -0
  5. package/dist/index.mjs +14463 -0
  6. package/package.json +68 -66
  7. package/BackgroundColorContext.d.ts +0 -10
  8. package/BackgroundColorContext.js +0 -47
  9. package/HalstackContext.d.ts +0 -1336
  10. package/HalstackContext.js +0 -335
  11. package/accordion/Accordion.d.ts +0 -4
  12. package/accordion/Accordion.js +0 -234
  13. package/accordion/Accordion.stories.tsx +0 -395
  14. package/accordion/Accordion.test.js +0 -71
  15. package/accordion/types.d.ts +0 -69
  16. package/accordion/types.js +0 -5
  17. package/accordion-group/AccordionGroup.d.ts +0 -7
  18. package/accordion-group/AccordionGroup.js +0 -149
  19. package/accordion-group/AccordionGroup.stories.tsx +0 -251
  20. package/accordion-group/AccordionGroup.test.js +0 -126
  21. package/accordion-group/types.d.ts +0 -79
  22. package/accordion-group/types.js +0 -5
  23. package/alert/Alert.d.ts +0 -4
  24. package/alert/Alert.js +0 -291
  25. package/alert/Alert.stories.tsx +0 -198
  26. package/alert/Alert.test.js +0 -92
  27. package/alert/types.d.ts +0 -49
  28. package/alert/types.js +0 -5
  29. package/badge/Badge.d.ts +0 -4
  30. package/badge/Badge.js +0 -61
  31. package/badge/types.d.ts +0 -5
  32. package/badge/types.js +0 -5
  33. package/bleed/Bleed.d.ts +0 -3
  34. package/bleed/Bleed.js +0 -51
  35. package/bleed/Bleed.stories.tsx +0 -341
  36. package/bleed/types.d.ts +0 -37
  37. package/bleed/types.js +0 -5
  38. package/box/Box.d.ts +0 -4
  39. package/box/Box.js +0 -114
  40. package/box/Box.stories.tsx +0 -147
  41. package/box/Box.test.js +0 -18
  42. package/box/types.d.ts +0 -44
  43. package/box/types.js +0 -5
  44. package/bulleted-list/BulletedList.d.ts +0 -7
  45. package/bulleted-list/BulletedList.js +0 -123
  46. package/bulleted-list/BulletedList.stories.tsx +0 -200
  47. package/bulleted-list/types.d.ts +0 -11
  48. package/bulleted-list/types.js +0 -5
  49. package/button/Button.d.ts +0 -4
  50. package/button/Button.js +0 -154
  51. package/button/Button.stories.tsx +0 -425
  52. package/button/Button.test.js +0 -35
  53. package/button/types.d.ts +0 -53
  54. package/button/types.js +0 -5
  55. package/card/Card.d.ts +0 -4
  56. package/card/Card.js +0 -160
  57. package/card/Card.stories.tsx +0 -200
  58. package/card/Card.test.js +0 -50
  59. package/card/ice-cream.jpg +0 -0
  60. package/card/types.d.ts +0 -68
  61. package/card/types.js +0 -5
  62. package/checkbox/Checkbox.d.ts +0 -4
  63. package/checkbox/Checkbox.js +0 -250
  64. package/checkbox/Checkbox.stories.tsx +0 -260
  65. package/checkbox/Checkbox.test.js +0 -155
  66. package/checkbox/types.d.ts +0 -68
  67. package/checkbox/types.js +0 -5
  68. package/chip/Chip.d.ts +0 -4
  69. package/chip/Chip.js +0 -153
  70. package/chip/Chip.stories.tsx +0 -206
  71. package/chip/Chip.test.js +0 -54
  72. package/chip/types.d.ts +0 -45
  73. package/chip/types.js +0 -5
  74. package/common/OpenSans.css +0 -81
  75. package/common/fonts/OpenSans-Bold.ttf +0 -0
  76. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  77. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  78. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  79. package/common/fonts/OpenSans-Italic.ttf +0 -0
  80. package/common/fonts/OpenSans-Light.ttf +0 -0
  81. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  82. package/common/fonts/OpenSans-Regular.ttf +0 -0
  83. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  84. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  85. package/common/utils.d.ts +0 -1
  86. package/common/utils.js +0 -22
  87. package/common/variables.d.ts +0 -1625
  88. package/common/variables.js +0 -1504
  89. package/date-input/Calendar.d.ts +0 -4
  90. package/date-input/Calendar.js +0 -258
  91. package/date-input/DateInput.d.ts +0 -4
  92. package/date-input/DateInput.js +0 -269
  93. package/date-input/DateInput.stories.tsx +0 -304
  94. package/date-input/DateInput.test.js +0 -835
  95. package/date-input/DatePicker.d.ts +0 -4
  96. package/date-input/DatePicker.js +0 -146
  97. package/date-input/Icons.d.ts +0 -6
  98. package/date-input/Icons.js +0 -75
  99. package/date-input/YearPicker.d.ts +0 -4
  100. package/date-input/YearPicker.js +0 -126
  101. package/date-input/types.d.ts +0 -158
  102. package/date-input/types.js +0 -5
  103. package/dialog/Dialog.d.ts +0 -4
  104. package/dialog/Dialog.js +0 -149
  105. package/dialog/Dialog.stories.tsx +0 -319
  106. package/dialog/Dialog.test.js +0 -369
  107. package/dialog/types.d.ts +0 -44
  108. package/dialog/types.js +0 -5
  109. package/dropdown/Dropdown.d.ts +0 -4
  110. package/dropdown/Dropdown.js +0 -388
  111. package/dropdown/Dropdown.stories.tsx +0 -438
  112. package/dropdown/Dropdown.test.js +0 -586
  113. package/dropdown/DropdownMenu.d.ts +0 -4
  114. package/dropdown/DropdownMenu.js +0 -70
  115. package/dropdown/DropdownMenuItem.d.ts +0 -4
  116. package/dropdown/DropdownMenuItem.js +0 -79
  117. package/dropdown/types.d.ts +0 -100
  118. package/dropdown/types.js +0 -5
  119. package/file-input/FileInput.d.ts +0 -4
  120. package/file-input/FileInput.js +0 -547
  121. package/file-input/FileInput.stories.tsx +0 -618
  122. package/file-input/FileInput.test.js +0 -457
  123. package/file-input/FileItem.d.ts +0 -4
  124. package/file-input/FileItem.js +0 -162
  125. package/file-input/types.d.ts +0 -129
  126. package/file-input/types.js +0 -5
  127. package/flex/Flex.d.ts +0 -4
  128. package/flex/Flex.js +0 -69
  129. package/flex/Flex.stories.tsx +0 -103
  130. package/flex/types.d.ts +0 -32
  131. package/flex/types.js +0 -5
  132. package/footer/Footer.d.ts +0 -4
  133. package/footer/Footer.js +0 -183
  134. package/footer/Footer.stories.tsx +0 -228
  135. package/footer/Footer.test.js +0 -97
  136. package/footer/Icons.d.ts +0 -2
  137. package/footer/Icons.js +0 -77
  138. package/footer/types.d.ts +0 -66
  139. package/footer/types.js +0 -5
  140. package/grid/Grid.d.ts +0 -7
  141. package/grid/Grid.js +0 -91
  142. package/grid/Grid.stories.tsx +0 -219
  143. package/grid/types.d.ts +0 -46
  144. package/grid/types.js +0 -5
  145. package/header/Header.d.ts +0 -8
  146. package/header/Header.js +0 -303
  147. package/header/Header.stories.tsx +0 -315
  148. package/header/Header.test.js +0 -79
  149. package/header/Icons.d.ts +0 -2
  150. package/header/Icons.js +0 -34
  151. package/header/types.d.ts +0 -48
  152. package/header/types.js +0 -5
  153. package/heading/Heading.d.ts +0 -4
  154. package/heading/Heading.js +0 -159
  155. package/heading/Heading.stories.tsx +0 -54
  156. package/heading/Heading.test.js +0 -186
  157. package/heading/types.d.ts +0 -33
  158. package/heading/types.js +0 -5
  159. package/inset/Inset.d.ts +0 -3
  160. package/inset/Inset.js +0 -51
  161. package/inset/Inset.stories.tsx +0 -229
  162. package/inset/types.d.ts +0 -37
  163. package/inset/types.js +0 -5
  164. package/layout/ApplicationLayout.d.ts +0 -20
  165. package/layout/ApplicationLayout.js +0 -171
  166. package/layout/ApplicationLayout.stories.tsx +0 -162
  167. package/layout/Icons.d.ts +0 -5
  168. package/layout/Icons.js +0 -66
  169. package/layout/SidenavContext.d.ts +0 -5
  170. package/layout/SidenavContext.js +0 -19
  171. package/layout/types.d.ts +0 -42
  172. package/layout/types.js +0 -5
  173. package/link/Link.d.ts +0 -4
  174. package/link/Link.js +0 -136
  175. package/link/Link.stories.tsx +0 -253
  176. package/link/Link.test.js +0 -81
  177. package/link/types.d.ts +0 -54
  178. package/link/types.js +0 -5
  179. package/main.d.ts +0 -45
  180. package/main.js +0 -377
  181. package/nav-tabs/NavTabs.d.ts +0 -8
  182. package/nav-tabs/NavTabs.js +0 -125
  183. package/nav-tabs/NavTabs.stories.tsx +0 -260
  184. package/nav-tabs/NavTabs.test.js +0 -82
  185. package/nav-tabs/Tab.d.ts +0 -4
  186. package/nav-tabs/Tab.js +0 -150
  187. package/nav-tabs/types.d.ts +0 -53
  188. package/nav-tabs/types.js +0 -5
  189. package/number-input/NumberInput.d.ts +0 -4
  190. package/number-input/NumberInput.js +0 -76
  191. package/number-input/NumberInput.stories.tsx +0 -115
  192. package/number-input/NumberInput.test.js +0 -542
  193. package/number-input/NumberInputContext.d.ts +0 -4
  194. package/number-input/NumberInputContext.js +0 -19
  195. package/number-input/numberInputContextTypes.d.ts +0 -19
  196. package/number-input/numberInputContextTypes.js +0 -5
  197. package/number-input/types.d.ts +0 -124
  198. package/number-input/types.js +0 -5
  199. package/paginator/Icons.d.ts +0 -5
  200. package/paginator/Icons.js +0 -54
  201. package/paginator/Paginator.d.ts +0 -4
  202. package/paginator/Paginator.js +0 -163
  203. package/paginator/Paginator.stories.tsx +0 -87
  204. package/paginator/Paginator.test.js +0 -305
  205. package/paginator/types.d.ts +0 -38
  206. package/paginator/types.js +0 -5
  207. package/paragraph/Paragraph.d.ts +0 -5
  208. package/paragraph/Paragraph.js +0 -38
  209. package/paragraph/Paragraph.stories.tsx +0 -44
  210. package/password-input/PasswordInput.d.ts +0 -4
  211. package/password-input/PasswordInput.js +0 -166
  212. package/password-input/PasswordInput.stories.tsx +0 -131
  213. package/password-input/PasswordInput.test.js +0 -181
  214. package/password-input/types.d.ts +0 -110
  215. package/password-input/types.js +0 -5
  216. package/progress-bar/ProgressBar.d.ts +0 -4
  217. package/progress-bar/ProgressBar.js +0 -176
  218. package/progress-bar/ProgressBar.stories.jsx +0 -93
  219. package/progress-bar/ProgressBar.test.js +0 -110
  220. package/progress-bar/types.d.ts +0 -37
  221. package/progress-bar/types.js +0 -5
  222. package/quick-nav/QuickNav.d.ts +0 -4
  223. package/quick-nav/QuickNav.js +0 -117
  224. package/quick-nav/QuickNav.stories.tsx +0 -356
  225. package/quick-nav/types.d.ts +0 -21
  226. package/quick-nav/types.js +0 -5
  227. package/radio-group/Radio.d.ts +0 -4
  228. package/radio-group/Radio.js +0 -156
  229. package/radio-group/RadioGroup.d.ts +0 -4
  230. package/radio-group/RadioGroup.js +0 -283
  231. package/radio-group/RadioGroup.stories.tsx +0 -214
  232. package/radio-group/RadioGroup.test.js +0 -722
  233. package/radio-group/types.d.ts +0 -114
  234. package/radio-group/types.js +0 -5
  235. package/resultsetTable/Icons.d.ts +0 -7
  236. package/resultsetTable/Icons.js +0 -51
  237. package/resultsetTable/ResultsetTable.d.ts +0 -4
  238. package/resultsetTable/ResultsetTable.js +0 -195
  239. package/resultsetTable/ResultsetTable.stories.tsx +0 -300
  240. package/resultsetTable/ResultsetTable.test.js +0 -325
  241. package/resultsetTable/types.d.ts +0 -67
  242. package/resultsetTable/types.js +0 -5
  243. package/select/Icons.d.ts +0 -10
  244. package/select/Icons.js +0 -93
  245. package/select/Listbox.d.ts +0 -4
  246. package/select/Listbox.js +0 -169
  247. package/select/Option.d.ts +0 -4
  248. package/select/Option.js +0 -97
  249. package/select/Select.d.ts +0 -4
  250. package/select/Select.js +0 -666
  251. package/select/Select.stories.tsx +0 -971
  252. package/select/Select.test.js +0 -2228
  253. package/select/types.d.ts +0 -210
  254. package/select/types.js +0 -5
  255. package/sidenav/Sidenav.d.ts +0 -10
  256. package/sidenav/Sidenav.js +0 -266
  257. package/sidenav/Sidenav.stories.tsx +0 -282
  258. package/sidenav/Sidenav.test.js +0 -44
  259. package/sidenav/types.d.ts +0 -73
  260. package/sidenav/types.js +0 -5
  261. package/slider/Slider.d.ts +0 -4
  262. package/slider/Slider.js +0 -342
  263. package/slider/Slider.stories.tsx +0 -240
  264. package/slider/Slider.test.js +0 -250
  265. package/slider/types.d.ts +0 -86
  266. package/slider/types.js +0 -5
  267. package/spinner/Spinner.d.ts +0 -4
  268. package/spinner/Spinner.js +0 -244
  269. package/spinner/Spinner.stories.jsx +0 -129
  270. package/spinner/Spinner.test.js +0 -64
  271. package/spinner/types.d.ts +0 -32
  272. package/spinner/types.js +0 -5
  273. package/switch/Switch.d.ts +0 -4
  274. package/switch/Switch.js +0 -262
  275. package/switch/Switch.stories.tsx +0 -171
  276. package/switch/Switch.test.js +0 -225
  277. package/switch/types.d.ts +0 -66
  278. package/switch/types.js +0 -5
  279. package/table/Table.d.ts +0 -4
  280. package/table/Table.js +0 -118
  281. package/table/Table.stories.jsx +0 -356
  282. package/table/Table.test.js +0 -26
  283. package/table/types.d.ts +0 -21
  284. package/table/types.js +0 -5
  285. package/tabs/Tab.d.ts +0 -4
  286. package/tabs/Tab.js +0 -133
  287. package/tabs/Tabs.d.ts +0 -4
  288. package/tabs/Tabs.js +0 -465
  289. package/tabs/Tabs.stories.tsx +0 -226
  290. package/tabs/Tabs.test.js +0 -350
  291. package/tabs/types.d.ts +0 -92
  292. package/tabs/types.js +0 -5
  293. package/tag/Tag.d.ts +0 -4
  294. package/tag/Tag.js +0 -181
  295. package/tag/Tag.stories.tsx +0 -155
  296. package/tag/Tag.test.js +0 -60
  297. package/tag/types.d.ts +0 -69
  298. package/tag/types.js +0 -5
  299. package/text-input/Icons.d.ts +0 -8
  300. package/text-input/Icons.js +0 -60
  301. package/text-input/Suggestion.d.ts +0 -4
  302. package/text-input/Suggestion.js +0 -84
  303. package/text-input/Suggestions.d.ts +0 -4
  304. package/text-input/Suggestions.js +0 -134
  305. package/text-input/TextInput.d.ts +0 -4
  306. package/text-input/TextInput.js +0 -673
  307. package/text-input/TextInput.stories.tsx +0 -569
  308. package/text-input/TextInput.test.js +0 -1723
  309. package/text-input/types.d.ts +0 -197
  310. package/text-input/types.js +0 -5
  311. package/textarea/Textarea.d.ts +0 -4
  312. package/textarea/Textarea.js +0 -277
  313. package/textarea/Textarea.stories.jsx +0 -216
  314. package/textarea/Textarea.test.js +0 -437
  315. package/textarea/types.d.ts +0 -137
  316. package/textarea/types.js +0 -5
  317. package/toggle-group/ToggleGroup.d.ts +0 -4
  318. package/toggle-group/ToggleGroup.js +0 -218
  319. package/toggle-group/ToggleGroup.stories.tsx +0 -215
  320. package/toggle-group/ToggleGroup.test.js +0 -156
  321. package/toggle-group/types.d.ts +0 -105
  322. package/toggle-group/types.js +0 -5
  323. package/typography/Typography.d.ts +0 -4
  324. package/typography/Typography.js +0 -32
  325. package/typography/Typography.stories.tsx +0 -198
  326. package/typography/types.d.ts +0 -18
  327. package/typography/types.js +0 -5
  328. package/useTheme.d.ts +0 -1235
  329. package/useTheme.js +0 -22
  330. package/useTranslatedLabels.d.ts +0 -85
  331. package/useTranslatedLabels.js +0 -20
  332. package/utils/BaseTypography.d.ts +0 -21
  333. package/utils/BaseTypography.js +0 -108
  334. package/utils/FocusLock.d.ts +0 -13
  335. package/utils/FocusLock.js +0 -139
  336. package/wizard/Wizard.d.ts +0 -4
  337. package/wizard/Wizard.js +0 -285
  338. package/wizard/Wizard.stories.tsx +0 -253
  339. package/wizard/Wizard.test.js +0 -141
  340. package/wizard/types.d.ts +0 -64
  341. package/wizard/types.js +0 -5
@@ -1,282 +0,0 @@
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
- import { HalstackProvider } from "../HalstackContext";
7
-
8
- export default {
9
- title: "Sidenav",
10
- component: DxcSidenav,
11
- };
12
-
13
- const iconSVG = (
14
- <svg
15
- version="1.1"
16
- id="Capa_1"
17
- x="0px"
18
- y="0px"
19
- width="438.536px"
20
- height="438.536px"
21
- viewBox="0 0 438.536 438.536"
22
- fill="currentColor"
23
- >
24
- <g>
25
- <path
26
- d="M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123
27
- C8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126
28
- h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
29
- C438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402
30
- c0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401
31
- c-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
32
- />
33
- </g>
34
- </svg>
35
- );
36
-
37
- const TitleComponent = () => {
38
- return <DxcSidenav.Title>Dxc technology</DxcSidenav.Title>;
39
- };
40
-
41
- const opinionatedTheme = {
42
- sidenav: {
43
- baseColor: "#f2f2f2",
44
- },
45
- };
46
-
47
- export const Chromatic = () => (
48
- <>
49
- <ExampleContainer>
50
- <Title title="Default sidenav" theme="light" level={4} />
51
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
52
- <DxcSidenav.Section>
53
- <p>
54
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
55
- vitae lacinia libero.
56
- </p>
57
- </DxcSidenav.Section>
58
- <DxcSidenav.Section>
59
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
60
- <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
61
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
62
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
63
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
64
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
65
- </DxcSidenav.Group>
66
- </DxcSidenav.Section>
67
- <DxcSidenav.Section>
68
- <DxcSidenav.Group
69
- collapsable={true}
70
- title="Section Group"
71
- icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png"
72
- >
73
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
74
- <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
75
- </DxcSidenav.Group>
76
- <DxcSidenav.Link icon="https://upload.wikimedia.org/wikipedia/commons/7/73/Flat_tick_icon.svg" newWindow>
77
- Single Link
78
- </DxcSidenav.Link>
79
- <DxcSidenav.Link newWindow>Single Link</DxcSidenav.Link>
80
- <DxcSidenav.Group collapsable={false} title="Section Group">
81
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
82
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
83
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
84
- </DxcSidenav.Group>
85
- </DxcSidenav.Section>
86
- </DxcSidenav>
87
- </ExampleContainer>
88
- <ExampleContainer pseudoState="pseudo-focus">
89
- <Title title="Focused options sidenav" theme="light" level={4} />
90
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
91
- <DxcSidenav.Section>
92
- <p>
93
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
94
- vitae lacinia libero.
95
- </p>
96
- </DxcSidenav.Section>
97
- <DxcSidenav.Section>
98
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
99
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
100
- <DxcSidenav.Link icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png">Group Link</DxcSidenav.Link>
101
- </DxcSidenav.Group>
102
- </DxcSidenav.Section>
103
- <DxcSidenav.Section>
104
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
105
- <DxcSidenav.Link selected icon={iconSVG}>
106
- Group Link
107
- </DxcSidenav.Link>
108
- </DxcSidenav.Group>
109
- <DxcSidenav.Group collapsable={false} title="Section Group">
110
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
111
- </DxcSidenav.Group>
112
- </DxcSidenav.Section>
113
- </DxcSidenav>
114
- </ExampleContainer>
115
- <Title title="Opinionated theme" theme="light" level={2} />
116
- <ExampleContainer>
117
- <HalstackProvider theme={opinionatedTheme}>
118
- <DxcSidenav title={<TitleComponent />}>
119
- <DxcSidenav.Section>
120
- <p>
121
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
122
- vitae lacinia libero.
123
- </p>
124
- </DxcSidenav.Section>
125
- <DxcSidenav.Section>
126
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
127
- <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
128
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
129
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
130
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
131
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
132
- </DxcSidenav.Group>
133
- </DxcSidenav.Section>
134
- <DxcSidenav.Section>
135
- <DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
136
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
137
- <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
138
- </DxcSidenav.Group>
139
- <DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
140
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
141
- <DxcSidenav.Group collapsable={false} title="Section Group">
142
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
143
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
144
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
145
- </DxcSidenav.Group>
146
- </DxcSidenav.Section>
147
- </DxcSidenav>
148
- </HalstackProvider>
149
- </ExampleContainer>
150
- </>
151
- );
152
-
153
- const CollapsedGroup = () => (
154
- <>
155
- <ExampleContainer>
156
- <Title title="Default sidenav" theme="light" level={4} />
157
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
158
- <DxcSidenav.Section>
159
- <DxcSidenav.Group collapsable={true} title="Collapsable Group" icon={iconSVG}>
160
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
161
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
162
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
163
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
164
- </DxcSidenav.Group>
165
- </DxcSidenav.Section>
166
- <DxcSidenav.Section>
167
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
168
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
169
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
170
- </DxcSidenav.Group>
171
- <DxcSidenav.Group collapsable={false} title="Section Group">
172
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
173
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
174
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
175
- </DxcSidenav.Group>
176
- </DxcSidenav.Section>
177
- </DxcSidenav>
178
- </ExampleContainer>
179
- </>
180
- );
181
-
182
- const HoverSidenav = () => (
183
- <ExampleContainer pseudoState="pseudo-hover">
184
- <Title title="Default sidenav" theme="light" level={4} />
185
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
186
- <DxcSidenav.Section>
187
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
188
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
189
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
190
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
191
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
192
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
193
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
194
- </DxcSidenav.Group>
195
- </DxcSidenav.Section>
196
- <DxcSidenav.Section>
197
- <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
198
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
199
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
200
- </DxcSidenav.Group>
201
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
202
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
203
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
204
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
205
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
206
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
207
- </DxcSidenav.Group>
208
-
209
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
210
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
211
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
212
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
213
- </DxcSidenav.Group>
214
- </DxcSidenav.Section>
215
- </DxcSidenav>
216
- </ExampleContainer>
217
- );
218
-
219
- const HoverSidenavOpinionated = () => (
220
- <ExampleContainer pseudoState="pseudo-hover">
221
- <Title title="Default sidenav" theme="light" level={4} />
222
- <HalstackProvider theme={opinionatedTheme}>
223
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
224
- <DxcSidenav.Section>
225
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
226
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
227
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
228
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
229
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
230
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
231
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
232
- </DxcSidenav.Group>
233
- </DxcSidenav.Section>
234
- <DxcSidenav.Section>
235
- <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
236
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
237
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
238
- </DxcSidenav.Group>
239
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
240
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
241
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
242
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
243
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
244
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
245
- </DxcSidenav.Group>
246
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
247
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
248
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
249
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
250
- </DxcSidenav.Group>
251
- </DxcSidenav.Section>
252
- </DxcSidenav>
253
- </HalstackProvider>
254
- </ExampleContainer>
255
- );
256
-
257
- export const CollapseGroup = CollapsedGroup.bind({});
258
- CollapseGroup.play = async ({ canvasElement }) => {
259
- const canvas = within(canvasElement);
260
- const collapsableGroups = canvas.getAllByText("Collapsable Group");
261
- collapsableGroups.forEach((group) => {
262
- userEvent.click(group);
263
- });
264
- };
265
-
266
- export const CollapseHoverGroup = HoverSidenav.bind({});
267
- CollapseHoverGroup.play = async ({ canvasElement }) => {
268
- const canvas = within(canvasElement);
269
- const collapsableGroups = canvas.getAllByText("Collapsable Group");
270
- collapsableGroups.forEach((group) => {
271
- userEvent.click(group);
272
- });
273
- };
274
-
275
- export const CollapseHoverGroupOpinionated = HoverSidenavOpinionated.bind({});
276
- CollapseHoverGroupOpinionated.play = async ({ canvasElement }) => {
277
- const canvas = within(canvasElement);
278
- const collapsableGroups = canvas.getAllByText("Collapsable Group");
279
- collapsableGroups.forEach((group) => {
280
- userEvent.click(group);
281
- });
282
- };
@@ -1,44 +0,0 @@
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
- });
@@ -1,73 +0,0 @@
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;
package/sidenav/types.js DELETED
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- import SliderPropsType from "./types";
3
- declare const DxcSlider: React.ForwardRefExoticComponent<SliderPropsType & React.RefAttributes<HTMLDivElement>>;
4
- export default DxcSlider;