@dxc-technology/halstack-react 0.0.0-97eade8 → 0.0.0-9852702

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 (346) hide show
  1. package/README.md +46 -0
  2. package/dist/index.d.mts +6802 -0
  3. package/dist/index.d.ts +6802 -0
  4. package/dist/index.js +4372 -0
  5. package/dist/index.mjs +4372 -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 -8
  18. package/accordion-group/AccordionGroup.js +0 -128
  19. package/accordion-group/AccordionGroup.stories.tsx +0 -251
  20. package/accordion-group/AccordionGroup.test.js +0 -126
  21. package/accordion-group/AccordionGroupAccordion.d.ts +0 -4
  22. package/accordion-group/AccordionGroupAccordion.js +0 -43
  23. package/accordion-group/types.d.ts +0 -79
  24. package/accordion-group/types.js +0 -5
  25. package/alert/Alert.d.ts +0 -4
  26. package/alert/Alert.js +0 -289
  27. package/alert/Alert.stories.tsx +0 -198
  28. package/alert/Alert.test.js +0 -92
  29. package/alert/types.d.ts +0 -49
  30. package/alert/types.js +0 -5
  31. package/badge/Badge.d.ts +0 -4
  32. package/badge/Badge.js +0 -61
  33. package/badge/types.d.ts +0 -5
  34. package/badge/types.js +0 -5
  35. package/bleed/Bleed.d.ts +0 -3
  36. package/bleed/Bleed.js +0 -51
  37. package/bleed/Bleed.stories.tsx +0 -342
  38. package/bleed/types.d.ts +0 -37
  39. package/bleed/types.js +0 -5
  40. package/box/Box.d.ts +0 -4
  41. package/box/Box.js +0 -97
  42. package/box/Box.stories.tsx +0 -119
  43. package/box/Box.test.js +0 -18
  44. package/box/types.d.ts +0 -32
  45. package/box/types.js +0 -5
  46. package/bulleted-list/BulletedList.d.ts +0 -7
  47. package/bulleted-list/BulletedList.js +0 -125
  48. package/bulleted-list/BulletedList.stories.tsx +0 -206
  49. package/bulleted-list/types.d.ts +0 -38
  50. package/bulleted-list/types.js +0 -5
  51. package/button/Button.d.ts +0 -4
  52. package/button/Button.js +0 -153
  53. package/button/Button.stories.tsx +0 -425
  54. package/button/Button.test.js +0 -35
  55. package/button/types.d.ts +0 -53
  56. package/button/types.js +0 -5
  57. package/card/Card.d.ts +0 -4
  58. package/card/Card.js +0 -143
  59. package/card/Card.stories.tsx +0 -171
  60. package/card/Card.test.js +0 -50
  61. package/card/types.d.ts +0 -62
  62. package/card/types.js +0 -5
  63. package/checkbox/Checkbox.d.ts +0 -4
  64. package/checkbox/Checkbox.js +0 -250
  65. package/checkbox/Checkbox.stories.tsx +0 -260
  66. package/checkbox/Checkbox.test.js +0 -155
  67. package/checkbox/types.d.ts +0 -68
  68. package/checkbox/types.js +0 -5
  69. package/chip/Chip.d.ts +0 -4
  70. package/chip/Chip.js +0 -140
  71. package/chip/Chip.stories.tsx +0 -214
  72. package/chip/Chip.test.js +0 -54
  73. package/chip/types.d.ts +0 -45
  74. package/chip/types.js +0 -5
  75. package/common/OpenSans.css +0 -69
  76. package/common/coreTokens.d.ts +0 -146
  77. package/common/coreTokens.js +0 -167
  78. package/common/fonts/OpenSans-Bold.ttf +0 -0
  79. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  80. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  81. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  82. package/common/fonts/OpenSans-Italic.ttf +0 -0
  83. package/common/fonts/OpenSans-Light.ttf +0 -0
  84. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  85. package/common/fonts/OpenSans-Regular.ttf +0 -0
  86. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  87. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  88. package/common/utils.d.ts +0 -1
  89. package/common/utils.js +0 -22
  90. package/common/variables.d.ts +0 -1482
  91. package/common/variables.js +0 -1361
  92. package/date-input/Calendar.d.ts +0 -4
  93. package/date-input/Calendar.js +0 -258
  94. package/date-input/DateInput.d.ts +0 -4
  95. package/date-input/DateInput.js +0 -269
  96. package/date-input/DateInput.stories.tsx +0 -304
  97. package/date-input/DateInput.test.js +0 -835
  98. package/date-input/DatePicker.d.ts +0 -4
  99. package/date-input/DatePicker.js +0 -146
  100. package/date-input/Icons.d.ts +0 -6
  101. package/date-input/Icons.js +0 -75
  102. package/date-input/YearPicker.d.ts +0 -4
  103. package/date-input/YearPicker.js +0 -126
  104. package/date-input/types.d.ts +0 -158
  105. package/date-input/types.js +0 -5
  106. package/dialog/Dialog.d.ts +0 -4
  107. package/dialog/Dialog.js +0 -131
  108. package/dialog/Dialog.stories.tsx +0 -195
  109. package/dialog/Dialog.test.js +0 -369
  110. package/dialog/types.d.ts +0 -31
  111. package/dialog/types.js +0 -5
  112. package/dropdown/Dropdown.d.ts +0 -4
  113. package/dropdown/Dropdown.js +0 -388
  114. package/dropdown/Dropdown.stories.tsx +0 -438
  115. package/dropdown/Dropdown.test.js +0 -586
  116. package/dropdown/DropdownMenu.d.ts +0 -4
  117. package/dropdown/DropdownMenu.js +0 -74
  118. package/dropdown/DropdownMenuItem.d.ts +0 -4
  119. package/dropdown/DropdownMenuItem.js +0 -79
  120. package/dropdown/types.d.ts +0 -100
  121. package/dropdown/types.js +0 -5
  122. package/file-input/FileInput.d.ts +0 -4
  123. package/file-input/FileInput.js +0 -547
  124. package/file-input/FileInput.stories.tsx +0 -618
  125. package/file-input/FileInput.test.js +0 -457
  126. package/file-input/FileItem.d.ts +0 -4
  127. package/file-input/FileItem.js +0 -162
  128. package/file-input/types.d.ts +0 -129
  129. package/file-input/types.js +0 -5
  130. package/flex/Flex.d.ts +0 -4
  131. package/flex/Flex.js +0 -71
  132. package/flex/Flex.stories.tsx +0 -112
  133. package/flex/types.d.ts +0 -97
  134. package/flex/types.js +0 -5
  135. package/footer/Footer.d.ts +0 -4
  136. package/footer/Footer.js +0 -170
  137. package/footer/Footer.stories.tsx +0 -140
  138. package/footer/Footer.test.js +0 -97
  139. package/footer/Icons.d.ts +0 -2
  140. package/footer/Icons.js +0 -77
  141. package/footer/types.d.ts +0 -60
  142. package/footer/types.js +0 -5
  143. package/grid/Grid.d.ts +0 -7
  144. package/grid/Grid.js +0 -91
  145. package/grid/Grid.stories.tsx +0 -219
  146. package/grid/types.d.ts +0 -115
  147. package/grid/types.js +0 -5
  148. package/header/Header.d.ts +0 -8
  149. package/header/Header.js +0 -303
  150. package/header/Header.stories.tsx +0 -315
  151. package/header/Header.test.js +0 -79
  152. package/header/Icons.d.ts +0 -2
  153. package/header/Icons.js +0 -34
  154. package/header/types.d.ts +0 -48
  155. package/header/types.js +0 -5
  156. package/heading/Heading.d.ts +0 -4
  157. package/heading/Heading.js +0 -159
  158. package/heading/Heading.stories.tsx +0 -54
  159. package/heading/Heading.test.js +0 -186
  160. package/heading/types.d.ts +0 -33
  161. package/heading/types.js +0 -5
  162. package/inset/Inset.d.ts +0 -3
  163. package/inset/Inset.js +0 -51
  164. package/inset/Inset.stories.tsx +0 -230
  165. package/inset/types.d.ts +0 -37
  166. package/inset/types.js +0 -5
  167. package/layout/ApplicationLayout.d.ts +0 -20
  168. package/layout/ApplicationLayout.js +0 -171
  169. package/layout/ApplicationLayout.stories.tsx +0 -162
  170. package/layout/Icons.d.ts +0 -5
  171. package/layout/Icons.js +0 -66
  172. package/layout/SidenavContext.d.ts +0 -5
  173. package/layout/SidenavContext.js +0 -19
  174. package/layout/types.d.ts +0 -41
  175. package/layout/types.js +0 -5
  176. package/link/Link.d.ts +0 -4
  177. package/link/Link.js +0 -136
  178. package/link/Link.stories.tsx +0 -253
  179. package/link/Link.test.js +0 -81
  180. package/link/types.d.ts +0 -54
  181. package/link/types.js +0 -5
  182. package/main.d.ts +0 -45
  183. package/main.js +0 -377
  184. package/nav-tabs/NavTabs.d.ts +0 -8
  185. package/nav-tabs/NavTabs.js +0 -122
  186. package/nav-tabs/NavTabs.stories.tsx +0 -274
  187. package/nav-tabs/NavTabs.test.js +0 -82
  188. package/nav-tabs/Tab.d.ts +0 -4
  189. package/nav-tabs/Tab.js +0 -146
  190. package/nav-tabs/types.d.ts +0 -52
  191. package/nav-tabs/types.js +0 -5
  192. package/number-input/NumberInput.d.ts +0 -4
  193. package/number-input/NumberInput.js +0 -76
  194. package/number-input/NumberInput.stories.tsx +0 -115
  195. package/number-input/NumberInput.test.js +0 -542
  196. package/number-input/NumberInputContext.d.ts +0 -4
  197. package/number-input/NumberInputContext.js +0 -19
  198. package/number-input/numberInputContextTypes.d.ts +0 -19
  199. package/number-input/numberInputContextTypes.js +0 -5
  200. package/number-input/types.d.ts +0 -124
  201. package/number-input/types.js +0 -5
  202. package/paginator/Icons.d.ts +0 -5
  203. package/paginator/Icons.js +0 -54
  204. package/paginator/Paginator.d.ts +0 -4
  205. package/paginator/Paginator.js +0 -163
  206. package/paginator/Paginator.stories.tsx +0 -87
  207. package/paginator/Paginator.test.js +0 -318
  208. package/paginator/types.d.ts +0 -38
  209. package/paginator/types.js +0 -5
  210. package/paragraph/Paragraph.d.ts +0 -5
  211. package/paragraph/Paragraph.js +0 -38
  212. package/paragraph/Paragraph.stories.tsx +0 -44
  213. package/password-input/PasswordInput.d.ts +0 -4
  214. package/password-input/PasswordInput.js +0 -166
  215. package/password-input/PasswordInput.stories.tsx +0 -131
  216. package/password-input/PasswordInput.test.js +0 -181
  217. package/password-input/types.d.ts +0 -110
  218. package/password-input/types.js +0 -5
  219. package/progress-bar/ProgressBar.d.ts +0 -4
  220. package/progress-bar/ProgressBar.js +0 -176
  221. package/progress-bar/ProgressBar.stories.jsx +0 -93
  222. package/progress-bar/ProgressBar.test.js +0 -110
  223. package/progress-bar/types.d.ts +0 -37
  224. package/progress-bar/types.js +0 -5
  225. package/quick-nav/QuickNav.d.ts +0 -4
  226. package/quick-nav/QuickNav.js +0 -117
  227. package/quick-nav/QuickNav.stories.tsx +0 -356
  228. package/quick-nav/types.d.ts +0 -21
  229. package/quick-nav/types.js +0 -5
  230. package/radio-group/Radio.d.ts +0 -4
  231. package/radio-group/Radio.js +0 -156
  232. package/radio-group/RadioGroup.d.ts +0 -4
  233. package/radio-group/RadioGroup.js +0 -281
  234. package/radio-group/RadioGroup.stories.tsx +0 -214
  235. package/radio-group/RadioGroup.test.js +0 -722
  236. package/radio-group/types.d.ts +0 -114
  237. package/radio-group/types.js +0 -5
  238. package/resultsetTable/Icons.d.ts +0 -7
  239. package/resultsetTable/Icons.js +0 -51
  240. package/resultsetTable/ResultsetTable.d.ts +0 -4
  241. package/resultsetTable/ResultsetTable.js +0 -195
  242. package/resultsetTable/ResultsetTable.stories.tsx +0 -300
  243. package/resultsetTable/ResultsetTable.test.js +0 -325
  244. package/resultsetTable/types.d.ts +0 -67
  245. package/resultsetTable/types.js +0 -5
  246. package/select/Icons.d.ts +0 -10
  247. package/select/Icons.js +0 -93
  248. package/select/Listbox.d.ts +0 -4
  249. package/select/Listbox.js +0 -169
  250. package/select/Option.d.ts +0 -4
  251. package/select/Option.js +0 -97
  252. package/select/Select.d.ts +0 -4
  253. package/select/Select.js +0 -666
  254. package/select/Select.stories.tsx +0 -971
  255. package/select/Select.test.js +0 -2228
  256. package/select/types.d.ts +0 -210
  257. package/select/types.js +0 -5
  258. package/sidenav/Icons.d.ts +0 -7
  259. package/sidenav/Icons.js +0 -51
  260. package/sidenav/Sidenav.d.ts +0 -10
  261. package/sidenav/Sidenav.js +0 -238
  262. package/sidenav/Sidenav.stories.tsx +0 -282
  263. package/sidenav/Sidenav.test.js +0 -44
  264. package/sidenav/types.d.ts +0 -76
  265. package/sidenav/types.js +0 -5
  266. package/slider/Slider.d.ts +0 -4
  267. package/slider/Slider.js +0 -342
  268. package/slider/Slider.stories.tsx +0 -240
  269. package/slider/Slider.test.js +0 -250
  270. package/slider/types.d.ts +0 -86
  271. package/slider/types.js +0 -5
  272. package/spinner/Spinner.d.ts +0 -4
  273. package/spinner/Spinner.js +0 -244
  274. package/spinner/Spinner.stories.jsx +0 -129
  275. package/spinner/Spinner.test.js +0 -64
  276. package/spinner/types.d.ts +0 -32
  277. package/spinner/types.js +0 -5
  278. package/switch/Switch.d.ts +0 -4
  279. package/switch/Switch.js +0 -262
  280. package/switch/Switch.stories.tsx +0 -171
  281. package/switch/Switch.test.js +0 -225
  282. package/switch/types.d.ts +0 -66
  283. package/switch/types.js +0 -5
  284. package/table/Table.d.ts +0 -4
  285. package/table/Table.js +0 -118
  286. package/table/Table.stories.jsx +0 -356
  287. package/table/Table.test.js +0 -26
  288. package/table/types.d.ts +0 -21
  289. package/table/types.js +0 -5
  290. package/tabs/Tab.d.ts +0 -4
  291. package/tabs/Tab.js +0 -132
  292. package/tabs/Tabs.d.ts +0 -4
  293. package/tabs/Tabs.js +0 -461
  294. package/tabs/Tabs.stories.tsx +0 -226
  295. package/tabs/Tabs.test.js +0 -350
  296. package/tabs/types.d.ts +0 -92
  297. package/tabs/types.js +0 -5
  298. package/tag/Tag.d.ts +0 -4
  299. package/tag/Tag.js +0 -181
  300. package/tag/Tag.stories.tsx +0 -155
  301. package/tag/Tag.test.js +0 -60
  302. package/tag/types.d.ts +0 -69
  303. package/tag/types.js +0 -5
  304. package/text-input/Icons.d.ts +0 -8
  305. package/text-input/Icons.js +0 -60
  306. package/text-input/Suggestion.d.ts +0 -4
  307. package/text-input/Suggestion.js +0 -84
  308. package/text-input/Suggestions.d.ts +0 -4
  309. package/text-input/Suggestions.js +0 -134
  310. package/text-input/TextInput.d.ts +0 -4
  311. package/text-input/TextInput.js +0 -673
  312. package/text-input/TextInput.stories.tsx +0 -569
  313. package/text-input/TextInput.test.js +0 -1723
  314. package/text-input/types.d.ts +0 -197
  315. package/text-input/types.js +0 -5
  316. package/textarea/Textarea.d.ts +0 -4
  317. package/textarea/Textarea.js +0 -276
  318. package/textarea/Textarea.stories.jsx +0 -216
  319. package/textarea/Textarea.test.js +0 -435
  320. package/textarea/types.d.ts +0 -137
  321. package/textarea/types.js +0 -5
  322. package/toggle-group/ToggleGroup.d.ts +0 -4
  323. package/toggle-group/ToggleGroup.js +0 -218
  324. package/toggle-group/ToggleGroup.stories.tsx +0 -215
  325. package/toggle-group/ToggleGroup.test.js +0 -156
  326. package/toggle-group/types.d.ts +0 -105
  327. package/toggle-group/types.js +0 -5
  328. package/typography/Typography.d.ts +0 -4
  329. package/typography/Typography.js +0 -32
  330. package/typography/Typography.stories.tsx +0 -198
  331. package/typography/types.d.ts +0 -18
  332. package/typography/types.js +0 -5
  333. package/useTheme.d.ts +0 -1235
  334. package/useTheme.js +0 -22
  335. package/useTranslatedLabels.d.ts +0 -85
  336. package/useTranslatedLabels.js +0 -20
  337. package/utils/BaseTypography.d.ts +0 -21
  338. package/utils/BaseTypography.js +0 -108
  339. package/utils/FocusLock.d.ts +0 -13
  340. package/utils/FocusLock.js +0 -138
  341. package/wizard/Wizard.d.ts +0 -4
  342. package/wizard/Wizard.js +0 -285
  343. package/wizard/Wizard.stories.tsx +0 -253
  344. package/wizard/Wizard.test.js +0 -141
  345. package/wizard/types.d.ts +0 -64
  346. package/wizard/types.js +0 -5
