@dxc-technology/halstack-react 0.0.0-c9b5c13 → 0.0.0-c9efd3e

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 (396) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1243 -6
  4. package/HalstackContext.js +126 -111
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +104 -161
  9. package/accordion/Accordion.stories.tsx +84 -140
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +12 -17
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +32 -125
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +14 -55
  40. package/bleed/Bleed.stories.tsx +95 -95
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +19 -60
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  48. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  49. package/bulleted-list/BulletedList.d.ts +7 -0
  50. package/bulleted-list/BulletedList.js +92 -0
  51. package/bulleted-list/BulletedList.stories.tsx +115 -0
  52. package/bulleted-list/types.d.ts +38 -0
  53. package/button/Button.accessibility.test.js +127 -0
  54. package/button/Button.d.ts +1 -1
  55. package/button/Button.js +64 -117
  56. package/button/Button.stories.tsx +151 -100
  57. package/button/Button.test.js +20 -17
  58. package/button/types.d.ts +12 -8
  59. package/card/Card.accessibility.test.js +36 -0
  60. package/card/Card.d.ts +1 -1
  61. package/card/Card.js +48 -89
  62. package/card/Card.stories.tsx +12 -42
  63. package/card/Card.test.js +11 -22
  64. package/card/types.d.ts +6 -11
  65. package/checkbox/Checkbox.accessibility.test.js +87 -0
  66. package/checkbox/Checkbox.d.ts +2 -2
  67. package/checkbox/Checkbox.js +140 -182
  68. package/checkbox/Checkbox.stories.tsx +128 -94
  69. package/checkbox/Checkbox.test.js +160 -39
  70. package/checkbox/types.d.ts +11 -3
  71. package/chip/Chip.accessibility.test.js +67 -0
  72. package/chip/Chip.js +43 -80
  73. package/chip/Chip.stories.tsx +102 -26
  74. package/chip/Chip.test.js +18 -33
  75. package/chip/types.d.ts +4 -4
  76. package/common/coreTokens.d.ts +237 -0
  77. package/common/coreTokens.js +184 -0
  78. package/common/utils.d.ts +1 -0
  79. package/common/utils.js +6 -12
  80. package/common/variables.d.ts +1395 -0
  81. package/common/variables.js +942 -1145
  82. package/container/Container.d.ts +4 -0
  83. package/container/Container.js +194 -0
  84. package/container/Container.stories.tsx +214 -0
  85. package/container/types.d.ts +74 -0
  86. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  87. package/contextual-menu/ContextualMenu.d.ts +7 -0
  88. package/contextual-menu/ContextualMenu.js +71 -0
  89. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  90. package/contextual-menu/ContextualMenu.test.js +71 -0
  91. package/contextual-menu/MenuItemAction.d.ts +4 -0
  92. package/contextual-menu/MenuItemAction.js +46 -0
  93. package/contextual-menu/types.d.ts +22 -0
  94. package/date-input/Calendar.d.ts +4 -0
  95. package/date-input/Calendar.js +214 -0
  96. package/date-input/DateInput.accessibility.test.js +216 -0
  97. package/date-input/DateInput.js +150 -299
  98. package/date-input/DateInput.stories.tsx +203 -56
  99. package/date-input/DateInput.test.js +700 -371
  100. package/date-input/DatePicker.d.ts +4 -0
  101. package/date-input/DatePicker.js +115 -0
  102. package/date-input/Icons.d.ts +6 -0
  103. package/date-input/Icons.js +58 -0
  104. package/date-input/YearPicker.d.ts +4 -0
  105. package/date-input/YearPicker.js +100 -0
  106. package/date-input/types.d.ts +72 -15
  107. package/dialog/Dialog.accessibility.test.js +69 -0
  108. package/dialog/Dialog.d.ts +1 -1
  109. package/dialog/Dialog.js +73 -107
  110. package/dialog/Dialog.stories.tsx +320 -167
  111. package/dialog/Dialog.test.js +287 -20
  112. package/dialog/types.d.ts +18 -25
  113. package/divider/Divider.accessibility.test.js +33 -0
  114. package/divider/Divider.d.ts +4 -0
  115. package/divider/Divider.js +36 -0
  116. package/divider/Divider.stories.tsx +223 -0
  117. package/divider/Divider.test.js +38 -0
  118. package/divider/types.d.ts +21 -0
  119. package/dropdown/Dropdown.accessibility.test.js +180 -0
  120. package/dropdown/Dropdown.d.ts +1 -1
  121. package/dropdown/Dropdown.js +231 -303
  122. package/dropdown/Dropdown.stories.tsx +235 -57
  123. package/dropdown/Dropdown.test.js +575 -165
  124. package/dropdown/DropdownMenu.d.ts +4 -0
  125. package/dropdown/DropdownMenu.js +63 -0
  126. package/dropdown/DropdownMenuItem.d.ts +4 -0
  127. package/dropdown/DropdownMenuItem.js +70 -0
  128. package/dropdown/types.d.ts +35 -19
  129. package/file-input/FileInput.accessibility.test.js +160 -0
  130. package/file-input/FileInput.d.ts +2 -2
  131. package/file-input/FileInput.js +241 -391
  132. package/file-input/FileInput.stories.tsx +123 -12
  133. package/file-input/FileInput.test.js +292 -367
  134. package/file-input/FileItem.d.ts +4 -14
  135. package/file-input/FileItem.js +52 -117
  136. package/file-input/types.d.ts +25 -8
  137. package/flex/Flex.d.ts +4 -0
  138. package/flex/Flex.js +57 -0
  139. package/flex/Flex.stories.tsx +112 -0
  140. package/flex/types.d.ts +97 -0
  141. package/footer/Footer.accessibility.test.js +117 -0
  142. package/footer/Footer.d.ts +1 -1
  143. package/footer/Footer.js +73 -118
  144. package/footer/Footer.stories.tsx +87 -21
  145. package/footer/Footer.test.js +33 -57
  146. package/footer/Icons.d.ts +3 -2
  147. package/footer/Icons.js +67 -8
  148. package/footer/types.d.ts +26 -27
  149. package/grid/Grid.d.ts +7 -0
  150. package/grid/Grid.js +76 -0
  151. package/grid/Grid.stories.tsx +219 -0
  152. package/grid/types.d.ts +115 -0
  153. package/grid/types.js +5 -0
  154. package/header/Header.accessibility.test.js +84 -0
  155. package/header/Header.d.ts +4 -3
  156. package/header/Header.js +88 -182
  157. package/header/Header.stories.tsx +118 -39
  158. package/header/Header.test.js +13 -26
  159. package/header/Icons.d.ts +2 -2
  160. package/header/Icons.js +4 -9
  161. package/header/types.d.ts +7 -21
  162. package/heading/Heading.accessibility.test.js +33 -0
  163. package/heading/Heading.js +10 -32
  164. package/heading/Heading.test.js +71 -88
  165. package/heading/types.d.ts +7 -7
  166. package/icon/Icon.accessibility.test.js +30 -0
  167. package/icon/Icon.d.ts +4 -0
  168. package/icon/Icon.js +33 -0
  169. package/icon/Icon.stories.tsx +28 -0
  170. package/icon/types.d.ts +4 -0
  171. package/icon/types.js +5 -0
  172. package/image/Image.accessibility.test.js +56 -0
  173. package/image/Image.d.ts +4 -0
  174. package/image/Image.js +70 -0
  175. package/image/Image.stories.tsx +129 -0
  176. package/image/types.d.ts +72 -0
  177. package/image/types.js +5 -0
  178. package/inset/Inset.js +14 -55
  179. package/inset/Inset.stories.tsx +37 -36
  180. package/inset/types.d.ts +2 -2
  181. package/layout/ApplicationLayout.d.ts +15 -6
  182. package/layout/ApplicationLayout.js +52 -117
  183. package/layout/ApplicationLayout.stories.tsx +81 -45
  184. package/layout/Icons.d.ts +8 -5
  185. package/layout/Icons.js +49 -59
  186. package/layout/types.d.ts +21 -32
  187. package/link/Link.accessibility.test.js +112 -0
  188. package/link/Link.js +32 -51
  189. package/link/Link.stories.tsx +74 -7
  190. package/link/Link.test.js +24 -44
  191. package/link/types.d.ts +14 -14
  192. package/main.d.ts +14 -12
  193. package/main.js +63 -99
  194. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  195. package/nav-tabs/NavTabs.d.ts +7 -0
  196. package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
  197. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +115 -9
  198. package/{tabs-nav → nav-tabs}/NavTabs.test.js +39 -45
  199. package/nav-tabs/NavTabsContext.d.ts +3 -0
  200. package/nav-tabs/NavTabsContext.js +8 -0
  201. package/nav-tabs/Tab.js +118 -0
  202. package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
  203. package/nav-tabs/types.js +5 -0
  204. package/number-input/NumberInput.accessibility.test.js +228 -0
  205. package/number-input/NumberInput.js +46 -36
  206. package/number-input/NumberInput.stories.tsx +42 -26
  207. package/number-input/NumberInput.test.js +860 -377
  208. package/number-input/NumberInputContext.d.ts +3 -4
  209. package/number-input/NumberInputContext.js +3 -14
  210. package/number-input/types.d.ts +17 -5
  211. package/package.json +49 -51
  212. package/paginator/Icons.d.ts +5 -0
  213. package/paginator/Icons.js +21 -47
  214. package/paginator/Paginator.accessibility.test.js +79 -0
  215. package/paginator/Paginator.js +23 -59
  216. package/paginator/Paginator.stories.tsx +24 -0
  217. package/paginator/Paginator.test.js +280 -211
  218. package/paginator/types.d.ts +3 -3
  219. package/paragraph/Paragraph.accessibility.test.js +28 -0
  220. package/paragraph/Paragraph.d.ts +5 -0
  221. package/paragraph/Paragraph.js +22 -0
  222. package/paragraph/Paragraph.stories.tsx +27 -0
  223. package/password-input/Icons.d.ts +6 -0
  224. package/password-input/Icons.js +35 -0
  225. package/password-input/PasswordInput.accessibility.test.js +153 -0
  226. package/password-input/PasswordInput.js +57 -126
  227. package/password-input/PasswordInput.stories.tsx +1 -33
  228. package/password-input/PasswordInput.test.js +160 -142
  229. package/password-input/types.d.ts +8 -7
  230. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  231. package/progress-bar/ProgressBar.js +65 -91
  232. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  233. package/progress-bar/ProgressBar.test.js +72 -44
  234. package/progress-bar/types.d.ts +3 -3
  235. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  236. package/quick-nav/QuickNav.js +29 -47
  237. package/quick-nav/QuickNav.stories.tsx +146 -27
  238. package/quick-nav/types.d.ts +10 -10
  239. package/radio-group/Radio.d.ts +1 -1
  240. package/radio-group/Radio.js +59 -76
  241. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  242. package/radio-group/RadioGroup.js +67 -114
  243. package/radio-group/RadioGroup.stories.tsx +132 -18
  244. package/radio-group/RadioGroup.test.js +518 -457
  245. package/radio-group/types.d.ts +10 -10
  246. package/resultset-table/Icons.d.ts +7 -0
  247. package/resultset-table/Icons.js +47 -0
  248. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  249. package/resultset-table/ResultsetTable.d.ts +7 -0
  250. package/resultset-table/ResultsetTable.js +170 -0
  251. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -30
  252. package/resultset-table/ResultsetTable.test.js +381 -0
  253. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  254. package/resultset-table/types.js +5 -0
  255. package/select/Icons.d.ts +7 -7
  256. package/select/Icons.js +1 -5
  257. package/select/Listbox.d.ts +1 -1
  258. package/select/Listbox.js +42 -51
  259. package/select/Option.js +27 -50
  260. package/select/Select.accessibility.test.js +217 -0
  261. package/select/Select.js +152 -207
  262. package/select/Select.stories.tsx +515 -139
  263. package/select/Select.test.js +2001 -1751
  264. package/select/types.d.ts +16 -20
  265. package/sidenav/Sidenav.accessibility.test.js +59 -0
  266. package/sidenav/Sidenav.d.ts +6 -5
  267. package/sidenav/Sidenav.js +132 -78
  268. package/sidenav/Sidenav.stories.tsx +246 -151
  269. package/sidenav/Sidenav.test.js +26 -45
  270. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  271. package/{layout → sidenav}/SidenavContext.js +3 -9
  272. package/sidenav/types.d.ts +52 -26
  273. package/slider/Slider.accessibility.test.js +104 -0
  274. package/slider/Slider.d.ts +2 -2
  275. package/slider/Slider.js +148 -181
  276. package/slider/Slider.test.js +185 -81
  277. package/slider/types.d.ts +7 -3
  278. package/spinner/Spinner.accessibility.test.js +96 -0
  279. package/spinner/Spinner.js +31 -75
  280. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  281. package/spinner/Spinner.test.js +26 -35
  282. package/spinner/types.d.ts +3 -3
  283. package/status-light/StatusLight.accessibility.test.js +157 -0
  284. package/status-light/StatusLight.d.ts +4 -0
  285. package/status-light/StatusLight.js +51 -0
  286. package/status-light/StatusLight.stories.tsx +74 -0
  287. package/status-light/StatusLight.test.js +25 -0
  288. package/status-light/types.d.ts +17 -0
  289. package/status-light/types.js +5 -0
  290. package/switch/Switch.accessibility.test.js +89 -0
  291. package/switch/Switch.d.ts +2 -2
  292. package/switch/Switch.js +145 -126
  293. package/switch/Switch.stories.tsx +37 -60
  294. package/switch/Switch.test.js +138 -56
  295. package/switch/types.d.ts +7 -3
  296. package/table/DropdownTheme.js +62 -0
  297. package/table/Table.accessibility.test.js +82 -0
  298. package/table/Table.d.ts +6 -2
  299. package/table/Table.js +78 -35
  300. package/table/Table.stories.tsx +651 -0
  301. package/table/Table.test.js +95 -8
  302. package/table/types.d.ts +34 -6
  303. package/tabs/Tab.d.ts +4 -0
  304. package/tabs/Tab.js +116 -0
  305. package/tabs/Tabs.accessibility.test.js +56 -0
  306. package/tabs/Tabs.js +314 -141
  307. package/tabs/Tabs.stories.tsx +120 -6
  308. package/tabs/Tabs.test.js +223 -69
  309. package/tabs/types.d.ts +28 -18
  310. package/tag/Tag.accessibility.test.js +69 -0
  311. package/tag/Tag.js +35 -67
  312. package/tag/Tag.stories.tsx +18 -8
  313. package/tag/Tag.test.js +18 -37
  314. package/tag/types.d.ts +9 -9
  315. package/text-input/Suggestion.js +40 -28
  316. package/text-input/Suggestions.d.ts +4 -0
  317. package/text-input/Suggestions.js +86 -0
  318. package/text-input/TextInput.accessibility.test.js +321 -0
  319. package/text-input/TextInput.js +311 -514
  320. package/text-input/TextInput.stories.tsx +266 -275
  321. package/text-input/TextInput.test.js +1419 -1375
  322. package/text-input/types.d.ts +43 -16
  323. package/textarea/Textarea.accessibility.test.js +155 -0
  324. package/textarea/Textarea.js +70 -113
  325. package/textarea/Textarea.stories.tsx +174 -0
  326. package/textarea/Textarea.test.js +152 -183
  327. package/textarea/types.d.ts +9 -5
  328. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  329. package/toggle-group/ToggleGroup.d.ts +2 -2
  330. package/toggle-group/ToggleGroup.js +92 -106
  331. package/toggle-group/ToggleGroup.stories.tsx +49 -4
  332. package/toggle-group/ToggleGroup.test.js +69 -88
  333. package/toggle-group/types.d.ts +26 -17
  334. package/typography/Typography.accessibility.test.js +339 -0
  335. package/typography/Typography.d.ts +4 -0
  336. package/typography/Typography.js +23 -0
  337. package/typography/Typography.stories.tsx +198 -0
  338. package/typography/types.d.ts +18 -0
  339. package/typography/types.js +5 -0
  340. package/useTheme.d.ts +1147 -1
  341. package/useTheme.js +2 -9
  342. package/useTranslatedLabels.d.ts +84 -1
  343. package/useTranslatedLabels.js +1 -7
  344. package/utils/BaseTypography.d.ts +21 -0
  345. package/utils/BaseTypography.js +94 -0
  346. package/utils/FocusLock.d.ts +13 -0
  347. package/utils/FocusLock.js +124 -0
  348. package/wizard/Wizard.accessibility.test.js +55 -0
  349. package/wizard/Wizard.js +24 -66
  350. package/wizard/Wizard.stories.tsx +40 -1
  351. package/wizard/Wizard.test.js +54 -81
  352. package/wizard/types.d.ts +8 -8
  353. package/card/ice-cream.jpg +0 -0
  354. package/common/OpenSans.css +0 -81
  355. package/common/RequiredComponent.js +0 -32
  356. package/common/fonts/OpenSans-Bold.ttf +0 -0
  357. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  358. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  359. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  360. package/common/fonts/OpenSans-Italic.ttf +0 -0
  361. package/common/fonts/OpenSans-Light.ttf +0 -0
  362. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  363. package/common/fonts/OpenSans-Regular.ttf +0 -0
  364. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  365. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  366. package/list/List.d.ts +0 -4
  367. package/list/List.js +0 -47
  368. package/list/List.stories.tsx +0 -95
  369. package/list/types.d.ts +0 -7
  370. package/number-input/numberInputContextTypes.d.ts +0 -19
  371. package/resultsetTable/ResultsetTable.d.ts +0 -4
  372. package/resultsetTable/ResultsetTable.js +0 -254
  373. package/resultsetTable/ResultsetTable.test.js +0 -306
  374. package/row/Row.d.ts +0 -3
  375. package/row/Row.js +0 -127
  376. package/row/Row.stories.tsx +0 -237
  377. package/row/types.d.ts +0 -28
  378. package/slider/Slider.stories.tsx +0 -177
  379. package/stack/Stack.d.ts +0 -3
  380. package/stack/Stack.js +0 -97
  381. package/stack/Stack.stories.tsx +0 -164
  382. package/stack/types.d.ts +0 -24
  383. package/table/Table.stories.jsx +0 -277
  384. package/tabs-nav/NavTabs.d.ts +0 -8
  385. package/tabs-nav/Tab.js +0 -132
  386. package/text/Text.d.ts +0 -7
  387. package/text/Text.js +0 -30
  388. package/text/Text.stories.tsx +0 -19
  389. package/textarea/Textarea.stories.jsx +0 -157
  390. /package/{list → action-icon}/types.js +0 -0
  391. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  392. /package/{row → container}/types.js +0 -0
  393. /package/{stack → contextual-menu}/types.js +0 -0
  394. /package/{tabs-nav → divider}/types.js +0 -0
  395. /package/{number-input/numberInputContextTypes.js → flex/types.js} +0 -0
  396. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
