@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,76 @@
1
+ import AccountPopover from "../common/account-popover";
2
+ import AppBar from "@mui/material/AppBar";
3
+ import { HEADER } from "../config-layout";
4
+ import HeaderShadow from "./header-shadow";
5
+ import Logo from "../../components/logo";
6
+ import NavDesktop from "../MainLayout/nav/desktop";
7
+ import NotificationsPopover from "../common/notifications-popover";
8
+ import ProjectBar from "../common/ProjectBar";
9
+ import React from "react";
10
+ import SettingsButton from "./settings-button";
11
+ import Stack from "@mui/material/Stack";
12
+ import Toolbar from "@mui/material/Toolbar";
13
+ import { bgBlur } from "../../theme/css";
14
+ import config from "../../config/config";
15
+ import { useOffSetTop } from "../../hooks/use-off-set-top";
16
+ import { useResponsive } from "../../hooks/use-responsive";
17
+ import { useTheme } from "@mui/material/styles";
18
+
19
+ // ----------------------------------------------------------------------
20
+
21
+ export default function HeaderSimple({
22
+ handleItemSelect,
23
+ selectedItem,
24
+ setSelectedItem,
25
+ }) {
26
+ const { menu } = config();
27
+ const theme = useTheme();
28
+ const { topMenu } = menu;
29
+ const mdUp = useResponsive("up", "md");
30
+ const offsetTop = useOffSetTop(HEADER.H_DESKTOP);
31
+
32
+ return (
33
+ <AppBar data-cy="header">
34
+ <Toolbar
35
+ sx={{
36
+ justifyContent: "space-between",
37
+ height: {
38
+ xs: HEADER.H_MOBILE,
39
+ md: HEADER.H_DESKTOP,
40
+ },
41
+ transition: theme.transitions.create(["height"], {
42
+ easing: theme.transitions.easing.easeInOut,
43
+ duration: theme.transitions.duration.shorter,
44
+ }),
45
+ ...(offsetTop && {
46
+ ...bgBlur({
47
+ color: theme.palette.background.default,
48
+ }),
49
+ height: {
50
+ md: HEADER.H_DESKTOP_OFFSET,
51
+ },
52
+ }),
53
+ }}
54
+ >
55
+ <Stack direction="row" alignItems="center" spacing={5}>
56
+ <Logo />
57
+ <ProjectBar
58
+ handleItemSelect={handleItemSelect}
59
+ selectedItem={selectedItem}
60
+ setSelectedItem={setSelectedItem}
61
+ />
62
+ </Stack>
63
+ <Stack direction="row" alignItems="center" spacing={1}>
64
+ {mdUp && <NavDesktop data={topMenu} />}
65
+ <NotificationsPopover />
66
+
67
+ <SettingsButton />
68
+
69
+ <AccountPopover />
70
+ </Stack>
71
+ </Toolbar>
72
+
73
+ {offsetTop && <HeaderShadow />}
74
+ </AppBar>
75
+ );
76
+ }
@@ -0,0 +1,57 @@
1
+ import IconButton from "@mui/material/IconButton";
2
+ import Iconify from "../../components/Iconify";
3
+ import { NAV } from "../config-layout";
4
+ import React from "react";
5
+ import { bgBlur } from "../../theme/css";
6
+ import { useResponsive } from "../../hooks/use-responsive";
7
+ import { useSettingsContext } from "../../components/settings";
8
+ import { useTheme } from "@mui/material/styles";
9
+
10
+ // ----------------------------------------------------------------------
11
+
12
+ export default function NavToggleButton({ sx, ...other }) {
13
+ const theme = useTheme();
14
+
15
+ const settings = useSettingsContext();
16
+
17
+ const lgUp = useResponsive("up", "lg");
18
+
19
+ if (!lgUp) {
20
+ return null;
21
+ }
22
+
23
+ return (
24
+ <IconButton
25
+ size="small"
26
+ onClick={() =>
27
+ settings.onUpdate(
28
+ "themeLayout",
29
+ settings.themeLayout === "vertical" ? "mini" : "vertical"
30
+ )
31
+ }
32
+ sx={{
33
+ p: 0.5,
34
+ top: 32,
35
+ position: "fixed",
36
+ left: NAV.W_VERTICAL - 12,
37
+ zIndex: 0,
38
+ border: `dashed 1px ${theme.palette.divider}`,
39
+ ...bgBlur({ opacity: 0.48, color: theme.palette.background.default }),
40
+ "&:hover": {
41
+ bgcolor: "background.default",
42
+ },
43
+ ...sx,
44
+ }}
45
+ {...other}
46
+ >
47
+ <Iconify
48
+ width={16}
49
+ icon={
50
+ settings.themeLayout === "vertical"
51
+ ? "eva:arrow-ios-back-fill"
52
+ : "eva:arrow-ios-forward-fill"
53
+ }
54
+ />
55
+ </IconButton>
56
+ );
57
+ }
@@ -0,0 +1,177 @@
1
+ import Badge from "@mui/material/Badge";
2
+ import Box from "@mui/material/Box";
3
+ import Divider from "@mui/material/Divider";
4
+ import Drawer from "@mui/material/Drawer";
5
+ import IconButton from "@mui/material/IconButton";
6
+ import Iconify from "../../../components/Iconify";
7
+ import Label from "../../../components/label";
8
+ import React from "react";
9
+ import Stack from "@mui/material/Stack";
10
+ import Tab from "@mui/material/Tab";
11
+ import Tabs from "@mui/material/Tabs";
12
+ import Tooltip from "@mui/material/Tooltip";
13
+ import Typography from "@mui/material/Typography";
14
+ import { motion } from "framer-motion";
15
+ import { useBoolean } from "../../../hooks/use-boolean";
16
+ import { useResponsive } from "../../../hooks/use-responsive";
17
+ import { varHover } from "../../../components/animate";
18
+
19
+ import { useCallback, useState } from "react";
20
+
21
+ // ----------------------------------------------------------------------
22
+
23
+ const TABS = [
24
+ {
25
+ value: "all",
26
+ label: "All",
27
+ count: 0,
28
+ },
29
+ {
30
+ value: "unread",
31
+ label: "Unread",
32
+ count: 0,
33
+ },
34
+ {
35
+ value: "archived",
36
+ label: "Archived",
37
+ count: 0,
38
+ },
39
+ ];
40
+
41
+ // ----------------------------------------------------------------------
42
+
43
+ export default function NotificationsPopover() {
44
+ const drawer = useBoolean();
45
+
46
+ const smUp = useResponsive("up", "sm");
47
+
48
+ const [currentTab, setCurrentTab] = useState("all");
49
+
50
+ const handleChangeTab = useCallback((event, newValue) => {
51
+ setCurrentTab(newValue);
52
+ }, []);
53
+
54
+ const [notifications, setNotifications] = useState([]);
55
+
56
+ const totalUnRead = notifications.filter(
57
+ (item) => item.isUnRead === true
58
+ ).length;
59
+
60
+ const handleMarkAllAsRead = () => {
61
+ setNotifications(
62
+ notifications.map((notification) => ({
63
+ ...notification,
64
+ isUnRead: false,
65
+ }))
66
+ );
67
+ };
68
+
69
+ const renderHead = (
70
+ <Stack
71
+ direction="row"
72
+ alignItems="center"
73
+ sx={{ py: 2, pl: 2.5, pr: 1, minHeight: 68 }}
74
+ >
75
+ <Typography variant="h6" sx={{ flexGrow: 1 }}>
76
+ Notifications
77
+ </Typography>
78
+
79
+ {!!totalUnRead && (
80
+ <Tooltip title="Mark all as read">
81
+ <IconButton color="primary" onClick={handleMarkAllAsRead}>
82
+ <Iconify icon="eva:done-all-fill" />
83
+ </IconButton>
84
+ </Tooltip>
85
+ )}
86
+
87
+ {!smUp && (
88
+ <IconButton onClick={drawer.onFalse}>
89
+ <Iconify icon="mingcute:close-line" />
90
+ </IconButton>
91
+ )}
92
+ </Stack>
93
+ );
94
+
95
+ const renderTabs = (
96
+ <Tabs value={currentTab} onChange={handleChangeTab}>
97
+ {TABS.map((tab) => (
98
+ <Tab
99
+ key={tab.value}
100
+ iconPosition="end"
101
+ value={tab.value}
102
+ label={tab.label}
103
+ icon={
104
+ <Label
105
+ variant={
106
+ ((tab.value === "all" || tab.value === currentTab) &&
107
+ "filled") ||
108
+ "soft"
109
+ }
110
+ color={
111
+ (tab.value === "unread" && "info") ||
112
+ (tab.value === "archived" && "success") ||
113
+ "default"
114
+ }
115
+ >
116
+ {tab.count}
117
+ </Label>
118
+ }
119
+ sx={{
120
+ "&:not(:last-of-type)": {
121
+ mr: 3,
122
+ },
123
+ }}
124
+ />
125
+ ))}
126
+ </Tabs>
127
+ );
128
+
129
+ return (
130
+ <>
131
+ <IconButton
132
+ component={motion.button}
133
+ whileTap="tap"
134
+ whileHover="hover"
135
+ variants={varHover(1.05)}
136
+ color={drawer.value ? "primary" : "default"}
137
+ onClick={drawer.onTrue}
138
+ >
139
+ <Badge badgeContent={totalUnRead} color="error">
140
+ <Iconify icon="solar:bell-bing-bold-duotone" width={24} />
141
+ </Badge>
142
+ </IconButton>
143
+
144
+ <Drawer
145
+ open={drawer.value}
146
+ onClose={drawer.onFalse}
147
+ anchor="right"
148
+ slotProps={{
149
+ backdrop: { invisible: true },
150
+ }}
151
+ PaperProps={{
152
+ sx: { width: 1, maxWidth: 420 },
153
+ }}
154
+ >
155
+ {renderHead}
156
+
157
+ <Divider />
158
+
159
+ <Stack
160
+ direction="row"
161
+ alignItems="center"
162
+ justifyContent="space-between"
163
+ sx={{ pl: 2.5, pr: 1 }}
164
+ >
165
+ {renderTabs}
166
+ <IconButton onClick={handleMarkAllAsRead}>
167
+ <Iconify icon="solar:settings-bold-duotone" />
168
+ </IconButton>
169
+ </Stack>
170
+
171
+ <Divider />
172
+
173
+ <Box sx={{ p: 1 }}></Box>
174
+ </Drawer>
175
+ </>
176
+ );
177
+ }
@@ -0,0 +1,252 @@
1
+ import Avatar from "@mui/material/Avatar";
2
+ import Box from "@mui/material/Box";
3
+ import Button from "@mui/material/Button";
4
+ import FileThumbnail from "../../../components/file-thumbnail";
5
+ import Label from "../../../components/label";
6
+ import ListItemAvatar from "@mui/material/ListItemAvatar";
7
+ import ListItemButton from "@mui/material/ListItemButton";
8
+ import ListItemText from "@mui/material/ListItemText";
9
+ import React from "react";
10
+ import Stack from "@mui/material/Stack";
11
+ import Typography from "@mui/material/Typography";
12
+ import { fToNow } from "../../../utils/format-time";
13
+
14
+ // ----------------------------------------------------------------------
15
+
16
+ export default function NotificationItem({ notification }) {
17
+ const renderAvatar = (
18
+ <ListItemAvatar>
19
+ {notification.avatarUrl ? (
20
+ <Avatar
21
+ src={notification.avatarUrl}
22
+ sx={{ bgcolor: "background.neutral" }}
23
+ />
24
+ ) : (
25
+ <Stack
26
+ alignItems="center"
27
+ justifyContent="center"
28
+ sx={{
29
+ width: 40,
30
+ height: 40,
31
+ borderRadius: "50%",
32
+ bgcolor: "background.neutral",
33
+ }}
34
+ >
35
+ <Box
36
+ component="img"
37
+ src={`/assets/icons/notification/${
38
+ (notification.type === "order" && "ic_order") ||
39
+ (notification.type === "chat" && "ic_chat") ||
40
+ (notification.type === "mail" && "ic_mail") ||
41
+ (notification.type === "delivery" && "ic_delivery")
42
+ }.svg`}
43
+ sx={{ width: 24, height: 24 }}
44
+ />
45
+ </Stack>
46
+ )}
47
+ </ListItemAvatar>
48
+ );
49
+
50
+ const renderText = (
51
+ <ListItemText
52
+ disableTypography
53
+ primary={reader(notification.title)}
54
+ secondary={
55
+ <Stack
56
+ direction="row"
57
+ alignItems="center"
58
+ sx={{ typography: "caption", color: "text.disabled" }}
59
+ divider={
60
+ <Box
61
+ sx={{
62
+ width: 2,
63
+ height: 2,
64
+ bgcolor: "currentColor",
65
+ mx: 0.5,
66
+ borderRadius: "50%",
67
+ }}
68
+ />
69
+ }
70
+ >
71
+ {fToNow(notification.createdAt)}
72
+ {notification.category}
73
+ </Stack>
74
+ }
75
+ />
76
+ );
77
+
78
+ const renderUnReadBadge = notification.isUnRead && (
79
+ <Box
80
+ sx={{
81
+ top: 26,
82
+ width: 8,
83
+ height: 8,
84
+ right: 20,
85
+ borderRadius: "50%",
86
+ bgcolor: "info.main",
87
+ position: "absolute",
88
+ }}
89
+ />
90
+ );
91
+
92
+ const friendAction = (
93
+ <Stack spacing={1} direction="row" sx={{ mt: 1.5 }}>
94
+ <Button size="small" variant="contained">
95
+ Accept
96
+ </Button>
97
+ <Button size="small" variant="outlined">
98
+ Decline
99
+ </Button>
100
+ </Stack>
101
+ );
102
+
103
+ const projectAction = (
104
+ <Stack alignItems="flex-start">
105
+ <Box
106
+ sx={{
107
+ p: 1.5,
108
+ my: 1.5,
109
+ borderRadius: 1.5,
110
+ color: "text.secondary",
111
+ bgcolor: "background.neutral",
112
+ }}
113
+ >
114
+ {reader(
115
+ `<p><strong>@Jaydon Frankie</strong> feedback by asking questions or just leave a note of appreciation.</p>`
116
+ )}
117
+ </Box>
118
+
119
+ <Button size="small" variant="contained">
120
+ Reply
121
+ </Button>
122
+ </Stack>
123
+ );
124
+
125
+ const fileAction = (
126
+ <Stack
127
+ spacing={1}
128
+ direction="row"
129
+ sx={{
130
+ pl: 1,
131
+ p: 1.5,
132
+ mt: 1.5,
133
+ borderRadius: 1.5,
134
+ bgcolor: "background.neutral",
135
+ }}
136
+ >
137
+ <FileThumbnail
138
+ file="http://localhost:8080/httpsdesign-suriname-2015.mp3"
139
+ sx={{ width: 40, height: 40 }}
140
+ />
141
+
142
+ <Stack
143
+ spacing={1}
144
+ direction={{ xs: "column", sm: "row" }}
145
+ flexGrow={1}
146
+ sx={{ minWidth: 0 }}
147
+ >
148
+ <ListItemText
149
+ disableTypography
150
+ primary={
151
+ <Typography
152
+ variant="subtitle2"
153
+ component="div"
154
+ sx={{ color: "text.secondary" }}
155
+ noWrap
156
+ >
157
+ design-suriname-2015.mp3
158
+ </Typography>
159
+ }
160
+ secondary={
161
+ <Stack
162
+ direction="row"
163
+ alignItems="center"
164
+ sx={{ typography: "caption", color: "text.disabled" }}
165
+ divider={
166
+ <Box
167
+ sx={{
168
+ mx: 0.5,
169
+ width: 2,
170
+ height: 2,
171
+ borderRadius: "50%",
172
+ bgcolor: "currentColor",
173
+ }}
174
+ />
175
+ }
176
+ >
177
+ <span>2.3 GB</span>
178
+ <span>30 min ago</span>
179
+ </Stack>
180
+ }
181
+ />
182
+
183
+ <Button size="small" variant="outlined">
184
+ Download
185
+ </Button>
186
+ </Stack>
187
+ </Stack>
188
+ );
189
+
190
+ const tagsAction = (
191
+ <Stack direction="row" spacing={0.75} flexWrap="wrap" sx={{ mt: 1.5 }}>
192
+ <Label variant="outlined" color="info">
193
+ Design
194
+ </Label>
195
+ <Label variant="outlined" color="warning">
196
+ Dashboard
197
+ </Label>
198
+ <Label variant="outlined">Design system</Label>
199
+ </Stack>
200
+ );
201
+
202
+ const paymentAction = (
203
+ <Stack direction="row" spacing={1} sx={{ mt: 1.5 }}>
204
+ <Button size="small" variant="contained">
205
+ Pay
206
+ </Button>
207
+ <Button size="small" variant="outlined">
208
+ Decline
209
+ </Button>
210
+ </Stack>
211
+ );
212
+
213
+ return (
214
+ <ListItemButton
215
+ disableRipple
216
+ sx={{
217
+ p: 2.5,
218
+ alignItems: "flex-start",
219
+ borderBottom: (theme) => `dashed 1px ${theme.palette.divider}`,
220
+ }}
221
+ >
222
+ {renderUnReadBadge}
223
+
224
+ {renderAvatar}
225
+
226
+ <Stack sx={{ flexGrow: 1 }}>
227
+ {renderText}
228
+ {notification.type === "friend" && friendAction}
229
+ {notification.type === "project" && projectAction}
230
+ {notification.type === "file" && fileAction}
231
+ {notification.type === "tags" && tagsAction}
232
+ {notification.type === "payment" && paymentAction}
233
+ </Stack>
234
+ </ListItemButton>
235
+ );
236
+ }
237
+
238
+ // ----------------------------------------------------------------------
239
+
240
+ function reader(data) {
241
+ return (
242
+ <Box
243
+ dangerouslySetInnerHTML={{ __html: data }}
244
+ sx={{
245
+ mb: 0.5,
246
+ "& p": { typography: "body2", m: 0 },
247
+ "& a": { color: "inherit", textDecoration: "none" },
248
+ "& strong": { typography: "subtitle2" },
249
+ }}
250
+ />
251
+ );
252
+ }
@@ -0,0 +1,48 @@
1
+ import Box from "@mui/material/Box";
2
+ import IconButton from "@mui/material/IconButton";
3
+ import Iconify from "../../components/Iconify";
4
+ import React from "react";
5
+ import SettingsDialog from "../../widgets/SettingsDialog";
6
+ import { motion } from "framer-motion";
7
+ import { varHover } from "../../components/animate";
8
+
9
+ // ----------------------------------------------------------------------
10
+
11
+ export default function SettingsButton({ sx }) {
12
+ const [settingsOpen, setSettingsOpen] = React.useState(false);
13
+
14
+ return (
15
+ <>
16
+ <Box
17
+ component={motion.div}
18
+ animate={{
19
+ rotate: [0, settingsOpen ? 0 : 360],
20
+ }}
21
+ transition={{
22
+ duration: 12,
23
+ ease: "linear",
24
+ repeat: Infinity,
25
+ }}
26
+ >
27
+ <IconButton
28
+ component={motion.button}
29
+ whileTap="tap"
30
+ whileHover="hover"
31
+ variants={varHover(1.05)}
32
+ aria-label="settings"
33
+ onClick={() => setSettingsOpen(true)}
34
+ sx={{
35
+ width: 40,
36
+ height: 40,
37
+ }}
38
+ >
39
+ <Iconify icon="solar:settings-bold-duotone" width={24} />
40
+ </IconButton>
41
+ </Box>
42
+ <SettingsDialog
43
+ open={settingsOpen}
44
+ handleClose={() => setSettingsOpen(false)}
45
+ />
46
+ </>
47
+ );
48
+ }
@@ -0,0 +1,12 @@
1
+ // ----------------------------------------------------------------------
2
+
3
+ export const HEADER = {
4
+ H_MOBILE: 64,
5
+ H_DESKTOP: 80,
6
+ H_DESKTOP_OFFSET: 80 - 16,
7
+ };
8
+
9
+ export const NAV = {
10
+ W_VERTICAL: 280,
11
+ W_MINI: 88,
12
+ };
@@ -0,0 +1,7 @@
1
+ "use client";
2
+ export { default as CompactLayout } from "./CompactLayout";
3
+ export { default as DashboardLayout } from "./DashboardLayout";
4
+ export { default as MainLayout } from "./MainLayout";
5
+ export { default as SimpleLayout } from "./SimpleLayout";
6
+ export { default as TwoSideLayout } from "./TwoSideLayout";
7
+ export { default as FullScreenLayout } from "./FullScreenLayout";