@learningpool/ui 1.6.0 → 1.6.1

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 (437) hide show
  1. package/.eslintrc.js +40 -0
  2. package/.github/pull_request_template.md +23 -0
  3. package/.github/renovate.json +57 -0
  4. package/.github/workflows/integration.yml +53 -0
  5. package/.github/workflows/wss.yml +22 -0
  6. package/.jest-test-results.json +1 -0
  7. package/.releaserc +32 -0
  8. package/.storybook/learningpoolTheme.js +39 -0
  9. package/.storybook/main.js +21 -0
  10. package/.storybook/manager-head.html +175 -0
  11. package/.storybook/manager.js +34 -0
  12. package/.storybook/preview-head.html +212 -0
  13. package/.storybook/preview.js +120 -0
  14. package/.storybook/storybook-sort.js +54 -0
  15. package/CHANGELOG.md +6 -0
  16. package/amplify.yml +16 -0
  17. package/babel.config.json +14 -0
  18. package/{assets → dist/assets}/Images.d.ts +0 -0
  19. package/{assets → dist/assets}/Images.js +0 -0
  20. package/{components → dist/components}/atoms/Autocomplete/Autocomplete.d.ts +0 -0
  21. package/{components → dist/components}/atoms/Autocomplete/Autocomplete.js +0 -0
  22. package/{components → dist/components}/atoms/Button/Button.d.ts +0 -0
  23. package/{components → dist/components}/atoms/Button/Button.js +0 -0
  24. package/{components → dist/components}/atoms/Checkbox/Checkbox.d.ts +0 -0
  25. package/{components → dist/components}/atoms/Checkbox/Checkbox.js +0 -0
  26. package/{components → dist/components}/atoms/IconButton/IconButton.d.ts +0 -0
  27. package/{components → dist/components}/atoms/IconButton/IconButton.js +0 -0
  28. package/{components → dist/components}/atoms/Radio/Radio.d.ts +0 -0
  29. package/{components → dist/components}/atoms/Radio/Radio.js +0 -0
  30. package/{components → dist/components}/atoms/Select/Select.d.ts +0 -0
  31. package/{components → dist/components}/atoms/Select/Select.js +0 -0
  32. package/{components → dist/components}/atoms/Slider/Slider.d.ts +0 -0
  33. package/{components → dist/components}/atoms/Slider/Slider.js +0 -0
  34. package/{components → dist/components}/atoms/Switch/Switch.d.ts +0 -0
  35. package/{components → dist/components}/atoms/Switch/Switch.js +0 -0
  36. package/{components → dist/components}/atoms/TextField/TextField.d.ts +0 -0
  37. package/{components → dist/components}/atoms/TextField/TextField.js +0 -0
  38. package/{components → dist/components}/atoms/ToggleButton/ToggleButton.d.ts +0 -0
  39. package/{components → dist/components}/atoms/ToggleButton/ToggleButton.js +0 -0
  40. package/{components → dist/components}/datadisplay/Avatar/Avatar.d.ts +0 -0
  41. package/{components → dist/components}/datadisplay/Avatar/Avatar.js +0 -0
  42. package/{components → dist/components}/datadisplay/Chip/Chip.d.ts +0 -0
  43. package/{components → dist/components}/datadisplay/Chip/Chip.js +0 -0
  44. package/{components → dist/components}/datadisplay/List/List.d.ts +0 -0
  45. package/{components → dist/components}/datadisplay/List/List.js +0 -0
  46. package/{components → dist/components}/datadisplay/Tooltip/Tooltip.d.ts +0 -0
  47. package/{components → dist/components}/datadisplay/Tooltip/Tooltip.js +0 -0
  48. package/{components → dist/components}/feedback/Alert/Alert.d.ts +0 -0
  49. package/{components → dist/components}/feedback/Alert/Alert.js +0 -0
  50. package/{components → dist/components}/landmarks/Header/Header.d.ts +0 -0
  51. package/{components → dist/components}/landmarks/Header/Header.js +0 -0
  52. package/{components → dist/components}/landmarks/Header/HeaderActionButtons.d.ts +0 -0
  53. package/{components → dist/components}/landmarks/Header/HeaderActionButtons.js +0 -0
  54. package/{components → dist/components}/landmarks/Header/HeaderStyles.d.ts +0 -0
  55. package/{components → dist/components}/landmarks/Header/HeaderStyles.js +0 -0
  56. package/{components → dist/components}/navigation/Drawer/Drawer.d.ts +0 -0
  57. package/{components → dist/components}/navigation/Drawer/Drawer.js +0 -0
  58. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigation.d.ts +0 -0
  59. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigation.js +64 -41
  60. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationAvatar.d.ts +0 -0
  61. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationAvatar.js +23 -19
  62. package/dist/components/navigation/MobileNavigation/MobileNavigationAvatarStyles.d.ts +3296 -0
  63. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationAvatarStyles.js +4 -4
  64. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationDrawer.d.ts +0 -0
  65. package/dist/components/navigation/MobileNavigation/MobileNavigationDrawer.js +71 -0
  66. package/dist/components/navigation/MobileNavigation/MobileNavigationDrawerStyles.d.ts +1215 -0
  67. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationDrawerStyles.js +2 -2
  68. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItem.d.ts +0 -0
  69. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItem.js +0 -0
  70. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenu.d.ts +0 -0
  71. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenu.js +0 -0
  72. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenuStyles.d.ts +0 -0
  73. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenuStyles.js +0 -0
  74. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemStyles.d.ts +0 -0
  75. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemStyles.js +0 -0
  76. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationMotion.d.ts +0 -0
  77. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationMotion.js +0 -0
  78. package/dist/components/navigation/MobileNavigation/MobileNavigationNotchIndicator.d.ts +3 -0
  79. package/dist/components/navigation/MobileNavigation/MobileNavigationNotchIndicator.js +19 -0
  80. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationSearch.d.ts +0 -0
  81. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationSearch.js +8 -6
  82. package/dist/components/navigation/MobileNavigation/MobileNavigationSearchStyles.d.ts +1080 -0
  83. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationSearchStyles.js +2 -2
  84. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationStyles.d.ts +0 -0
  85. package/{components → dist/components}/navigation/MobileNavigation/MobileNavigationStyles.js +0 -0
  86. package/dist/components/navigation/MobileNavigation/MobileNavigationToggleSearchX.d.ts +3 -0
  87. package/dist/components/navigation/MobileNavigation/MobileNavigationToggleSearchX.js +28 -0
  88. package/dist/components/navigation/MobileNavigation/MobileNavigationToggleX.d.ts +3 -0
  89. package/dist/components/navigation/MobileNavigation/MobileNavigationToggleX.js +28 -0
  90. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigation.d.ts +0 -0
  91. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigation.js +18 -16
  92. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationAvatar.d.ts +0 -0
  93. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationAvatar.js +20 -25
  94. package/dist/components/navigation/VerticalNavigation/VerticalNavigationAvatarStyles.d.ts +3296 -0
  95. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationAvatarStyles.js +4 -4
  96. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItem.d.ts +0 -0
  97. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItem.js +5 -1
  98. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenu.d.ts +0 -0
  99. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenu.js +0 -0
  100. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenuStyles.d.ts +0 -0
  101. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenuStyles.js +0 -0
  102. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemStyles.d.ts +0 -0
  103. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemStyles.js +0 -0
  104. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationMotion.d.ts +0 -0
  105. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationMotion.js +0 -0
  106. package/dist/components/navigation/VerticalNavigation/VerticalNavigationStyles.d.ts +1163 -0
  107. package/{components → dist/components}/navigation/VerticalNavigation/VerticalNavigationStyles.js +3 -2
  108. package/{components → dist/components}/pages/ErrorPage/ErrorPage.d.ts +0 -0
  109. package/{components → dist/components}/pages/ErrorPage/ErrorPage.js +0 -0
  110. package/{components → dist/components}/pages/ErrorPage/ErrorPageStyles.d.ts +0 -0
  111. package/{components → dist/components}/pages/ErrorPage/ErrorPageStyles.js +0 -0
  112. package/{components → dist/components}/pages/SideInSide/SideInSide.d.ts +0 -0
  113. package/{components → dist/components}/pages/SideInSide/SideInSide.js +0 -0
  114. package/{components → dist/components}/pages/SideInSide/SideInSideStyles.d.ts +0 -0
  115. package/{components → dist/components}/pages/SideInSide/SideInSideStyles.js +0 -0
  116. package/{components → dist/components}/stream/AppSwitcher/AppSwitcher.d.ts +0 -0
  117. package/{components → dist/components}/stream/AppSwitcher/AppSwitcher.js +0 -0
  118. package/{components → dist/components}/stream/AppSwitcher/AppSwitcherItem.d.ts +0 -0
  119. package/{components → dist/components}/stream/AppSwitcher/AppSwitcherItem.js +0 -0
  120. package/{components → dist/components}/stream/AppSwitcher/AppSwitcherStyles.d.ts +0 -0
  121. package/{components → dist/components}/stream/AppSwitcher/AppSwitcherStyles.js +0 -0
  122. package/{components → dist/components}/stream/AppSwitcher/constants.d.ts +0 -0
  123. package/{components → dist/components}/stream/AppSwitcher/constants.js +0 -0
  124. package/{index.d.ts → dist/index.d.ts} +0 -0
  125. package/{index.js → dist/index.js} +0 -0
  126. package/{lang → dist/lang}/en-us.d.ts +0 -0
  127. package/{lang → dist/lang}/en-us.js +0 -0
  128. package/dist/package.json +41 -0
  129. package/{types → dist/types}/components/navigation/VerticalNavigation.d.ts +0 -0
  130. package/{types → dist/types}/components/navigation/VerticalNavigation.js +0 -0
  131. package/{types → dist/types}/components/navigation/VerticalNavigationAvatar.d.ts +1 -0
  132. package/{types → dist/types}/components/navigation/VerticalNavigationAvatar.js +0 -0
  133. package/{types → dist/types}/components/stream/AppSwitcher.d.ts +0 -0
  134. package/{types → dist/types}/components/stream/AppSwitcher.js +0 -0
  135. package/{types → dist/types}/index.d.ts +0 -0
  136. package/{types → dist/types}/index.js +0 -0
  137. package/{utils → dist/utils}/constants.d.ts +0 -0
  138. package/{utils → dist/utils}/constants.js +0 -0
  139. package/dist/utils/helpers.d.ts +21 -0
  140. package/dist/utils/helpers.js +64 -0
  141. package/{utils → dist/utils}/hooks.d.ts +0 -0
  142. package/{utils → dist/utils}/hooks.js +0 -0
  143. package/{utils → dist/utils}/index.d.ts +0 -0
  144. package/{utils → dist/utils}/index.js +0 -0
  145. package/{utils → dist/utils}/theme.d.ts +0 -0
  146. package/{utils → dist/utils}/theme.js +0 -0
  147. package/jest.config.ts +11 -0
  148. package/jest.setup.ts +5 -0
  149. package/{LICENSE → license} +0 -0
  150. package/merge.js +27 -0
  151. package/package.json +71 -4
  152. package/public/android-chrome-192x192.png +0 -0
  153. package/public/android-chrome-512x512.png +0 -0
  154. package/public/apple-touch-icon.png +0 -0
  155. package/public/assets/atoms.svg +5 -0
  156. package/public/assets/automation.svg +1 -0
  157. package/public/assets/avatar-1.jpg +0 -0
  158. package/public/assets/avatar-2.jpg +0 -0
  159. package/public/assets/avatar-3.jpg +0 -0
  160. package/public/assets/flux/icon-dark.svg +6 -0
  161. package/public/assets/flux/icon-light.svg +1 -0
  162. package/public/assets/flux/icon-white.svg +6 -0
  163. package/public/assets/flux/icon.svg +6 -0
  164. package/public/assets/flux/logo-dark.svg +22 -0
  165. package/public/assets/flux/logo-light.svg +1 -0
  166. package/public/assets/flux/logo-white.svg +22 -0
  167. package/public/assets/flux/logo.svg +22 -0
  168. package/public/assets/iPhone6.jpg +0 -0
  169. package/public/assets/iPhone6Plus.jpg +0 -0
  170. package/public/assets/lp-logo.png +0 -0
  171. package/public/assets/lplogo.svg +1 -0
  172. package/public/assets/molecules.svg +8 -0
  173. package/public/assets/organisms.svg +21 -0
  174. package/public/assets/pages.svg +4 -0
  175. package/public/assets/particles.svg +3 -0
  176. package/public/assets/stream-dark.png +0 -0
  177. package/public/assets/stream-suite-logo.svg +38 -0
  178. package/public/assets/stream-white.png +0 -0
  179. package/public/assets/stream.png +0 -0
  180. package/public/assets/templates.svg +3 -0
  181. package/public/favicon-16x16.png +0 -0
  182. package/public/favicon-32x32.png +0 -0
  183. package/public/favicon.ico +0 -0
  184. package/public/index.html +43 -0
  185. package/public/logo192.png +0 -0
  186. package/public/logo512.png +0 -0
  187. package/public/manifest.json +25 -0
  188. package/public/robots.txt +3 -0
  189. package/public/site.webmanifest +1 -0
  190. package/{README.md → readme.md} +0 -0
  191. package/src/docs.tsx +167 -0
  192. package/src/lib/assets/Images.tsx +47 -0
  193. package/src/lib/assets/stream-suite-logo.svg +38 -0
  194. package/src/lib/components/atoms/Autocomplete/Autocomplete.test.tsx +179 -0
  195. package/src/lib/components/atoms/Autocomplete/Autocomplete.tsx +14 -0
  196. package/src/lib/components/atoms/Button/Button.test.tsx +166 -0
  197. package/src/lib/components/atoms/Button/Button.tsx +16 -0
  198. package/src/lib/components/atoms/Checkbox/Checkbox.test.tsx +85 -0
  199. package/src/lib/components/atoms/Checkbox/Checkbox.tsx +10 -0
  200. package/src/lib/components/atoms/IconButton/IconButton.test.tsx +60 -0
  201. package/src/lib/components/atoms/IconButton/IconButton.tsx +9 -0
  202. package/src/lib/components/atoms/Radio/Radio.test.tsx +136 -0
  203. package/src/lib/components/atoms/Radio/Radio.tsx +10 -0
  204. package/src/lib/components/atoms/Select/Select.test.tsx +158 -0
  205. package/src/lib/components/atoms/Select/Select.tsx +12 -0
  206. package/src/lib/components/atoms/Slider/Slider.test.tsx +103 -0
  207. package/src/lib/components/atoms/Slider/Slider.tsx +10 -0
  208. package/src/lib/components/atoms/Switch/Switch.test.tsx +96 -0
  209. package/src/lib/components/atoms/Switch/Switch.tsx +10 -0
  210. package/src/lib/components/atoms/TextField/TextField.test.tsx +131 -0
  211. package/src/lib/components/atoms/TextField/TextField.tsx +31 -0
  212. package/src/lib/components/atoms/ToggleButton/ToggleButton.test.tsx +122 -0
  213. package/src/lib/components/atoms/ToggleButton/ToggleButton.tsx +10 -0
  214. package/src/lib/components/datadisplay/Avatar/Avatar.test.tsx +187 -0
  215. package/src/lib/components/datadisplay/Avatar/Avatar.tsx +35 -0
  216. package/src/lib/components/datadisplay/Avatar/avatar-1.jpg +0 -0
  217. package/src/lib/components/datadisplay/Chip/Chip.test.tsx +82 -0
  218. package/src/lib/components/datadisplay/Chip/Chip.tsx +11 -0
  219. package/src/lib/components/datadisplay/List/List.test.tsx +168 -0
  220. package/src/lib/components/datadisplay/List/List.tsx +8 -0
  221. package/src/lib/components/datadisplay/Tooltip/Tooltip.test.tsx +98 -0
  222. package/src/lib/components/datadisplay/Tooltip/Tooltip.tsx +9 -0
  223. package/src/lib/components/feedback/Alert/Alert.test.tsx +139 -0
  224. package/src/lib/components/feedback/Alert/Alert.tsx +10 -0
  225. package/src/lib/components/landmarks/Header/Header.tsx +140 -0
  226. package/src/lib/components/landmarks/Header/HeaderActionButtons.tsx +117 -0
  227. package/src/lib/components/landmarks/Header/HeaderStyles.tsx +62 -0
  228. package/src/lib/components/navigation/Drawer/Drawer.test.tsx +95 -0
  229. package/src/lib/components/navigation/Drawer/Drawer.tsx +21 -0
  230. package/src/lib/components/navigation/MobileNavigation/MobileNavigation.tsx +276 -0
  231. package/src/lib/components/navigation/MobileNavigation/MobileNavigationAvatar.tsx +334 -0
  232. package/src/lib/components/navigation/MobileNavigation/MobileNavigationAvatarStyles.tsx +77 -0
  233. package/src/lib/components/navigation/MobileNavigation/MobileNavigationDrawer.tsx +197 -0
  234. package/src/lib/components/navigation/MobileNavigation/MobileNavigationDrawerStyles.tsx +143 -0
  235. package/src/lib/components/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItem.tsx +192 -0
  236. package/src/lib/components/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenu.tsx +67 -0
  237. package/src/lib/components/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemFlyoutMenuStyles.tsx +192 -0
  238. package/src/lib/components/navigation/MobileNavigation/MobileNavigationItem/MobileNavigationItemStyles.tsx +217 -0
  239. package/src/lib/components/navigation/MobileNavigation/MobileNavigationMotion.tsx +119 -0
  240. package/src/lib/components/navigation/MobileNavigation/MobileNavigationNotchIndicator.tsx +35 -0
  241. package/src/lib/components/navigation/MobileNavigation/MobileNavigationSearch.tsx +114 -0
  242. package/src/lib/components/navigation/MobileNavigation/MobileNavigationSearchStyles.tsx +47 -0
  243. package/src/lib/components/navigation/MobileNavigation/MobileNavigationStyles.tsx +320 -0
  244. package/src/lib/components/navigation/MobileNavigation/MobileNavigationToggleSearchX.tsx +59 -0
  245. package/src/lib/components/navigation/MobileNavigation/MobileNavigationToggleX.tsx +51 -0
  246. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigation.tsx +467 -0
  247. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationAvatar.tsx +208 -0
  248. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationAvatarStyles.tsx +75 -0
  249. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItem.tsx +196 -0
  250. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenu.tsx +94 -0
  251. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemFlyoutMenuStyles.tsx +212 -0
  252. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationItem/VerticalNavigationItemStyles.tsx +240 -0
  253. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationMotion.tsx +119 -0
  254. package/src/lib/components/navigation/VerticalNavigation/VerticalNavigationStyles.tsx +303 -0
  255. package/src/lib/components/pages/ErrorPage/ErrorPage.test.tsx +78 -0
  256. package/src/lib/components/pages/ErrorPage/ErrorPage.tsx +50 -0
  257. package/src/lib/components/pages/ErrorPage/ErrorPageStyles.tsx +30 -0
  258. package/src/lib/components/pages/SideInSide/SideInSide.tsx +100 -0
  259. package/src/lib/components/pages/SideInSide/SideInSideStyles.tsx +62 -0
  260. package/src/lib/components/stream/AppSwitcher/AppSwitcher.tsx +392 -0
  261. package/src/lib/components/stream/AppSwitcher/AppSwitcherItem.tsx +83 -0
  262. package/src/lib/components/stream/AppSwitcher/AppSwitcherStyles.tsx +325 -0
  263. package/src/lib/components/stream/AppSwitcher/constants.tsx +28 -0
  264. package/src/lib/index.tsx +148 -0
  265. package/src/lib/lang/en-us.js +6 -0
  266. package/src/lib/types/components/navigation/VerticalNavigation.ts +52 -0
  267. package/src/lib/types/components/navigation/VerticalNavigationAvatar.ts +26 -0
  268. package/src/lib/types/components/stream/AppSwitcher.ts +10 -0
  269. package/src/lib/types/index.ts +9 -0
  270. package/src/lib/utils/constants.tsx +11 -0
  271. package/src/lib/utils/helpers.tsx +77 -0
  272. package/src/lib/utils/hooks.tsx +33 -0
  273. package/src/lib/utils/index.tsx +4 -0
  274. package/src/lib/utils/theme.tsx +79 -0
  275. package/src/react-app-env.d.ts +1 -0
  276. package/src/setupTests.ts +5 -0
  277. package/src/stories/Components/DataDisplay/Avatar/Accessibility.stories.mdx +34 -0
  278. package/src/stories/Components/DataDisplay/Avatar/AllCombinations.tsx +56 -0
  279. package/src/stories/Components/DataDisplay/Avatar/Avatar.stories.tsx +19 -0
  280. package/src/stories/Components/DataDisplay/Avatar/Examples.stories.tsx +278 -0
  281. package/src/stories/Components/DataDisplay/Avatar/Overview.stories.mdx +47 -0
  282. package/src/stories/Components/DataDisplay/Chip/Accessibility.stories.mdx +29 -0
  283. package/src/stories/Components/DataDisplay/Chip/AllCombinations.tsx +58 -0
  284. package/src/stories/Components/DataDisplay/Chip/Chip.stories.tsx +21 -0
  285. package/src/stories/Components/DataDisplay/Chip/Examples.stories.tsx +126 -0
  286. package/src/stories/Components/DataDisplay/Chip/Overview.stories.mdx +57 -0
  287. package/src/stories/Components/DataDisplay/List/Accessibility.stories.mdx +54 -0
  288. package/src/stories/Components/DataDisplay/List/AllCombinations.tsx +396 -0
  289. package/src/stories/Components/DataDisplay/List/Examples.stories.tsx +501 -0
  290. package/src/stories/Components/DataDisplay/List/List.stories.tsx +35 -0
  291. package/src/stories/Components/DataDisplay/List/Overview.stories.mdx +69 -0
  292. package/src/stories/Components/DataDisplay/Table/Overview.stories.mdx +70 -0
  293. package/src/stories/Components/DataDisplay/Tooltip/Accessibility.stories.mdx +39 -0
  294. package/src/stories/Components/DataDisplay/Tooltip/AllCombinations.tsx +134 -0
  295. package/src/stories/Components/DataDisplay/Tooltip/Examples.stories.tsx +237 -0
  296. package/src/stories/Components/DataDisplay/Tooltip/Overview.stories.mdx +58 -0
  297. package/src/stories/Components/DataDisplay/Tooltip/Tooltip.stories.tsx +22 -0
  298. package/src/stories/Components/Feedback/Alert/Accessibility.stories.mdx +25 -0
  299. package/src/stories/Components/Feedback/Alert/Alert.stories.tsx +22 -0
  300. package/src/stories/Components/Feedback/Alert/AllCombinations.tsx +37 -0
  301. package/src/stories/Components/Feedback/Alert/Examples.stories.tsx +137 -0
  302. package/src/stories/Components/Feedback/Alert/Overview.stories.mdx +62 -0
  303. package/src/stories/Components/Inputs/Autocomplete/Accessibility.stories.mdx +31 -0
  304. package/src/stories/Components/Inputs/Autocomplete/AllCombinations.tsx +182 -0
  305. package/src/stories/Components/Inputs/Autocomplete/Autocomplete.stories.tsx +31 -0
  306. package/src/stories/Components/Inputs/Autocomplete/Examples.stories.tsx +233 -0
  307. package/src/stories/Components/Inputs/Autocomplete/Overview.stories.mdx +52 -0
  308. package/src/stories/Components/Inputs/Button/Accessibility.stories.mdx +52 -0
  309. package/src/stories/Components/Inputs/Button/AllCombinations.tsx +53 -0
  310. package/src/stories/Components/Inputs/Button/Button.stories.tsx +23 -0
  311. package/src/stories/Components/Inputs/Button/Examples.stories.tsx +190 -0
  312. package/src/stories/Components/Inputs/Button/Overview.stories.mdx +52 -0
  313. package/src/stories/Components/Inputs/Checkbox/Accessibility.stories.mdx +38 -0
  314. package/src/stories/Components/Inputs/Checkbox/AllCombinations.tsx +55 -0
  315. package/src/stories/Components/Inputs/Checkbox/Checkbox.stories.tsx +22 -0
  316. package/src/stories/Components/Inputs/Checkbox/Examples.stories.tsx +363 -0
  317. package/src/stories/Components/Inputs/Checkbox/Overview.stories.mdx +63 -0
  318. package/src/stories/Components/Inputs/IconButton/Examples.stories.tsx +24 -0
  319. package/src/stories/Components/Inputs/IconButton/IconButton.stories.tsx +26 -0
  320. package/src/stories/Components/Inputs/Radio/Accessibility.stories.mdx +61 -0
  321. package/src/stories/Components/Inputs/Radio/AllCombinations.tsx +75 -0
  322. package/src/stories/Components/Inputs/Radio/Examples.stories.tsx +333 -0
  323. package/src/stories/Components/Inputs/Radio/Overview.stories.mdx +74 -0
  324. package/src/stories/Components/Inputs/Radio/Radio.stories.tsx +22 -0
  325. package/src/stories/Components/Inputs/Select/Accessibility.stories.mdx +51 -0
  326. package/src/stories/Components/Inputs/Select/AllCombinations.tsx +63 -0
  327. package/src/stories/Components/Inputs/Select/Examples.stories.tsx +803 -0
  328. package/src/stories/Components/Inputs/Select/Overview.stories.mdx +73 -0
  329. package/src/stories/Components/Inputs/Select/Select.stories.tsx +22 -0
  330. package/src/stories/Components/Inputs/Slider/Accessibility.stories.mdx +43 -0
  331. package/src/stories/Components/Inputs/Slider/AllCombinations.tsx +30 -0
  332. package/src/stories/Components/Inputs/Slider/Examples.stories.tsx +146 -0
  333. package/src/stories/Components/Inputs/Slider/Overview.stories.mdx +59 -0
  334. package/src/stories/Components/Inputs/Slider/Slider.stories.tsx +27 -0
  335. package/src/stories/Components/Inputs/Switch/Accessibility.stories.mdx +34 -0
  336. package/src/stories/Components/Inputs/Switch/AllCombinations.tsx +45 -0
  337. package/src/stories/Components/Inputs/Switch/Examples.stories.tsx +213 -0
  338. package/src/stories/Components/Inputs/Switch/Overview.stories.mdx +62 -0
  339. package/src/stories/Components/Inputs/Switch/Switch.stories.tsx +22 -0
  340. package/src/stories/Components/Inputs/TextField/Accessibility.stories.mdx +29 -0
  341. package/src/stories/Components/Inputs/TextField/AllCombinations.tsx +57 -0
  342. package/src/stories/Components/Inputs/TextField/Examples.stories.tsx +127 -0
  343. package/src/stories/Components/Inputs/TextField/Overview.stories.mdx +60 -0
  344. package/src/stories/Components/Inputs/TextField/TextField.stories.tsx +261 -0
  345. package/src/stories/Components/Inputs/ToggleButton/Accessibility.stories.mdx +32 -0
  346. package/src/stories/Components/Inputs/ToggleButton/AllCombinations.tsx +113 -0
  347. package/src/stories/Components/Inputs/ToggleButton/Examples.stories.tsx +339 -0
  348. package/src/stories/Components/Inputs/ToggleButton/Overview.stories.mdx +55 -0
  349. package/src/stories/Components/Inputs/ToggleButton/ToggleButton.stories.tsx +19 -0
  350. package/src/stories/Components/Landmarks/Header/Examples.stories.tsx +197 -0
  351. package/src/stories/Components/Landmarks/Header/Header.stories.tsx +34 -0
  352. package/src/stories/Components/Landmarks/Header/Overview.stories.mdx +44 -0
  353. package/src/stories/Components/Navigation/Drawer/Accessibility.stories.mdx +13 -0
  354. package/src/stories/Components/Navigation/Drawer/Drawer.stories.tsx +80 -0
  355. package/src/stories/Components/Navigation/Drawer/Examples.stories.tsx +440 -0
  356. package/src/stories/Components/Navigation/Drawer/Overview.stories.mdx +43 -0
  357. package/src/stories/Components/Navigation/MobileNavigation/Accessibility.stories.mdx +14 -0
  358. package/src/stories/Components/Navigation/MobileNavigation/Examples.stories.tsx +384 -0
  359. package/src/stories/Components/Navigation/MobileNavigation/MobileNavigation.stories.tsx +24 -0
  360. package/src/stories/Components/Navigation/MobileNavigation/Overview.stories.mdx +47 -0
  361. package/src/stories/Components/Navigation/VerticalNavigation/Accessibility.stories.mdx +14 -0
  362. package/src/stories/Components/Navigation/VerticalNavigation/Examples.stories.tsx +307 -0
  363. package/src/stories/Components/Navigation/VerticalNavigation/Overview.stories.mdx +47 -0
  364. package/src/stories/Components/Navigation/VerticalNavigation/VerticalNavigation.stories.tsx +24 -0
  365. package/src/stories/ContactUs.stories.mdx +21 -0
  366. package/src/stories/Experimental/Test.stories.mdx +46 -0
  367. package/src/stories/GettingStarted/Designer.stories.mdx +86 -0
  368. package/src/stories/GettingStarted/Developer.stories.mdx +134 -0
  369. package/src/stories/Guidelines/Accessibility/AssistiveTechnology.stories.mdx +70 -0
  370. package/src/stories/Guidelines/Accessibility/ColorAndContrast.stories.mdx +109 -0
  371. package/src/stories/Guidelines/Accessibility/Hierarchy.stories.mdx +119 -0
  372. package/src/stories/Guidelines/Accessibility/Imagery.stories.mdx +136 -0
  373. package/src/stories/Guidelines/Accessibility/Overview.stories.mdx +44 -0
  374. package/src/stories/Guidelines/Accessibility/Principles.stories.mdx +156 -0
  375. package/src/stories/Guidelines/Accessibility/SoundAndMotion.stories.mdx +59 -0
  376. package/src/stories/Guidelines/Accessibility/Typography.stories.mdx +69 -0
  377. package/src/stories/Guidelines/Accessibility/Writing.stories.mdx +188 -0
  378. package/src/stories/Guidelines/Styleguide/ColorSwatch.tsx +53 -0
  379. package/src/stories/Guidelines/Styleguide/Colors.stories.mdx +118 -0
  380. package/src/stories/Guidelines/Styleguide/Typography.stories.mdx +84 -0
  381. package/src/stories/Introduction.stories.mdx +65 -0
  382. package/src/stories/Pages/ErrorPage.stories.tsx +30 -0
  383. package/src/stories/Pages/SideInSide.stories.tsx +195 -0
  384. package/src/stories/Roadmap.stories.mdx +19 -0
  385. package/src/stories/Templates/Login.stories.mdx +46 -0
  386. package/src/stories/assets/Atomic_Design_Icons-Dark.svg +24 -0
  387. package/src/stories/assets/Atomic_Design_Icons-Light.svg +25 -0
  388. package/src/stories/assets/accessibility-1.png +0 -0
  389. package/src/stories/assets/accessibility-2.png +0 -0
  390. package/src/stories/assets/accessibility-3.png +0 -0
  391. package/src/stories/assets/accessibility-banner.png +0 -0
  392. package/src/stories/assets/atoms.svg +6 -0
  393. package/src/stories/assets/design_system_2022-02-11_12.22pm.png +0 -0
  394. package/src/stories/assets/figma-tokens.png +0 -0
  395. package/src/stories/assets/hierarchy-1.jpg +0 -0
  396. package/src/stories/assets/hierarchy-2.jpg +0 -0
  397. package/src/stories/assets/hierarchy-3.jpg +0 -0
  398. package/src/stories/assets/icon-contrast-1.jpg +0 -0
  399. package/src/stories/assets/icon-contrast-2.jpg +0 -0
  400. package/src/stories/assets/imagery-1.png +0 -0
  401. package/src/stories/assets/imagery-2.png +0 -0
  402. package/src/stories/assets/imagery-3.png +0 -0
  403. package/src/stories/assets/imagery-4.jpg +0 -0
  404. package/src/stories/assets/molecules.svg +9 -0
  405. package/src/stories/assets/organisms.svg +22 -0
  406. package/src/stories/assets/pages.svg +5 -0
  407. package/src/stories/assets/particles.svg +4 -0
  408. package/src/stories/assets/templates.svg +4 -0
  409. package/src/stories/assets/testData.tsx +102 -0
  410. package/src/stories/assets/text-contrast-1.jpg +0 -0
  411. package/src/stories/assets/text-contrast-2.jpg +0 -0
  412. package/src/stories/assets/typography-1.png +0 -0
  413. package/src/stories/assets/visual-clues-1.png +0 -0
  414. package/src/stories/assets/visual-clues-2.png +0 -0
  415. package/src/stories/assets/writing-1.jpg +0 -0
  416. package/src/stories/assets/writing-2.png +0 -0
  417. package/src/stories/assets/writing-3.png +0 -0
  418. package/src/stories/assets/writing-4.png +0 -0
  419. package/src/stories/utils/CustomIcons.tsx +44 -0
  420. package/tsconfig.eslint.json +16 -0
  421. package/tsconfig.json +50 -0
  422. package/components/navigation/MobileNavigation/MobileNavigationAvatarStyles.d.ts +0 -827
  423. package/components/navigation/MobileNavigation/MobileNavigationDrawer.js +0 -147
  424. package/components/navigation/MobileNavigation/MobileNavigationDrawerStyles.d.ts +0 -392
  425. package/components/navigation/MobileNavigation/MobileNavigationNotchIndicator.d.ts +0 -3
  426. package/components/navigation/MobileNavigation/MobileNavigationNotchIndicator.js +0 -31
  427. package/components/navigation/MobileNavigation/MobileNavigationSearchStyles.d.ts +0 -257
  428. package/components/navigation/MobileNavigation/MobileNavigationToggleSearchX.d.ts +0 -3
  429. package/components/navigation/MobileNavigation/MobileNavigationToggleSearchX.js +0 -33
  430. package/components/navigation/MobileNavigation/MobileNavigationToggleX.d.ts +0 -3
  431. package/components/navigation/MobileNavigation/MobileNavigationToggleX.js +0 -27
  432. package/components/navigation/MobileNavigation/MobileNavigationToggleXStyles.d.ts +0 -36
  433. package/components/navigation/MobileNavigation/MobileNavigationToggleXStyles.js +0 -10
  434. package/components/navigation/VerticalNavigation/VerticalNavigationAvatarStyles.d.ts +0 -827
  435. package/components/navigation/VerticalNavigation/VerticalNavigationStyles.d.ts +0 -88
  436. package/utils/helpers.d.ts +0 -6
  437. package/utils/helpers.js +0 -17