package/select/types.d.ts CHANGED
@@ -1,13 +1,13 @@
1
- /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
1
+ import React from "react";
2
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- declare type SVG = React.SVGProps<SVGSVGElement>;
10
- declare type OptionGroup = {
9
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
10
+ export type OptionGroup = {
11
11
  /**
12
12
  * Label of the group to be shown in the select's listbox.
13
13
  */
@@ -17,7 +17,7 @@ declare type OptionGroup = {
17
17
  */
18
18
  options: Option[];
19
19
  };
20
- declare type Option = {
20
+ export type Option = {
21
21
  /**
22
22
  * Element used as the icon that will be placed before the option label.
23
23
  * It can be a url of an image or an inline SVG. If the url option
@@ -36,7 +36,7 @@ declare type Option = {
36
36
  */
37
37
  value: string;
38
38
  };
39
- declare type CommonProps = {
39
+ type CommonProps = {
40
40
  /**
41
41
  * Text to be placed above the select.
42
42
  */
@@ -45,9 +45,8 @@ declare type CommonProps = {
45
45
  * Name attribute of the input element. This attribute will allow users
46
46
  * to find the component's value during the submit event. In this event,
47
47
  * the component's value will always be a regular string, for both single
48
- * and multiple selection modes, been in the first one a single option
49
- * value and in the multiple variant more than one option value,
50
- * separated by commas.
48
+ * and multiple selection modes, being a single option value in the first case
49
+ * and more than one value when multiple selection is available, separated by commas.
51
50
  */
52
51
  name?: string;
53
52
  /**
@@ -101,7 +100,7 @@ declare type CommonProps = {
101
100
  */
102
101
  tabIndex?: number;
103
102
  };
104
- declare type SingleSelect = CommonProps & {
103
+ type SingleSelect = CommonProps & {
105
104
  /**
106
105
  * If true, the select component will support multiple selected options.
107
106
  * In that case, value will be an array of strings with each selected
@@ -137,7 +136,7 @@ declare type SingleSelect = CommonProps & {
137
136
  error?: string;
138
137
  }) => void;
139
138
  };
140
- declare type MultipleSelect = CommonProps & {
139
+ type MultipleSelect = CommonProps & {
141
140
  /**
142
141
  * If true, the select component will support multiple selected options.
143
142
  * In that case, value will be an array of strings with each selected
@@ -173,11 +172,11 @@ declare type MultipleSelect = CommonProps & {
173
172
  error?: string;
174
173
  }) => void;
175
174
  };
176
- declare type Props = SingleSelect | MultipleSelect;
175
+ type Props = SingleSelect | MultipleSelect;
177
176
  /**
178
177
  * Single option of the select component.
179
178
  */
180
- export declare type OptionProps = {
179
+ export type OptionProps = {
181
180
  id: string;
182
181
  option: Option;
183
182
  onClick: (option: Option) => void;
@@ -190,7 +189,7 @@ export declare type OptionProps = {
190
189
  /**
191
190
  * Listbox from the select component.
192
191
  */
193
- export declare type ListboxProps = {
192
+ export type ListboxProps = {
194
193
  id: string;
195
194
  currentValue: string | string[];
196
195
  options: Option[] | OptionGroup[];
@@ -201,13 +200,10 @@ export declare type ListboxProps = {
201
200
  optionalItem: Option;
202
201
  searchable: boolean;
203
202
  handleOptionOnClick: (option: Option) => void;
203
+ styles: React.CSSProperties;
204
204
  };
205
- /**
206
- * Reference to the listbox component.
207
- */
208
- export declare type ListboxRefType = HTMLUListElement;
209
205
  /**
210
206
  * Reference to the select component.
211
207
  */
212
- export declare type RefType = HTMLDivElement;
208
+ export type RefType = HTMLDivElement;
213
209
  export default Props;
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _jestAxe = require("jest-axe");
9
+ var _Sidenav = _interopRequireDefault(require("./Sidenav.tsx"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "currentColor"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123\nC8.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\nh274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225\nC438.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\nc0-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\nc-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ })));
21
+ describe("Sidenav component accessibility tests", function () {
22
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
23
+ var _render, container, results;
24
+ return _regenerator["default"].wrap(function _callee$(_context) {
25
+ while (1) switch (_context.prev = _context.next) {
26
+ case 0:
27
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Sidenav["default"], {
28
+ title: "Title"
29
+ }, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement("p", null, "nav-content-test"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
30
+ href: "#",
31
+ icon: iconSVG,
32
+ selected: true
33
+ }, "Link")), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Section, null, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Group, {
34
+ title: "Collapsable",
35
+ icon: iconSVG,
36
+ collapsable: true
37
+ }, /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
38
+ href: "#"
39
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
40
+ href: "#"
41
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
42
+ href: "#"
43
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
44
+ href: "#"
45
+ }, "Lorem ipsum"), /*#__PURE__*/_react["default"].createElement(_Sidenav["default"].Link, {
46
+ href: "#"
47
+ }, "Lorem ipsum"))))), container = _render.container;
48
+ _context.next = 3;
49
+ return (0, _jestAxe.axe)(container);
50
+ case 3:
51
+ results = _context.sent;
52
+ expect(results).toHaveNoViolations();
53
+ case 5:
54
+ case "end":
55
+ return _context.stop();
56
+ }
57
+ }, _callee);
58
+ })));
59
+ });
@@ -1,9 +1,10 @@
1
- /// <reference types="react" />
2
- import SidenavPropsType, { SidenavTitlePropsType, SidenavSubtitlePropsType, SidenavLinkPropsType } from "./types";
1
+ import React from "react";
2
+ import SidenavPropsType, { SidenavGroupPropsType, SidenavLinkPropsType, SidenavSectionPropsType, SidenavTitlePropsType } from "./types.js";
3
3
  declare const DxcSidenav: {
4
- ({ padding, children }: SidenavPropsType): JSX.Element;
4
+ ({ title, children }: SidenavPropsType): JSX.Element;
5
+ Section: ({ children }: SidenavSectionPropsType) => JSX.Element;
6
+ Group: ({ title, collapsable, icon, children }: SidenavGroupPropsType) => JSX.Element;
7
+ Link: React.ForwardRefExoticComponent<SidenavLinkPropsType & React.RefAttributes<HTMLAnchorElement>>;
5
8
  Title: ({ children }: SidenavTitlePropsType) => JSX.Element;
6
- Subtitle: ({ children }: SidenavSubtitlePropsType) => JSX.Element;
7
- Link: ({ tabIndex, href, onClick, children }: SidenavLinkPropsType) => JSX.Element;
8
9
  };
