@dxc-technology/halstack-react 0.0.0-b061aa1 → 0.0.0-b063530

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 (549) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1280 -0
  4. package/HalstackContext.js +320 -0
  5. package/README.md +47 -0
  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 +1 -1
  9. package/accordion/Accordion.js +103 -193
  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 +12 -23
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +3 -3
  17. package/accordion-group/AccordionGroup.js +39 -108
  18. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +94 -0
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +18 -23
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +41 -128
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +75 -0
  40. package/alert/types.d.ts +5 -5
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +4 -0
  44. package/badge/Badge.js +142 -40
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +54 -0
  49. package/bar-chart/BarChart.d.ts +4 -0
  50. package/bar-chart/BarChart.js +152 -0
  51. package/bar-chart/BarChart.stories.tsx +281 -0
  52. package/bar-chart/BarChart.test.d.ts +1 -0
  53. package/bar-chart/BarChart.test.js +194 -0
  54. package/bar-chart/theme.d.ts +3 -0
  55. package/bar-chart/theme.js +31 -0
  56. package/bar-chart/types.d.ts +118 -0
  57. package/bleed/Bleed.d.ts +3 -0
  58. package/bleed/Bleed.js +43 -0
  59. package/bleed/Bleed.stories.tsx +341 -0
  60. package/bleed/types.d.ts +37 -0
  61. package/bleed/types.js +5 -0
  62. package/box/Box.accessibility.test.d.ts +1 -0
  63. package/box/Box.accessibility.test.js +33 -0
  64. package/box/Box.d.ts +1 -1
  65. package/box/Box.js +31 -82
  66. package/box/Box.stories.tsx +38 -51
  67. package/box/Box.test.d.ts +1 -0
  68. package/box/Box.test.js +13 -0
  69. package/box/types.d.ts +3 -14
  70. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  71. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  72. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  73. package/breadcrumbs/Breadcrumbs.js +79 -0
  74. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  75. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  76. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  77. package/breadcrumbs/Item.d.ts +4 -0
  78. package/breadcrumbs/Item.js +52 -0
  79. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  80. package/breadcrumbs/dropdownTheme.js +62 -0
  81. package/breadcrumbs/types.d.ts +40 -0
  82. package/breadcrumbs/types.js +5 -0
  83. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  84. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  85. package/bulleted-list/BulletedList.d.ts +7 -0
  86. package/bulleted-list/BulletedList.js +92 -0
  87. package/bulleted-list/BulletedList.stories.tsx +115 -0
  88. package/bulleted-list/types.d.ts +38 -0
  89. package/bulleted-list/types.js +5 -0
  90. package/button/Button.accessibility.test.d.ts +1 -0
  91. package/button/Button.accessibility.test.js +127 -0
  92. package/button/Button.d.ts +1 -1
  93. package/button/Button.js +65 -123
  94. package/button/Button.stories.tsx +155 -106
  95. package/button/Button.test.d.ts +1 -0
  96. package/button/Button.test.js +38 -0
  97. package/button/types.d.ts +12 -12
  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 +1 -1
  101. package/card/Card.js +60 -103
  102. package/card/Card.stories.tsx +14 -44
  103. package/card/Card.test.d.ts +1 -0
  104. package/card/Card.test.js +39 -0
  105. package/card/types.d.ts +6 -11
  106. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  107. package/checkbox/Checkbox.accessibility.test.js +87 -0
  108. package/checkbox/Checkbox.d.ts +2 -2
  109. package/checkbox/Checkbox.js +141 -182
  110. package/checkbox/Checkbox.stories.tsx +166 -136
  111. package/checkbox/Checkbox.test.d.ts +1 -0
  112. package/checkbox/Checkbox.test.js +199 -0
  113. package/checkbox/types.d.ts +19 -7
  114. package/chip/Chip.accessibility.test.d.ts +1 -0
  115. package/chip/Chip.accessibility.test.js +67 -0
  116. package/chip/Chip.d.ts +1 -1
  117. package/chip/Chip.js +51 -124
  118. package/chip/Chip.stories.tsx +105 -31
  119. package/chip/Chip.test.d.ts +1 -0
  120. package/chip/Chip.test.js +41 -0
  121. package/chip/types.d.ts +10 -18
  122. package/common/coreTokens.d.ts +236 -0
  123. package/common/coreTokens.js +183 -0
  124. package/common/utils.d.ts +1 -0
  125. package/common/utils.js +6 -12
  126. package/common/variables.d.ts +1432 -0
  127. package/common/variables.js +1117 -1397
  128. package/container/Container.d.ts +4 -0
  129. package/container/Container.js +194 -0
  130. package/container/Container.stories.tsx +214 -0
  131. package/container/types.d.ts +176 -0
  132. package/container/types.js +5 -0
  133. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  134. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  135. package/contextual-menu/ContextualMenu.d.ts +5 -0
  136. package/contextual-menu/ContextualMenu.js +136 -0
  137. package/contextual-menu/ContextualMenu.stories.tsx +231 -0
  138. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  139. package/contextual-menu/ContextualMenu.test.js +247 -0
  140. package/contextual-menu/GroupItem.d.ts +4 -0
  141. package/contextual-menu/GroupItem.js +67 -0
  142. package/contextual-menu/ItemAction.d.ts +4 -0
  143. package/contextual-menu/ItemAction.js +88 -0
  144. package/contextual-menu/MenuItem.d.ts +4 -0
  145. package/contextual-menu/MenuItem.js +29 -0
  146. package/contextual-menu/SingleItem.d.ts +4 -0
  147. package/contextual-menu/SingleItem.js +38 -0
  148. package/contextual-menu/types.d.ts +65 -0
  149. package/contextual-menu/types.js +5 -0
  150. package/date-input/Calendar.d.ts +4 -0
  151. package/date-input/Calendar.js +230 -0
  152. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  153. package/date-input/DateInput.accessibility.test.js +229 -0
  154. package/date-input/DateInput.js +181 -314
  155. package/date-input/DateInput.stories.tsx +210 -57
  156. package/date-input/DateInput.test.d.ts +1 -0
  157. package/date-input/DateInput.test.js +808 -0
  158. package/date-input/DatePicker.d.ts +4 -0
  159. package/date-input/DatePicker.js +121 -0
  160. package/date-input/YearPicker.d.ts +4 -0
  161. package/date-input/YearPicker.js +105 -0
  162. package/date-input/types.d.ts +86 -22
  163. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  164. package/dialog/Dialog.accessibility.test.js +69 -0
  165. package/dialog/Dialog.d.ts +1 -1
  166. package/dialog/Dialog.js +57 -129
  167. package/dialog/Dialog.stories.tsx +324 -167
  168. package/dialog/Dialog.test.d.ts +1 -0
  169. package/dialog/Dialog.test.js +370 -0
  170. package/dialog/types.d.ts +18 -25
  171. package/divider/Divider.accessibility.test.d.ts +1 -0
  172. package/divider/Divider.accessibility.test.js +33 -0
  173. package/divider/Divider.d.ts +4 -0
  174. package/divider/Divider.js +36 -0
  175. package/divider/Divider.stories.tsx +224 -0
  176. package/divider/Divider.test.d.ts +1 -0
  177. package/divider/Divider.test.js +38 -0
  178. package/divider/types.d.ts +21 -0
  179. package/divider/types.js +5 -0
  180. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  181. package/dropdown/Dropdown.accessibility.test.js +183 -0
  182. package/dropdown/Dropdown.d.ts +1 -1
  183. package/dropdown/Dropdown.js +233 -330
  184. package/dropdown/Dropdown.stories.tsx +427 -0
  185. package/dropdown/Dropdown.test.d.ts +1 -0
  186. package/dropdown/Dropdown.test.js +628 -0
  187. package/dropdown/DropdownMenu.d.ts +4 -0
  188. package/dropdown/DropdownMenu.js +63 -0
  189. package/dropdown/DropdownMenuItem.d.ts +4 -0
  190. package/dropdown/DropdownMenuItem.js +71 -0
  191. package/dropdown/types.d.ts +37 -30
  192. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  193. package/file-input/FileInput.accessibility.test.js +167 -0
  194. package/file-input/FileInput.d.ts +2 -2
  195. package/file-input/FileInput.js +264 -337
  196. package/file-input/FileInput.stories.tsx +618 -0
  197. package/file-input/FileInput.test.d.ts +1 -0
  198. package/file-input/FileInput.test.js +404 -0
  199. package/file-input/FileItem.d.ts +4 -14
  200. package/file-input/FileItem.js +63 -122
  201. package/file-input/types.d.ts +52 -14
  202. package/flex/Flex.d.ts +4 -0
  203. package/flex/Flex.js +57 -0
  204. package/flex/Flex.stories.tsx +112 -0
  205. package/flex/types.d.ts +97 -0
  206. package/flex/types.js +5 -0
  207. package/footer/Footer.accessibility.test.d.ts +1 -0
  208. package/footer/Footer.accessibility.test.js +125 -0
  209. package/footer/Footer.d.ts +1 -1
  210. package/footer/Footer.js +74 -200
  211. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +96 -39
  212. package/footer/Footer.test.d.ts +1 -0
  213. package/footer/Footer.test.js +85 -0
  214. package/footer/Icons.d.ts +3 -0
  215. package/footer/Icons.js +54 -23
  216. package/footer/types.d.ts +26 -31
  217. package/grid/Grid.d.ts +7 -0
  218. package/grid/Grid.js +76 -0
  219. package/grid/Grid.stories.tsx +221 -0
  220. package/grid/types.d.ts +115 -0
  221. package/grid/types.js +5 -0
  222. package/header/Header.accessibility.test.d.ts +1 -0
  223. package/header/Header.accessibility.test.js +94 -0
  224. package/header/Header.d.ts +4 -3
  225. package/header/Header.js +105 -219
  226. package/header/Header.stories.tsx +169 -64
  227. package/header/Header.test.d.ts +1 -0
  228. package/header/Header.test.js +66 -0
  229. package/header/Icons.d.ts +2 -0
  230. package/header/Icons.js +5 -15
  231. package/header/types.d.ts +7 -21
  232. package/heading/Heading.accessibility.test.d.ts +1 -0
  233. package/heading/Heading.accessibility.test.js +33 -0
  234. package/heading/Heading.js +11 -33
  235. package/heading/Heading.stories.tsx +3 -2
  236. package/heading/Heading.test.d.ts +1 -0
  237. package/heading/Heading.test.js +156 -0
  238. package/heading/types.d.ts +7 -7
  239. package/icon/Icon.accessibility.test.d.ts +1 -0
  240. package/icon/Icon.accessibility.test.js +30 -0
  241. package/icon/Icon.d.ts +4 -0
  242. package/icon/Icon.js +33 -0
  243. package/icon/Icon.stories.tsx +28 -0
  244. package/icon/types.d.ts +4 -0
  245. package/icon/types.js +5 -0
  246. package/image/Image.accessibility.test.d.ts +1 -0
  247. package/image/Image.accessibility.test.js +56 -0
  248. package/image/Image.d.ts +4 -0
  249. package/image/Image.js +70 -0
  250. package/image/Image.stories.tsx +129 -0
  251. package/image/types.d.ts +72 -0
  252. package/image/types.js +5 -0
  253. package/inset/Inset.d.ts +3 -0
  254. package/inset/Inset.js +43 -0
  255. package/inset/Inset.stories.tsx +230 -0
  256. package/inset/types.d.ts +37 -0
  257. package/inset/types.js +5 -0
  258. package/layout/ApplicationLayout.d.ts +16 -6
  259. package/layout/ApplicationLayout.js +88 -175
  260. package/layout/ApplicationLayout.stories.tsx +162 -0
  261. package/layout/Icons.d.ts +7 -0
  262. package/layout/Icons.js +41 -48
  263. package/layout/types.d.ts +19 -35
  264. package/link/Link.accessibility.test.d.ts +1 -0
  265. package/link/Link.accessibility.test.js +108 -0
  266. package/link/Link.d.ts +3 -2
  267. package/link/Link.js +65 -109
  268. package/link/Link.stories.tsx +161 -54
  269. package/link/Link.test.d.ts +1 -0
  270. package/link/Link.test.js +63 -0
  271. package/link/types.d.ts +15 -35
  272. package/main.d.ts +21 -14
  273. package/main.js +106 -98
  274. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  275. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  276. package/nav-tabs/NavTabs.d.ts +7 -0
  277. package/nav-tabs/NavTabs.js +108 -0
  278. package/nav-tabs/NavTabs.stories.tsx +294 -0
  279. package/nav-tabs/NavTabs.test.d.ts +1 -0
  280. package/nav-tabs/NavTabs.test.js +77 -0
  281. package/nav-tabs/NavTabsContext.d.ts +3 -0
  282. package/nav-tabs/NavTabsContext.js +8 -0
  283. package/nav-tabs/Tab.d.ts +4 -0
  284. package/nav-tabs/Tab.js +117 -0
  285. package/nav-tabs/types.d.ts +52 -0
  286. package/nav-tabs/types.js +5 -0
  287. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  288. package/number-input/NumberInput.accessibility.test.js +227 -0
  289. package/number-input/NumberInput.js +52 -49
  290. package/number-input/NumberInput.stories.tsx +39 -28
  291. package/number-input/NumberInput.test.d.ts +1 -0
  292. package/number-input/NumberInput.test.js +988 -0
  293. package/number-input/NumberInputContext.d.ts +3 -4
  294. package/number-input/NumberInputContext.js +3 -14
  295. package/number-input/types.d.ts +34 -15
  296. package/package.json +59 -52
  297. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  298. package/paginator/Paginator.accessibility.test.js +78 -0
  299. package/paginator/Paginator.js +47 -107
  300. package/paginator/Paginator.stories.tsx +24 -0
  301. package/paginator/Paginator.test.d.ts +1 -0
  302. package/paginator/Paginator.test.js +334 -0
  303. package/paginator/types.d.ts +3 -3
  304. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  305. package/paragraph/Paragraph.accessibility.test.js +28 -0
  306. package/paragraph/Paragraph.d.ts +5 -0
  307. package/paragraph/Paragraph.js +22 -0
  308. package/paragraph/Paragraph.stories.tsx +27 -0
  309. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  310. package/password-input/PasswordInput.accessibility.test.js +152 -0
  311. package/password-input/PasswordInput.js +63 -127
  312. package/password-input/PasswordInput.stories.tsx +13 -36
  313. package/password-input/PasswordInput.test.d.ts +1 -0
  314. package/password-input/PasswordInput.test.js +197 -0
  315. package/password-input/types.d.ts +21 -17
  316. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  317. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  318. package/progress-bar/ProgressBar.js +69 -93
  319. package/progress-bar/ProgressBar.stories.tsx +93 -0
  320. package/progress-bar/ProgressBar.test.d.ts +1 -0
  321. package/progress-bar/ProgressBar.test.js +93 -0
  322. package/progress-bar/types.d.ts +3 -3
  323. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  324. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  325. package/quick-nav/QuickNav.d.ts +4 -0
  326. package/quick-nav/QuickNav.js +94 -0
  327. package/quick-nav/QuickNav.stories.tsx +356 -0
  328. package/quick-nav/types.d.ts +21 -0
  329. package/quick-nav/types.js +5 -0
  330. package/radio-group/Radio.d.ts +4 -0
  331. package/radio-group/Radio.js +121 -0
  332. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  333. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  334. package/radio-group/RadioGroup.d.ts +4 -0
  335. package/radio-group/RadioGroup.js +233 -0
  336. package/radio-group/RadioGroup.stories.tsx +214 -0
  337. package/radio-group/RadioGroup.test.d.ts +1 -0
  338. package/radio-group/RadioGroup.test.js +754 -0
  339. package/radio-group/types.d.ts +114 -0
  340. package/radio-group/types.js +5 -0
  341. package/resultset-table/Icons.d.ts +7 -0
  342. package/resultset-table/Icons.js +47 -0
  343. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  344. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  345. package/resultset-table/ResultsetTable.d.ts +7 -0
  346. package/resultset-table/ResultsetTable.js +195 -0
  347. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  348. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  349. package/resultset-table/ResultsetTable.test.js +450 -0
  350. package/{resultsetTable → resultset-table}/types.d.ts +45 -11
  351. package/resultset-table/types.js +5 -0
  352. package/select/Listbox.d.ts +4 -0
  353. package/select/Listbox.js +151 -0
  354. package/select/Option.d.ts +4 -0
  355. package/select/Option.js +89 -0
  356. package/select/Select.accessibility.test.d.ts +1 -0
  357. package/select/Select.accessibility.test.js +227 -0
  358. package/select/Select.d.ts +4 -0
  359. package/select/Select.js +251 -514
  360. package/select/Select.stories.tsx +611 -255
  361. package/select/Select.test.d.ts +1 -0
  362. package/select/Select.test.js +2168 -0
  363. package/select/types.d.ts +209 -0
  364. package/select/types.js +5 -0
  365. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  366. package/sidenav/Sidenav.accessibility.test.js +59 -0
  367. package/sidenav/Sidenav.d.ts +6 -5
  368. package/sidenav/Sidenav.js +137 -72
  369. package/sidenav/Sidenav.stories.tsx +246 -134
  370. package/sidenav/Sidenav.test.d.ts +1 -0
  371. package/sidenav/Sidenav.test.js +37 -0
  372. package/sidenav/SidenavContext.d.ts +5 -0
  373. package/sidenav/SidenavContext.js +13 -0
  374. package/sidenav/types.d.ts +52 -26
  375. package/slider/Slider.accessibility.test.d.ts +1 -0
  376. package/slider/Slider.accessibility.test.js +103 -0
  377. package/slider/Slider.d.ts +2 -2
  378. package/slider/Slider.js +148 -182
  379. package/slider/Slider.stories.tsx +68 -65
  380. package/slider/Slider.test.d.ts +1 -0
  381. package/slider/Slider.test.js +256 -0
  382. package/slider/types.d.ts +11 -3
  383. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  384. package/spinner/Spinner.accessibility.test.js +96 -0
  385. package/spinner/Spinner.d.ts +1 -1
  386. package/spinner/Spinner.js +51 -110
  387. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  388. package/spinner/Spinner.test.d.ts +1 -0
  389. package/spinner/Spinner.test.js +55 -0
  390. package/spinner/types.d.ts +3 -3
  391. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  392. package/status-light/StatusLight.accessibility.test.js +157 -0
  393. package/status-light/StatusLight.d.ts +4 -0
  394. package/status-light/StatusLight.js +51 -0
  395. package/status-light/StatusLight.stories.tsx +74 -0
  396. package/status-light/StatusLight.test.d.ts +1 -0
  397. package/status-light/StatusLight.test.js +25 -0
  398. package/status-light/types.d.ts +17 -0
  399. package/status-light/types.js +5 -0
  400. package/switch/Switch.accessibility.test.d.ts +1 -0
  401. package/switch/Switch.accessibility.test.js +98 -0
  402. package/switch/Switch.d.ts +2 -2
  403. package/switch/Switch.js +147 -115
  404. package/switch/Switch.stories.tsx +57 -68
  405. package/switch/Switch.test.d.ts +1 -0
  406. package/switch/Switch.test.js +180 -0
  407. package/switch/types.d.ts +13 -5
  408. package/table/DropdownTheme.js +62 -0
  409. package/table/Table.accessibility.test.d.ts +1 -0
  410. package/table/Table.accessibility.test.js +92 -0
  411. package/table/Table.d.ts +6 -2
  412. package/table/Table.js +79 -36
  413. package/table/Table.stories.tsx +663 -0
  414. package/table/Table.test.d.ts +1 -0
  415. package/table/Table.test.js +111 -0
  416. package/table/types.d.ts +34 -6
  417. package/tabs/Tab.d.ts +4 -0
  418. package/tabs/Tab.js +117 -0
  419. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  420. package/tabs/Tabs.accessibility.test.js +56 -0
  421. package/tabs/Tabs.d.ts +1 -1
  422. package/tabs/Tabs.js +307 -147
  423. package/tabs/Tabs.stories.tsx +127 -18
  424. package/tabs/Tabs.test.d.ts +1 -0
  425. package/tabs/Tabs.test.js +276 -0
  426. package/tabs/types.d.ts +46 -24
  427. package/tag/Tag.accessibility.test.d.ts +1 -0
  428. package/tag/Tag.accessibility.test.js +69 -0
  429. package/tag/Tag.d.ts +1 -1
  430. package/tag/Tag.js +44 -86
  431. package/tag/Tag.stories.tsx +38 -31
  432. package/tag/Tag.test.d.ts +1 -0
  433. package/tag/Tag.test.js +41 -0
  434. package/tag/types.d.ts +25 -16
  435. package/text-input/Suggestion.d.ts +4 -0
  436. package/text-input/Suggestion.js +67 -0
  437. package/text-input/Suggestions.d.ts +4 -0
  438. package/text-input/Suggestions.js +94 -0
  439. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  440. package/text-input/TextInput.accessibility.test.js +320 -0
  441. package/text-input/TextInput.js +335 -552
  442. package/text-input/TextInput.stories.tsx +292 -271
  443. package/text-input/TextInput.test.d.ts +1 -0
  444. package/text-input/TextInput.test.js +1755 -0
  445. package/text-input/types.d.ts +71 -25
  446. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  447. package/textarea/Textarea.accessibility.test.js +155 -0
  448. package/textarea/Textarea.d.ts +4 -0
  449. package/textarea/Textarea.js +92 -173
  450. package/textarea/Textarea.stories.tsx +174 -0
  451. package/textarea/Textarea.test.d.ts +1 -0
  452. package/textarea/Textarea.test.js +406 -0
  453. package/textarea/types.d.ts +141 -0
  454. package/textarea/types.js +5 -0
  455. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  456. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  457. package/toggle-group/ToggleGroup.d.ts +2 -2
  458. package/toggle-group/ToggleGroup.js +96 -114
  459. package/toggle-group/ToggleGroup.stories.tsx +80 -40
  460. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  461. package/toggle-group/ToggleGroup.test.js +137 -0
  462. package/toggle-group/types.d.ts +67 -37
  463. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  464. package/tooltip/Tooltip.accessibility.test.js +144 -0
  465. package/tooltip/Tooltip.d.ts +4 -0
  466. package/tooltip/Tooltip.js +50 -0
  467. package/tooltip/Tooltip.stories.tsx +111 -0
  468. package/tooltip/Tooltip.test.d.ts +1 -0
  469. package/tooltip/Tooltip.test.js +112 -0
  470. package/tooltip/types.d.ts +16 -0
  471. package/tooltip/types.js +5 -0
  472. package/typography/Typography.accessibility.test.d.ts +1 -0
  473. package/typography/Typography.accessibility.test.js +339 -0
  474. package/typography/Typography.d.ts +4 -0
  475. package/typography/Typography.js +23 -0
  476. package/typography/Typography.stories.tsx +196 -0
  477. package/typography/Typography.test.js +23 -0
  478. package/typography/types.d.ts +18 -0
  479. package/typography/types.js +5 -0
  480. package/useTheme.d.ts +1168 -0
  481. package/useTheme.js +4 -11
  482. package/useTranslatedLabels.d.ts +96 -0
  483. package/useTranslatedLabels.js +14 -0
  484. package/utils/BaseTypography.d.ts +21 -0
  485. package/utils/BaseTypography.js +98 -0
  486. package/utils/FocusLock.d.ts +13 -0
  487. package/utils/FocusLock.js +125 -0
  488. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  489. package/wizard/Wizard.accessibility.test.js +55 -0
  490. package/wizard/Wizard.d.ts +1 -1
  491. package/wizard/Wizard.js +122 -114
  492. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +68 -20
  493. package/wizard/Wizard.test.d.ts +1 -0
  494. package/wizard/Wizard.test.js +114 -0
  495. package/wizard/types.d.ts +15 -15
  496. package/ThemeContext.js +0 -246
  497. package/V3Select/V3Select.js +0 -455
  498. package/V3Select/index.d.ts +0 -27
  499. package/V3Textarea/V3Textarea.js +0 -260
  500. package/V3Textarea/index.d.ts +0 -27
  501. package/card/ice-cream.jpg +0 -0
  502. package/common/OpenSans.css +0 -81
  503. package/common/RequiredComponent.js +0 -32
  504. package/common/fonts/OpenSans-Bold.ttf +0 -0
  505. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  506. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  507. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  508. package/common/fonts/OpenSans-Italic.ttf +0 -0
  509. package/common/fonts/OpenSans-Light.ttf +0 -0
  510. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  511. package/common/fonts/OpenSans-Regular.ttf +0 -0
  512. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  513. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  514. package/date/Date.js +0 -373
  515. package/date/index.d.ts +0 -27
  516. package/input-text/Icons.js +0 -22
  517. package/input-text/InputText.js +0 -611
  518. package/input-text/index.d.ts +0 -36
  519. package/number-input/numberInputContextTypes.d.ts +0 -19
  520. package/paginator/Icons.js +0 -66
  521. package/progress-bar/ProgressBar.stories.jsx +0 -58
  522. package/radio/Radio.d.ts +0 -4
  523. package/radio/Radio.js +0 -174
  524. package/radio/Radio.stories.tsx +0 -192
  525. package/radio/types.d.ts +0 -54
  526. package/resultsetTable/ResultsetTable.d.ts +0 -4
  527. package/resultsetTable/ResultsetTable.js +0 -251
  528. package/select/index.d.ts +0 -131
  529. package/table/Table.stories.jsx +0 -276
  530. package/textarea/Textarea.stories.jsx +0 -135
  531. package/textarea/index.d.ts +0 -127
  532. package/toggle/Toggle.js +0 -186
  533. package/toggle/index.d.ts +0 -21
  534. package/upload/Upload.js +0 -201
  535. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  536. package/upload/buttons-upload/Icons.js +0 -40
  537. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  538. package/upload/dragAndDropArea/Icons.js +0 -39
  539. package/upload/file-upload/FileToUpload.js +0 -115
  540. package/upload/file-upload/Icons.js +0 -66
  541. package/upload/files-upload/FilesToUpload.js +0 -109
  542. package/upload/index.d.ts +0 -15
  543. package/upload/transaction/Icons.js +0 -160
  544. package/upload/transaction/Transaction.js +0 -104
  545. package/upload/transactions/Transactions.js +0 -94
  546. package/wizard/Icons.js +0 -65
  547. /package/{radio → action-icon}/types.js +0 -0
  548. /package/{resultsetTable → badge}/types.js +0 -0
  549. /package/{number-input/numberInputContextTypes.js → bar-chart/types.js} +0 -0