@@ -0,0 +1,197 @@
1
+ import * as React from 'react'
2
+ import { useTheme } from '@mui/material/styles'
3
+ import { List, ListItemText } from '../../../index'
4
+ import {
5
+ StyledSwipeableDrawer, StyledBox, StyledListItem, StyledDivider,
6
+ StyledListSecondaryItem, StyledDrawerLogo, StyledDrawerLogoText,
7
+ StyledListSecondaryList, StyledListItemText, StyledListSecondaryButton,
8
+ StyledChildList, StyledChildListItem, StyledChildListItemText,
9
+ StyledListItemButton, StyledChildListItemButton
10
+ } from './MobileNavigationDrawerStyles'
11
+ import { StreamSuiteLogo } from '../../../assets/Images'
12
+ import { animated } from '@react-spring/web'
13
+ import { useStaggerAnimation } from '../../../utils/helpers'
14
+
15
+ export interface IMobileNavigationItemProps {
16
+ label: string
17
+ onClick?: any
18
+ isActive?: boolean
19
+ children?: IMobileNavigationItemProps[]
20
+ isDrawerOpen?: boolean
21
+ index?: number
22
+ content?: React.ReactElement
23
+ style?: any
24
+ open?: boolean
25
+ }
26
+
27
+ export interface ISwipeableTemporaryDrawerProps {
28
+ isDrawerOpen: boolean
29
+ setIsDrawerOpen?: any
30
+ items?: IMobileNavigationItemProps[]
31
+ secondaryItems?: IMobileNavigationItemProps[]
32
+ logo?: string
33
+ logoText?: string
34
+ logoOnClick?: any
35
+ label: string
36
+ children?: ISwipeableTemporaryDrawerProps[]
37
+ }
38
+
39
+ export default function SwipeableTemporaryDrawer (props: ISwipeableTemporaryDrawerProps) {
40
+ const {
41
+ isDrawerOpen, setIsDrawerOpen, items, secondaryItems,
42
+ logo, logoText, logoOnClick
43
+ } = props
44
+ const theme = useTheme()
45
+ const [isOpen, setIsOpen] = React.useState(isDrawerOpen ?? false)
46
+
47
+ React.useEffect(() => handleOpenState(isDrawerOpen), [isDrawerOpen])
48
+
49
+ const handleOpenState = (open: boolean): void => {
50
+ setIsOpen(open)
51
+ setIsDrawerOpen(open)
52
+ }
53
+
54
+ const toggleDrawer =
55
+ (open: boolean) =>
56
+ (event: React.KeyboardEvent | React.MouseEvent) => {
57
+ if (event && event.type === 'keydown' &&
58
+ ((event as React.KeyboardEvent).key === 'Tab' ||
59
+ (event as React.KeyboardEvent).key === 'Shift')
60
+ ) {
61
+ return
62
+ }
63
+
64
+ handleOpenState(open)
65
+ }
66
+
67
+ // First item starts at 70ms
68
+ // see STAGGER_ITEMS_DELAY in helpers.js
69
+ let animationCount = 1
70
+ const incrementAnimationCount = () => animationCount++
71
+
72
+ const list = () => (
73
+ <StyledBox
74
+ onClick={toggleDrawer(false)}
75
+ onKeyDown={toggleDrawer(false)}
76
+ >
77
+ <StyledDrawerLogo
78
+ onClick={logoOnClick ?? null}
79
+ style={useStaggerAnimation(isDrawerOpen, animationCount, incrementAnimationCount)}
80
+ // whileHover={{ scale: 1.02 }}
81
+ // whileTap={{ scale: 0.95 }}
82
+ >
83
+ {logo
84
+ ? typeof logo === 'string'
85
+ ? (
86
+ <img
87
+ height={38}
88
+ width={38}
89
+ src={logo}
90
+ alt={logoText ?? 'Site Logo'}
91
+ />)
92
+ : logo
93
+ : (
94
+ <StreamSuiteLogo style={{
95
+ fill: theme.palette.mode === 'dark'
96
+ ? theme.palette.primary.main
97
+ : theme.palette.primary.main
98
+ }} />)}
99
+ <StyledDrawerLogoText variant='body1'>
100
+ {logoText ?? 'Site Logo'}
101
+ </StyledDrawerLogoText>
102
+ </StyledDrawerLogo>
103
+ <List>
104
+ {items && items.length > 0 && items.map((item, index) => {
105
+ const { label, children } = item
106
+
107
+ return (
108
+ <StyledListItem
109
+ key={label}
110
+ disablePadding
111
+ // @ts-expect-error
112
+ component={animated.li}
113
+ style={useStaggerAnimation(isDrawerOpen, animationCount, incrementAnimationCount)}
114
+ >
115
+ <StyledListItemButton
116
+ // whileHover={{ scale: 1.02 }}
117
+ // whileTap={{ scale: 0.95 }}
118
+ {...item}
119
+ // component={animated.button}
120
+ // onMouseEnter={() => set({ y: 0, color: '#000' })}
121
+ // onMouseLeave={() => set({ y: 100, color: '#fff' })}
122
+ // style={{
123
+ // y,
124
+ // color
125
+ // }}
126
+ >
127
+ <StyledListItemText primary={label} />
128
+ </StyledListItemButton>
129
+
130
+ {children && children.length > 0 && (
131
+ <StyledChildList aria-label={label}>
132
+ {children.map(childItem => (
133
+ <StyledChildListItem
134
+ key={childItem.label}
135
+ // whileHover={{ scale: 1.02 }}
136
+ // whileTap={{ scale: 0.95 }}
137
+ >
138
+ <StyledChildListItemButton
139
+ // whileHover={{ scale: 1.02 }}
140
+ // whileTap={{ scale: 0.95 }}
141
+ {...childItem}
142
+ >
143
+ <StyledChildListItemText key={childItem.label} primary={childItem.label} />
144
+ </StyledChildListItemButton>
145
+ </StyledChildListItem>
146
+ ))}
147
+ </StyledChildList>
148
+ )}
149
+ </StyledListItem>
150
+ )
151
+ })}
152
+ </List>
153
+ {secondaryItems && secondaryItems.length > 0 && (
154
+ <>
155
+ <animated.div style={useStaggerAnimation(isDrawerOpen, animationCount, incrementAnimationCount)}>
156
+ <StyledDivider/>
157
+ </animated.div>
158
+ <StyledListSecondaryList>
159
+ {secondaryItems && secondaryItems.length > 0 && secondaryItems.map((item, index) => (
160
+ <StyledListSecondaryItem
161
+ key={item.label}
162
+ disablePadding
163
+ // @ts-expect-error
164
+ component={animated.li}
165
+ style={useStaggerAnimation(isDrawerOpen, animationCount, incrementAnimationCount)}
166
+ >
167
+ <StyledListSecondaryButton
168
+ // whileHover={{ scale: 1.02 }}
169
+ // whileTap={{ scale: 0.95, boxShadow: '0 6px 15px rgb(36 37 38 / 0%);' }}
170
+ {...item}
171
+ >
172
+ <ListItemText primary={item.label} />
173
+ </StyledListSecondaryButton>
174
+ </StyledListSecondaryItem>
175
+ ))}
176
+ </StyledListSecondaryList>
177
+ </>
178
+ )}
179
+ </StyledBox>
180
+ )
181
+
182
+ return (
183
+ <aside>
184
+ <StyledSwipeableDrawer
185
+ anchor='bottom'
186
+ open={isOpen}
187
+ onClose={toggleDrawer(false)}
188
+ hideBackdrop
189
+ ModalProps={{
190
+ keepMounted: true
191
+ }}
192
+ >
193
+ {list()}
194
+ </StyledSwipeableDrawer>
195
+ </aside>
196
+ )
197
+ }
@@ -0,0 +1,143 @@
1
+ import {
2
+ Box, List, ListItem, ListItemText,
3
+ ListItemButton, Typography
4
+ } from '../../../index'
5
+ import { Drawer } from '@mui/material'
6
+ import { styled } from '@mui/material/styles'
7
+ import { animated } from '@react-spring/web'
8
+
9
+ export const StyledSwipeableDrawer = styled(Drawer)`
10
+ .MuiPaper-root {
11
+ background-color: ${props => props.theme.palette.mode === 'dark'
12
+ ? '#003366'
13
+ : props.theme.palette.background.paper};
14
+ background-image: ${props => props.theme.palette.mode === 'dark'
15
+ ? 'none'
16
+ : 'radial-gradient( circle farthest-corner at 10% 20%, #fdfbfb 0.1%, #ebedee 99.8% )'};
17
+ height: 100vh;
18
+ border: none;
19
+ z-index: 1;
20
+ }
21
+ `
22
+
23
+ export const StyledBox = styled(Box)`
24
+ height: 100%;
25
+ overflow: auto;
26
+ padding-bottom: 6rem;
27
+ `
28
+
29
+ export const StyledDrawerLogo = styled(animated.div)`
30
+ background-color: transparent;
31
+ display: flex;
32
+ align-items: center;
33
+ margin: 1.5rem 0 2.5rem 1.5rem;
34
+
35
+ .MuiSvgIcon-root {
36
+ width: 2rem;
37
+ height: 2rem;
38
+ }
39
+ `
40
+
41
+ export const StyledDrawerLogoText = styled(Typography)`
42
+ font-size: 1.2rem;
43
+ margin-left: .5rem;
44
+ color: ${props => props.theme.palette.mode === 'dark'
45
+ ? 'rgba(255,255,255,.9)'
46
+ : '#555'};
47
+ `
48
+
49
+ export const StyledListItem = styled(ListItem)`
50
+ flex-direction: column;
51
+ align-items: flex-start;
52
+ margin: 0 1rem;
53
+ max-width: calc(100% - 2rem);
54
+
55
+ > .MuiListItemButton-root {
56
+ padding: .5rem 1.5rem;
57
+ }
58
+ `
59
+
60
+ export const StyledListItemButton = styled(ListItemButton)`
61
+ border-radius: 50px;
62
+ `
63
+
64
+ export const StyledListItemText = styled(ListItemText)`
65
+ > .MuiTypography-root {
66
+ font-size: 1.5rem;
67
+ font-weight: bold;
68
+ color: ${props => props.theme.palette.mode === 'dark'
69
+ ? 'rgba(255,255,255,.85)'
70
+ : '#555'};
71
+ &:hover,
72
+ &:focus,
73
+ &:active {
74
+ color: ${props => props.theme.palette.mode === 'dark'
75
+ ? 'rgba(255,255,255,.97)'
76
+ : '#333'};
77
+ }
78
+ }
79
+ `
80
+
81
+ export const StyledChildList = styled(List)`
82
+ display: flex;
83
+ flex-wrap: wrap;
84
+ margin: -.25rem 1rem 0 1.5rem;
85
+ padding: 0;
86
+
87
+ `
88
+
89
+ export const StyledChildListItem = styled(ListItem)`
90
+ display: flex;
91
+ align-items: center;
92
+ padding: 0;
93
+ `
94
+
95
+ export const StyledChildListItemText = styled(ListItemText)`
96
+ font-size: .9rem;
97
+ color: ${props => props.theme.palette.mode === 'dark'
98
+ ? 'rgba(255,255,255,.75)'
99
+ : '#666'};
100
+ `
101
+
102
+ export const StyledChildListItemButton = styled(ListItemButton)`
103
+ border-radius: 50px;
104
+ flex-grow: 0;
105
+ `
106
+
107
+ export const StyledListSecondaryList = styled(List)`
108
+ display: flex;
109
+ flex-wrap: wrap;
110
+ margin: 0 1rem;
111
+ `
112
+
113
+ export const StyledListSecondaryItem = styled(ListItem)`
114
+ flex: 1 0 50%;
115
+ display: flex;
116
+ align-items: center;
117
+ `
118
+
119
+ export const StyledListSecondaryButton = styled(ListItemButton)`
120
+ color: ${props => props.theme.palette.mode === 'dark'
121
+ ? 'rgba(255,255,255,.8)'
122
+ : '#555'};
123
+ margin: 0.25rem 0.25rem 0.5rem;
124
+ padding: 0.3rem 1rem;
125
+ background: ${props => props.theme.palette.mode === 'dark'
126
+ ? 'rgba(255,255,255,.12)'
127
+ : 'rgba(255,255,255,.6)'};
128
+ border-radius: 50px;
129
+ box-shadow: ${props => props.theme.palette.mode === 'dark'
130
+ ? '0 6px 15px rgb(36 37 38 / 16%)'
131
+ : '0 6px 15px rgb(36 37 38 / 8%)'};
132
+ `
133
+
134
+ export const StyledDivider = styled('div')`
135
+ background-color: ${props => props.theme.palette.mode === 'dark'
136
+ ? 'rgba(62, 106, 179, .5)'
137
+ : 'rgba(0,0,0,.075)'};
138
+ width: 75%;
139
+ height: 3px;
140
+ border: none;
141
+ border-radius: 3px;
142
+ margin: 2rem auto;
143
+ `
@@ -0,0 +1,192 @@
1
+ import React from 'react'
2
+ import { useTheme } from '@mui/material/styles'
3
+ import {
4
+ Link, List, Tooltip, Collapse
5
+ } from '../../../../index'
6
+ import MailIcon from '@mui/icons-material/Mail'
7
+ import {
8
+ ListItem, ListItemButton, ListItemButtonChild,
9
+ ListItemIcon, ListItemText
10
+ } from './MobileNavigationItemStyles'
11
+ import { tooltipDelay } from '../../../../utils/theme'
12
+ import MobileNavigationItemFlyoutMenu from './MobileNavigationItemFlyoutMenu'
13
+
14
+ export interface IMobileNavigationItemProps {
15
+ label: string
16
+ icon: React.ReactElement
17
+ selectedIcon?: React.ReactElement
18
+ onClick?: any
19
+ isActive?: boolean
20
+ children?: IMobileNavigationItemProps[]
21
+ isDrawerOpen?: boolean
22
+ index?: number
23
+ isSecondary?: boolean
24
+ hasFlyout?: boolean
25
+ fullHeightFlyout?: boolean
26
+ content?: React.ReactElement
27
+ style?: any
28
+ open?: boolean
29
+ }
30
+
31
+ const MobileNavigationItem = (
32
+ props: IMobileNavigationItemProps
33
+ ): React.ReactElement => {
34
+ const theme = useTheme()
35
+ const {
36
+ label, icon, onClick, isActive, children, isDrawerOpen,
37
+ index, hasFlyout, fullHeightFlyout, isSecondary,
38
+ content, style, ...rest
39
+ } = props
40
+ const [isExpanded, setIsExpanded] = React.useState(false)
41
+ const [anchorEl, setAnchorEl] = React.useState<null | HTMLElement>(null)
42
+ const open = Boolean(anchorEl)
43
+ const handlePopoverOpen = (event: (React.MouseEvent<HTMLElement> | any)): void => {
44
+ if (open) {
45
+ handlePopoverClose()
46
+ return
47
+ }
48
+
49
+ setAnchorEl(event?.currentTarget)
50
+ }
51
+
52
+ const handlePopoverClose = (): void => {
53
+ setAnchorEl(null)
54
+ }
55
+
56
+ const handleClick = (event: (React.MouseEvent<HTMLElement> | any)): void => {
57
+ if (fullHeightFlyout) {
58
+ handlePopoverOpen(event)
59
+ return
60
+ }
61
+
62
+ if (children && children.length > 0) {
63
+ setIsExpanded(!isExpanded)
64
+ return
65
+ }
66
+
67
+ if (onClick) {
68
+ onClick(event)
69
+ }
70
+
71
+ setAnchorEl(null)
72
+ }
73
+
74
+ return (
75
+ <ListItem
76
+ disablePadding
77
+ style={style}
78
+ {...rest}
79
+ isDrawerOpen={isDrawerOpen}
80
+ >
81
+ <ListItemButton
82
+ // @ts-expect-error
83
+ component={Link}
84
+ key={label}
85
+ onClick={handleClick}
86
+ isActive={isActive}
87
+ isDrawerOpen={isDrawerOpen}
88
+ isExpanded={isExpanded}
89
+ open={open}
90
+ onMouseEnter={event => fullHeightFlyout
91
+ ? null
92
+ : handlePopoverOpen(event)}
93
+ onMouseLeave={() => fullHeightFlyout
94
+ ? null
95
+ : handlePopoverClose()}
96
+ onFocus={event => fullHeightFlyout
97
+ ? null
98
+ : handlePopoverOpen(event)}
99
+ onBlur={() => fullHeightFlyout
100
+ ? null
101
+ : handlePopoverClose()}
102
+ aria-expanded={(children && children.length > 0) ? open : null}
103
+ aria-haspopup={(children && children.length > 0) ? 'true' : null}
104
+ aria-current={isActive ? 'page' : null}
105
+ role={(children && children.length > 0) ? 'button' : 'link'}
106
+ >
107
+ <Tooltip
108
+ disableHoverListener={(children && children.length > 0) ?? isDrawerOpen}
109
+ disableFocusListener={(children && children.length > 0) ?? isDrawerOpen}
110
+ disableTouchListener={(children && children.length > 0) ?? isDrawerOpen}
111
+ title={label}
112
+ placement={theme.direction === 'rtl' ? 'left' : 'right'}
113
+ enterDelay={tooltipDelay.start}
114
+ leaveDelay={tooltipDelay.end}
115
+ >
116
+ <ListItemIcon aria-hidden={true}>
117
+ {icon ?? <MailIcon />}
118
+ </ListItemIcon>
119
+ </Tooltip>
120
+ <ListItemText
121
+ primary={label}
122
+ isDrawerOpen={isDrawerOpen}
123
+ index={index}
124
+ sx={{
125
+ '& .MuiTypography-root': {
126
+ fontSize: isSecondary ? '14px' : 'inherit'
127
+ }
128
+ }}
129
+ />
130
+ {children && children.length > 0 && (
131
+ <Collapse component='div' in={isDrawerOpen ? isExpanded : false} timeout="auto">
132
+ <List
133
+ aria-label={label}
134
+ disablePadding
135
+ >
136
+ {children.map((childItem, index) => (
137
+ <ListItem
138
+ disablePadding
139
+ isDrawerOpen={isDrawerOpen}
140
+ >
141
+ <ListItemButtonChild
142
+ // @ts-expect-error
143
+ component={Link}
144
+ key={label}
145
+ index={index}
146
+ isDrawerOpen={isDrawerOpen}
147
+ >
148
+ <ListItemIcon>{childItem.icon}</ListItemIcon>
149
+ <ListItemText
150
+ primary={childItem.label}
151
+ isDrawerOpen={isDrawerOpen}
152
+ sx={{
153
+ '& .MuiTypography-root': {
154
+ fontSize: '14px !important',
155
+ color: theme.palette.mode === 'dark'
156
+ ? theme.palette.primary.contrastText
157
+ : theme.palette.getContrastText(theme.palette.background.paper)
158
+ }
159
+ }}
160
+ />
161
+ </ListItemButtonChild>
162
+ </ListItem>
163
+ ))}
164
+ </List>
165
+ </Collapse>
166
+ )}
167
+ </ListItemButton>
168
+
169
+ {!fullHeightFlyout && children && children.length > 0 && (!isExpanded || !isDrawerOpen) && (
170
+ <MobileNavigationItemFlyoutMenu
171
+ isDrawerOpen={isDrawerOpen}
172
+ anchorEl={anchorEl}
173
+ open={open}
174
+ children={children}
175
+ label={label}
176
+ />
177
+ )}
178
+
179
+ {fullHeightFlyout && content && (
180
+ <MobileNavigationItemFlyoutMenu
181
+ isDrawerOpen={isDrawerOpen}
182
+ fullHeightFlyout
183
+ anchorEl={anchorEl}
184
+ open={open}
185
+ content={content}
186
+ />
187
+ )}
188
+ </ListItem>
189
+ )
190
+ }
191
+
192
+ export default MobileNavigationItem
@@ -0,0 +1,67 @@
1
+ import React from 'react'
2
+ import { Link, ListItemText } from '../../../../index'
3
+ import { IMobileNavigationItemProps } from './MobileNavigationItem'
4
+ import {
5
+ FlyoutMenuPaper,
6
+ FlyoutMenuWrap,
7
+ FlyoutMenuList,
8
+ FlyoutMenuButton,
9
+ FlyoutMenuItem
10
+ } from './MobileNavigationItemFlyoutMenuStyles'
11
+ export interface IMobileNavigationItemFlyoutMenuProps {
12
+ label?: string
13
+ children?: IMobileNavigationItemProps[]
14
+ isDrawerOpen?: boolean
15
+ hasFlyout?: boolean
16
+ content?: React.ReactElement
17
+ style?: any
18
+
19
+ fullHeightFlyout?: boolean
20
+ anchorEl?: null | HTMLElement
21
+ open?: boolean
22
+ }
23
+
24
+ const MobileNavigationItemFlyoutMenu = (
25
+ props: IMobileNavigationItemFlyoutMenuProps
26
+ ): React.ReactElement => {
27
+ const {
28
+ label, children, isDrawerOpen, anchorEl
29
+ } = props
30
+ const [flyoutHovered, setFlyoutHovered] = React.useState(false)
31
+ const open = flyoutHovered || props?.open
32
+
33
+ return (
34
+ <FlyoutMenuPaper
35
+ isDrawerOpen={isDrawerOpen}
36
+ open={open}
37
+ anchorEl={anchorEl ?? undefined}
38
+ onMouseEnter={() => setFlyoutHovered(true)}
39
+ onMouseLeave={() => setFlyoutHovered(false)}
40
+ onFocus={() => setFlyoutHovered(true)}
41
+ onBlur={() => setFlyoutHovered(false)}
42
+ >
43
+ <FlyoutMenuWrap open={open}>
44
+ <FlyoutMenuList
45
+ aria-label={label}
46
+ open={open}
47
+ >
48
+ {children?.map(childItem => (
49
+ <FlyoutMenuItem>
50
+ <FlyoutMenuButton
51
+ // @ts-expect-error
52
+ component={Link}
53
+ key={childItem.label}
54
+ onClick={childItem.onClick}
55
+ role='link'
56
+ >
57
+ <ListItemText primary={childItem.label} />
58
+ </FlyoutMenuButton>
59
+ </FlyoutMenuItem>
60
+ ))}
61
+ </FlyoutMenuList>
62
+ </FlyoutMenuWrap>
63
+ </FlyoutMenuPaper>
64
+ )
65
+ }
66
+
67
+ export default MobileNavigationItemFlyoutMenu