9
10
  export default DxcSidenav;
@@ -1,99 +1,141 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports["default"] = void 0;
11
-
12
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
-
14
- var _react = _interopRequireDefault(require("react"));
15
-
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+ var _react = _interopRequireWildcard(require("react"));
16
14
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
17
-
18
- var _variables = require("../common/variables.js");
19
-
15
+ var _variables = require("../common/variables");
16
+ var _SidenavContext = require("./SidenavContext");
20
17
  var _useTheme = _interopRequireDefault(require("../useTheme"));
21
-
22
- var _BackgroundColorContext = require("../BackgroundColorContext");
23
-
24
- var _SidenavContext = require("../layout/SidenavContext");
25
-
26
- var _templateObject, _templateObject2, _templateObject3, _templateObject4;
27
-
28
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
-
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
-
18
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
19
+ var _Bleed = _interopRequireDefault(require("../bleed/Bleed"));
20
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
21
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
22
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
23
+ var _excluded = ["href", "newWindow", "selected", "icon", "onClick", "tabIndex", "children"];
24
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
25
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
32
26
  var DxcSidenav = function DxcSidenav(_ref) {
33
- var padding = _ref.padding,
34
- children = _ref.children;
27
+ var title = _ref.title,
28
+ children = _ref.children;
35
29
  var colorsTheme = (0, _useTheme["default"])();
36
30
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
37
31
  theme: colorsTheme.sidenav
38
- }, /*#__PURE__*/_react["default"].createElement(SidenavContainer, {
39
- padding: padding
40
- }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
41
- color: colorsTheme.sidenav.backgroundColor
32
+ }, /*#__PURE__*/_react["default"].createElement(SidenavContainer, null, title, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
33
+ direction: "column",
34
+ gap: "1rem"
42
35
  }, children)));
