@dxc-technology/halstack-react 0.0.0-f2bad31 → 0.0.0-f319e71

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 (330) hide show
  1. package/BackgroundColorContext.js +1 -1
  2. package/HalstackContext.d.ts +2 -5
  3. package/HalstackContext.js +6 -6
  4. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  5. package/accordion/Accordion.accessibility.test.js +4 -4
  6. package/accordion/Accordion.js +9 -10
  7. package/accordion/Accordion.stories.tsx +4 -14
  8. package/accordion/Accordion.test.d.ts +1 -0
  9. package/accordion/Accordion.test.js +3 -3
  10. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  11. package/accordion-group/AccordionGroup.accessibility.test.js +11 -17
  12. package/accordion-group/AccordionGroup.js +1 -1
  13. package/accordion-group/AccordionGroup.stories.tsx +23 -23
  14. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.test.js +5 -9
  16. package/accordion-group/AccordionGroupAccordion.js +1 -1
  17. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  18. package/action-icon/ActionIcon.accessibility.test.js +4 -4
  19. package/action-icon/ActionIcon.test.d.ts +1 -0
  20. package/action-icon/ActionIcon.test.js +1 -1
  21. package/alert/Alert.accessibility.test.d.ts +1 -0
  22. package/alert/Alert.accessibility.test.js +6 -6
  23. package/alert/Alert.js +6 -3
  24. package/alert/Alert.test.d.ts +1 -0
  25. package/alert/Alert.test.js +1 -1
  26. package/badge/Badge.accessibility.test.d.ts +1 -0
  27. package/badge/Badge.accessibility.test.js +5 -5
  28. package/badge/Badge.js +6 -4
  29. package/badge/Badge.stories.tsx +11 -11
  30. package/badge/Badge.test.d.ts +1 -0
  31. package/badge/Badge.test.js +2 -2
  32. package/badge/types.d.ts +1 -1
  33. package/box/Box.accessibility.test.d.ts +1 -0
  34. package/box/Box.accessibility.test.js +3 -3
  35. package/box/Box.js +1 -1
  36. package/box/Box.test.d.ts +1 -0
  37. package/box/Box.test.js +1 -1
  38. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  39. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  40. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  41. package/breadcrumbs/Breadcrumbs.js +79 -0
  42. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  43. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  44. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  45. package/breadcrumbs/Item.d.ts +4 -0
  46. package/breadcrumbs/Item.js +52 -0
  47. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  48. package/breadcrumbs/dropdownTheme.js +62 -0
  49. package/breadcrumbs/types.d.ts +16 -0
  50. package/breadcrumbs/types.js +5 -0
  51. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  52. package/bulleted-list/BulletedList.accessibility.test.js +18 -6
  53. package/bulleted-list/BulletedList.js +2 -2
  54. package/button/Button.accessibility.test.d.ts +1 -0
  55. package/button/Button.accessibility.test.js +6 -6
  56. package/button/Button.js +1 -1
  57. package/button/Button.stories.tsx +3 -3
  58. package/button/Button.test.d.ts +1 -0
  59. package/button/Button.test.js +1 -1
  60. package/card/Card.accessibility.test.d.ts +1 -0
  61. package/card/Card.accessibility.test.js +3 -3
  62. package/card/Card.js +3 -2
  63. package/card/Card.stories.tsx +1 -1
  64. package/card/Card.test.d.ts +1 -0
  65. package/card/Card.test.js +1 -1
  66. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  67. package/checkbox/Checkbox.accessibility.test.js +5 -5
  68. package/checkbox/Checkbox.js +10 -13
  69. package/checkbox/Checkbox.test.d.ts +1 -0
  70. package/checkbox/Checkbox.test.js +1 -1
  71. package/chip/Chip.accessibility.test.d.ts +1 -0
  72. package/chip/Chip.accessibility.test.js +4 -4
  73. package/chip/Chip.js +3 -1
  74. package/chip/Chip.stories.tsx +1 -1
  75. package/chip/Chip.test.d.ts +1 -0
  76. package/chip/Chip.test.js +1 -1
  77. package/common/coreTokens.js +3 -3
  78. package/common/variables.d.ts +2 -5
  79. package/common/variables.js +68 -71
  80. package/container/Container.stories.tsx +3 -3
  81. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  82. package/contextual-menu/ContextualMenu.accessibility.test.js +15 -3
  83. package/contextual-menu/ContextualMenu.d.ts +3 -5
  84. package/contextual-menu/ContextualMenu.js +89 -52
  85. package/contextual-menu/ContextualMenu.stories.tsx +115 -74
  86. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  87. package/contextual-menu/ContextualMenu.test.js +200 -24
  88. package/contextual-menu/GroupItem.d.ts +4 -0
  89. package/contextual-menu/GroupItem.js +67 -0
  90. package/contextual-menu/ItemAction.d.ts +4 -0
  91. package/contextual-menu/ItemAction.js +50 -0
  92. package/contextual-menu/MenuItem.d.ts +4 -0
  93. package/contextual-menu/MenuItem.js +29 -0
  94. package/contextual-menu/SingleItem.d.ts +4 -0
  95. package/contextual-menu/SingleItem.js +38 -0
  96. package/contextual-menu/types.d.ts +50 -11
  97. package/date-input/Calendar.js +47 -31
  98. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  99. package/date-input/DateInput.accessibility.test.js +24 -11
  100. package/date-input/DateInput.js +28 -23
  101. package/date-input/DateInput.stories.tsx +18 -12
  102. package/date-input/DateInput.test.d.ts +1 -0
  103. package/date-input/DateInput.test.js +39 -39
  104. package/date-input/DatePicker.js +13 -7
  105. package/date-input/YearPicker.js +10 -5
  106. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  107. package/dialog/Dialog.accessibility.test.js +5 -5
  108. package/dialog/Dialog.js +9 -20
  109. package/dialog/Dialog.stories.tsx +8 -4
  110. package/dialog/Dialog.test.d.ts +1 -0
  111. package/dialog/Dialog.test.js +111 -48
  112. package/divider/Divider.accessibility.test.d.ts +1 -0
  113. package/divider/Divider.accessibility.test.js +2 -2
  114. package/divider/Divider.stories.tsx +2 -1
  115. package/divider/Divider.test.d.ts +1 -0
  116. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  117. package/dropdown/Dropdown.accessibility.test.js +12 -9
  118. package/dropdown/Dropdown.js +16 -15
  119. package/dropdown/Dropdown.stories.tsx +11 -11
  120. package/dropdown/Dropdown.test.d.ts +1 -0
  121. package/dropdown/Dropdown.test.js +101 -72
  122. package/dropdown/DropdownMenu.js +4 -4
  123. package/dropdown/DropdownMenuItem.js +2 -1
  124. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  125. package/file-input/FileInput.accessibility.test.js +30 -23
  126. package/file-input/FileInput.js +6 -47
  127. package/file-input/FileInput.test.d.ts +1 -0
  128. package/file-input/FileInput.test.js +51 -106
  129. package/file-input/FileItem.js +18 -28
  130. package/file-input/types.d.ts +0 -4
  131. package/footer/Footer.accessibility.test.d.ts +1 -0
  132. package/footer/Footer.accessibility.test.js +13 -5
  133. package/footer/Footer.js +8 -6
  134. package/footer/Footer.stories.tsx +39 -1
  135. package/footer/Footer.test.d.ts +1 -0
  136. package/footer/Footer.test.js +1 -1
  137. package/footer/Icons.js +2 -30
  138. package/footer/types.d.ts +1 -1
  139. package/grid/Grid.stories.tsx +3 -1
  140. package/header/Header.accessibility.test.d.ts +1 -0
  141. package/header/Header.accessibility.test.js +16 -6
  142. package/header/Header.js +12 -22
  143. package/header/Header.stories.tsx +17 -1
  144. package/header/Header.test.d.ts +1 -0
  145. package/header/Header.test.js +1 -1
  146. package/header/Icons.js +1 -6
  147. package/heading/Heading.accessibility.test.d.ts +1 -0
  148. package/heading/Heading.accessibility.test.js +3 -3
  149. package/heading/Heading.js +1 -1
  150. package/heading/Heading.test.d.ts +1 -0
  151. package/heading/Heading.test.js +1 -14
  152. package/icon/Icon.accessibility.test.d.ts +1 -0
  153. package/icon/Icon.accessibility.test.js +2 -2
  154. package/icon/Icon.js +1 -1
  155. package/icon/Icon.stories.tsx +1 -1
  156. package/image/Image.accessibility.test.d.ts +1 -0
  157. package/image/Image.accessibility.test.js +3 -3
  158. package/image/Image.js +1 -1
  159. package/layout/ApplicationLayout.js +9 -6
  160. package/layout/Icons.d.ts +0 -1
  161. package/layout/Icons.js +1 -9
  162. package/link/Link.accessibility.test.d.ts +1 -0
  163. package/link/Link.accessibility.test.js +8 -12
  164. package/link/Link.js +8 -6
  165. package/link/Link.stories.tsx +4 -4
  166. package/link/Link.test.d.ts +1 -0
  167. package/link/Link.test.js +1 -1
  168. package/link/types.d.ts +1 -1
  169. package/main.d.ts +2 -1
  170. package/main.js +8 -1
  171. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  172. package/nav-tabs/NavTabs.accessibility.test.js +8 -16
  173. package/nav-tabs/NavTabs.js +19 -4
  174. package/nav-tabs/NavTabs.stories.tsx +41 -23
  175. package/nav-tabs/NavTabs.test.d.ts +1 -0
  176. package/nav-tabs/NavTabs.test.js +10 -9
  177. package/nav-tabs/Tab.js +17 -18
  178. package/nav-tabs/types.d.ts +1 -1
  179. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  180. package/number-input/NumberInput.accessibility.test.js +9 -10
  181. package/number-input/NumberInput.js +6 -3
  182. package/number-input/NumberInput.stories.tsx +11 -16
  183. package/number-input/NumberInput.test.d.ts +1 -0
  184. package/number-input/NumberInput.test.js +6 -7
  185. package/package.json +25 -20
  186. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  187. package/paginator/Paginator.accessibility.test.js +4 -5
  188. package/paginator/Paginator.js +13 -10
  189. package/paginator/Paginator.test.d.ts +1 -0
  190. package/paginator/Paginator.test.js +2 -3
  191. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  192. package/paragraph/Paragraph.accessibility.test.js +2 -2
  193. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  194. package/password-input/PasswordInput.accessibility.test.js +7 -8
  195. package/password-input/PasswordInput.js +11 -8
  196. package/password-input/PasswordInput.stories.tsx +10 -1
  197. package/password-input/PasswordInput.test.d.ts +1 -0
  198. package/password-input/PasswordInput.test.js +6 -7
  199. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  200. package/progress-bar/ProgressBar.accessibility.test.js +3 -3
  201. package/progress-bar/ProgressBar.js +6 -4
  202. package/progress-bar/ProgressBar.test.d.ts +1 -0
  203. package/progress-bar/ProgressBar.test.js +1 -1
  204. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  205. package/quick-nav/QuickNav.accessibility.test.js +2 -2
  206. package/quick-nav/QuickNav.js +1 -1
  207. package/radio-group/Radio.js +6 -9
  208. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  209. package/radio-group/RadioGroup.accessibility.test.js +4 -4
  210. package/radio-group/RadioGroup.js +14 -16
  211. package/radio-group/RadioGroup.test.d.ts +1 -0
  212. package/radio-group/RadioGroup.test.js +3 -5
  213. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  214. package/resultset-table/ResultsetTable.accessibility.test.js +16 -6
  215. package/resultset-table/ResultsetTable.js +36 -11
  216. package/resultset-table/ResultsetTable.stories.tsx +14 -2
  217. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  218. package/resultset-table/ResultsetTable.test.js +103 -34
  219. package/select/Listbox.js +24 -16
  220. package/select/Option.js +12 -10
  221. package/select/Select.accessibility.test.d.ts +1 -0
  222. package/select/Select.accessibility.test.js +18 -8
  223. package/select/Select.js +41 -29
  224. package/select/Select.stories.tsx +69 -111
  225. package/select/Select.test.d.ts +1 -0
  226. package/select/Select.test.js +371 -474
  227. package/select/types.d.ts +1 -1
  228. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  229. package/sidenav/Sidenav.accessibility.test.js +3 -3
  230. package/sidenav/Sidenav.js +16 -12
  231. package/sidenav/Sidenav.stories.tsx +5 -9
  232. package/sidenav/Sidenav.test.d.ts +1 -0
  233. package/sidenav/Sidenav.test.js +1 -1
  234. package/sidenav/types.d.ts +2 -2
  235. package/slider/Slider.accessibility.test.d.ts +1 -0
  236. package/slider/Slider.accessibility.test.js +5 -6
  237. package/slider/Slider.js +11 -13
  238. package/slider/Slider.stories.tsx +180 -0
  239. package/slider/Slider.test.d.ts +1 -0
  240. package/slider/Slider.test.js +13 -11
  241. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  242. package/spinner/Spinner.accessibility.test.js +6 -6
  243. package/spinner/Spinner.js +6 -2
  244. package/spinner/Spinner.test.d.ts +1 -0
  245. package/spinner/Spinner.test.js +1 -1
  246. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  247. package/status-light/StatusLight.accessibility.test.js +8 -8
  248. package/status-light/StatusLight.test.d.ts +1 -0
  249. package/status-light/StatusLight.test.js +1 -1
  250. package/switch/Switch.accessibility.test.d.ts +1 -0
  251. package/switch/Switch.accessibility.test.js +14 -5
  252. package/switch/Switch.js +6 -9
  253. package/switch/Switch.stories.tsx +12 -0
  254. package/switch/Switch.test.d.ts +1 -0
  255. package/switch/Switch.test.js +1 -1
  256. package/table/Table.accessibility.test.d.ts +1 -0
  257. package/table/Table.accessibility.test.js +16 -6
  258. package/table/Table.js +1 -1
  259. package/table/Table.stories.tsx +13 -1
  260. package/table/Table.test.d.ts +1 -0
  261. package/table/Table.test.js +2 -4
  262. package/tabs/Tab.js +6 -5
  263. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  264. package/tabs/Tabs.accessibility.test.js +3 -3
  265. package/tabs/Tabs.js +9 -20
  266. package/tabs/Tabs.stories.tsx +7 -3
  267. package/tabs/Tabs.test.d.ts +1 -0
  268. package/tabs/Tabs.test.js +20 -38
  269. package/tabs/types.d.ts +2 -2
  270. package/tag/Tag.accessibility.test.d.ts +1 -0
  271. package/tag/Tag.accessibility.test.js +4 -4
  272. package/tag/Tag.js +7 -7
  273. package/tag/Tag.stories.tsx +5 -8
  274. package/tag/Tag.test.d.ts +1 -0
  275. package/tag/Tag.test.js +5 -13
  276. package/tag/types.d.ts +2 -2
  277. package/text-input/Suggestion.js +1 -1
  278. package/text-input/Suggestions.js +14 -6
  279. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  280. package/text-input/TextInput.accessibility.test.js +11 -12
  281. package/text-input/TextInput.js +29 -25
  282. package/text-input/TextInput.stories.tsx +19 -7
  283. package/text-input/TextInput.test.d.ts +1 -0
  284. package/text-input/TextInput.test.js +2 -3
  285. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  286. package/textarea/Textarea.accessibility.test.js +7 -7
  287. package/textarea/Textarea.js +14 -13
  288. package/textarea/Textarea.test.d.ts +1 -0
  289. package/textarea/Textarea.test.js +1 -1
  290. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  291. package/toggle-group/ToggleGroup.accessibility.test.js +5 -5
  292. package/toggle-group/ToggleGroup.js +10 -12
  293. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  294. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  295. package/toggle-group/ToggleGroup.test.js +1 -1
  296. package/toggle-group/types.d.ts +2 -2
  297. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  298. package/tooltip/Tooltip.accessibility.test.js +144 -0
  299. package/tooltip/Tooltip.d.ts +4 -0
  300. package/tooltip/Tooltip.js +50 -0
  301. package/tooltip/Tooltip.stories.tsx +111 -0
  302. package/tooltip/Tooltip.test.d.ts +1 -0
  303. package/tooltip/Tooltip.test.js +112 -0
  304. package/tooltip/types.d.ts +16 -0
  305. package/tooltip/types.js +5 -0
  306. package/typography/Typography.accessibility.test.d.ts +1 -0
  307. package/typography/Typography.accessibility.test.js +12 -12
  308. package/typography/Typography.stories.tsx +1 -3
  309. package/useTheme.d.ts +2 -5
  310. package/utils/BaseTypography.js +1 -1
  311. package/utils/FocusLock.js +3 -2
  312. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  313. package/wizard/Wizard.accessibility.test.js +3 -3
  314. package/wizard/Wizard.js +14 -25
  315. package/wizard/Wizard.stories.tsx +20 -1
  316. package/wizard/Wizard.test.d.ts +1 -0
  317. package/wizard/Wizard.test.js +1 -1
  318. package/wizard/types.d.ts +1 -1
  319. package/contextual-menu/MenuItemAction.d.ts +0 -4
  320. package/contextual-menu/MenuItemAction.js +0 -46
  321. package/date-input/Icons.d.ts +0 -6
  322. package/date-input/Icons.js +0 -58
  323. package/paginator/Icons.d.ts +0 -5
  324. package/paginator/Icons.js +0 -40
  325. package/password-input/Icons.d.ts +0 -6
  326. package/password-input/Icons.js +0 -35
  327. package/select/Icons.d.ts +0 -10
  328. package/select/Icons.js +0 -89
  329. package/sidenav/Icons.d.ts +0 -7
  330. package/sidenav/Icons.js +0 -47
