@ebubekirylmaz/link-test 1.0.0

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 (409) hide show
  1. package/.babelrc +3 -0
  2. package/.browserslistrc +1 -0
  3. package/.env +2 -0
  4. package/.eslintignore +3 -0
  5. package/.eslintrc.json +58 -0
  6. package/.gitattributes +1 -0
  7. package/.github/workflows/publish.yml +66 -0
  8. package/.prettierignore +1 -0
  9. package/.prettierrc +10 -0
  10. package/.storybook/main.js +15 -0
  11. package/.storybook/preview.js +17 -0
  12. package/.storybook/vitest.setup.js +6 -0
  13. package/README.md +1 -0
  14. package/cypress.config.js +11 -0
  15. package/index.js +1 -0
  16. package/package.json +111 -0
  17. package/project/.eslintrc.cjs +22 -0
  18. package/project/config.js +18 -0
  19. package/project/config.menu.js +39 -0
  20. package/project/config.template.js +31 -0
  21. package/project/cypress/e2e/layouts.cy.js +170 -0
  22. package/project/cypress/e2e/login.cy.js +35 -0
  23. package/project/cypress/e2e/selectbar.cy.js +80 -0
  24. package/project/cypress/fixtures/CONFIG/MENU_CONFIG.js +39 -0
  25. package/project/cypress/fixtures/EMPEROR/EMPERORS_GET.json +51 -0
  26. package/project/cypress/fixtures/EMPEROR/EMPERORS_POST.json +9 -0
  27. package/project/cypress/fixtures/OAUTH/GITHUB/user.json +46 -0
  28. package/project/cypress/fixtures/example.json +5 -0
  29. package/project/cypress/support/commands.js +104 -0
  30. package/project/cypress/support/e2e.js +1 -0
  31. package/project/cypress.config.js +10 -0
  32. package/project/index.html +12 -0
  33. package/project/media/ProjectIcons/3d.png +0 -0
  34. package/project/media/ProjectIcons/box.png +0 -0
  35. package/project/media/ProjectIcons/cafe.png +0 -0
  36. package/project/media/ProjectIcons/cargo.png +0 -0
  37. package/project/media/ProjectIcons/cloud.png +0 -0
  38. package/project/media/ProjectIcons/code.png +0 -0
  39. package/project/media/ProjectIcons/company.png +0 -0
  40. package/project/media/ProjectIcons/conversation.png +0 -0
  41. package/project/media/ProjectIcons/distributed.png +0 -0
  42. package/project/media/ProjectIcons/fingerprint.png +0 -0
  43. package/project/media/ProjectIcons/forest.png +0 -0
  44. package/project/media/ProjectIcons/headphones.png +0 -0
  45. package/project/media/ProjectIcons/office.png +0 -0
  46. package/project/media/ProjectIcons/path.png +0 -0
  47. package/project/media/ProjectIcons/printer.png +0 -0
  48. package/project/media/ProjectIcons/project.png +0 -0
  49. package/project/media/ProjectIcons/resume.png +0 -0
  50. package/project/media/ProjectIcons/rocket.png +0 -0
  51. package/project/media/ProjectIcons/rtruck.png +0 -0
  52. package/project/media/ProjectIcons/sign.png +0 -0
  53. package/project/media/ProjectIcons/site.png +0 -0
  54. package/project/media/ProjectIcons/truck.png +0 -0
  55. package/project/media/logo.png +0 -0
  56. package/project/package-lock.json +22434 -0
  57. package/project/package.json +42 -0
  58. package/project/public/assets/background/overlay_2.jpg +0 -0
  59. package/project/public/assets/illustrations/illustration_dashboard.png +0 -0
  60. package/project/public/media/largeLogo.png +0 -0
  61. package/project/public/media/logo.png +0 -0
  62. package/project/public/vite.svg +1 -0
  63. package/project/routes.jsx +47 -0
  64. package/project/server/mock.json +110 -0
  65. package/project/server/oauthMock.js +27 -0
  66. package/project/server/package-lock.json +1505 -0
  67. package/project/server/package.json +20 -0
  68. package/project/server/server.js +127 -0
  69. package/project/src/Container.jsx +7 -0
  70. package/project/src/components/ActionButton.jsx +18 -0
  71. package/project/src/hooks/useEmperor.jsx +21 -0
  72. package/project/src/http/index.js +39 -0
  73. package/project/src/main.jsx +10 -0
  74. package/project/src/pages/Battles.jsx +16 -0
  75. package/project/src/pages/Emperor.jsx +50 -0
  76. package/project/src/pages/index.jsx +33 -0
  77. package/project/src/theme.js +151 -0
  78. package/project/src/widgets/ActionButton.jsx +68 -0
  79. package/project/src/widgets/AddNewEmperor.jsx +120 -0
  80. package/project/src/widgets/ProjectContainer.jsx +27 -0
  81. package/project/vite.config.js +6 -0
  82. package/project/vite.config.js.timestamp-1709564450418-45fdd27900806.mjs +341 -0
  83. package/public/assets/background/overlay_2.jpg +0 -0
  84. package/public/assets/illustrations/illustration_dashboard.png +0 -0
  85. package/public/vite.svg +1 -0
  86. package/src/ContextProvider/ContextProvider.jsx +19 -0
  87. package/src/GlobalSnackMessage/GlobalSnackMessage.jsx +45 -0
  88. package/src/GlobalSnackMessage/index.js +1 -0
  89. package/src/GlobalSnackMessage/styles.js +3 -0
  90. package/src/Platform.jsx +76 -0
  91. package/src/RouteManager/RouteManager.jsx +56 -0
  92. package/src/RouteManager/index.js +1 -0
  93. package/src/assets/illustrations/avatar-shape.jsx +31 -0
  94. package/src/assets/illustrations/background-shape.jsx +37 -0
  95. package/src/assets/illustrations/booking-illustration.jsx +335 -0
  96. package/src/assets/illustrations/check-in-illustration.jsx +96 -0
  97. package/src/assets/illustrations/check-out-illustration.jsx +69 -0
  98. package/src/assets/illustrations/coming-soon-illustration.jsx +125 -0
  99. package/src/assets/illustrations/forbidden-illustration.jsx +95 -0
  100. package/src/assets/illustrations/index.js +2 -0
  101. package/src/assets/illustrations/maintenance-illustration.jsx +228 -0
  102. package/src/assets/illustrations/motivation-illustration.jsx +74 -0
  103. package/src/assets/illustrations/order-complete-illustration.jsx +126 -0
  104. package/src/assets/illustrations/page-not-found-illustration.jsx +81 -0
  105. package/src/assets/illustrations/seo-illustration.jsx +244 -0
  106. package/src/assets/illustrations/sever-error-illustration.jsx +152 -0
  107. package/src/assets/illustrations/upgrade-storage-illustration.jsx +161 -0
  108. package/src/assets/illustrations/upload-illustration.jsx +622 -0
  109. package/src/components/Iconify/Iconify.jsx +18 -0
  110. package/src/components/Iconify/index.js +1 -0
  111. package/src/components/MiniTopBar/MiniTopBar.jsx +25 -0
  112. package/src/components/MiniTopBar/index.js +1 -0
  113. package/src/components/MiniTopBar/styles.js +6 -0
  114. package/src/components/NucleoidLoginForm/NucleoidLoginForm.jsx +69 -0
  115. package/src/components/NucleoidLoginForm/index.js +1 -0
  116. package/src/components/NucleoidLoginForm/styles.js +3 -0
  117. package/src/components/Sidebar/Sidebar.jsx +76 -0
  118. package/src/components/Sidebar/index.js +1 -0
  119. package/src/components/Sidebar/styles.js +25 -0
  120. package/src/components/SocialLoginButtons/SocialLoginButtons.jsx +55 -0
  121. package/src/components/SocialLoginButtons/index.js +1 -0
  122. package/src/components/SocialLoginButtons/styles.js +3 -0
  123. package/src/components/TopNavBar/TopNavBar.jsx +186 -0
  124. package/src/components/TopNavBar/index.js +1 -0
  125. package/src/components/TopNavBar/styles.js +7 -0
  126. package/src/components/animate/index.js +4 -0
  127. package/src/components/animate/motion-container.jsx +38 -0
  128. package/src/components/animate/motion-lazy.jsx +11 -0
  129. package/src/components/animate/motion-viewport.jsx +30 -0
  130. package/src/components/animate/variants/actions.js +4 -0
  131. package/src/components/animate/variants/background.js +97 -0
  132. package/src/components/animate/variants/bounce.js +107 -0
  133. package/src/components/animate/variants/container.js +20 -0
  134. package/src/components/animate/variants/fade.js +127 -0
  135. package/src/components/animate/variants/flip.js +54 -0
  136. package/src/components/animate/variants/index.js +12 -0
  137. package/src/components/animate/variants/path.js +12 -0
  138. package/src/components/animate/variants/rotate.js +33 -0
  139. package/src/components/animate/variants/scale.js +54 -0
  140. package/src/components/animate/variants/slide.js +65 -0
  141. package/src/components/animate/variants/transition.js +20 -0
  142. package/src/components/animate/variants/zoom.js +130 -0
  143. package/src/components/chart/chart.js +69 -0
  144. package/src/components/chart/index.js +5 -0
  145. package/src/components/chart/use-chart.js +215 -0
  146. package/src/components/custom-popover/custom-popover.jsx +46 -0
  147. package/src/components/custom-popover/index.js +3 -0
  148. package/src/components/custom-popover/styles.js +84 -0
  149. package/src/components/custom-popover/use-popover.js +22 -0
  150. package/src/components/custom-popover/utils.js +100 -0
  151. package/src/components/file-thumbnail/download-button.jsx +39 -0
  152. package/src/components/file-thumbnail/file-thumbnail.jsx +72 -0
  153. package/src/components/file-thumbnail/index.js +5 -0
  154. package/src/components/file-thumbnail/utils.js +148 -0
  155. package/src/components/image/image.jsx +119 -0
  156. package/src/components/image/index.js +1 -0
  157. package/src/components/image/utils.js +15 -0
  158. package/src/components/label/index.js +1 -0
  159. package/src/components/label/label.jsx +51 -0
  160. package/src/components/label/styles.js +78 -0
  161. package/src/components/loading-screen/index.js +2 -0
  162. package/src/components/loading-screen/loading-screen.jsx +23 -0
  163. package/src/components/loading-screen/splash-screen.jsx +95 -0
  164. package/src/components/logo/index.js +1 -0
  165. package/src/components/logo/logo.jsx +61 -0
  166. package/src/components/logo/styles.js +17 -0
  167. package/src/components/nav-section/horizontal/index.js +1 -0
  168. package/src/components/nav-section/horizontal/nav-item.jsx +224 -0
  169. package/src/components/nav-section/horizontal/nav-list.jsx +113 -0
  170. package/src/components/nav-section/horizontal/nav-section-horizontal.jsx +41 -0
  171. package/src/components/nav-section/index.js +3 -0
  172. package/src/components/nav-section/mini/index.js +1 -0
  173. package/src/components/nav-section/mini/nav-item.jsx +242 -0
  174. package/src/components/nav-section/mini/nav-list.jsx +107 -0
  175. package/src/components/nav-section/mini/nav-section-mini.jsx +35 -0
  176. package/src/components/nav-section/vertical/index.js +1 -0
  177. package/src/components/nav-section/vertical/nav-item.jsx +294 -0
  178. package/src/components/nav-section/vertical/nav-list.jsx +66 -0
  179. package/src/components/nav-section/vertical/nav-section-vertical.jsx +74 -0
  180. package/src/components/scrollbar/index.js +1 -0
  181. package/src/components/scrollbar/scrollbar.jsx +39 -0
  182. package/src/components/scrollbar/styles.js +27 -0
  183. package/src/components/search-not-found/index.js +1 -0
  184. package/src/components/search-not-found/search-not-found.jsx +29 -0
  185. package/src/components/settings/context/index.js +2 -0
  186. package/src/components/settings/context/settings-context.js +14 -0
  187. package/src/components/settings/context/settings-provider.jsx +46 -0
  188. package/src/components/settings/drawer/base-option.jsx +52 -0
  189. package/src/components/settings/drawer/fullscreen-option.jsx +58 -0
  190. package/src/components/settings/drawer/index.js +1 -0
  191. package/src/components/settings/drawer/layout-options.jsx +144 -0
  192. package/src/components/settings/drawer/presets-options.jsx +53 -0
  193. package/src/components/settings/drawer/settings-drawer.jsx +189 -0
  194. package/src/components/settings/drawer/stretch-options.jsx +67 -0
  195. package/src/components/settings/index.js +3 -0
  196. package/src/components/svg-color/index.js +1 -0
  197. package/src/components/svg-color/svg-color.jsx +23 -0
  198. package/src/config/config.js +48 -0
  199. package/src/config/schemas.js +148 -0
  200. package/src/context/reducer.js +52 -0
  201. package/src/global.css +2 -0
  202. package/src/hooks/index.js +2 -0
  203. package/src/hooks/use-boolean.js +27 -0
  204. package/src/hooks/use-event-listener.js +34 -0
  205. package/src/hooks/use-local-storage.js +89 -0
  206. package/src/hooks/use-off-set-top.js +37 -0
  207. package/src/hooks/use-responsive.js +47 -0
  208. package/src/hooks/use-scroll-to-top.js +14 -0
  209. package/src/hooks/use-user.js +58 -0
  210. package/src/hooks/useApi.js +25 -0
  211. package/src/hooks/useItemsState.js +23 -0
  212. package/src/hooks/useProjects.js +24 -0
  213. package/src/hooks/useSettings.jsx +51 -0
  214. package/src/http/index.js +155 -0
  215. package/src/http/oauth.js +27 -0
  216. package/src/http/user.js +110 -0
  217. package/src/layouts/AppLayout.jsx +113 -0
  218. package/src/layouts/CompactLayout/CompactLayout.jsx +32 -0
  219. package/src/layouts/CompactLayout/index.js +1 -0
  220. package/src/layouts/DashboardLayout/DashboardLayout.jsx +87 -0
  221. package/src/layouts/DashboardLayout/config-navigation.jsx +0 -0
  222. package/src/layouts/DashboardLayout/header.jsx +104 -0
  223. package/src/layouts/DashboardLayout/index.js +2 -0
  224. package/src/layouts/DashboardLayout/main.jsx +64 -0
  225. package/src/layouts/DashboardLayout/nav-horizontal.jsx +62 -0
  226. package/src/layouts/DashboardLayout/nav-mini.jsx +99 -0
  227. package/src/layouts/DashboardLayout/nav-vertical.jsx +201 -0
  228. package/src/layouts/FullScreenLayout/FullScreenLayout.jsx +101 -0
  229. package/src/layouts/FullScreenLayout/index.js +1 -0
  230. package/src/layouts/FullScreenLayout/nav-horizontal.jsx +50 -0
  231. package/src/layouts/FullScreenLayout/nav-vertical.jsx +136 -0
  232. package/src/layouts/MainLayout/MainLayout.jsx +21 -0
  233. package/src/layouts/MainLayout/footer.jsx +153 -0
  234. package/src/layouts/MainLayout/header.jsx +81 -0
  235. package/src/layouts/MainLayout/index.js +1 -0
  236. package/src/layouts/MainLayout/nav/desktop/index.jsx +20 -0
  237. package/src/layouts/MainLayout/nav/desktop/nav-item.jsx +186 -0
  238. package/src/layouts/MainLayout/nav/desktop/nav-list.jsx +145 -0
  239. package/src/layouts/MainLayout/nav/mobile/index.jsx +60 -0
  240. package/src/layouts/MainLayout/nav/mobile/nav-item.jsx +90 -0
  241. package/src/layouts/MainLayout/nav/mobile/nav-list.jsx +72 -0
  242. package/src/layouts/Page.jsx +16 -0
  243. package/src/layouts/SimpleLayout/SimpleLayout.jsx +8 -0
  244. package/src/layouts/SimpleLayout/index.js +1 -0
  245. package/src/layouts/TwoSideLayout/TwoSideLayout.jsx +31 -0
  246. package/src/layouts/TwoSideLayout/index.js +1 -0
  247. package/src/layouts/auth/classic.jsx +95 -0
  248. package/src/layouts/auth/modern-compact.jsx +51 -0
  249. package/src/layouts/auth/modern.jsx +94 -0
  250. package/src/layouts/common/ProjectBar/index.jsx +325 -0
  251. package/src/layouts/common/ProjectBar/result-item.jsx +90 -0
  252. package/src/layouts/common/ProjectBar/utils.js +86 -0
  253. package/src/layouts/common/account-popover.jsx +116 -0
  254. package/src/layouts/common/header-shadow.jsx +26 -0
  255. package/src/layouts/common/header-sim.jsx +52 -0
  256. package/src/layouts/common/header-simple.jsx +76 -0
  257. package/src/layouts/common/nav-toggle-button.jsx +57 -0
  258. package/src/layouts/common/notifications-popover/index.jsx +177 -0
  259. package/src/layouts/common/notifications-popover/notification-item.jsx +252 -0
  260. package/src/layouts/common/settings-button.jsx +48 -0
  261. package/src/layouts/config-layout.js +12 -0
  262. package/src/layouts/index.js +7 -0
  263. package/src/lib/AddItemWizard/AddItemWizard.jsx +211 -0
  264. package/src/lib/AddItemWizard/index.js +1 -0
  265. package/src/lib/CustomBreadcrumbs/CustomBreadcrumbs.jsx +88 -0
  266. package/src/lib/CustomBreadcrumbs/index.js +1 -0
  267. package/src/lib/CustomBreadcrumbs/link-item.jsx +58 -0
  268. package/src/lib/CustomPopover/CustomPopover.jsx +46 -0
  269. package/src/lib/CustomPopover/index.js +3 -0
  270. package/src/lib/CustomPopover/styles.js +82 -0
  271. package/src/lib/CustomPopover/usePopover.js +20 -0
  272. package/src/lib/CustomPopover/utils.js +100 -0
  273. package/src/lib/Flow/connectors/DynamicConnector.jsx +247 -0
  274. package/src/lib/Flow/core/Flow.jsx +79 -0
  275. package/src/lib/Flow/core/FlowNode.jsx +68 -0
  276. package/src/lib/Flow/core/FlowViewport.jsx +259 -0
  277. package/src/lib/Flow/graph/FloatingGraph.jsx +44 -0
  278. package/src/lib/Flow/hooks/useGraphOperations.js +362 -0
  279. package/src/lib/Flow/hooks/useNodeStyle.js +56 -0
  280. package/src/lib/Flow/index.js +1 -0
  281. package/src/lib/Flow/layouts/ActionNode.jsx +78 -0
  282. package/src/lib/Flow/layouts/AnimatedNode.jsx +22 -0
  283. package/src/lib/Flow/layouts/CardLayout.jsx +397 -0
  284. package/src/lib/Flow/layouts/InfoNode.jsx +255 -0
  285. package/src/lib/Flow/layouts/LoadingNode.jsx +37 -0
  286. package/src/lib/Flow/nodes/DefaultCard.jsx +107 -0
  287. package/src/lib/Flow/nodes/DraggableNode.jsx +162 -0
  288. package/src/lib/Flow/nodes/FlowNodeView.jsx +214 -0
  289. package/src/lib/Flow/selection/SelectionContext.jsx +259 -0
  290. package/src/lib/Flow/selection/SelectionOverlay.jsx +31 -0
  291. package/src/lib/Flow/styles.js +154 -0
  292. package/src/lib/Flow/utils/flowUtils.js +268 -0
  293. package/src/lib/FormProvider/FormProvider.jsx +16 -0
  294. package/src/lib/FormProvider/index.js +1 -0
  295. package/src/lib/IconSelector/IconSelector.jsx +89 -0
  296. package/src/lib/Iconify/Iconify.jsx +17 -0
  297. package/src/lib/Iconify/index.js +1 -0
  298. package/src/lib/Image/Image.jsx +116 -0
  299. package/src/lib/Image/index.js +1 -0
  300. package/src/lib/Image/utils.js +15 -0
  301. package/src/lib/ItemSummary/ItemSummary.jsx +77 -0
  302. package/src/lib/ItemSummary/ItemsSummary.jsx +163 -0
  303. package/src/lib/Label/Label.jsx +51 -0
  304. package/src/lib/Label/index.js +1 -0
  305. package/src/lib/Label/styles.js +76 -0
  306. package/src/lib/ProjectWizard.jsx +137 -0
  307. package/src/lib/RHFTextfield/RHFTextfield.jsx +39 -0
  308. package/src/lib/RHFTextfield/index.js +1 -0
  309. package/src/lib/Scrollbar/Scrollbar.jsx +39 -0
  310. package/src/lib/Scrollbar/index.js +1 -0
  311. package/src/lib/Scrollbar/styles.js +27 -0
  312. package/src/lib/SearchNotFound/SearchNotFound.jsx +29 -0
  313. package/src/lib/SearchNotFound/index.js +1 -0
  314. package/src/lib/SparkleInput/SparkleInput.jsx +51 -0
  315. package/src/lib/StepComponent/StepComponent.jsx +98 -0
  316. package/src/lib/SvgColor/SvgColor.jsx +28 -0
  317. package/src/lib/SvgColor/index.js +1 -0
  318. package/src/lib/TableHeadCustom/TableHeadCustom.jsx +87 -0
  319. package/src/lib/TableHeadCustom/index.js +1 -0
  320. package/src/lib/TableSelectedAction/TableSelectedAction.jsx +72 -0
  321. package/src/lib/TableSelectedAction/index.js +1 -0
  322. package/src/lib/index.js +36 -0
  323. package/src/lib/lib/Icons.js +40 -0
  324. package/src/lib/lib/context.json +272 -0
  325. package/src/lib/useChart/useChart.js +179 -0
  326. package/src/lib/useTable/useTable.js +121 -0
  327. package/src/pages/404.jsx +17 -0
  328. package/src/pages/Callback.jsx +126 -0
  329. package/src/pages/ConfigError.jsx +49 -0
  330. package/src/pages/LoginPage.jsx +43 -0
  331. package/src/routes/components/index.js +1 -0
  332. package/src/routes/components/router-link.jsx +11 -0
  333. package/src/routes/hooks/index.js +4 -0
  334. package/src/routes/hooks/use-active-link.js +15 -0
  335. package/src/routes/hooks/use-pathname.js +10 -0
  336. package/src/routes/hooks/use-router.js +21 -0
  337. package/src/stories/FlowChart.stories.jsx +333 -0
  338. package/src/stories/Iconify.stories.jsx +183 -0
  339. package/src/stories/Label.stories.jsx +447 -0
  340. package/src/stories/Navbar.stories.jsx +588 -0
  341. package/src/theme/css.js +152 -0
  342. package/src/theme/custom-shadows.js +47 -0
  343. package/src/theme/index.jsx +100 -0
  344. package/src/theme/options/contrast.js +34 -0
  345. package/src/theme/options/presets.js +89 -0
  346. package/src/theme/options/right-to-left.jsx +26 -0
  347. package/src/theme/overrides/components/accordion.js +43 -0
  348. package/src/theme/overrides/components/alert.js +69 -0
  349. package/src/theme/overrides/components/appbar.js +13 -0
  350. package/src/theme/overrides/components/autocomplete.js +44 -0
  351. package/src/theme/overrides/components/avatar.js +111 -0
  352. package/src/theme/overrides/components/backdrop.js +18 -0
  353. package/src/theme/overrides/components/badge.js +90 -0
  354. package/src/theme/overrides/components/breadcrumbs.js +21 -0
  355. package/src/theme/overrides/components/button-group.js +90 -0
  356. package/src/theme/overrides/components/button.js +145 -0
  357. package/src/theme/overrides/components/card.js +30 -0
  358. package/src/theme/overrides/components/checkbox.js +13 -0
  359. package/src/theme/overrides/components/chip.js +129 -0
  360. package/src/theme/overrides/components/css-baseline.js +48 -0
  361. package/src/theme/overrides/components/data-grid.js +94 -0
  362. package/src/theme/overrides/components/date-picker.jsx +94 -0
  363. package/src/theme/overrides/components/dialog.js +49 -0
  364. package/src/theme/overrides/components/drawer.js +39 -0
  365. package/src/theme/overrides/components/fab.js +165 -0
  366. package/src/theme/overrides/components/list.js +33 -0
  367. package/src/theme/overrides/components/loading-button.js +30 -0
  368. package/src/theme/overrides/components/menu.js +15 -0
  369. package/src/theme/overrides/components/pagination.js +81 -0
  370. package/src/theme/overrides/components/paper.js +18 -0
  371. package/src/theme/overrides/components/popover.js +20 -0
  372. package/src/theme/overrides/components/progress.js +40 -0
  373. package/src/theme/overrides/components/radio.js +22 -0
  374. package/src/theme/overrides/components/rating.js +40 -0
  375. package/src/theme/overrides/components/select.js +26 -0
  376. package/src/theme/overrides/components/skeleton.js +16 -0
  377. package/src/theme/overrides/components/slider.js +30 -0
  378. package/src/theme/overrides/components/stepper.js +13 -0
  379. package/src/theme/overrides/components/svg-icon.js +15 -0
  380. package/src/theme/overrides/components/switch.js +66 -0
  381. package/src/theme/overrides/components/table.js +79 -0
  382. package/src/theme/overrides/components/tabs.js +39 -0
  383. package/src/theme/overrides/components/textfield.js +146 -0
  384. package/src/theme/overrides/components/timeline.js +20 -0
  385. package/src/theme/overrides/components/toggle-button.js +70 -0
  386. package/src/theme/overrides/components/tooltip.js +18 -0
  387. package/src/theme/overrides/components/tree-view.js +16 -0
  388. package/src/theme/overrides/components/typography.js +16 -0
  389. package/src/theme/overrides/default-props.jsx +238 -0
  390. package/src/theme/overrides/index.js +100 -0
  391. package/src/theme/palette.js +144 -0
  392. package/src/theme/shadows.js +41 -0
  393. package/src/theme/typography.js +107 -0
  394. package/src/utils/flatten-array.js +16 -0
  395. package/src/utils/format-number.js +37 -0
  396. package/src/utils/format-time.js +27 -0
  397. package/src/utils/storage-available.js +24 -0
  398. package/src/widgets/Login/CognitoLogin.jsx +43 -0
  399. package/src/widgets/Login/Login.jsx +58 -0
  400. package/src/widgets/Login/cognitoAuth.jsx +26 -0
  401. package/src/widgets/LoginForm/LoginForm.jsx +87 -0
  402. package/src/widgets/LoginForm/LoginFormStyles.js +43 -0
  403. package/src/widgets/LoginForm/index.js +1 -0
  404. package/src/widgets/SettingsDialog.jsx +308 -0
  405. package/src/widgets/error/index.js +1 -0
  406. package/src/widgets/error/not-found-view.jsx +42 -0
  407. package/vite/vite.js +77 -0
  408. package/vite.config.js +7 -0
  409. package/vitest.config.js +32 -0