43
36
  };
44
-
45
37
  var Title = function Title(_ref2) {
46
38
  var children = _ref2.children;
47
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuTitle, null, children);
39
+ return /*#__PURE__*/_react["default"].createElement(_Bleed["default"], {
40
+ horizontal: "1rem"
41
+ }, /*#__PURE__*/_react["default"].createElement(SidenavTitle, null, children));
48
42
  };
49
-
50
- var Subtitle = function Subtitle(_ref3) {
43
+ var Section = function Section(_ref3) {
51
44
  var children = _ref3.children;
52
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuSubTitle, null, children);
45
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_Bleed["default"], {
46
+ horizontal: "1rem"
47
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
48
+ direction: "column"
49
+ }, children)), /*#__PURE__*/_react["default"].createElement(Divider, null));
53
50
  };
54
-
55
- var Link = function Link(_ref4) {
56
- var _ref4$tabIndex = _ref4.tabIndex,
57
- tabIndex = _ref4$tabIndex === void 0 ? 0 : _ref4$tabIndex,
58
- href = _ref4.href,
59
- onClick = _ref4.onClick,
60
- children = _ref4.children;
51
+ var GroupContext = /*#__PURE__*/_react["default"].createContext(null);
52
+ var Group = function Group(_ref4) {
53
+ var title = _ref4.title,
54
+ _ref4$collapsable = _ref4.collapsable,
55
+ collapsable = _ref4$collapsable === void 0 ? false : _ref4$collapsable,
56
+ icon = _ref4.icon,
57
+ children = _ref4.children;
58
+ var _useState = (0, _react.useState)(false),
59
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
60
+ collapsed = _useState2[0],
61
+ setCollapsed = _useState2[1];
62
+ var _useState3 = (0, _react.useState)(false),
63
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
64
+ isSelected = _useState4[0],
65
+ changeIsSelected = _useState4[1];
66
+ return /*#__PURE__*/_react["default"].createElement(GroupContext.Provider, {
67
+ value: changeIsSelected
68
+ }, /*#__PURE__*/_react["default"].createElement(SidenavGroup, null, collapsable && title ? /*#__PURE__*/_react["default"].createElement(SidenavGroupTitleButton, {
69
+ "aria-expanded": !collapsed,
70
+ onClick: function onClick() {
71
+ return setCollapsed(!collapsed);
72
+ },
73
+ selectedGroup: collapsed && isSelected
74
+ }, /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
75
+ alignItems: "center",
76
+ gap: "0.5rem"
77
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
78
+ icon: icon
79
+ }) : icon, title), /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
80
+ icon: collapsed ? "expand_more" : "expand_less"
81
+ })) : title && /*#__PURE__*/_react["default"].createElement(SidenavGroupTitle, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
82
+ icon: icon
83
+ }) : icon, title), !collapsed && children));
84
+ };
85
+ var Link = /*#__PURE__*/(0, _react.forwardRef)(function (_ref5, ref) {
86
+ var href = _ref5.href,
87
+ _ref5$newWindow = _ref5.newWindow,
88
+ newWindow = _ref5$newWindow === void 0 ? false : _ref5$newWindow,
89
+ _ref5$selected = _ref5.selected,
90
+ selected = _ref5$selected === void 0 ? false : _ref5$selected,
91
+ icon = _ref5.icon,
92
+ onClick = _ref5.onClick,
93
+ _ref5$tabIndex = _ref5.tabIndex,
94
+ tabIndex = _ref5$tabIndex === void 0 ? 0 : _ref5$tabIndex,
95
+ children = _ref5.children,
96
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref5, _excluded);
97
+ var changeIsGroupSelected = (0, _react.useContext)(GroupContext);
61
98
  var setIsSidenavVisibleResponsive = (0, _SidenavContext.useResponsiveSidenavVisibility)();
62
-
63
- var handleClick = function handleClick() {
64
- onClick === null || onClick === void 0 ? void 0 : onClick();
99
+ var handleClick = function handleClick($event) {
100
+ onClick === null || onClick === void 0 ? void 0 : onClick($event);
65
101
  setIsSidenavVisibleResponsive === null || setIsSidenavVisibleResponsive === void 0 ? void 0 : setIsSidenavVisibleResponsive(false);
66
102
  };
67
-
68
- return /*#__PURE__*/_react["default"].createElement(SidenavMenuLink, {
103
+ (0, _react.useEffect)(function () {
104
+ changeIsGroupSelected === null || changeIsGroupSelected === void 0 ? void 0 : changeIsGroupSelected(function (isGroupSelected) {
105
+ return !isGroupSelected ? selected : isGroupSelected;
106
+ });
107
+ }, [selected, changeIsGroupSelected]);
108
+ return /*#__PURE__*/_react["default"].createElement(SidenavLink, (0, _extends2["default"])({
109
+ selected: selected,
110
+ href: href ? href : undefined,
111
+ target: href ? newWindow ? "_blank" : "_self" : undefined,
112
+ ref: ref,
69
113
  tabIndex: tabIndex,
70
- href: href,
71
114
  onClick: handleClick
72
- }, children);
73
- };
74
-
75
- var SidenavContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n background-color: ", ";\n\n @media (max-width: ", "rem) {\n width: ", ";\n }\n\n width: ", ";\n padding: ", ";\n\n overflow-y: auto;\n overflow-x: hidden;\n ::-webkit-scrollbar {\n width: 2px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n"])), function (props) {
115
+ }, otherProps), /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
116
+ alignItems: "center",
117
+ gap: "0.5rem"
118
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
119
+ icon: icon
120
+ }) : icon, children), newWindow && /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
121
+ icon: "open_in_new"
122
+ }));
123
+ });
124
+ var SidenavContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n width: 280px;\n @media (max-width: ", "rem) {\n width: 100vw;\n }\n padding: 2rem 1rem;\n background-color: ", ";\n\n overflow-y: auto;\n overflow-x: hidden;\n ::-webkit-scrollbar {\n width: 2px;\n }\n ::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 3px;\n }\n ::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 3px;\n }\n"])), _variables.responsiveSizes.medium, function (props) {
76
125
  return props.theme.backgroundColor;