@@ -1,32 +1,34 @@
1
1
  import React from "react";
2
2
  import Title from "../../.storybook/components/Title";
3
- import DxcContextualMenu from "./ContextualMenu";
3
+ import DxcContextualMenu, { ContextualMenuContext } from "./ContextualMenu";
4
4
  import DxcContainer from "../container/Container";
5
- import MenuItemAction from "./MenuItemAction";
5
+ import SingleItem from "./SingleItem";
6
6
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
7
+ import DxcBadge from "../badge/Badge";
8
+ import { disabledRules } from "../../test/accessibility/rules/specific/contextual-menu/disabledRules";
9
+ import preview from "../../.storybook/preview";
7
10
 
8
11
  export default {
9
12
  title: "Contextual Menu",
10
13
  component: DxcContextualMenu,
14
+ parameters: {
15
+ // TODO: REMOVE
16
+ a11y: {
17
+ config: {
18
+ rules: [
19
+ ...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
20
+ ...preview?.parameters?.a11y?.config?.rules,
21
+ ],
22
+ },
23
+ },
24
+ },
11
25
  };
12
26
 
13
- const key_icon = (
14
- <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24" fill="currentColor">
15
- <path d="M280-400q-33 0-56.5-23.5T200-480q0-33 23.5-56.5T280-560q33 0 56.5 23.5T360-480q0 33-23.5 56.5T280-400Zm0 160q-100 0-170-70T40-480q0-100 70-170t170-70q67 0 121.5 33t86.5 87h352l120 120-180 180-80-60-80 60-85-60h-47q-32 54-86.5 87T280-240Zm0-80q56 0 98.5-34t56.5-86h125l58 41 82-61 71 55 75-75-40-40H435q-14-52-56.5-86T280-640q-66 0-113 47t-47 113q0 66 47 113t113 47Z" />
16
- </svg>
17
- );
18
-
19
- const fav_icon = (
20
- <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24" fill="currentColor">
21
- <path d="m480-120-58-52q-101-91-167-157T150-447.5Q111-500 95.5-544T80-634q0-94 63-157t157-63q52 0 99 22t81 62q34-40 81-62t99-22q94 0 157 63t63 157q0 46-15.5 90T810-447.5Q771-395 705-329T538-172l-58 52Zm0-108q96-86 158-147.5t98-107q36-45.5 50-81t14-70.5q0-60-40-100t-100-40q-47 0-87 26.5T518-680h-76q-15-41-55-67.5T300-774q-60 0-100 40t-40 100q0 35 14 70.5t50 81q36 45.5 98 107T480-228Zm0-273Z" />
22
- </svg>
23
- );
24
-
25
27
  const items = [{ label: "Item 1" }, { label: "Item 2" }, { label: "Item 3" }, { label: "Item 4" }];