@@ -0,0 +1,325 @@
1
+ import Box from "@mui/material/Box";
2
+ import IconButton from "@mui/material/IconButton";
3
+ import Iconify from "../../../components/Iconify";
4
+ import InputAdornment from "@mui/material/InputAdornment";
5
+ import InputBase from "@mui/material/InputBase";
6
+ import Label from "../../../components/label";
7
+ import List from "@mui/material/List";
8
+ import ResultItem from "./result-item";
9
+ import Scrollbar from "../../../components/scrollbar";
10
+ import SearchNotFound from "../../../components/search-not-found";
11
+ import Stack from "@mui/material/Stack";
12
+ import SvgColor from "../../../components/svg-color";
13
+ import { alpha } from "@mui/material/styles";
14
+ import { applyFilter } from "./utils.js";
15
+ import config from "../../../config/config.js";
16
+ import match from "autosuggest-highlight/match";
17
+ import oauth from "../../../http/oauth.js";
18
+ import parse from "autosuggest-highlight/parse";
19
+ import { useBoolean } from "../../../hooks/use-boolean.js";
20
+ import { useEffect } from "react";
21
+ import { useEventListener } from "../../../hooks/use-event-listener";
22
+ import { useNavigate } from "react-router-dom";
23
+ import useProjects from "../../../hooks/useProjects";
24
+
25
+ import { Button, DialogActions } from "@mui/material";
26
+ import Dialog, { dialogClasses } from "@mui/material/Dialog";
27
+ import React, { useCallback, useState } from "react";
28
+ import { publish, useEvent } from "@nucleoidai/react-event";
29
+ import { storage, useStorage } from "@nucleoidjs/webstorage";
30
+ import { useMediaQuery, useTheme } from "@mui/material";
31
+
32
+ function ProjectBar() {
33
+ const label = config().template?.projectBar?.label;
34
+ const { appId } = config();
35
+ const theme = useTheme();
36
+ const isSmallScreen = useMediaQuery(theme.breakpoints.down(435));
37
+ const { loading, projects, getProjects } = useProjects();
38
+
39
+ const [projectCreated] = useEvent("PROJECT_CREATED", { project: null });
40
+
41
+ useEffect(() => {
42
+ console.log("ProjectBar useEffect", projectCreated);
43
+
44
+ getProjects();
45
+ }, [projectCreated]);
46
+
47
+ const id = window.matchMedia("projectId").matches;
48
+ const [selectedProjectId] = useStorage("projectId", id);
49
+
50
+ const [selectedProject, setSelectedProject] = useState();
51
+
52
+ const navigate = useNavigate();
53
+
54
+ const search = useBoolean();
55
+
56
+ const [searchQuery, setSearchQuery] = useState("");
57
+
58
+ useEffect(() => {
59
+ if (!selectedProjectId && projects?.length > 0) {
60
+ search.onTrue();
61
+ }
62
+ }, [projects]);
63
+
64
+ useEffect(() => {
65
+ if (projects?.length === 0 && !loading) {
66
+ publish("PLATFORM", "PROJECT_BAR_DIALOG", {
67
+ open: true,
68
+ });
69
+ }
70
+ }, [projects]);
71
+
72
+ useEffect(() => {
73
+ if (projectCreated.project) {
74
+ handleSelect(projectCreated.project);
75
+ }
76
+ }, [projectCreated]);
77
+
78
+ useEffect(() => {
79
+ setSelectedProject(
80
+ projects.find((project) => project.id === selectedProjectId)
81
+ );
82
+ // eslint-disable-next-line react-hooks/exhaustive-deps
83
+ }, [projects]);
84
+
85
+ const AddNewDialogOpen = () => {
86
+ publish("PLATFORM", "PROJECT_BAR_DIALOG", {
87
+ open: true,
88
+ });
89
+ };
90
+
91
+ const handleSelect = (project) => {
92
+ const { id: projectId } = project;
93
+
94
+ const refreshToken = storage.get("link", "refreshToken");
95
+ const identityProvider = storage.get("link", "identityProvider");
96
+
97
+ oauth
98
+ .post("/oauth", { appId, refreshToken, projectId, identityProvider })
99
+ .then(({ data }) => {
100
+ const { refreshToken, accessToken } = data;
101
+ storage.set("link", "accessToken", accessToken);
102
+ storage.set("link", "refreshToken", refreshToken);
103
+ storage.set("projectId", projectId);
104
+ })
105
+ .finally(() => {
106
+ setSelectedProject(project);
107
+
108
+ publish("PROJECT_SELECTED", { projectId });
109
+
110
+ search.onFalse();
111
+ setSearchQuery("");
112
+ });
113
+ };
114
+
115
+ const handleClose = useCallback(() => {
116
+ search.onFalse();
117
+ setSearchQuery("");
118
+ }, [search]);
119
+
120
+ const handleKeyDown = (event) => {
121
+ if (event.key === "k" && event.metaKey) {
122
+ search.onToggle();
123
+ setSearchQuery("");
124
+ }
125
+ };
126
+
127
+ useEventListener("keydown", handleKeyDown);
128
+
129
+ const handleSearch = useCallback((event) => {
130
+ setSearchQuery(event.target.value);
131
+ }, []);
132
+
133
+ const dataFiltered = applyFilter({
134
+ inputData: projects,
135
+ query: searchQuery,
136
+ });
137
+ const notFound = searchQuery && !dataFiltered.length;
138
+
139
+ const renderItems = () => (
140
+ <List data-cy="item-list" disablePadding>
141
+ {dataFiltered.map((item) => {
142
+ const title = item?.name;
143
+ const icon = item?.icon?.slice(1, -1);
144
+ const organizationName = item?.organization?.name;
145
+ const partsTitle = parse(title, match(title, searchQuery));
146
+ return (
147
+ <ResultItem
148
+ name={organizationName}
149
+ icon={icon || "eva:question-mark-circle"}
150
+ title={partsTitle}
151
+ key={`${title}`}
152
+ groupLabel={searchQuery && title}
153
+ onClickItem={() => {
154
+ handleSelect(item);
155
+ navigate(`/`, { replace: true });
156
+ }}
157
+ />
158
+ );
159
+ })}
160
+ </List>
161
+ );
162
+
163
+ const renderButton = (
164
+ <Stack
165
+ direction="row"
166
+ alignItems="center"
167
+ justifyContent={"flex-start"}
168
+ sx={{ width: "100%" }}
169
+ >
170
+ <IconButton
171
+ data-cy="open-select-bar-button"
172
+ onClick={search.onTrue}
173
+ sx={{
174
+ color: "text.disabled",
175
+ typography: "subtitle2",
176
+ "& .svg-color": {
177
+ background: (theme) =>
178
+ selectedProjectId
179
+ ? `linear-gradient(135deg, ${theme.palette.primary.light} 0%, ${theme.palette.primary.main} 100%)`
180
+ : "gray",
181
+ },
182
+ }}
183
+ >
184
+ <SvgColor
185
+ src={
186
+ selectedProjectId
187
+ ? `https://api.iconify.design/${selectedProject?.icon?.slice(
188
+ 1,
189
+ -1
190
+ )}.svg`
191
+ : "https://api.iconify.design/ph:circle-duotone.svg"
192
+ }
193
+ sx={{ width: 32, height: 32 }}
194
+ />
195
+ </IconButton>
196
+
197
+ {!isSmallScreen && (
198
+ <Label
199
+ color={selectedProjectId ? "primary" : "default"}
200
+ onClick={search.onTrue}
201
+ sx={{
202
+ px: 0.75,
203
+ fontSize: 14,
204
+ cursor: "pointer",
205
+ }}
206
+ >
207
+ {selectedProject ? selectedProject.name : "Select Project"}
208
+ </Label>
209
+ )}
210
+
211
+ {isSmallScreen && selectedProject && (
212
+ <Label
213
+ color="primary"
214
+ onClick={search.onTrue}
215
+ sx={{
216
+ px: 0.75,
217
+ fontSize: 14,
218
+ cursor: "pointer",
219
+ }}
220
+ >
221
+ {selectedProject.name.split(" ").slice(0, 2).join(" ")}
222
+ </Label>
223
+ )}
224
+ </Stack>
225
+ );
226
+
227
+ const AddNewButton = (
228
+ <DialogActions disableSpacing>
229
+ <Button
230
+ data-cy="add-new-item-button"
231
+ fullWidth={true}
232
+ onClick={AddNewDialogOpen}
233
+ >
234
+ <Label
235
+ sx={{
236
+ width: "100%",
237
+ height: "3rem",
238
+ px: 0.75,
239
+ fontSize: 18,
240
+ color: "text.secondary",
241
+ "&:hover": {
242
+ borderRadius: 1,
243
+ borderColor: (theme) => theme.palette.primary.main,
244
+ backgroundColor: (theme) =>
245
+ alpha(
246
+ theme.palette.primary.main,
247
+ theme.palette.action.hoverOpacity
248
+ ),
249
+ },
250
+ }}
251
+ >
252
+ Add New {label}
253
+ </Label>
254
+ </Button>
255
+ </DialogActions>
256
+ );
257
+
258
+ return (
259
+ <>
260
+ {renderButton}
261
+
262
+ <Dialog
263
+ data-cy="select-bar-dialog"
264
+ fullWidth={true}
265
+ maxWidth="sm"
266
+ open={search.value}
267
+ onClose={selectedProjectId && handleClose}
268
+ transitionDuration={{
269
+ enter: theme.transitions.duration.shortest,
270
+ exit: 0,
271
+ }}
272
+ PaperProps={{
273
+ sx: {
274
+ mt: 15,
275
+ overflow: "unset",
276
+ },
277
+ }}
278
+ sx={{
279
+ [`& .${dialogClasses.container}`]: {
280
+ alignItems: "flex-start",
281
+ },
282
+ }}
283
+ >
284
+ <Box sx={{ p: 3, borderBottom: `solid 1px gray` }}>
285
+ <InputBase
286
+ data-cy="item-input"
287
+ fullWidth={true}
288
+ autoFocus
289
+ placeholder="Search..."
290
+ value={searchQuery}
291
+ onChange={handleSearch}
292
+ startAdornment={
293
+ <InputAdornment position="start">
294
+ <Iconify
295
+ icon="eva:search-fill"
296
+ width={24}
297
+ sx={{ color: "text.disabled" }}
298
+ />
299
+ </InputAdornment>
300
+ }
301
+ endAdornment={
302
+ <Label sx={{ letterSpacing: 1, color: "text.secondary" }}>
303
+ esc
304
+ </Label>
305
+ }
306
+ inputProps={{
307
+ sx: { typography: "h6" },
308
+ }}
309
+ />
310
+ </Box>
311
+
312
+ <Scrollbar sx={{ p: 3, pt: 2, height: 400 }}>
313
+ {notFound ? (
314
+ <SearchNotFound query={searchQuery} sx={{ py: 10 }} />
315
+ ) : (
316
+ renderItems()
317
+ )}
318
+ </Scrollbar>
319
+ {AddNewButton}
320
+ </Dialog>
321
+ </>
322
+ );
323
+ }
324
+
325
+ export default ProjectBar;
@@ -0,0 +1,90 @@
1
+ import Box from "@mui/material/Box";
2
+ import Label from "../../../components/label";
3
+ import ListItemButton from "@mui/material/ListItemButton";
4
+ import ListItemText from "@mui/material/ListItemText";
5
+ import React from "react";
6
+ import SvgColor from "../../../components/svg-color";
7
+ import { alpha } from "@mui/material/styles";
8
+ import { useTheme } from "@mui/material/styles";
9
+
10
+ import { Stack, Typography, useMediaQuery } from "@mui/material";
11
+
12
+ export default function ResultItem({
13
+ title,
14
+ icon,
15
+ groupLabel,
16
+ onClickItem,
17
+ name,
18
+ }) {
19
+ const theme = useTheme();
20
+ const isSmallScreen = useMediaQuery(theme.breakpoints.down(435));
21
+
22
+ const displayTitle = isSmallScreen
23
+ ? title
24
+ .map((part) => part.text)
25
+ .join(" ")
26
+ .split(" ")
27
+ .slice(0, 2)
28
+ .join(" ")
29
+ : title.map((part, index) => (
30
+ <Box
31
+ key={index}
32
+ component="span"
33
+ sx={{ color: part.highlight ? "primary.main" : "text.primary" }}
34
+ >
35
+ {part.text}
36
+ </Box>
37
+ ));
38
+
39
+ const displayName = isSmallScreen
40
+ ? name.split(" ").slice(0, 2).join(" ")
41
+ : name;
42
+
43
+ return (
44
+ <ListItemButton
45
+ data-cy="item-button"
46
+ onClick={onClickItem}
47
+ sx={{
48
+ borderBottom: `1px dashed ${theme.palette.divider}`,
49
+ "&:hover": {
50
+ borderRadius: 1,
51
+ borderColor: "primary.main",
52
+ backgroundColor: alpha(
53
+ theme.palette.primary.main,
54
+ theme.palette.action.hoverOpacity
55
+ ),
56
+ borderStyle: "dashed",
57
+ borderWidth: 1,
58
+ },
59
+ }}
60
+ >
61
+ <Stack>
62
+ <SvgColor
63
+ src={`https://api.iconify.design/${icon}.svg`}
64
+ sx={{
65
+ width: 32,
66
+ height: 32,
67
+ mx: 2,
68
+ background: `linear-gradient(135deg, ${theme.palette.primary.light} 0%, ${theme.palette.primary.main} 100%)`,
69
+ }}
70
+ />
71
+ </Stack>
72
+
73
+ <ListItemText
74
+ primary={
75
+ <Typography variant="subtitle2" sx={{ textTransform: "capitalize" }}>
76
+ {displayTitle}
77
+ </Typography>
78
+ }
79
+ />
80
+
81
+ <Label
82
+ sx={{ height: "auto", whiteSpace: "normal", wordWrap: "break-word" }}
83
+ >
84
+ <Typography variant="caption">{displayName}</Typography>
85
+ </Label>
86
+
87
+ {groupLabel && <Label color="info">{groupLabel}</Label>}
88
+ </ListItemButton>
89
+ );
90
+ }
@@ -0,0 +1,86 @@
1
+ import { flattenArray } from "../../../utils/flatten-array";
2
+
3
+ // ----------------------------------------------------------------------
4
+
5
+ export function getAllItems({ data }) {
6
+ const reduceItems = data
7
+ .map((list) => handleLoop(list.items, list.subheader))
8
+ .flat();
9
+
10
+ const items = flattenArray(reduceItems).map((option) => {
11
+ const group = splitPath(reduceItems, option.path);
12
+
13
+ return {
14
+ group: group && group.length > 1 ? group[0] : option.subheader,
15
+ title: option.title,
16
+ path: option.path,
17
+ };
18
+ });
19
+
20
+ return items;
21
+ }
22
+
23
+ // ----------------------------------------------------------------------
24
+
25
+ export function applyFilter({ inputData, query }) {
26
+ if (query) {
27
+ inputData = inputData.filter(
28
+ (item) => item.name.toLowerCase().indexOf(query.toLowerCase()) !== -1
29
+ );
30
+ }
31
+
32
+ return inputData;
33
+ }
34
+
35
+ // ----------------------------------------------------------------------
36
+
37
+ export function splitPath(array, key) {
38
+ let stack = array.map((item) => ({
39
+ path: [item.title],
40
+ currItem: item,
41
+ }));
42
+
43
+ while (stack.length) {
44
+ const { path, currItem } = stack.pop();
45
+
46
+ if (currItem.path === key) {
47
+ return path;
48
+ }
49
+
50
+ if (currItem.children?.length) {
51
+ stack = stack.concat(
52
+ currItem.children.map((item) => ({
53
+ path: path.concat(item.title),
54
+ currItem: item,
55
+ }))
56
+ );
57
+ }
58
+ }
59
+ return null;
60
+ }
61
+
62
+ // ----------------------------------------------------------------------
63
+
64
+ export function handleLoop(array, subheader) {
65
+ return array?.map((list) => ({
66
+ subheader,
67
+ ...list,
68
+ ...(list.children && {
69
+ children: handleLoop(list.children, subheader),
70
+ }),
71
+ }));
72
+ }
73
+
74
+ // ----------------------------------------------------------------------
75
+
76
+ export function groupedData(array) {
77
+ const group = array.reduce((groups, item) => {
78
+ groups[item.group] = groups[item.group] || [];
79
+
80
+ groups[item.group].push(item);
81
+
82
+ return groups;
83
+ }, {});
84
+
85
+ return group;
86
+ }
@@ -0,0 +1,116 @@
1
+ import Avatar from "@mui/material/Avatar";
2
+ import Box from "@mui/material/Box";
3
+ import Divider from "@mui/material/Divider";
4
+ import IconButton from "@mui/material/IconButton";
5
+ import MenuItem from "@mui/material/MenuItem";
6
+ import React from "react";
7
+ import Stack from "@mui/material/Stack";
8
+ import Typography from "@mui/material/Typography";
9
+ import { alpha } from "@mui/material/styles";
10
+ import config from "../../config/config";
11
+ import { motion } from "framer-motion";
12
+ import { storage } from "@nucleoidjs/webstorage";
13
+ import { useRouter } from "../../routes/hooks";
14
+ import { useUser } from "../../hooks/use-user";
15
+ import { varHover } from "../../components/animate";
16
+
17
+ import CustomPopover, { usePopover } from "../../components/custom-popover";
18
+
19
+ // ----------------------------------------------------------------------
20
+
21
+ export default function AccountPopover() {
22
+ const { options } = config().menu;
23
+ const router = useRouter();
24
+ const { user } = useUser();
25
+
26
+ const popover = usePopover();
27
+
28
+ const handleLogout = async () => {
29
+ try {
30
+ storage.remove("link", "accessToken");
31
+ storage.remove("link", "refreshToken");
32
+ popover.onClose();
33
+ router.replace("/login");
34
+ } catch (error) {
35
+ console.error(error);
36
+ }
37
+ };
38
+
39
+ const handleClickItem = (path) => {
40
+ popover.onClose();
41
+ router.push(path);
42
+ };
43
+
44
+ return (
45
+ <>
46
+ <IconButton
47
+ component={motion.button}
48
+ whileTap="tap"
49
+ whileHover="hover"
50
+ variants={varHover(1.05)}
51
+ onClick={popover.onOpen}
52
+ data-cy="account-popover"
53
+ sx={{
54
+ width: 40,
55
+ height: 40,
56
+ background: (theme) => alpha(theme.palette.grey[500], 0.08),
57
+ ...(popover.open && {
58
+ background: (theme) =>
59
+ `linear-gradient(135deg, ${theme.palette.primary.light} 0%, ${theme.palette.primary.main} 100%)`,
60
+ }),
61
+ }}
62
+ >
63
+ <Avatar
64
+ data-cy="account-popover-avatar"
65
+ src={user?.avatarUrl}
66
+ alt={user?.name}
67
+ sx={{
68
+ width: 36,
69
+ height: 36,
70
+ border: (theme) => `solid 2px ${theme.palette.background.default}`,
71
+ }}
72
+ >
73
+ {user?.name.charAt(0).toUpperCase()}
74
+ </Avatar>
75
+ </IconButton>
76
+
77
+ <CustomPopover
78
+ open={popover.open}
79
+ onClose={popover.onClose}
80
+ sx={{ width: 200, p: 0 }}
81
+ >
82
+ <Box sx={{ p: 2, pb: 1.5 }}>
83
+ <Typography data-cy="account-popover-name" variant="subtitle2" noWrap>
84
+ {user?.name}
85
+ </Typography>
86
+
87
+ <Typography variant="body2" sx={{ color: "text.secondary" }} noWrap>
88
+ {user?.email}
89
+ </Typography>
90
+ </Box>
91
+
92
+ <Divider sx={{ borderStyle: "dashed" }} />
93
+
94
+ <Stack sx={{ p: 1 }}>
95
+ {options.map((option) => (
96
+ <MenuItem
97
+ key={option.label}
98
+ onClick={() => handleClickItem(option.linkTo)}
99
+ >
100
+ {option.label}
101
+ </MenuItem>
102
+ ))}
103
+ </Stack>
104
+
105
+ <Divider sx={{ borderStyle: "dashed" }} />
106
+
107
+ <MenuItem
108
+ onClick={handleLogout}
109
+ sx={{ m: 1, fontWeight: "fontWeightBold", color: "error.main" }}
110
+ >
111
+ Logout
112
+ </MenuItem>
113
+ </CustomPopover>
114
+ </>
115
+ );
116
+ }
@@ -0,0 +1,26 @@
1
+ import Box from "@mui/material/Box";
2
+ import React from "react";
3
+
4
+ // ----------------------------------------------------------------------
5
+
6
+ export default function HeaderShadow({ sx, ...other }) {
7
+ return (
8
+ <Box
9
+ sx={{
10
+ left: 0,
11
+ right: 0,
12
+ bottom: 0,
13
+ m: "auto",
14
+ height: 24,
15
+ zIndex: -1,
16
+ opacity: 0.48,
17
+ borderRadius: "50%",
18
+ position: "absolute",
19
+ width: `calc(100% - 48px)`,
20
+ boxShadow: (theme) => theme.customShadows.z8,
21
+ ...sx,
22
+ }}
23
+ {...other}
24
+ />
25
+ );
26
+ }
@@ -0,0 +1,52 @@
1
+ import AppBar from "@mui/material/AppBar";
2
+ import { HEADER } from "../config-layout";
3
+ import HeaderShadow from "./header-shadow";
4
+ import Logo from "../../components/logo";
5
+ import React from "react";
6
+ import SettingsButton from "./settings-button";
7
+ import Stack from "@mui/material/Stack";
8
+ import Toolbar from "@mui/material/Toolbar";
9
+ import { bgBlur } from "../../theme/css";
10
+ import { useOffSetTop } from "../../hooks/use-off-set-top";
11
+ import { useTheme } from "@mui/material/styles";
12
+ // ----------------------------------------------------------------------
13
+
14
+ export default function HeaderSim() {
15
+ const theme = useTheme();
16
+
17
+ const offsetTop = useOffSetTop(HEADER.H_DESKTOP);
18
+
19
+ return (
20
+ <AppBar>
21
+ <Toolbar
22
+ sx={{
23
+ justifyContent: "space-between",
24
+ height: {
25
+ xs: HEADER.H_MOBILE,
26
+ md: HEADER.H_DESKTOP,
27
+ },
28
+ transition: theme.transitions.create(["height"], {
29
+ easing: theme.transitions.easing.easeInOut,
30
+ duration: theme.transitions.duration.shorter,
31
+ }),
32
+ ...(offsetTop && {
33
+ ...bgBlur({
34
+ color: theme.palette.background.default,
35
+ }),
36
+ height: {
37
+ md: HEADER.H_DESKTOP_OFFSET,
38
+ },
39
+ }),
40
+ }}
41
+ >
42
+ <Logo />
43
+
44
+ <Stack direction="row" alignItems="center" spacing={1}>
45
+ <SettingsButton />
46
+ </Stack>
47
+ </Toolbar>
48
+
49
+ {offsetTop && <HeaderShadow />}
50
+ </AppBar>
51
+ );
52
+ }