@dxc-technology/halstack-react 0.0.0-f2bc144 → 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 (716) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1246 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +4 -0
  9. package/accordion/Accordion.js +168 -0
  10. package/accordion/Accordion.stories.tsx +241 -0
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +57 -0
  14. package/accordion/types.js +5 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  16. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  17. package/accordion-group/AccordionGroup.d.ts +7 -0
  18. package/accordion-group/AccordionGroup.js +101 -0
  19. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  20. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  21. package/accordion-group/AccordionGroup.test.js +94 -0
  22. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  23. package/accordion-group/AccordionGroupAccordion.js +31 -0
  24. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  25. package/accordion-group/AccordionGroupContext.js +8 -0
  26. package/accordion-group/types.d.ts +67 -0
  27. package/accordion-group/types.js +5 -0
  28. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  29. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  30. package/action-icon/ActionIcon.d.ts +4 -0
  31. package/action-icon/ActionIcon.js +48 -0
  32. package/action-icon/ActionIcon.stories.tsx +41 -0
  33. package/action-icon/ActionIcon.test.d.ts +1 -0
  34. package/action-icon/ActionIcon.test.js +64 -0
  35. package/action-icon/types.d.ts +26 -0
  36. package/action-icon/types.js +5 -0
  37. package/alert/Alert.accessibility.test.d.ts +1 -0
  38. package/alert/Alert.accessibility.test.js +95 -0
  39. package/alert/Alert.d.ts +4 -0
  40. package/alert/Alert.js +203 -0
  41. package/alert/Alert.stories.tsx +198 -0
  42. package/alert/Alert.test.d.ts +1 -0
  43. package/alert/Alert.test.js +75 -0
  44. package/alert/types.d.ts +49 -0
  45. package/alert/types.js +5 -0
  46. package/badge/Badge.accessibility.test.d.ts +1 -0
  47. package/badge/Badge.accessibility.test.js +129 -0
  48. package/badge/Badge.d.ts +4 -0
  49. package/badge/Badge.js +161 -0
  50. package/badge/Badge.stories.tsx +210 -0
  51. package/badge/Badge.test.d.ts +1 -0
  52. package/badge/Badge.test.js +30 -0
  53. package/badge/types.d.ts +54 -0
  54. package/badge/types.js +5 -0
  55. package/bleed/Bleed.d.ts +3 -0
  56. package/bleed/Bleed.js +43 -0
  57. package/bleed/Bleed.stories.tsx +342 -0
  58. package/bleed/types.d.ts +37 -0
  59. package/bleed/types.js +5 -0
  60. package/box/Box.accessibility.test.d.ts +1 -0
  61. package/box/Box.accessibility.test.js +33 -0
  62. package/box/Box.d.ts +4 -0
  63. package/box/Box.js +75 -0
  64. package/box/Box.stories.tsx +119 -0
  65. package/box/Box.test.d.ts +1 -0
  66. package/box/Box.test.js +13 -0
  67. package/box/types.d.ts +32 -0
  68. package/box/types.js +5 -0
  69. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  70. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  71. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  72. package/breadcrumbs/Breadcrumbs.js +79 -0
  73. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  74. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  75. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  76. package/breadcrumbs/Item.d.ts +4 -0
  77. package/breadcrumbs/Item.js +52 -0
  78. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  79. package/breadcrumbs/dropdownTheme.js +62 -0
  80. package/breadcrumbs/types.d.ts +16 -0
  81. package/breadcrumbs/types.js +5 -0
  82. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  83. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  84. package/bulleted-list/BulletedList.d.ts +7 -0
  85. package/bulleted-list/BulletedList.js +92 -0
  86. package/bulleted-list/BulletedList.stories.tsx +115 -0
  87. package/bulleted-list/types.d.ts +38 -0
  88. package/bulleted-list/types.js +5 -0
  89. package/button/Button.accessibility.test.d.ts +1 -0
  90. package/button/Button.accessibility.test.js +127 -0
  91. package/button/Button.d.ts +4 -0
  92. package/button/Button.js +121 -0
  93. package/button/Button.stories.tsx +325 -0
  94. package/button/Button.test.d.ts +1 -0
  95. package/button/Button.test.js +38 -0
  96. package/button/types.d.ts +57 -0
  97. package/button/types.js +5 -0
  98. package/card/Card.accessibility.test.d.ts +1 -0
  99. package/card/Card.accessibility.test.js +36 -0
  100. package/card/Card.d.ts +4 -0
  101. package/card/Card.js +121 -0
  102. package/card/Card.stories.tsx +171 -0
  103. package/card/Card.test.d.ts +1 -0
  104. package/card/Card.test.js +39 -0
  105. package/card/types.d.ts +62 -0
  106. package/card/types.js +5 -0
  107. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  108. package/checkbox/Checkbox.accessibility.test.js +87 -0
  109. package/checkbox/Checkbox.d.ts +4 -0
  110. package/checkbox/Checkbox.js +212 -0
  111. package/checkbox/Checkbox.stories.tsx +222 -0
  112. package/checkbox/Checkbox.test.d.ts +1 -0
  113. package/checkbox/Checkbox.test.js +199 -0
  114. package/checkbox/types.d.ts +72 -0
  115. package/checkbox/types.js +5 -0
  116. package/chip/Chip.accessibility.test.d.ts +1 -0
  117. package/chip/Chip.accessibility.test.js +67 -0
  118. package/chip/Chip.d.ts +4 -0
  119. package/chip/Chip.js +126 -0
  120. package/chip/Chip.stories.tsx +195 -0
  121. package/chip/Chip.test.d.ts +1 -0
  122. package/chip/Chip.test.js +41 -0
  123. package/chip/types.d.ts +45 -0
  124. package/chip/types.js +5 -0
  125. package/common/coreTokens.d.ts +237 -0
  126. package/common/coreTokens.js +184 -0
  127. package/common/utils.d.ts +1 -0
  128. package/common/utils.js +16 -0
  129. package/common/variables.d.ts +1392 -0
  130. package/common/variables.js +1264 -0
  131. package/container/Container.d.ts +4 -0
  132. package/container/Container.js +194 -0
  133. package/container/Container.stories.tsx +214 -0
  134. package/container/types.d.ts +74 -0
  135. package/container/types.js +5 -0
  136. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  137. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  138. package/contextual-menu/ContextualMenu.d.ts +5 -0
  139. package/contextual-menu/ContextualMenu.js +108 -0
  140. package/contextual-menu/ContextualMenu.stories.tsx +223 -0
  141. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  142. package/contextual-menu/ContextualMenu.test.js +247 -0
  143. package/contextual-menu/GroupItem.d.ts +4 -0
  144. package/contextual-menu/GroupItem.js +67 -0
  145. package/contextual-menu/ItemAction.d.ts +4 -0
  146. package/contextual-menu/ItemAction.js +50 -0
  147. package/contextual-menu/MenuItem.d.ts +4 -0
  148. package/contextual-menu/MenuItem.js +29 -0
  149. package/contextual-menu/SingleItem.d.ts +4 -0
  150. package/contextual-menu/SingleItem.js +38 -0
  151. package/contextual-menu/types.d.ts +61 -0
  152. package/contextual-menu/types.js +5 -0
  153. package/date-input/Calendar.d.ts +4 -0
  154. package/date-input/Calendar.js +230 -0
  155. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  156. package/date-input/DateInput.accessibility.test.js +229 -0
  157. package/date-input/DateInput.d.ts +4 -0
  158. package/date-input/DateInput.js +228 -0
  159. package/date-input/DateInput.stories.tsx +291 -0
  160. package/date-input/DateInput.test.d.ts +1 -0
  161. package/date-input/DateInput.test.js +808 -0
  162. package/date-input/DatePicker.d.ts +4 -0
  163. package/date-input/DatePicker.js +121 -0
  164. package/date-input/YearPicker.d.ts +4 -0
  165. package/date-input/YearPicker.js +105 -0
  166. package/date-input/types.d.ts +164 -0
  167. package/date-input/types.js +5 -0
  168. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  169. package/dialog/Dialog.accessibility.test.js +69 -0
  170. package/dialog/Dialog.d.ts +4 -0
  171. package/dialog/Dialog.js +93 -0
  172. package/dialog/Dialog.stories.tsx +369 -0
  173. package/dialog/Dialog.test.d.ts +1 -0
  174. package/dialog/Dialog.test.js +370 -0
  175. package/dialog/types.d.ts +36 -0
  176. package/dialog/types.js +5 -0
  177. package/divider/Divider.accessibility.test.d.ts +1 -0
  178. package/divider/Divider.accessibility.test.js +33 -0
  179. package/divider/Divider.d.ts +4 -0
  180. package/divider/Divider.js +36 -0
  181. package/divider/Divider.stories.tsx +224 -0
  182. package/divider/Divider.test.d.ts +1 -0
  183. package/divider/Divider.test.js +38 -0
  184. package/divider/types.d.ts +21 -0
  185. package/divider/types.js +5 -0
  186. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  187. package/dropdown/Dropdown.accessibility.test.js +183 -0
  188. package/dropdown/Dropdown.d.ts +4 -0
  189. package/dropdown/Dropdown.js +320 -0
  190. package/dropdown/Dropdown.stories.tsx +427 -0
  191. package/dropdown/Dropdown.test.d.ts +1 -0
  192. package/dropdown/Dropdown.test.js +628 -0
  193. package/dropdown/DropdownMenu.d.ts +4 -0
  194. package/dropdown/DropdownMenu.js +63 -0
  195. package/dropdown/DropdownMenuItem.d.ts +4 -0
  196. package/dropdown/DropdownMenuItem.js +71 -0
  197. package/dropdown/types.d.ts +96 -0
  198. package/dropdown/types.js +5 -0
  199. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  200. package/file-input/FileInput.accessibility.test.js +167 -0
  201. package/file-input/FileInput.d.ts +4 -0
  202. package/file-input/FileInput.js +438 -0
  203. package/file-input/FileInput.stories.tsx +618 -0
  204. package/file-input/FileInput.test.d.ts +1 -0
  205. package/file-input/FileInput.test.js +404 -0
  206. package/file-input/FileItem.d.ts +4 -0
  207. package/file-input/FileItem.js +125 -0
  208. package/file-input/types.d.ts +125 -0
  209. package/file-input/types.js +5 -0
  210. package/flex/Flex.d.ts +4 -0
  211. package/flex/Flex.js +57 -0
  212. package/flex/Flex.stories.tsx +112 -0
  213. package/flex/types.d.ts +97 -0
  214. package/flex/types.js +5 -0
  215. package/footer/Footer.accessibility.test.d.ts +1 -0
  216. package/footer/Footer.accessibility.test.js +125 -0
  217. package/footer/Footer.d.ts +4 -0
  218. package/footer/Footer.js +140 -0
  219. package/footer/Footer.stories.tsx +208 -0
  220. package/footer/Footer.test.d.ts +1 -0
  221. package/footer/Footer.test.js +85 -0
  222. package/footer/Icons.d.ts +3 -0
  223. package/footer/Icons.js +108 -0
  224. package/footer/types.d.ts +64 -0
  225. package/footer/types.js +5 -0
  226. package/grid/Grid.d.ts +7 -0
  227. package/grid/Grid.js +76 -0
  228. package/grid/Grid.stories.tsx +221 -0
  229. package/grid/types.d.ts +115 -0
  230. package/grid/types.js +5 -0
  231. package/header/Header.accessibility.test.d.ts +1 -0
  232. package/header/Header.accessibility.test.js +94 -0
  233. package/header/Header.d.ts +8 -0
  234. package/header/Header.js +210 -0
  235. package/header/Header.stories.tsx +267 -0
  236. package/header/Header.test.d.ts +1 -0
  237. package/header/Header.test.js +66 -0
  238. package/header/Icons.d.ts +2 -0
  239. package/header/Icons.js +24 -0
  240. package/header/types.d.ts +33 -0
  241. package/header/types.js +5 -0
  242. package/heading/Heading.accessibility.test.d.ts +1 -0
  243. package/heading/Heading.accessibility.test.js +33 -0
  244. package/heading/Heading.d.ts +4 -0
  245. package/heading/Heading.js +137 -0
  246. package/heading/Heading.stories.tsx +54 -0
  247. package/heading/Heading.test.d.ts +1 -0
  248. package/heading/Heading.test.js +156 -0
  249. package/heading/types.d.ts +33 -0
  250. package/heading/types.js +5 -0
  251. package/icon/Icon.accessibility.test.d.ts +1 -0
  252. package/icon/Icon.accessibility.test.js +30 -0
  253. package/icon/Icon.d.ts +4 -0
  254. package/icon/Icon.js +33 -0
  255. package/icon/Icon.stories.tsx +28 -0
  256. package/icon/types.d.ts +4 -0
  257. package/icon/types.js +5 -0
  258. package/image/Image.accessibility.test.d.ts +1 -0
  259. package/image/Image.accessibility.test.js +56 -0
  260. package/image/Image.d.ts +4 -0
  261. package/image/Image.js +70 -0
  262. package/image/Image.stories.tsx +129 -0
  263. package/image/types.d.ts +72 -0
  264. package/image/types.js +5 -0
  265. package/inset/Inset.d.ts +3 -0
  266. package/inset/Inset.js +43 -0
  267. package/inset/Inset.stories.tsx +230 -0
  268. package/inset/types.d.ts +37 -0
  269. package/inset/types.js +5 -0
  270. package/layout/ApplicationLayout.d.ts +20 -0
  271. package/layout/ApplicationLayout.js +137 -0
  272. package/layout/ApplicationLayout.stories.tsx +162 -0
  273. package/layout/Icons.d.ts +7 -0
  274. package/layout/Icons.js +48 -0
  275. package/layout/types.d.ts +41 -0
  276. package/layout/types.js +5 -0
  277. package/link/Link.accessibility.test.d.ts +1 -0
  278. package/link/Link.accessibility.test.js +108 -0
  279. package/link/Link.d.ts +4 -0
  280. package/link/Link.js +117 -0
  281. package/link/Link.stories.tsx +253 -0
  282. package/link/Link.test.d.ts +1 -0
  283. package/link/Link.test.js +63 -0
  284. package/link/types.d.ts +54 -0
  285. package/link/types.js +5 -0
  286. package/main.d.ts +50 -0
  287. package/{dist/main.js → main.js} +172 -111
  288. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  289. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  290. package/nav-tabs/NavTabs.d.ts +7 -0
  291. package/nav-tabs/NavTabs.js +108 -0
  292. package/nav-tabs/NavTabs.stories.tsx +294 -0
  293. package/nav-tabs/NavTabs.test.d.ts +1 -0
  294. package/nav-tabs/NavTabs.test.js +77 -0
  295. package/nav-tabs/NavTabsContext.d.ts +3 -0
  296. package/nav-tabs/NavTabsContext.js +8 -0
  297. package/nav-tabs/Tab.d.ts +4 -0
  298. package/nav-tabs/Tab.js +117 -0
  299. package/nav-tabs/types.d.ts +52 -0
  300. package/nav-tabs/types.js +5 -0
  301. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  302. package/number-input/NumberInput.accessibility.test.js +227 -0
  303. package/number-input/NumberInput.d.ts +4 -0
  304. package/number-input/NumberInput.js +89 -0
  305. package/number-input/NumberInput.stories.tsx +126 -0
  306. package/number-input/NumberInput.test.d.ts +1 -0
  307. package/number-input/NumberInput.test.js +988 -0
  308. package/number-input/NumberInputContext.d.ts +3 -0
  309. package/number-input/NumberInputContext.js +8 -0
  310. package/number-input/types.d.ts +136 -0
  311. package/number-input/types.js +5 -0
  312. package/package.json +67 -52
  313. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  314. package/paginator/Paginator.accessibility.test.js +78 -0
  315. package/paginator/Paginator.d.ts +4 -0
  316. package/paginator/Paginator.js +138 -0
  317. package/paginator/Paginator.stories.tsx +87 -0
  318. package/paginator/Paginator.test.d.ts +1 -0
  319. package/paginator/Paginator.test.js +334 -0
  320. package/paginator/types.d.ts +38 -0
  321. package/paginator/types.js +5 -0
  322. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  323. package/paragraph/Paragraph.accessibility.test.js +28 -0
  324. package/paragraph/Paragraph.d.ts +5 -0
  325. package/paragraph/Paragraph.js +22 -0
  326. package/paragraph/Paragraph.stories.tsx +27 -0
  327. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  328. package/password-input/PasswordInput.accessibility.test.js +152 -0
  329. package/password-input/PasswordInput.d.ts +4 -0
  330. package/password-input/PasswordInput.js +100 -0
  331. package/password-input/PasswordInput.stories.tsx +108 -0
  332. package/password-input/PasswordInput.test.d.ts +1 -0
  333. package/password-input/PasswordInput.test.js +197 -0
  334. package/password-input/types.d.ts +111 -0
  335. package/password-input/types.js +5 -0
  336. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  337. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  338. package/progress-bar/ProgressBar.d.ts +4 -0
  339. package/progress-bar/ProgressBar.js +146 -0
  340. package/progress-bar/ProgressBar.stories.tsx +93 -0
  341. package/progress-bar/ProgressBar.test.d.ts +1 -0
  342. package/progress-bar/ProgressBar.test.js +93 -0
  343. package/progress-bar/types.d.ts +37 -0
  344. package/progress-bar/types.js +5 -0
  345. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  346. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  347. package/quick-nav/QuickNav.d.ts +4 -0
  348. package/quick-nav/QuickNav.js +94 -0
  349. package/quick-nav/QuickNav.stories.tsx +356 -0
  350. package/quick-nav/types.d.ts +21 -0
  351. package/quick-nav/types.js +5 -0
  352. package/radio-group/Radio.d.ts +4 -0
  353. package/radio-group/Radio.js +121 -0
  354. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  355. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  356. package/radio-group/RadioGroup.d.ts +4 -0
  357. package/radio-group/RadioGroup.js +233 -0
  358. package/radio-group/RadioGroup.stories.tsx +214 -0
  359. package/radio-group/RadioGroup.test.d.ts +1 -0
  360. package/radio-group/RadioGroup.test.js +754 -0
  361. package/radio-group/types.d.ts +114 -0
  362. package/radio-group/types.js +5 -0
  363. package/resultset-table/Icons.d.ts +7 -0
  364. package/resultset-table/Icons.js +47 -0
  365. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  366. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  367. package/resultset-table/ResultsetTable.d.ts +7 -0
  368. package/resultset-table/ResultsetTable.js +195 -0
  369. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  370. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  371. package/resultset-table/ResultsetTable.test.js +450 -0
  372. package/resultset-table/types.d.ts +100 -0
  373. package/resultset-table/types.js +5 -0
  374. package/select/Listbox.d.ts +4 -0
  375. package/select/Listbox.js +151 -0
  376. package/select/Option.d.ts +4 -0
  377. package/select/Option.js +89 -0
  378. package/select/Select.accessibility.test.d.ts +1 -0
  379. package/select/Select.accessibility.test.js +227 -0
  380. package/select/Select.d.ts +4 -0
  381. package/select/Select.js +602 -0
  382. package/select/Select.stories.tsx +928 -0
  383. package/select/Select.test.d.ts +1 -0
  384. package/select/Select.test.js +2267 -0
  385. package/select/types.d.ts +209 -0
  386. package/select/types.js +5 -0
  387. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  388. package/sidenav/Sidenav.accessibility.test.js +59 -0
  389. package/sidenav/Sidenav.d.ts +10 -0
  390. package/sidenav/Sidenav.js +201 -0
  391. package/sidenav/Sidenav.stories.tsx +277 -0
  392. package/sidenav/Sidenav.test.d.ts +1 -0
  393. package/sidenav/Sidenav.test.js +37 -0
  394. package/sidenav/SidenavContext.d.ts +5 -0
  395. package/sidenav/SidenavContext.js +13 -0
  396. package/sidenav/types.d.ts +76 -0
  397. package/sidenav/types.js +5 -0
  398. package/slider/Slider.accessibility.test.d.ts +1 -0
  399. package/slider/Slider.accessibility.test.js +103 -0
  400. package/slider/Slider.d.ts +4 -0
  401. package/slider/Slider.js +283 -0
  402. package/slider/Slider.stories.tsx +180 -0
  403. package/slider/Slider.test.d.ts +1 -0
  404. package/slider/Slider.test.js +256 -0
  405. package/slider/types.d.ts +86 -0
  406. package/slider/types.js +5 -0
  407. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  408. package/spinner/Spinner.accessibility.test.js +96 -0
  409. package/spinner/Spinner.d.ts +4 -0
  410. package/spinner/Spinner.js +210 -0
  411. package/spinner/Spinner.stories.tsx +129 -0
  412. package/spinner/Spinner.test.d.ts +1 -0
  413. package/spinner/Spinner.test.js +55 -0
  414. package/spinner/types.d.ts +32 -0
  415. package/spinner/types.js +5 -0
  416. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  417. package/status-light/StatusLight.accessibility.test.js +157 -0
  418. package/status-light/StatusLight.d.ts +4 -0
  419. package/status-light/StatusLight.js +51 -0
  420. package/status-light/StatusLight.stories.tsx +74 -0
  421. package/status-light/StatusLight.test.d.ts +1 -0
  422. package/status-light/StatusLight.test.js +25 -0
  423. package/status-light/types.d.ts +17 -0
  424. package/status-light/types.js +5 -0
  425. package/switch/Switch.accessibility.test.d.ts +1 -0
  426. package/switch/Switch.accessibility.test.js +98 -0
  427. package/switch/Switch.d.ts +4 -0
  428. package/switch/Switch.js +211 -0
  429. package/switch/Switch.stories.tsx +149 -0
  430. package/switch/Switch.test.d.ts +1 -0
  431. package/switch/Switch.test.js +180 -0
  432. package/switch/types.d.ts +66 -0
  433. package/switch/types.js +5 -0
  434. package/table/DropdownTheme.js +62 -0
  435. package/table/Table.accessibility.test.d.ts +1 -0
  436. package/table/Table.accessibility.test.js +92 -0
  437. package/table/Table.d.ts +8 -0
  438. package/table/Table.js +161 -0
  439. package/table/Table.stories.tsx +663 -0
  440. package/table/Table.test.d.ts +1 -0
  441. package/table/Table.test.js +111 -0
  442. package/table/types.d.ts +49 -0
  443. package/table/types.js +5 -0
  444. package/tabs/Tab.d.ts +4 -0
  445. package/tabs/Tab.js +117 -0
  446. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  447. package/tabs/Tabs.accessibility.test.js +56 -0
  448. package/tabs/Tabs.d.ts +4 -0
  449. package/tabs/Tabs.js +373 -0
  450. package/tabs/Tabs.stories.tsx +230 -0
  451. package/tabs/Tabs.test.d.ts +1 -0
  452. package/tabs/Tabs.test.js +276 -0
  453. package/tabs/types.d.ts +92 -0
  454. package/tabs/types.js +5 -0
  455. package/tag/Tag.accessibility.test.d.ts +1 -0
  456. package/tag/Tag.accessibility.test.js +69 -0
  457. package/tag/Tag.d.ts +4 -0
  458. package/tag/Tag.js +151 -0
  459. package/tag/Tag.stories.tsx +152 -0
  460. package/tag/Tag.test.d.ts +1 -0
  461. package/tag/Tag.test.js +41 -0
  462. package/tag/types.d.ts +69 -0
  463. package/tag/types.js +5 -0
  464. package/text-input/Suggestion.d.ts +4 -0
  465. package/text-input/Suggestion.js +67 -0
  466. package/text-input/Suggestions.d.ts +4 -0
  467. package/text-input/Suggestions.js +94 -0
  468. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  469. package/text-input/TextInput.accessibility.test.js +320 -0
  470. package/text-input/TextInput.d.ts +4 -0
  471. package/text-input/TextInput.js +571 -0
  472. package/text-input/TextInput.stories.tsx +477 -0
  473. package/text-input/TextInput.test.d.ts +1 -0
  474. package/text-input/TextInput.test.js +1755 -0
  475. package/text-input/types.d.ts +205 -0
  476. package/text-input/types.js +5 -0
  477. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  478. package/textarea/Textarea.accessibility.test.js +155 -0
  479. package/textarea/Textarea.d.ts +4 -0
  480. package/textarea/Textarea.js +235 -0
  481. package/textarea/Textarea.stories.tsx +174 -0
  482. package/textarea/Textarea.test.d.ts +1 -0
  483. package/textarea/Textarea.test.js +406 -0
  484. package/textarea/types.d.ts +141 -0
  485. package/textarea/types.js +5 -0
  486. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  487. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  488. package/toggle-group/ToggleGroup.d.ts +4 -0
  489. package/toggle-group/ToggleGroup.js +199 -0
  490. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  491. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  492. package/toggle-group/ToggleGroup.test.js +137 -0
  493. package/toggle-group/types.d.ts +114 -0
  494. package/toggle-group/types.js +5 -0
  495. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  496. package/tooltip/Tooltip.accessibility.test.js +144 -0
  497. package/tooltip/Tooltip.d.ts +4 -0
  498. package/tooltip/Tooltip.js +50 -0
  499. package/tooltip/Tooltip.stories.tsx +111 -0
  500. package/tooltip/Tooltip.test.d.ts +1 -0
  501. package/tooltip/Tooltip.test.js +112 -0
  502. package/tooltip/types.d.ts +16 -0
  503. package/tooltip/types.js +5 -0
  504. package/typography/Typography.accessibility.test.d.ts +1 -0
  505. package/typography/Typography.accessibility.test.js +339 -0
  506. package/typography/Typography.d.ts +4 -0
  507. package/typography/Typography.js +23 -0
  508. package/typography/Typography.stories.tsx +196 -0
  509. package/typography/types.d.ts +18 -0
  510. package/typography/types.js +5 -0
  511. package/useTheme.d.ts +1145 -0
  512. package/{dist/useTheme.js → useTheme.js} +4 -11
  513. package/useTranslatedLabels.d.ts +85 -0
  514. package/useTranslatedLabels.js +14 -0
  515. package/utils/BaseTypography.d.ts +21 -0
  516. package/utils/BaseTypography.js +94 -0
  517. package/utils/FocusLock.d.ts +13 -0
  518. package/utils/FocusLock.js +125 -0
  519. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  520. package/wizard/Wizard.accessibility.test.js +55 -0
  521. package/wizard/Wizard.d.ts +4 -0
  522. package/wizard/Wizard.js +239 -0
  523. package/wizard/Wizard.stories.tsx +272 -0
  524. package/wizard/Wizard.test.d.ts +1 -0
  525. package/wizard/Wizard.test.js +114 -0
  526. package/wizard/types.d.ts +64 -0
  527. package/wizard/types.js +5 -0
  528. package/babel.config.js +0 -8
  529. package/dist/ThemeContext.js +0 -180
  530. package/dist/accordion/Accordion.js +0 -268
  531. package/dist/accordion/Accordion.stories.js +0 -207
  532. package/dist/accordion/readme.md +0 -96
  533. package/dist/accordion-group/AccordionGroup.js +0 -156
  534. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  535. package/dist/accordion-group/readme.md +0 -70
  536. package/dist/alert/Alert.js +0 -303
  537. package/dist/alert/Alert.stories.js +0 -158
  538. package/dist/alert/close.svg +0 -4
  539. package/dist/alert/error.svg +0 -4
  540. package/dist/alert/info.svg +0 -4
  541. package/dist/alert/readme.md +0 -43
  542. package/dist/alert/success.svg +0 -4
  543. package/dist/alert/warning.svg +0 -4
  544. package/dist/badge/Badge.js +0 -42
  545. package/dist/box/Box.js +0 -145
  546. package/dist/button/Button.js +0 -199
  547. package/dist/button/Button.stories.js +0 -224
  548. package/dist/button/readme.md +0 -93
  549. package/dist/card/Card.js +0 -217
  550. package/dist/checkbox/Checkbox.js +0 -229
  551. package/dist/checkbox/Checkbox.stories.js +0 -144
  552. package/dist/checkbox/readme.md +0 -116
  553. package/dist/chip/Chip.js +0 -205
  554. package/dist/common/OpenSans.css +0 -81
  555. package/dist/common/RequiredComponent.js +0 -40
  556. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  557. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  558. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  559. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  560. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  561. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  562. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  563. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  564. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  565. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  566. package/dist/common/services/example-service.js +0 -10
  567. package/dist/common/services/example-service.test.js +0 -12
  568. package/dist/common/utils.js +0 -42
  569. package/dist/common/variables.js +0 -349
  570. package/dist/date/Date.js +0 -352
  571. package/dist/date/Date.stories.js +0 -205
  572. package/dist/date/calendar.svg +0 -1
  573. package/dist/date/calendar_dark.svg +0 -1
  574. package/dist/date/readme.md +0 -73
  575. package/dist/dialog/Dialog.js +0 -195
  576. package/dist/dialog/Dialog.stories.js +0 -217
  577. package/dist/dialog/readme.md +0 -32
  578. package/dist/dropdown/Dropdown.js +0 -446
  579. package/dist/dropdown/Dropdown.stories.js +0 -249
  580. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  581. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  582. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  583. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  584. package/dist/dropdown/readme.md +0 -69
  585. package/dist/footer/Footer.js +0 -366
  586. package/dist/footer/Footer.stories.js +0 -94
  587. package/dist/footer/dxc_logo_wht.png +0 -0
  588. package/dist/footer/readme.md +0 -41
  589. package/dist/header/Header.js +0 -368
  590. package/dist/header/Header.stories.js +0 -176
  591. package/dist/header/close_icon.svg +0 -1
  592. package/dist/header/dxc_logo_black.png +0 -0
  593. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  594. package/dist/header/dxc_logo_white.png +0 -0
  595. package/dist/header/hamb_menu_black.svg +0 -1
  596. package/dist/header/hamb_menu_white.svg +0 -1
  597. package/dist/header/readme.md +0 -33
  598. package/dist/heading/Heading.js +0 -153
  599. package/dist/input-text/InputText.js +0 -561
  600. package/dist/input-text/InputText.stories.js +0 -209
  601. package/dist/input-text/error.svg +0 -1
  602. package/dist/input-text/readme.md +0 -91
  603. package/dist/layout/ApplicationLayout.js +0 -330
  604. package/dist/layout/facebook.svg +0 -45
  605. package/dist/layout/linkedin.svg +0 -50
  606. package/dist/layout/twitter.svg +0 -53
  607. package/dist/link/Link.js +0 -187
  608. package/dist/link/readme.md +0 -51
  609. package/dist/paginator/Paginator.js +0 -247
  610. package/dist/paginator/images/next.svg +0 -3
  611. package/dist/paginator/images/nextPage.svg +0 -3
  612. package/dist/paginator/images/previous.svg +0 -3
  613. package/dist/paginator/images/previousPage.svg +0 -3
  614. package/dist/paginator/readme.md +0 -50
  615. package/dist/progress-bar/ProgressBar.js +0 -184
  616. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  617. package/dist/progress-bar/readme.md +0 -63
  618. package/dist/radio/Radio.js +0 -190
  619. package/dist/radio/Radio.stories.js +0 -166
  620. package/dist/radio/readme.md +0 -70
  621. package/dist/resultsetTable/ResultsetTable.js +0 -327
  622. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  623. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  624. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  625. package/dist/select/Select.js +0 -475
  626. package/dist/select/Select.stories.js +0 -235
  627. package/dist/select/readme.md +0 -72
  628. package/dist/sidenav/Sidenav.js +0 -123
  629. package/dist/slider/Slider.js +0 -257
  630. package/dist/slider/Slider.stories.js +0 -241
  631. package/dist/slider/readme.md +0 -64
  632. package/dist/spinner/Spinner.js +0 -190
  633. package/dist/spinner/Spinner.stories.js +0 -183
  634. package/dist/spinner/readme.md +0 -65
  635. package/dist/switch/Switch.js +0 -190
  636. package/dist/switch/Switch.stories.js +0 -134
  637. package/dist/switch/readme.md +0 -133
  638. package/dist/table/Table.js +0 -102
  639. package/dist/tabs/Tabs.js +0 -302
  640. package/dist/tabs/Tabs.stories.js +0 -130
  641. package/dist/tabs/readme.md +0 -78
  642. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  643. package/dist/tabs-for-sections/readme.md +0 -78
  644. package/dist/tag/Tag.js +0 -249
  645. package/dist/textarea/Textarea.js +0 -220
  646. package/dist/toggle/Toggle.js +0 -223
  647. package/dist/toggle/Toggle.stories.js +0 -297
  648. package/dist/toggle/readme.md +0 -80
  649. package/dist/toggle-group/ToggleGroup.js +0 -209
  650. package/dist/toggle-group/readme.md +0 -82
  651. package/dist/upload/Upload.js +0 -200
  652. package/dist/upload/Upload.stories.js +0 -72
  653. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  654. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  655. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  656. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  657. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  658. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  659. package/dist/upload/file-upload/FileToUpload.js +0 -158
  660. package/dist/upload/file-upload/audio-icon.svg +0 -4
  661. package/dist/upload/file-upload/close.svg +0 -4
  662. package/dist/upload/file-upload/file-icon.svg +0 -4
  663. package/dist/upload/file-upload/video-icon.svg +0 -4
  664. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  665. package/dist/upload/readme.md +0 -37
  666. package/dist/upload/transaction/Transaction.js +0 -155
  667. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  668. package/dist/upload/transaction/audio-icon.svg +0 -4
  669. package/dist/upload/transaction/error-icon.svg +0 -4
  670. package/dist/upload/transaction/file-icon-err.svg +0 -4
  671. package/dist/upload/transaction/file-icon.svg +0 -4
  672. package/dist/upload/transaction/image-icon-err.svg +0 -4
  673. package/dist/upload/transaction/image-icon.svg +0 -4
  674. package/dist/upload/transaction/success-icon.svg +0 -4
  675. package/dist/upload/transaction/video-icon-err.svg +0 -4
  676. package/dist/upload/transaction/video-icon.svg +0 -4
  677. package/dist/upload/transactions/Transactions.js +0 -120
  678. package/dist/wizard/Wizard.js +0 -325
  679. package/dist/wizard/invalid_icon.svg +0 -6
  680. package/dist/wizard/valid_icon.svg +0 -6
  681. package/dist/wizard/validation-wrong.svg +0 -6
  682. package/test/Accordion.test.js +0 -33
  683. package/test/AccordionGroup.test.js +0 -109
  684. package/test/Alert.test.js +0 -53
  685. package/test/Box.test.js +0 -10
  686. package/test/Button.test.js +0 -18
  687. package/test/Card.test.js +0 -30
  688. package/test/Checkbox.test.js +0 -45
  689. package/test/Chip.test.js +0 -25
  690. package/test/Date.test.js +0 -393
  691. package/test/Dialog.test.js +0 -23
  692. package/test/Dropdown.test.js +0 -130
  693. package/test/Footer.test.js +0 -99
  694. package/test/Header.test.js +0 -39
  695. package/test/Heading.test.js +0 -35
  696. package/test/InputText.test.js +0 -240
  697. package/test/Link.test.js +0 -42
  698. package/test/Paginator.test.js +0 -177
  699. package/test/ProgressBar.test.js +0 -35
  700. package/test/Radio.test.js +0 -37
  701. package/test/ResultsetTable.test.js +0 -330
  702. package/test/Select.test.js +0 -192
  703. package/test/Sidenav.test.js +0 -45
  704. package/test/Slider.test.js +0 -82
  705. package/test/Spinner.test.js +0 -27
  706. package/test/Switch.test.js +0 -45
  707. package/test/Table.test.js +0 -36
  708. package/test/Tabs.test.js +0 -109
  709. package/test/TabsForSections.test.js +0 -34
  710. package/test/Tag.test.js +0 -32
  711. package/test/TextArea.test.js +0 -52
  712. package/test/ToggleGroup.test.js +0 -81
  713. package/test/Upload.test.js +0 -60
  714. package/test/Wizard.test.js +0 -130
  715. package/test/mocks/pngMock.js +0 -1
  716. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,108 @@
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"] = exports.ContextualMenuContext = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
14
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
15
+ var _Divider = _interopRequireDefault(require("../divider/Divider"));
16
+ var _Inset = _interopRequireDefault(require("../inset/Inset"));
17
+ var _MenuItem = _interopRequireDefault(require("./MenuItem"));
18
+ var _templateObject, _templateObject2, _templateObject3;
19
+ 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); }
20
+ 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; }
21
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
22
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
23
+ var ContextualMenuContext = exports.ContextualMenuContext = /*#__PURE__*/(0, _react.createContext)(null);
24
+ var isGroupItem = function isGroupItem(item) {
25
+ return "items" in item;
26
+ };
27
+ var isSection = function isSection(item) {
28
+ return "items" in item && !("label" in item);
29
+ };
30
+ var addIdToItems = function addIdToItems(items) {
31
+ var accId = 0;
32
+ var innerAddIdToItems = function innerAddIdToItems(items) {
33
+ return items.map(function (item) {
34
+ return isSection(item) ? _objectSpread(_objectSpread({}, item), {}, {
35
+ items: innerAddIdToItems(item.items)
36
+ }) : isGroupItem(item) ? _objectSpread(_objectSpread({}, item), {}, {
37
+ items: innerAddIdToItems(item.items)
38
+ }) : _objectSpread(_objectSpread({}, item), {}, {
39
+ id: accId++
40
+ });
41
+ });
42
+ };
43
+ return innerAddIdToItems(items);
44
+ };
45
+ var DxcContextualMenu = function DxcContextualMenu(_ref) {
46
+ var items = _ref.items;
47
+ var _useState = (0, _react.useState)(-1),
48
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
49
+ selectedItemId = _useState2[0],
50
+ setSelectedItemId = _useState2[1];
51
+ var contextualMenuRef = (0, _react.useRef)(null);
52
+ var itemsWithId = (0, _react.useMemo)(function () {
53
+ return addIdToItems(items);
54
+ }, [items]);
55
+ var renderSection = function renderSection(section, currentSectionIndex, length) {
56
+ return /*#__PURE__*/_react["default"].createElement(_react.Fragment, {
57
+ key: "section-".concat(currentSectionIndex)
58
+ }, /*#__PURE__*/_react["default"].createElement("li", {
59
+ role: "group",
60
+ "aria-labelledby": section.title
61
+ }, section.title != null && /*#__PURE__*/_react["default"].createElement(Title, {
62
+ id: section.title
63
+ }, section.title), /*#__PURE__*/_react["default"].createElement(SectionList, null, section.items.map(function (item, index) {
64
+ return /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
65
+ item: item,
66
+ key: "".concat(item.label, "-").concat(index)
67
+ });
68
+ }))), currentSectionIndex !== length - 1 && /*#__PURE__*/_react["default"].createElement(_Inset["default"], {
69
+ top: "0.25rem",
70
+ bottom: "0.25rem"
71
+ }, /*#__PURE__*/_react["default"].createElement(_Divider["default"], {
72
+ color: "lightGrey"
73
+ })));
74
+ };
75
+ var _useState3 = (0, _react.useState)(true),
76
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
77
+ firstUpdate = _useState4[0],
78
+ setFirstUpdate = _useState4[1];
79
+ (0, _react.useLayoutEffect)(function () {
80
+ if (selectedItemId !== -1 && firstUpdate) {
81
+ var _contextualMenuEl$scr;
82
+ var contextualMenuEl = contextualMenuRef === null || contextualMenuRef === void 0 ? void 0 : contextualMenuRef.current;
83
+ var selectedItemEl = contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : contextualMenuEl.querySelector("[aria-selected='true']");
84
+ contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : (_contextualMenuEl$scr = contextualMenuEl.scrollTo) === null || _contextualMenuEl$scr === void 0 ? void 0 : _contextualMenuEl$scr.call(contextualMenuEl, {
85
+ top: (selectedItemEl === null || selectedItemEl === void 0 ? void 0 : selectedItemEl.offsetTop) - (contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : contextualMenuEl.clientHeight) / 2
86
+ });
87
+ setFirstUpdate(false);
88
+ }
89
+ }, [firstUpdate, selectedItemId]);
90
+ return /*#__PURE__*/_react["default"].createElement(ContextualMenu, {
91
+ role: "menu",
92
+ ref: contextualMenuRef
93
+ }, /*#__PURE__*/_react["default"].createElement(ContextualMenuContext.Provider, {
94
+ value: {
95
+ selectedItemId: selectedItemId,
96
+ setSelectedItemId: setSelectedItemId
97
+ }
98
+ }, itemsWithId.map(function (item, index) {
99
+ return "items" in item && !("label" in item) ? renderSection(item, index, itemsWithId.length) : /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
100
+ item: item,
101
+ key: "".concat(item.label, "-").concat(index)
102
+ });
103
+ })));
104
+ };
105
+ var ContextualMenu = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n margin: 0;\n border: 1px solid ", ";\n border-radius: 0.25rem;\n padding: ", " ", ";\n display: grid;\n gap: ", ";\n min-width: 248px;\n max-height: 100%;\n background-color: ", ";\n overflow-y: auto;\n &::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n }\n &::-webkit-scrollbar-thumb {\n background-color: ", ";\n border-radius: 0.25rem;\n }\n &::-webkit-scrollbar-track {\n background-color: ", ";\n border-radius: 0.25rem;\n }\n"])), _coreTokens["default"].color_grey_200, _coreTokens["default"].spacing_16, _coreTokens["default"].spacing_8, _coreTokens["default"].spacing_4, _coreTokens["default"].color_white, _coreTokens["default"].color_grey_700, _coreTokens["default"].color_grey_300);
106
+ var SectionList = _styledComponents["default"].ul(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n list-style: none;\n margin: 0;\n padding: 0;\n display: grid;\n gap: ", ";\n"])), _coreTokens["default"].spacing_4);
107
+ var Title = _styledComponents["default"].h2(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n margin: 0 0 ", " 0;\n padding: ", ";\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: 24px;\n"])), _coreTokens["default"].spacing_4, _coreTokens["default"].spacing_4, _coreTokens["default"].color_grey_900, _coreTokens["default"].type_sans, _coreTokens["default"].type_scale_03, _coreTokens["default"].type_semibold);
108
+ var _default = exports["default"] = DxcContextualMenu;
@@ -0,0 +1,223 @@
1
+ import React from "react";
2
+ import Title from "../../.storybook/components/Title";
3
+ import DxcContextualMenu, { ContextualMenuContext } from "./ContextualMenu";
4
+ import DxcContainer from "../container/Container";
5
+ import SingleItem from "./SingleItem";
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";
10
+
11
+ export default {
12
+ title: "Contextual Menu",
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
+ },
25
+ };
26
+
27
+ const items = [{ label: "Item 1" }, { label: "Item 2" }, { label: "Item 3" }, { label: "Item 4" }];
28
+
29
+ const sections = [
30
+ {
31
+ title: "Section title",
32
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
33
+ },
34
+ {
35
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
36
+ },
37
+ ];
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
+
75
+ const itemsWithIcon = [
76
+ {
77
+ label: "Item 1",
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
+ ),
83
+ },
84
+ {
85
+ label: "Item 2",
86
+ icon: "star",
87
+ },
88
+ ];
89
+
90
+ const itemsWithBadge = [
91
+ {
92
+ label: "Item 1",
93
+ badge: <DxcBadge color="green" label="New" />,
94
+ },
95
+ {
96
+ label: "Item 2",
97
+ badge: <DxcBadge color="purple" label="Experimental" />,
98
+ },
99
+ ];
100
+
101
+ const sectionsWithScroll = [
102
+ {
103
+ title: "Team repositories",
104
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
105
+ },
106
+ {
107
+ items: [
108
+ { label: "Approved locations" },
109
+ { label: "Approved locations" },
110
+ { label: "Approved locations" },
111
+ { label: "Approved locations" },
112
+ { label: "Approved locations" },
113
+ { label: "Approved locations" },
114
+ { label: "Approved locations" },
115
+ { label: "Approved locations" },
116
+ { label: "Approved locations", selectedByDefault: true },
117
+ ],
118
+ },
119
+ ];
120
+
121
+ const itemsWithTruncatedText = [
122
+ {
123
+ label: "Item with a very long label that should be truncated",
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
+ ),
130
+ },
131
+ {
132
+ label: "Item 2",
133
+ icon: "favorite",
134
+ },
135
+ ];
136
+
137
+ export const Chromatic = () => (
138
+ <>
139
+ <Title title="Default" theme="light" level={3} />
140
+ <ExampleContainer>
141
+ <DxcContextualMenu items={items} />
142
+ </ExampleContainer>
143
+ <Title title="With sections" theme="light" level={3} />
144
+ <ExampleContainer>
145
+ <DxcContainer width="300px">
146
+ <DxcContextualMenu items={sections} />
147
+ </DxcContainer>
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>
155
+ <Title title="With icons" theme="light" level={3} />
156
+ <ExampleContainer>
157
+ <DxcContainer width="300px">
158
+ <DxcContextualMenu items={itemsWithIcon} />
159
+ </DxcContainer>
160
+ </ExampleContainer>
161
+ <Title title="With badge" theme="light" level={3} />
162
+ <ExampleContainer>
163
+ <DxcContainer width="300px">
164
+ <DxcContextualMenu items={itemsWithBadge} />
165
+ </DxcContainer>
166
+ </ExampleContainer>
167
+ <Title title="With label truncated" theme="light" level={3} />
168
+ <ExampleContainer>
169
+ <DxcContainer width="300px">
170
+ <DxcContextualMenu items={itemsWithTruncatedText} />
171
+ </DxcContainer>
172
+ </ExampleContainer>
173
+ <Title title="With auto-scroll" theme="light" level={3} />
174
+ <ExampleContainer>
175
+ <DxcContainer height="300px" width="300px">
176
+ <DxcContextualMenu items={sectionsWithScroll} />
177
+ </DxcContainer>
178
+ </ExampleContainer>
179
+ <Title title="Width doesn't go below 248px" theme="light" level={3} />
180
+ <ExampleContainer>
181
+ <DxcContainer width="200px">
182
+ <DxcContextualMenu items={items} />
183
+ </DxcContainer>
184
+ </ExampleContainer>
185
+ </>
186
+ );
187
+
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>
223
+ );
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,247 @@
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 _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
9
+ var _ContextualMenu = _interopRequireDefault(require("./ContextualMenu"));
10
+ var items = [{
11
+ label: "Item 1"
12
+ }, {
13
+ label: "Item 2"
14
+ }, {
15
+ label: "Item 3"
16
+ }, {
17
+ label: "Item 4"
18
+ }];
19
+ var sections = [{
20
+ title: "Team repositories",
21
+ items: [{
22
+ label: "Approved locations"
23
+ }, {
24
+ label: "Approved locations"
25
+ }, {
26
+ label: "Approved locations"
27
+ }]
28
+ }, {
29
+ items: [{
30
+ label: "Approved locations"
31
+ }, {
32
+ label: "Approved locations"
33
+ }, {
34
+ label: "Approved locations"
35
+ }]
36
+ }];
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
91
+ })),
92
+ getByRole = _render2.getByRole;
93
+ var item = getByRole("button");
94
+ expect(item.getAttribute("aria-selected")).toBeTruthy();
95
+ });
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
168
+ })),
169
+ getByText = _render5.getByText,
170
+ getAllByRole = _render5.getAllByRole;
171
+ expect(getByText("Tested item")).toBeTruthy();
172
+ expect(getAllByRole("button")[1].getAttribute("aria-selected")).toBeTruthy();
173
+ });
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 () {
235
+ var test = [{
236
+ label: "Tested item",
237
+ onSelect: jest.fn()
238
+ }];
239
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
240
+ items: test
241
+ })),
242
+ getByRole = _render8.getByRole;
243
+ var item = getByRole("button");
244
+ _react2.fireEvent.click(item);
245
+ expect(test[0].onSelect).toHaveBeenCalled();
246
+ });
247
+ });
@@ -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;