26
28
 
27
29
  const sections = [
28
30
  {
29
- title: "Team repositories",
31
+ title: "Section title",
30
32
  items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
31
33
  },
32
34
  {
@@ -34,32 +36,65 @@ const sections = [
34
36
  },
35
37
  ];
36
38
 
39
+ const groupItems = [
40
+ {
41
+ title: "Section 1",
42
+ items: [
43
+ {
44
+ label: "Grouped Item 1",
45
+ icon: "favorite",
46
+ items: [
47
+ { label: "Item 1" },
48
+ {
49
+ label: "Grouped Item 2",
50
+ items: [
51
+ {
52
+ label: "Item 2",
53
+ icon: "bookmark",
54
+ badge: <DxcBadge color="purple" label="Experimental" />,
55
+ },
56
+ { label: "Selected Item 3", selectedByDefault: true },
57
+ ],
58
+ },
59
+ ],
60
+ badge: <DxcBadge color="green" label="New" />,
61
+ },
62
+ { label: "Item 4", icon: "key" },
63
+ ],
64
+ },
65
+ {
66
+ title: "Section 2",
67
+ items: [
68
+ { label: "Item 5" },
69
+ { label: "Grouped Item 6", items: [{ label: "Item 7" }, { label: "Item 8" }] },
70
+ { label: "Item 9" },
71
+ ],
72
+ },
73
+ ];
74
+
37
75
  const itemsWithIcon = [
38
76
  {
39
77
  label: "Item 1",
40
- icon: key_icon,
78
+ icon: (
79
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24">
80
+ <path d="M200-120v-640q0-33 23.5-56.5T280-840h400q33 0 56.5 23.5T760-760v640L480-240 200-120Zm80-122 200-86 200 86v-518H280v518Zm0-518h400-400Z" />
81
+ </svg>
82
+ ),
41
83
  },
42
84
  {
43
85
  label: "Item 2",
44
- icon: fav_icon,
86
+ icon: "star",
45
87
  },
46
88
  ];
47
89
 
48
- const itemsWithSlot = [
90
+ const itemsWithBadge = [
49
91
  {
50
92
  label: "Item 1",
51
- slot: <DxcContextualMenu.Badge color="green" label="New" />,
93
+ badge: <DxcBadge color="green" label="New" />,
52
94
  },
53
95
  {
54
96
  label: "Item 2",
55
- slot: (
56
- <svg width="12" height="12" viewBox="0 0 12 12" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
57
- <path
58
- d="M10.6667 10.6667H1.33333V1.33333H6V0H1.33333C0.593333 0 0 0.6 0 1.33333V10.6667C0 11.4 0.593333 12 1.33333 12H10.6667C11.4 12 12 11.4 12 10.6667V6H10.6667V10.6667ZM7.33333 0V1.33333H9.72667L3.17333 7.88667L4.11333 8.82667L10.6667 2.27333V4.66667H12V0H7.33333Z"
59
- fill="#323232"
60
- />
61
- </svg>
62
- ),
97
+ badge: <DxcBadge color="purple" label="Experimental" />,
63
98
  },
64
99
  ];
65
100
 
@@ -78,7 +113,7 @@ const sectionsWithScroll = [
78
113
  { label: "Approved locations" },
79
114
  { label: "Approved locations" },
80
115
  { label: "Approved locations" },
81
- { label: "Approved locations" },
116
+ { label: "Approved locations", selectedByDefault: true },
82
117
  ],
83
118
  },
84
119
  ];