77
- }, _variables.responsiveSizes.medium, function (props) {
78
- return props.padding ? "calc(100vw - ".concat(_variables.spaces[props.padding], " - ").concat(_variables.spaces[props.padding], ")") : "100vw";
79
- }, function (props) {
80
- return props.padding ? "calc(300px - ".concat(_variables.spaces[props.padding], " - ").concat(_variables.spaces[props.padding], ")") : "300px";
81
- }, function (props) {
82
- return props.padding ? _variables.spaces[props.padding] : "";
83
126
  }, function (props) {
84
127
  return props.theme.scrollBarTrackColor;
85
128
  }, function (props) {
86
129
  return props.theme.scrollBarThumbColor;
87
130
  });
88
-
89
- var SidenavMenuTitle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n margin-bottom: 16px;\n"])), function (props) {
131
+ var SidenavTitle = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n padding: 0.5rem 1.2rem;\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n"])), function (props) {
90
132
  return props.theme.titleFontFamily;
91
- }, function (props) {
92
- return props.theme.titleFontSize;
93
133
  }, function (props) {
94
134
  return props.theme.titleFontStyle;
95
135
  }, function (props) {
96
136
  return props.theme.titleFontWeight;
137
+ }, function (props) {
138
+ return props.theme.titleFontSize;
97
139
  }, function (props) {
98
140
  return props.theme.titleFontColor;
99
141
  }, function (props) {
@@ -101,33 +143,42 @@ var SidenavMenuTitle = _styledComponents["default"].div(_templateObject2 || (_te
101
143
  }, function (props) {
102
144
  return props.theme.titleFontTextTransform;
103
145
  });
104
-
105
- var SidenavMenuSubTitle = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n margin-bottom: 4px;\n"])), function (props) {
106
- return props.theme.subtitleFontFamily;
146
+ var Divider = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n height: 1px;\n background-color: ", ";\n\n &:last-child {\n display: none;\n }\n"])), _coreTokens["default"].color_grey_400);
147
+ var SidenavGroup = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n a {\n padding: 0.5rem 1.2rem 0.5rem 2.25rem;\n }\n"])));
148
+ var SidenavGroupTitle = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n align-items: center;\n gap: 0.5rem;\n padding: 0.5rem 1.2rem;\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n span::before {\n font-size: 16px;\n }\n svg {\n height: 16px;\n width: 16px;\n }\n"])), function (props) {
149
+ return props.theme.groupTitleFontFamily;
150
+ }, function (props) {
151
+ return props.theme.groupTitleFontStyle;
152
+ }, function (props) {
153
+ return props.theme.groupTitleFontWeight;
154
+ }, function (props) {
155
+ return props.theme.groupTitleFontSize;
156
+ });
157
+ var SidenavGroupTitleButton = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n all: unset;\n box-sizing: border-box;\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n padding: 0.5rem 1.2rem;\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n cursor: pointer;\n\n ", "\n\n &:focus, &:focus-visible {\n outline: 2px solid ", ";\n outline-offset: -2px;\n }\n &:hover {\n ", "\n }\n &:active {\n color: #fff;\n background-color: ", ";\n }\n span::before {\n font-size: 16px;\n }\n svg {\n height: 16px;\n width: 16px;\n }\n"])), function (props) {
158
+ return props.theme.groupTitleFontFamily;
107
159
  }, function (props) {
108
- return props.theme.subtitleFontSize;
160
+ return props.theme.groupTitleFontStyle;
109
161
  }, function (props) {
110
- return props.theme.subtitleFontStyle;
162
+ return props.theme.groupTitleFontWeight;
111
163
  }, function (props) {
112
- return props.theme.subtitleFontWeight;
164
+ return props.theme.groupTitleFontSize;
113
165
  }, function (props) {
114
- return props.theme.subtitleFontColor;
166
+ return props.selectedGroup ? "color: ".concat(props.theme.groupTitleSelectedFontColor, "; background-color: ").concat(props.theme.groupTitleSelectedBackgroundColor, ";") : "color: ".concat(props.theme.groupTitleFontColor, "; background-color: transparent;");
115
167
  }, function (props) {
116
- return props.theme.subtitleFontLetterSpacing;
168
+ return props.theme.linkFocusColor;
169
+ }, function (props) {
170
+ return props.selectedGroup ? "color: ".concat(props.theme.groupTitleSelectedHoverFontColor, "; background-color: ").concat(props.theme.groupTitleSelectedHoverBackgroundColor, ";") : "color: ".concat(props.theme.groupTitleFontColor, "; background-color: ").concat(props.theme.groupTitleHoverBackgroundColor, ";");
117
171
  }, function (props) {
118
- return props.theme.subtitleFontTextTransform;
172
+ return props.selectedGroup ? "#333" : props.theme.groupTitleActiveBackgroundColor;
119
173
  });