@@ -0,0 +1,98 @@
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 _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _ContextualMenu = _interopRequireDefault(require("./ContextualMenu"));
10
+ var _Badge = _interopRequireDefault(require("../badge/Badge"));
11
+ var _disabledRules = require("../../test/accessibility/rules/specific/contextual-menu/disabledRules.js");
12
+ // TODO: REMOVE
13
+
14
+ var disabledRules = {
15
+ rules: _disabledRules.disabledRules.reduce(function (rulesObj, rule) {
16
+ rulesObj[rule] = {
17
+ enabled: false
18
+ };
19
+ return rulesObj;
20
+ }, {})
21
+ };
22
+ var badge_icon = /*#__PURE__*/_react["default"].createElement("svg", {
23
+ width: "24",
24
+ height: "24",
25
+ viewBox: "0 0 24 24",
26
+ xmlns: "http://www.w3.org/2000/svg",
27
+ fill: "currentColor"
28
+ }, /*#__PURE__*/_react["default"].createElement("path", {
29
+ d: "M11 17H13V11H11V17ZM12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20ZM11 9H13V7H11V9Z"
30
+ }), /*#__PURE__*/_react["default"].createElement("path", {
31
+ d: "M11 7H13V9H11V7ZM11 11H13V17H11V11Z"
32
+ }), /*#__PURE__*/_react["default"].createElement("path", {
33
+ d: "M12 2C6.48 2 2 6.48 2 12C2 17.52 6.48 22 12 22C17.52 22 22 17.52 22 12C22 6.48 17.52 2 12 2ZM12 20C7.59 20 4 16.41 4 12C4 7.59 7.59 4 12 4C16.41 4 20 7.59 20 12C20 16.41 16.41 20 12 20Z"
34
+ }));
35
+ var key_icon = /*#__PURE__*/_react["default"].createElement("svg", {
36
+ xmlns: "http://www.w3.org/2000/svg",
37
+ height: "24",
38
+ viewBox: "0 -960 960 960",
39
+ width: "24",
40
+ fill: "currentColor"
41
+ }, /*#__PURE__*/_react["default"].createElement("path", {
42
+ 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"
43
+ }));
44
+ var fav_icon = /*#__PURE__*/_react["default"].createElement("svg", {
45
+ xmlns: "http://www.w3.org/2000/svg",
46
+ height: "24",
47
+ viewBox: "0 -960 960 960",
48
+ width: "24",
49
+ fill: "currentColor"
50
+ }, /*#__PURE__*/_react["default"].createElement("path", {
51
+ 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"
52
+ }));
53
+ var itemsWithTruncatedText = [{
54
+ label: "Item with a very long label that should be truncated",
55
+ slot: /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
56
+ color: "blue",
57
+ mode: "contextual",
58
+ label: "Label",
59
+ size: "small",
60
+ icon: badge_icon,
61
+ title: "Badge"
62
+ }),
63
+ icon: key_icon
64
+ }, {
65
+ label: "Item 2",
66
+ slot: /*#__PURE__*/_react["default"].createElement("svg", {
67
+ width: "12",
68
+ height: "12",
69
+ viewBox: "0 0 12 12",
70
+ fill: "currentColor",
71
+ xmlns: "http://www.w3.org/2000/svg"
72
+ }, /*#__PURE__*/_react["default"].createElement("path", {
73
+ 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",
74
+ fill: "#323232"
75
+ })),
76
+ icon: fav_icon
77
+ }];
78
+ describe("Context menu accessibility tests", function () {
79
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
80
+ var _render, container, results;
81
+ return _regenerator["default"].wrap(function _callee$(_context) {
82
+ while (1) switch (_context.prev = _context.next) {
83
+ case 0:
84
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ContextualMenu["default"], {
85
+ items: itemsWithTruncatedText
86
+ })), container = _render.container;
87
+ _context.next = 3;
88
+ return (0, _axeHelper.axe)(container, disabledRules);
89
+ case 3:
90
+ results = _context.sent;
91
+ expect(results).toHaveNoViolations();
92
+ case 5:
93
+ case "end":
94
+ return _context.stop();
95
+ }
96
+ }, _callee);
97
+ })));
98
+ });
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import ContextualMenuPropsType, { ContextualMenuContextProps } from "./types";
3
+ export declare const ContextualMenuContext: React.Context<ContextualMenuContextProps>;
4
+ declare const DxcContextualMenu: ({ items }: ContextualMenuPropsType) => React.JSX.Element;
5
+ export default DxcContextualMenu;
@@ -0,0 +1,136 @@
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 = _interopRequireWildcard(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 _useTheme = _interopRequireDefault(require("../useTheme"));
19
+ var _templateObject, _templateObject2, _templateObject3;
20
+ 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); }
21
+ 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; }
22
+ 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; }
23
+ 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; }
24
+ var ContextualMenuContext = exports.ContextualMenuContext = /*#__PURE__*/(0, _react.createContext)(null);
25
+ var isGroupItem = function isGroupItem(item) {
26
+ return "items" in item;
27
+ };
28
+ var isSection = function isSection(item) {
29
+ return "items" in item && !("label" in item);
30
+ };
31
+ var addIdToItems = function addIdToItems(items) {
32
+ var accId = 0;
33
+ var innerAddIdToItems = function innerAddIdToItems(items) {
34
+ return items.map(function (item) {
35
+ return isSection(item) ? _objectSpread(_objectSpread({}, item), {}, {
36
+ items: innerAddIdToItems(item.items)
37
+ }) : isGroupItem(item) ? _objectSpread(_objectSpread({}, item), {}, {
38
+ items: innerAddIdToItems(item.items)
39
+ }) : _objectSpread(_objectSpread({}, item), {}, {
40
+ id: accId++
41
+ });
42
+ });
43
+ };
44
+ return innerAddIdToItems(items);
45
+ };
46
+ var DxcContextualMenu = function DxcContextualMenu(_ref) {
47
+ var items = _ref.items;
48
+ var _useState = (0, _react.useState)(-1),
49
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
50
+ selectedItemId = _useState2[0],
51
+ setSelectedItemId = _useState2[1];
52
+ var contextualMenuRef = (0, _react.useRef)(null);
53
+ var itemsWithId = (0, _react.useMemo)(function () {
54
+ return addIdToItems(items);
55
+ }, [items]);
56
+ var colorsTheme = (0, _useTheme["default"])();
57
+ var renderSection = function renderSection(section, currentSectionIndex, length) {
58
+ return /*#__PURE__*/_react["default"].createElement(_react.Fragment, {
59
+ key: "section-".concat(currentSectionIndex)
60
+ }, /*#__PURE__*/_react["default"].createElement("li", {
61
+ role: "group",
62
+ "aria-labelledby": section.title
63
+ }, section.title != null && /*#__PURE__*/_react["default"].createElement(Title, {
64
+ id: section.title
65
+ }, section.title), /*#__PURE__*/_react["default"].createElement(SectionList, null, section.items.map(function (item, index) {
66
+ return /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
67
+ item: item,
68
+ key: "".concat(item.label, "-").concat(index)
69
+ });
70
+ }))), currentSectionIndex !== length - 1 && /*#__PURE__*/_react["default"].createElement(_Inset["default"], {
71
+ top: "0.25rem",
72
+ bottom: "0.25rem"
73
+ }, /*#__PURE__*/_react["default"].createElement(_Divider["default"], {
74
+ color: "lightGrey"
75
+ })));
76
+ };
77
+ var _useState3 = (0, _react.useState)(true),
78
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
79
+ firstUpdate = _useState4[0],
80
+ setFirstUpdate = _useState4[1];
81
+ (0, _react.useLayoutEffect)(function () {
82
+ if (selectedItemId !== -1 && firstUpdate) {
83
+ var _contextualMenuEl$scr;
84
+ var contextualMenuEl = contextualMenuRef === null || contextualMenuRef === void 0 ? void 0 : contextualMenuRef.current;
85
+ var selectedItemEl = contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : contextualMenuEl.querySelector("[aria-selected='true']");
86
+ contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : (_contextualMenuEl$scr = contextualMenuEl.scrollTo) === null || _contextualMenuEl$scr === void 0 ? void 0 : _contextualMenuEl$scr.call(contextualMenuEl, {
87
+ top: (selectedItemEl === null || selectedItemEl === void 0 ? void 0 : selectedItemEl.offsetTop) - (contextualMenuEl === null || contextualMenuEl === void 0 ? void 0 : contextualMenuEl.clientHeight) / 2
88
+ });
89
+ setFirstUpdate(false);
90
+ }
91
+ }, [firstUpdate, selectedItemId]);
92
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
93
+ theme: colorsTheme.contextualMenu
94
+ }, /*#__PURE__*/_react["default"].createElement(ContextualMenu, {
95
+ role: "menu",
96
+ ref: contextualMenuRef
97
+ }, /*#__PURE__*/_react["default"].createElement(ContextualMenuContext.Provider, {
98
+ value: {
99
+ selectedItemId: selectedItemId,
100
+ setSelectedItemId: setSelectedItemId
101
+ }
102
+ }, itemsWithId.map(function (item, index) {
103
+ return "items" in item && !("label" in item) ? renderSection(item, index, itemsWithId.length) : /*#__PURE__*/_react["default"].createElement(_MenuItem["default"], {
104
+ item: item,
105
+ key: "".concat(item.label, "-").concat(index)
106
+ });
107
+ }))));
108
+ };
109
+ 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"])), function (_ref2) {
110
+ var theme = _ref2.theme;
111
+ return theme.borderColor;
112
+ }, _coreTokens["default"].spacing_16, _coreTokens["default"].spacing_8, _coreTokens["default"].spacing_4, function (_ref3) {
113
+ var theme = _ref3.theme;
114
+ return theme.backgroundColor;
115
+ }, _coreTokens["default"].color_grey_700, _coreTokens["default"].color_grey_300);
116
+ 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);
117
+ 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-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), _coreTokens["default"].spacing_4, _coreTokens["default"].spacing_4, function (_ref4) {
118
+ var theme = _ref4.theme;
119
+ return theme.sectionTitleFontColor;
120
+ }, function (_ref5) {
121
+ var theme = _ref5.theme;
122
+ return theme.fontFamily;
123
+ }, function (_ref6) {
124
+ var theme = _ref6.theme;
125
+ return theme.sectionTitleFontSize;
126
+ }, function (_ref7) {
127
+ var theme = _ref7.theme;
128
+ return theme.sectionTitleFontStyle;
129
+ }, function (_ref8) {
130
+ var theme = _ref8.theme;
131
+ return theme.sectionTitleFontWeight;
132
+ }, function (_ref9) {
133
+ var theme = _ref9.theme;
134
+ return theme.sectionTitleLineHeight;
135
+ });
136
+ var _default = exports["default"] = DxcContextualMenu;
@@ -0,0 +1,231 @@
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
+ import { ThemeProvider } from "styled-components";
11
+ import useTheme from "../useTheme";
12
+
13
+ export default {
14
+ title: "Contextual Menu",
15
+ component: DxcContextualMenu,
16
+ parameters: {
17
+ // TODO: REMOVE
18
+ a11y: {
19
+ config: {
20
+ rules: [
21
+ ...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
22
+ ...preview?.parameters?.a11y?.config?.rules,
23
+ ],
24
+ },
25
+ },
26
+ },
27
+ };
28
+
29
+ const items = [{ label: "Item 1" }, { label: "Item 2" }, { label: "Item 3" }, { label: "Item 4" }];
30
+
31
+ const sections = [
32
+ {
33
+ title: "Section title",
34
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
35
+ },
36
+ {
37
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
38
+ },
39
+ ];
40
+
41
+ const groupItems = [
42
+ {
43
+ title: "Section 1",
44
+ items: [
45
+ {
46
+ label: "Grouped Item 1",
47
+ icon: "favorite",
48
+ items: [
49
+ { label: "Item 1" },
50
+ {
51
+ label: "Grouped Item 2",
52
+ items: [
53
+ {
54
+ label: "Item 2",
55
+ icon: "bookmark",
56
+ badge: <DxcBadge color="purple" label="Experimental" />,
57
+ },
58
+ { label: "Selected Item 3", selectedByDefault: true },
59
+ ],
60
+ },
61
+ ],
62
+ badge: <DxcBadge color="green" label="New" />,
63
+ },
64
+ { label: "Item 4", icon: "key" },
65
+ ],
66
+ },
67
+ {
68
+ title: "Section 2",
69
+ items: [
70
+ { label: "Item 5" },
71
+ { label: "Grouped Item 6", items: [{ label: "Item 7" }, { label: "Item 8" }] },
72
+ { label: "Item 9" },
73
+ ],
74
+ },
75
+ ];
76
+
77
+ const itemsWithIcon = [
78
+ {
79
+ label: "Item 1",
80
+ icon: (
81
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24" fill="currentColor">
82
+ <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" />
83
+ </svg>
84
+ ),
85
+ },
86
+ {
87
+ label: "Item 2",
88
+ icon: "star",
89
+ },
90
+ ];
91
+
92
+ const itemsWithBadge = [
93
+ {
94
+ label: "Item 1",
95
+ badge: <DxcBadge color="green" label="New" />,
96
+ },
97
+ {
98
+ label: "Item 2",
99
+ badge: <DxcBadge color="purple" label="Experimental" />,
100
+ },
101
+ ];
102
+
103
+ const sectionsWithScroll = [
104
+ {
105
+ title: "Team repositories",
106
+ items: [{ label: "Approved locations" }, { label: "Approved locations" }, { label: "Approved locations" }],
107
+ },
108
+ {
109
+ items: [
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" },
117
+ { label: "Approved locations" },
118
+ { label: "Approved locations", selectedByDefault: true },
119
+ ],
120
+ },
121
+ ];
122
+
123
+ const itemsWithTruncatedText = [
124
+ {
125
+ label: "Item with a very long label that should be truncated",
126
+ badge: <DxcBadge color="green" label="New" />,
127
+ icon: (
128
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24" fill="currentColor">
129
+ <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" />
130
+ </svg>
131
+ ),
132
+ },
133
+ {
134
+ label: "Item 2",
135
+ icon: "favorite",
136
+ },
137
+ ];
138
+
139
+ export const Chromatic = () => (
140
+ <>
141
+ <Title title="Default" theme="light" level={3} />
142
+ <ExampleContainer>
143
+ <DxcContextualMenu items={items} />
144
+ </ExampleContainer>
145
+ <Title title="With sections" theme="light" level={3} />
146
+ <ExampleContainer>
147
+ <DxcContainer width="300px">
148
+ <DxcContextualMenu items={sections} />
149
+ </DxcContainer>
150
+ </ExampleContainer>
151
+ <Title title="With group items" theme="light" level={3} />
152
+ <ExampleContainer>
153
+ <DxcContainer width="300px">
154
+ <DxcContextualMenu items={groupItems} />
155
+ </DxcContainer>
156
+ </ExampleContainer>
157
+ <Title title="With icons" theme="light" level={3} />
158
+ <ExampleContainer>
159
+ <DxcContainer width="300px">
160
+ <DxcContextualMenu items={itemsWithIcon} />
161
+ </DxcContainer>
162
+ </ExampleContainer>
163
+ <Title title="With badge" theme="light" level={3} />
164
+ <ExampleContainer>
165
+ <DxcContainer width="300px">
166
+ <DxcContextualMenu items={itemsWithBadge} />
167
+ </DxcContainer>
168
+ </ExampleContainer>
169
+ <Title title="With label truncated" theme="light" level={3} />
170
+ <ExampleContainer>
171
+ <DxcContainer width="300px">
172
+ <DxcContextualMenu items={itemsWithTruncatedText} />
173
+ </DxcContainer>
174
+ </ExampleContainer>
175
+ <Title title="With auto-scroll" theme="light" level={3} />
176
+ <ExampleContainer>
177
+ <DxcContainer height="300px" width="300px">
178
+ <DxcContextualMenu items={sectionsWithScroll} />
179
+ </DxcContainer>
180
+ </ExampleContainer>
181
+ <Title title="Width doesn't go below 248px" theme="light" level={3} />
182
+ <ExampleContainer>
183
+ <DxcContainer width="200px">
184
+ <DxcContextualMenu items={items} />
185
+ </DxcContainer>
186
+ </ExampleContainer>
187
+ </>
188
+ );
189
+
190
+ export const SingleItemStates = () => {
191
+ const colorsTheme = useTheme();
192
+
193
+ return (
194
+ <ThemeProvider theme={colorsTheme.contextualMenu}>
195
+ <DxcContainer width="300px">
196
+ <ContextualMenuContext.Provider value={{ selectedItemId: -1, setSelectedItemId: () => {} }}>
197
+ <Title title="Default" theme="light" level={3} />
198
+ <ExampleContainer>
199
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
200
+ </ExampleContainer>
201
+ <Title title="Focus" theme="light" level={3} />
202
+ <ExampleContainer pseudoState="pseudo-focus">
203
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
204
+ </ExampleContainer>
205
+ <Title title="Hover" theme="light" level={3} />
206
+ <ExampleContainer pseudoState="pseudo-hover">
207
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
208
+ </ExampleContainer>
209
+ <Title title="Active" theme="light" level={3} />
210
+ <ExampleContainer pseudoState="pseudo-active">
211
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
212
+ </ExampleContainer>
213
+ </ContextualMenuContext.Provider>
214
+ <ContextualMenuContext.Provider value={{ selectedItemId: 0, setSelectedItemId: () => {} }}>
215
+ <Title title="Selected" theme="light" level={3} />
216
+ <ExampleContainer>
217
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
218
+ </ExampleContainer>
219
+ <Title title="Selected hover" theme="light" level={3} />
220
+ <ExampleContainer pseudoState="pseudo-hover">
221
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
222
+ </ExampleContainer>
223
+ <Title title="Selected active" theme="light" level={3} />
224
+ <ExampleContainer pseudoState="pseudo-active">
225
+ <SingleItem {...items[0]} id={0} depthLevel={0} />
226
+ </ExampleContainer>
227
+ </ContextualMenuContext.Provider>
228
+ </DxcContainer>
229
+ </ThemeProvider>
230
+ );
231
+ };
@@ -0,0 +1 @@
1
+ export {};