@@ -86,20 +121,16 @@ const sectionsWithScroll = [
86
121
  const itemsWithTruncatedText = [
87
122
  {
88
123
  label: "Item with a very long label that should be truncated",
89
- slot: <DxcContextualMenu.Badge color="green" label="New" />,
90
- icon: key_icon,
124
+ badge: <DxcBadge color="green" label="New" />,
125
+ icon: (
126
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24">
127
+ <path d="M200-120v-640q0-33 23.5-56.5T280-840h400q33 0 56.5 23.5T760-760v640L480-240 200-120Zm80-122 200-86 200 86v-518H280v518Zm0-518h400-400Z" />
128
+ </svg>
129
+ ),
91
130
  },
92
131
  {
93
132
  label: "Item 2",
94
- slot: (
95
- <svg width="12" height="12" viewBox="0 0 12 12" fill="currentColor" xmlns="http://www.w3.org/2000/svg">
96
- <path
97
- d="M10.6667 10.6667H1.33333V1.33333H6V0H1.33333C0.593333 0 0 0.6 0 1.33333V10.6667C0 11.4 0.593333 12 1.33333 12H10.6667C11.4 12 12 11.4 12 10.6667V6H10.6667V10.6667ZM7.33333 0V1.33333H9.72667L3.17333 7.88667L4.11333 8.82667L10.6667 2.27333V4.66667H12V0H7.33333Z"
98
- fill="#323232"
99
- />
100
- </svg>
101
- ),
102
- icon: fav_icon,
133
+ icon: "favorite",
103
134
  },
104
135
  ];
105
136
 
@@ -115,16 +146,22 @@ export const Chromatic = () => (
115
146
  <DxcContextualMenu items={sections} />
116
147
  </DxcContainer>
117
148
  </ExampleContainer>
149
+ <Title title="With group items" theme="light" level={3} />
150
+ <ExampleContainer>
151
+ <DxcContainer width="300px">
152
+ <DxcContextualMenu items={groupItems} />
153
+ </DxcContainer>
154
+ </ExampleContainer>
118
155
  <Title title="With icons" theme="light" level={3} />
119
156
  <ExampleContainer>
120
157
  <DxcContainer width="300px">
121
- <DxcContextualMenu items={itemsWithIcon} defaultSelectedItemIndex={0} />
158
+ <DxcContextualMenu items={itemsWithIcon} />
122
159
  </DxcContainer>
123
160
  </ExampleContainer>
124
- <Title title="With slot" theme="light" level={3} />
161
+ <Title title="With badge" theme="light" level={3} />
125
162
  <ExampleContainer>
126
163
  <DxcContainer width="300px">
127
- <DxcContextualMenu items={itemsWithSlot} />
164
+ <DxcContextualMenu items={itemsWithBadge} />
128
165
  </DxcContainer>
129
166
  </ExampleContainer>
130
167
  <Title title="With label truncated" theme="light" level={3} />
@@ -133,7 +170,7 @@ export const Chromatic = () => (
133
170
  <DxcContextualMenu items={itemsWithTruncatedText} />
134
171
  </DxcContainer>
135
172
  </ExampleContainer>
136
- <Title title="With scroll" theme="light" level={3} />
173
+ <Title title="With auto-scroll" theme="light" level={3} />
137
174
  <ExampleContainer>
138
175
  <DxcContainer height="300px" width="300px">
139
176
  <DxcContextualMenu items={sectionsWithScroll} />
@@ -148,35 +185,39 @@ export const Chromatic = () => (
148
185
  </>
149
186
  );
150
187
 
151
- export const MenuItemStates = () => (
152
- <>
153
- <Title title="Default" theme="light" level={3} />
154
- <ExampleContainer>
155
- <MenuItemAction {...items[0]} selected={false} />
156
- </ExampleContainer>
157
- <Title title="Focus" theme="light" level={3} />
158
- <ExampleContainer pseudoState="pseudo-focus">
159
- <MenuItemAction {...items[0]} selected={false} />
160
- </ExampleContainer>
161
- <Title title="Hover" theme="light" level={3} />
162
- <ExampleContainer pseudoState="pseudo-hover">
163
- <MenuItemAction {...items[0]} selected={false} />
164
- </ExampleContainer>
165
- <Title title="Active" theme="light" level={3} />
166
- <ExampleContainer pseudoState="pseudo-active">
167
- <MenuItemAction {...items[0]} selected={false} />
168
- </ExampleContainer>
169
- <Title title="Selected" theme="light" level={3} />
170
- <ExampleContainer>
171
- <MenuItemAction {...items[0]} selected />
172
- </ExampleContainer>
173
- <Title title="Selected hover" theme="light" level={3} />
174
- <ExampleContainer pseudoState="pseudo-hover">
175
- <MenuItemAction {...items[0]} selected />
176
- </ExampleContainer>
177
- <Title title="Selected active" theme="light" level={3} />
178
- <ExampleContainer pseudoState="pseudo-active">
179
- <MenuItemAction {...items[0]} selected />
180
- </ExampleContainer>
181
- </>
188
+ export const SingleItemStates = () => (
189
+ <DxcContainer width="300px">
190
+ <ContextualMenuContext.Provider value={{ selectedItemId: -1, setSelectedItemId: () => {} }}>
191
+ <Title title="Default" theme="light" level={3} />
192
+ <ExampleContainer>
193
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
194
+ </ExampleContainer>
195
+ <Title title="Focus" theme="light" level={3} />
196
+ <ExampleContainer pseudoState="pseudo-focus">
197
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
198
+ </ExampleContainer>
199
+ <Title title="Hover" theme="light" level={3} />
200
+ <ExampleContainer pseudoState="pseudo-hover">
201
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
202
+ </ExampleContainer>
203
+ <Title title="Active" theme="light" level={3} />
204
+ <ExampleContainer pseudoState="pseudo-active">
205
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
206
+ </ExampleContainer>
207
+ </ContextualMenuContext.Provider>
208
+ <ContextualMenuContext.Provider value={{ selectedItemId: 0, setSelectedItemId: () => {} }}>
209
+ <Title title="Selected" theme="light" level={3} />
210
+ <ExampleContainer>
211
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
212
+ </ExampleContainer>
213
+ <Title title="Selected hover" theme="light" level={3} />
214
+ <ExampleContainer pseudoState="pseudo-hover">
215
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
216
+ </ExampleContainer>
217
+ <Title title="Selected active" theme="light" level={3} />
218
+ <ExampleContainer pseudoState="pseudo-active">
219
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
220
+ </ExampleContainer>
221
+ </ContextualMenuContext.Provider>
222
+ </DxcContainer>
182
223
  );
@@ -0,0 +1 @@
1
+ export {};
@@ -1,9 +1,12 @@
1
1
  "use strict";
2
2
 
3
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"));
4
6
  var _react = _interopRequireDefault(require("react"));
5
7
  var _react2 = require("@testing-library/react");
6
- var _ContextualMenu = _interopRequireDefault(require("./ContextualMenu.tsx"));
8
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
9
+ var _ContextualMenu = _interopRequireDefault(require("./ContextualMenu"));
7
10
  var items = [{
8
11
  label: "Item 1"
9
12
  }, {
@@ -31,39 +34,212 @@ var sections = [{
31
34
  label: "Approved locations"
32
35
  }]
33
36
  }];
34
- describe("Context menu component tests", function () {
35
- test("Context menu renders with correct aria attributes", function () {
36
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
37
- items: items,
38
- defaultSelectedItemIndex: 0
37
+ var groups = [{
38
+ label: "Grouped Item 1",
39
+ items: [{
40
+ label: "Item 1"
41
+ }, {
42
+ label: "Grouped Item 2",
43
+ items: [{
44
+ label: "Item 2"
45
+ }, {
46
+ label: "Item 3"
47
+ }]
48
+ }]
49
+ }, {
50
+ label: "Item 4",
51
+ icon: "key"
52
+ }, {
53
+ label: "Grouped Item 3",
54
+ items: [{
55
+ label: "Item 6"
56
+ }, {
57
+ label: "Item 7"
58
+ }]
59
+ }, {
60
+ label: "Item 8"
61
+ }];
62
+ describe("Contextual menu component tests", function () {
63
+ test("Single - Renders with correct aria attributes", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
64
+ var _render, getAllByRole, getByRole, actions;
65
+ return _regenerator["default"].wrap(function _callee$(_context) {
66
+ while (1) switch (_context.prev = _context.next) {
67
+ case 0:
68
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
69
+ items: items
70
+ })), getAllByRole = _render.getAllByRole, getByRole = _render.getByRole;
71
+ expect(getAllByRole("menuitem").length).toBe(4);
72
+ actions = getAllByRole("button");
73
+ _context.next = 5;
74
+ return _userEvent["default"].click(actions[0]);
75
+ case 5:
76
+ expect(actions[0].getAttribute("aria-selected")).toBeTruthy();
77
+ expect(getByRole("menu")).toBeTruthy();
78
+ case 7:
79
+ case "end":
80
+ return _context.stop();
81
+ }
82
+ }, _callee);
83
+ })));
84
+ test("Single - An item can appear as selected by default by using the attribute selectedByDefault", function () {
85
+ var test = [{
86
+ label: "Tested item",
87
+ selectedByDefault: true
88
+ }];
89
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
90
+ items: test
39
91
  })),
40
- getAllByRole = _render.getAllByRole,
41
- getByRole = _render.getByRole;
42
- expect(getAllByRole("menuitem").length).toBe(4);
43
- var actions = getAllByRole("button");
44
- expect(actions[0].getAttribute("aria-selected")).toBeTruthy();
45
- expect(getByRole("menu")).toBeTruthy();
92
+ getByRole = _render2.getByRole;
93
+ var item = getByRole("button");
94
+ expect(item.getAttribute("aria-selected")).toBeTruthy();
46
95
  });
47
- test("Context menu (with sections) renders with correct aria attributes", function () {
48
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
49
- items: sections,
50
- defaultSelectedItemIndex: 4
96
+ test("Group - Group items collapse when clicked", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
97
+ var _render3, queryByText, getByText;
98
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
99
+ while (1) switch (_context2.prev = _context2.next) {
100
+ case 0:
101
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
102
+ items: groups
103
+ })), queryByText = _render3.queryByText, getByText = _render3.getByText;
104
+ _context2.next = 3;
105
+ return _userEvent["default"].click(getByText("Grouped Item 1"));
106
+ case 3:
107
+ expect(getByText("Item 1")).toBeTruthy();
108
+ expect(getByText("Grouped Item 2")).toBeTruthy();
109
+ _context2.next = 7;
110
+ return _userEvent["default"].click(getByText("Grouped Item 2"));
111
+ case 7:
112
+ expect(getByText("Item 2")).toBeTruthy();
113
+ expect(getByText("Item 3")).toBeTruthy();
114
+ _context2.next = 11;
115
+ return _userEvent["default"].click(getByText("Grouped Item 1"));
116
+ case 11:
117
+ expect(queryByText("Item 1")).toBeFalsy();
118
+ expect(queryByText("Item 2")).toBeFalsy();
119
+ expect(queryByText("Item 3")).toBeFalsy();
120
+ case 14:
121
+ case "end":
122
+ return _context2.stop();
123
+ }
124
+ }, _callee2);
125
+ })));
126
+ test("Group - Renders with correct aria attributes", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
127
+ var _render4, getAllByRole, group1, optionToBeClicked;
128
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
129
+ while (1) switch (_context3.prev = _context3.next) {
130
+ case 0:
131
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
132
+ items: groups
133
+ })), getAllByRole = _render4.getAllByRole;
134
+ group1 = getAllByRole("button")[0];
135
+ _context3.next = 4;
136
+ return _userEvent["default"].click(group1);
137
+ case 4:
138
+ expect(group1.getAttribute("aria-expanded")).toBeTruthy();
139
+ expect(group1.getAttribute("aria-controls")).toBe(getAllByRole("list")[0].id);
140
+ _context3.next = 8;
141
+ return _userEvent["default"].click(getAllByRole("button")[2]);
142
+ case 8:
143
+ _context3.next = 10;
144
+ return _userEvent["default"].click(getAllByRole("button")[6]);
145
+ case 10:
146
+ expect(getAllByRole("menuitem").length).toBe(10);
147
+ optionToBeClicked = getAllByRole("button")[4];
148
+ _context3.next = 14;
149
+ return _userEvent["default"].click(optionToBeClicked);
150
+ case 14:
151
+ expect(optionToBeClicked.getAttribute("aria-selected")).toBeTruthy();
152
+ case 15:
153
+ case "end":
154
+ return _context3.stop();
155
+ }
156
+ }, _callee3);
157
+ })));
158
+ test("Group - A grouped item, selected by default, must be visible (expanded group) in the first render of the component", function () {
159
+ var test = [{
160
+ label: "Grouped item",
161
+ items: [{
162
+ label: "Tested item",
163
+ selectedByDefault: true
164
+ }]
165
+ }];
166
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
167
+ items: test
51
168
  })),