@@ -1,282 +0,0 @@
1
- import React from "react";
2
- import DxcSidenav from "./Sidenav";
3
- import DxcSelect from "../select/Select";
4
- import DxcInset from "../inset/Inset";
5
- import Title from "../../.storybook/components/Title";
6
- import ExampleContainer from "../../.storybook/components/ExampleContainer";
7
- import { userEvent, within } from "@storybook/testing-library";
8
- import { HalstackProvider } from "../HalstackContext";
9
-
10
- export default {
11
- title: "Sidenav",
12
- component: DxcSidenav,
13
- };
14
-
15
- const iconSVG = (
16
- <svg
17
- version="1.1"
18
- id="Capa_1"
19
- x="0px"
20
- y="0px"
21
- width="438.536px"
22
- height="438.536px"
23
- viewBox="0 0 438.536 438.536"
24
- fill="currentColor"
25
- >
26
- <g>
27
- <path
28
- 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
29
- 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
30
- h274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225
31
- 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
32
- 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
33
- 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"
34
- />
35
- </g>
36
- </svg>
37
- );
38
-
39
- const TitleComponent = () => {
40
- return <DxcSidenav.Title>Dxc technology</DxcSidenav.Title>;
41
- };
42
-
43
- const opinionatedTheme = {
44
- sidenav: {
45
- baseColor: "#f2f2f2",
46
- },
47
- };
48
-
49
- export const Chromatic = () => (
50
- <>
51
- <ExampleContainer>
52
- <Title title="Default sidenav" theme="light" level={4} />
53
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
54
- <DxcSidenav.Section>
55
- <p>
56
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
57
- vitae lacinia libero.
58
- </p>
59
- </DxcSidenav.Section>
60
- <DxcSidenav.Section>
61
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
62
- <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
63
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
64
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
65
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
66
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
67
- </DxcSidenav.Group>
68
- </DxcSidenav.Section>
69
- <DxcSidenav.Section>
70
- <DxcSidenav.Group
71
- collapsable={true}
72
- title="Section Group"
73
- icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png"
74
- >
75
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
76
- <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
77
- </DxcSidenav.Group>
78
- <DxcSidenav.Link icon="https://upload.wikimedia.org/wikipedia/commons/7/73/Flat_tick_icon.svg" newWindow>
79
- Single Link
80
- </DxcSidenav.Link>
81
- <DxcSidenav.Link newWindow>Single Link</DxcSidenav.Link>
82
- <DxcSidenav.Group collapsable={false} title="Section Group">
83
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
84
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
85
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
86
- </DxcSidenav.Group>
87
- </DxcSidenav.Section>
88
- </DxcSidenav>
89
- </ExampleContainer>
90
- <ExampleContainer pseudoState="pseudo-focus">
91
- <Title title="Focused options sidenav" theme="light" level={4} />
92
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
93
- <DxcSidenav.Section>
94
- <p>
95
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
96
- vitae lacinia libero.
97
- </p>
98
- </DxcSidenav.Section>
99
- <DxcSidenav.Section>
100
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
101
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
102
- <DxcSidenav.Link icon="https://cdn-icons-png.flaticon.com/512/5039/5039041.png">Group Link</DxcSidenav.Link>
103
- </DxcSidenav.Group>
104
- </DxcSidenav.Section>
105
- <DxcSidenav.Section>
106
- <DxcSidenav.Group collapsable={true} title="Collapsable Group">
107
- <DxcSidenav.Link selected icon={iconSVG}>
108
- Group Link
109
- </DxcSidenav.Link>
110
- </DxcSidenav.Group>
111
- <DxcSidenav.Group collapsable={false} title="Section Group">
112
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
113
- </DxcSidenav.Group>
114
- </DxcSidenav.Section>
115
- </DxcSidenav>
116
- </ExampleContainer>
117
- <Title title="Opinionated theme" theme="light" level={2} />
118
- <ExampleContainer>
119
- <HalstackProvider theme={opinionatedTheme}>
120
- <DxcSidenav title={<TitleComponent />}>
121
- <DxcSidenav.Section>
122
- <p>
123
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In ullamcorper consectetur mollis. Suspendisse
124
- vitae lacinia libero.
125
- </p>
126
- </DxcSidenav.Section>
127
- <DxcSidenav.Section>
128
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
129
- <DxcSidenav.Group collapsable={false} title="Single Group" icon={iconSVG}>
130
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
131
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
132
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
133
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
134
- </DxcSidenav.Group>
135
- </DxcSidenav.Section>
136
- <DxcSidenav.Section>
137
- <DxcSidenav.Group collapsable={true} title="Section Group" icon={iconSVG}>
138
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
139
- <DxcSidenav.Link icon={iconSVG}>Group Link</DxcSidenav.Link>
140
- </DxcSidenav.Group>
141
- <DxcSidenav.Link icon={iconSVG}>Single Link</DxcSidenav.Link>
142
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
143
- <DxcSidenav.Group collapsable={false} title="Section Group">
144
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
145
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
146
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
147
- </DxcSidenav.Group>
148
- </DxcSidenav.Section>
149
- </DxcSidenav>
150
- </HalstackProvider>
151
- </ExampleContainer>
152
- </>
153
- );
154
-
155
- const CollapsedGroupSidenav = () => (
156
- <>
157
- <ExampleContainer>
158
- <Title title="Collapsed group with a selected link" theme="light" level={4} />
159
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
160
- <DxcSidenav.Section>
161
- <DxcSidenav.Group collapsable={true} title="Collapsed Group" icon={iconSVG}>
162
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
163
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
164
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
165
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
166
- </DxcSidenav.Group>
167
- </DxcSidenav.Section>
168
- <DxcSidenav.Section>
169
- <DxcSidenav.Group collapsable={true} title="Collapsed Group">
170
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
171
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
172
- </DxcSidenav.Group>
173
- <DxcSidenav.Group collapsable={true} title="Section Group">
174
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
175
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
176
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
177
- </DxcSidenav.Group>
178
- </DxcSidenav.Section>
179
- </DxcSidenav>
180
- </ExampleContainer>
181
- </>
182
- );
183
-
184
- const HoveredGroupSidenav = () => (
185
- <ExampleContainer pseudoState="pseudo-hover">
186
- <Title title="Hover state for groups (selected and not)" theme="light" level={4} />
187
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
188
- <DxcSidenav.Section>
189
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
190
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
191
- <DxcSidenav.Group collapsable={true} title="Collapsed Group">
192
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
193
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
194
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
195
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
196
- </DxcSidenav.Group>
197
- </DxcSidenav.Section>
198
- <DxcSidenav.Section>
199
- <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
200
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
201
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
202
- </DxcSidenav.Group>
203
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
204
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
205
- <DxcSidenav.Group collapsable={true} title="Collapsed Group">
206
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
207
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
208
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
209
- </DxcSidenav.Group>
210
- <DxcSidenav.Group collapsable={true} title="Collapsed Group">
211
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
212
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
213
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
214
- </DxcSidenav.Group>
215
- </DxcSidenav.Section>
216
- </DxcSidenav>
217
- </ExampleContainer>
218
- );
219
-
220
- const ActiveGroupSidenav = () => (
221
- <ExampleContainer pseudoState="pseudo-active">
222
- <Title title="Active state for groups (selected and not)" theme="light" level={4} />
223
- <DxcSidenav title={<DxcSidenav.Title>Dxc technology</DxcSidenav.Title>}>
224
- <DxcSidenav.Section>
225
- <DxcInset space="1rem">
226
- <DxcSelect
227
- defaultValue="1"
228
- options={[
229
- { label: "v1.0.0", value: "1" },
230
- { label: "v2.0.0", value: "2" },
231
- { label: "v3.0.0", value: "3" },
232
- { label: "v4.0.0", value: "4" },
233
- ]}
234
- size="fillParent"
235
- />
236
- </DxcInset>
237
- </DxcSidenav.Section>
238
- <DxcSidenav.Section>
239
- <DxcSidenav.Group collapsable={true} title="Collapsed Group">
240
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
241
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
242
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
243
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
244
- </DxcSidenav.Group>
245
- </DxcSidenav.Section>
246
- <DxcSidenav.Section>
247
- <DxcSidenav.Group collapsable={true} title="Not Collapsed Group">
248
- <DxcSidenav.Link selected>Group Link</DxcSidenav.Link>
249
- <DxcSidenav.Link>Group Link</DxcSidenav.Link>
250
- </DxcSidenav.Group>
251
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
252
- <DxcSidenav.Link>Single Link</DxcSidenav.Link>
253
- </DxcSidenav.Section>
254
- </DxcSidenav>
255
- </ExampleContainer>
256
- );
257
-
258
- export const CollapsableGroup = CollapsedGroupSidenav.bind({});
259
- CollapsableGroup.play = async ({ canvasElement }) => {
260
- const canvas = within(canvasElement);
261
- const collapsableGroups = canvas.getAllByText("Collapsed Group");
262
- collapsableGroups.forEach((group) => {
263
- userEvent.click(group);
264
- });
265
- };
266
-
267
- export const CollapsedHoverGroup = HoveredGroupSidenav.bind({});
268
- CollapsedHoverGroup.play = async ({ canvasElement }) => {
269
- const canvas = within(canvasElement);
270
- const collapsableGroups = canvas.getAllByText("Collapsed Group");
271
- collapsableGroups.forEach((group) => {
272
- userEvent.click(group);
273
- });
274
- await new Promise((resolve) => setTimeout(resolve, 1000));
275
- };
276
-
277
- export const CollapsedActiveGroup = ActiveGroupSidenav.bind({});
278
- CollapsedActiveGroup.play = async ({ canvasElement }) => {
279
- const canvas = within(canvasElement);
280
- const collapsableGroups = canvas.getAllByText("Collapsed Group");
281
- userEvent.click(collapsableGroups[0]);
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,76 +0,0 @@
1
- /// <reference types="react" />
2
- declare type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
- declare type SidenavPropsType = {
4
- /**
5
- * The area assigned to render the sidenav title. It is highly recommended to use the sidenav title.
6
- */
7
- title?: React.ReactNode;
8
- /**
9
- * The area inside the sidenav. This area can be used to render the content inside the sidenav.
10
- */
11
- children: 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 title of the sidenav group.
28
- */
29
- title?: string;
30
- /**
31
- * If true, the sidenav group will be a button that will allow you to collapse the links contained within it.
32
- * In addition, if it's collapsed and contains the currently selected link, the group title will also be marked as selected.
33
- */
34
- collapsable?: boolean;
35
- /**
36
- * The icon to be displayed next to the title of the group.
37
- */
38
- icon?: string | SVG;
39
- /**
40
- * The area inside the sidenav group. This area can be used to render sidenav links.
41
- */
42
- children: React.ReactNode;
43
- };
44
- export declare type SidenavLinkPropsType = {
45
- /**
46
- * Page to be opened when the user clicks on the link.
47
- */
48
- href?: string;
49
- /**
50
- * If true, the page is opened in a new browser tab.
51
- */
52
- newWindow?: boolean;
53
- /**
54
- * Element or path used as the icon that will be placed to the left of the link text.
55
- */
56
- icon?: string | SVG;
57
- /**
58
- * If true, the link will be marked as selected. Moreover, in that same case,
59
- * if it is contained within a collapsed group, and consequently, the currently selected link is not visible,
60
- * the group title will appear as selected too.
61
- */
62
- selected?: boolean;
63
- /**
64
- * This function will be called when the user clicks the link and the event will be passed to this function.
65
- */
66
- onClick?: ($event: React.MouseEvent<HTMLAnchorElement>) => void;
67
- /**
68
- * Value of the tabindex.
69
- */
70
- tabIndex?: number;
71
- /**
72
- * The area inside the sidenav link.
73
- */
74
- children: React.ReactNode;
75
- };
76
- 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;