120
-
121
- var SidenavMenuLink = _styledComponents["default"].a(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n color: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n text-decoration: ", ";\n margin: ", ";\n cursor: pointer;\n\n :focus-visible {\n outline: 2px solid ", ";\n outline-offset: 1px;\n }\n"])), function (props) {
174
+ var SidenavLink = _styledComponents["default"].a(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 0.5rem;\n padding: 0.5rem 1.2rem;\n box-shadow: 0 0 0 2px transparent;\n font-family: ", ";\n font-style: ", ";\n font-weight: ", ";\n font-size: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n text-decoration: ", ";\n cursor: pointer;\n\n ", "\n\n &:focus, &:focus-visible {\n outline: 2px solid ", ";\n outline-offset: -2px;\n }\n &:hover {\n ", "\n }\n &:active {\n color: #fff;\n background-color: ", ";\n outline: 2px solid #0095ff;\n outline-offset: -2px;\n }\n span::before {\n font-size: 16px;\n }\n svg {\n height: 16px;\n width: 16px;\n }\n"])), function (props) {
122
175
  return props.theme.linkFontFamily;
123
- }, function (props) {
124
- return props.theme.linkFontSize;
125
176
  }, function (props) {
126
177
  return props.theme.linkFontStyle;
127
178
  }, function (props) {
128
179
  return props.theme.linkFontWeight;
129
180
  }, function (props) {
130
- return props.theme.linkFontColor;
181
+ return props.theme.linkFontSize;
131
182
  }, function (props) {
132
183
  return props.theme.linkFontLetterSpacing;
133
184
  }, function (props) {
@@ -135,13 +186,16 @@ var SidenavMenuLink = _styledComponents["default"].a(_templateObject4 || (_templ
135
186
  }, function (props) {
136
187
  return props.theme.linkTextDecoration;
137
188
  }, function (props) {
138
- return "".concat(props.theme.linkMarginTop, " ").concat(props.theme.linkMarginRight, " ").concat(props.theme.linkMarginBottom, " ").concat(props.theme.linkMarginLeft);
189
+ return props.selected ? "color: ".concat(props.theme.linkSelectedFontColor, "; background-color: ").concat(props.theme.linkSelectedBackgroundColor, ";") : "color: ".concat(props.theme.linkFontColor, "; background-color: transparent;");
139
190
  }, function (props) {
140
191
  return props.theme.linkFocusColor;
192
+ }, function (props) {
193
+ return props.selected ? "color: ".concat(props.theme.linkSelectedHoverFontColor, "; background-color: ").concat(props.theme.linkSelectedHoverBackgroundColor, ";") : "color: ".concat(props.theme.linkFontColor, "; background-color: ").concat(props.theme.linkHoverBackgroundColor, ";");
194
+ }, function (props) {
195
+ return props.selected ? "#333" : "#4d4d4d";
141
196
  });
142
-
143
- DxcSidenav.Title = Title;
144
- DxcSidenav.Subtitle = Subtitle;
197
+ DxcSidenav.Section = Section;
198
+ DxcSidenav.Group = Group;
145
199
  DxcSidenav.Link = Link;
146
- var _default = DxcSidenav;
147
- exports["default"] = _default;
200
+ DxcSidenav.Title = Title;
201
+ var _default = exports["default"] = DxcSidenav;