52
- getAllByRole = _render2.getAllByRole;
53
- expect(getAllByRole("menuitem").length).toBe(6);
54
- var actions = getAllByRole("button");
55
- expect(actions[4].getAttribute("aria-selected")).toBeTruthy();
56
- expect(getAllByRole("group").length).toBe(2);
169
+ getByText = _render5.getByText,
170
+ getAllByRole = _render5.getAllByRole;
171
+ expect(getByText("Tested item")).toBeTruthy();
172
+ expect(getAllByRole("button")[1].getAttribute("aria-selected")).toBeTruthy();
57
173
  });
58
- test("onSelect event from each item is called correctly", function () {
174
+ test("Group - Collapsed groups render as selected when containing a selected item", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
175
+ var _render6, getAllByRole, group1, group2, item;
176
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
177
+ while (1) switch (_context4.prev = _context4.next) {
178
+ case 0:
179
+ _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
180
+ items: groups
181
+ })), getAllByRole = _render6.getAllByRole;
182
+ group1 = getAllByRole("button")[0];
183
+ _context4.next = 4;
184
+ return _userEvent["default"].click(group1);
185
+ case 4:
186
+ group2 = getAllByRole("button")[2];
187
+ _context4.next = 7;
188
+ return _userEvent["default"].click(group2);
189
+ case 7:
190
+ item = getAllByRole("button")[3];
191
+ _context4.next = 10;
192
+ return _userEvent["default"].click(item);
193
+ case 10:
194
+ expect(item.getAttribute("aria-selected")).toBeTruthy();
195
+ expect(group1.getAttribute("aria-selected")).toBe("false");
196
+ expect(group2.getAttribute("aria-selected")).toBe("false");
197
+ _context4.next = 15;
198
+ return _userEvent["default"].click(group2);
199
+ case 15:
200
+ expect(group2.getAttribute("aria-selected")).toBe("true");
201
+ _context4.next = 18;
202
+ return _userEvent["default"].click(group1);
203
+ case 18:
204
+ expect(group1.getAttribute("aria-selected")).toBe("true");
205
+ case 19:
206
+ case "end":
207
+ return _context4.stop();
208
+ }
209
+ }, _callee4);
210
+ })));
211
+ test("Sections - Renders with correct aria attributes", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
212
+ var _render7, getAllByRole, actions, section;
213
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
214
+ while (1) switch (_context5.prev = _context5.next) {
215
+ case 0:
216
+ _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
217
+ items: sections
218
+ })), getAllByRole = _render7.getAllByRole;
219
+ expect(getAllByRole("menuitem").length).toBe(6);
220
+ actions = getAllByRole("button");
221
+ _context5.next = 5;
222
+ return _userEvent["default"].click(actions[0]);
223
+ case 5:
224
+ expect(actions[0].getAttribute("aria-selected")).toBeTruthy();
225
+ expect(getAllByRole("group").length).toBe(2);
226
+ section = getAllByRole("group")[0];
227
+ expect(section.getAttribute("aria-labelledby")).toBe("Team repositories");
228
+ case 9:
229
+ case "end":
230
+ return _context5.stop();
231
+ }
232
+ }, _callee5);
233
+ })));
234
+ test("The onSelect event from each item is called correctly", function () {
59
235
  var test = [{
60
236
  label: "Tested item",
61
237
  onSelect: jest.fn()
62
238
  }];
63
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
239
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
64
240
  items: test
65
241
  })),
66
- getByRole = _render3.getByRole;
242
+ getByRole = _render8.getByRole;
67
243
  var item = getByRole("button");
68
244
  _react2.fireEvent.click(item);
69
245
  expect(test[0].onSelect).toHaveBeenCalled();
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { GroupItemProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ items, ...props }: GroupItemProps) => React.JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
+ var _react = _interopRequireWildcard(require("react"));
14
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
15
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
16
+ var _MenuItem = _interopRequireDefault(require("./MenuItem"));
17
+ var _ItemAction = _interopRequireDefault(require("./ItemAction"));
18
+ var _ContextualMenu = require("./ContextualMenu");
19
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
20
+ var _templateObject;
21
+ var _excluded = ["items"];
22
+ 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); }
23
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
24
+ var isGroupSelected = function isGroupSelected(items, selectedItemId) {
25
+ return items.some(function (item) {
26
+ if ("items" in item) return isGroupSelected(item.items, selectedItemId);else if (selectedItemId !== -1) return item.id === selectedItemId;else return item.selectedByDefault;
27
+ });
28
+ };
29
+ var GroupItem = function GroupItem(_ref) {
30
+ var items = _ref.items,
31
+ props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
32
+ var groupMenuId = "group-menu-".concat(props.label);
33
+ var _useContext = (0, _react.useContext)(_ContextualMenu.ContextualMenuContext),
34
+ selectedItemId = _useContext.selectedItemId;
35
+ var groupSelected = (0, _react.useMemo)(function () {
36
+ return isGroupSelected(items, selectedItemId);
37
+ }, [items, selectedItemId]);
38
+ var _useState = (0, _react.useState)(groupSelected && selectedItemId === -1 ? true : false),
39
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
40
+ isOpen = _useState2[0],
41
+ setIsOpen = _useState2[1];
42
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_ItemAction["default"], (0, _extends2["default"])({
43
+ "aria-controls": groupMenuId,
44
+ "aria-expanded": isOpen ? true : undefined,
45
+ "aria-selected": groupSelected && !isOpen,
46
+ collapseIcon: isOpen ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
47
+ icon: "filled_expand_less"
48
+ }) : /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
49
+ icon: "filled_expand_more"
50
+ }),
51
+ onClick: function onClick() {
52
+ setIsOpen(function (isOpen) {
53
+ return !isOpen;
54
+ });
55
+ },
56
+ selected: groupSelected && !isOpen
57
+ }, props)), isOpen && /*#__PURE__*/_react["default"].createElement(ItemsList, {
58
+ id: groupMenuId
59
+ }, items.map(function (item) {
60
+ return /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
61
+ item: item,
62
+ depthLevel: props.depthLevel + 1
63
+ });
64
+ })));
65
+ };
66
+ var ItemsList = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0;\n display: grid;\n gap: ", ";\n list-style: none;\n"])), _coreTokens["default"].spacing_4);
67
+ var _default = exports["default"] = /*#__PURE__*/_react["default"].memo(GroupItem);
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { ItemActionProps } from "./types";
3
+ declare const ItemAction: ({ badge, collapseIcon, icon, label, depthLevel, ...props }: ItemActionProps) => React.JSX.Element;
4
+ export default ItemAction;
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
9
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
14
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
15
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4;
16
+ var _excluded = ["badge", "collapseIcon", "icon", "label", "depthLevel"];
17
+ var ItemAction = function ItemAction(_ref) {
18
+ var badge = _ref.badge,
19
+ collapseIcon = _ref.collapseIcon,
20
+ icon = _ref.icon,
21
+ label = _ref.label,
22
+ depthLevel = _ref.depthLevel,
23
+ props = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
24
+ var modifiedBadge = badge && /*#__PURE__*/_react["default"].cloneElement(badge, {
25
+ size: "small"
26
+ });
27
+ return /*#__PURE__*/_react["default"].createElement(Action, (0, _extends2["default"])({
28
+ depthLevel: depthLevel
29
+ }, props), /*#__PURE__*/_react["default"].createElement(Label, null, collapseIcon, icon && depthLevel === 0 && /*#__PURE__*/_react["default"].createElement(Icon, null, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
30
+ icon: icon
31
+ }) : icon), /*#__PURE__*/_react["default"].createElement(Text, {
32
+ onMouseEnter: function onMouseEnter(event) {
33
+ var text = event.currentTarget;
34
+ if (text.title === "" && text.scrollWidth > text.clientWidth) text.title = label;
35
+ }
36
+ }, label)), modifiedBadge);
37
+ };
38
+ var Action = _styledComponents["default"].button(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n border: none;\n border-radius: 4px;\n width: 100%;\n padding: ", ";\n box-shadow: inset 0 0 0 2px transparent;\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: ", ";\n ", ";\n cursor: pointer;\n overflow: hidden;\n\n &:hover {\n ", ";\n }\n &:active {\n ", ";\n }\n &:focus {\n outline: 2px solid ", ";\n outline-offset: -1px;\n }\n"])), function (props) {
39
+ return "".concat(_coreTokens["default"].spacing_4, " ").concat(_coreTokens["default"].spacing_8, " ").concat(_coreTokens["default"].spacing_4, " ", "\n calc(".concat(_coreTokens["default"].spacing_8, " + (").concat(_coreTokens["default"].spacing_24, " * ").concat(props.depthLevel, "))\n "), ";");
40
+ }, _coreTokens["default"].spacing_16, function (props) {
41
+ return props.selected ? "background-color: ".concat(_coreTokens["default"].color_purple_100, "; font-weight: ").concat(_coreTokens["default"].type_semibold, ";") : "background-color: ".concat(_coreTokens["default"].color_transparent);
42
+ }, function (props) {
43
+ return props.selected ? "background-color: ".concat(_coreTokens["default"].color_purple_200, ";") : "background-color: ".concat(_coreTokens["default"].color_grey_100, ";");
44
+ }, function (props) {
45
+ return props.selected ? "background-color: ".concat(_coreTokens["default"].color_purple_200, ";") : "background-color: ".concat(_coreTokens["default"].color_grey_100, ";");
46
+ }, _coreTokens["default"].color_blue_600);
47
+ var Icon = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: 16px;\n\n svg {\n height: 16px;\n width: 16px;\n }\n"])));
48
+ var Label = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n gap: ", ";\n overflow: hidden;\n"])), _coreTokens["default"].spacing_8);
49
+ var Text = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n line-height: 24px;\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n"])), _coreTokens["default"].color_grey_900, _coreTokens["default"].type_sans, _coreTokens["default"].type_scale_02);
50
+ var _default = exports["default"] = ItemAction;