@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,69 @@
1
+ import React from "react";
2
+ import styles from "../../widgets/LoginForm/LoginFormStyles";
3
+ import { Box, Button, Link as MuiLink, TextField } from "@mui/material";
4
+
5
+ const NucleoidLoginForm = ({
6
+ email,
7
+ password,
8
+ setEmail,
9
+ setPassword,
10
+ onSubmit,
11
+ }) => (
12
+ <Box
13
+ component="form"
14
+ sx={styles.formBoxStyle}
15
+ noValidate
16
+ autoComplete="off"
17
+ onSubmit={(e) => {
18
+ e.preventDefault();
19
+ if (typeof onSubmit === "function") {
20
+ onSubmit(email, password);
21
+ }
22
+ }}
23
+ >
24
+ <TextField
25
+ required
26
+ type="email"
27
+ label="Email"
28
+ variant="outlined"
29
+ sx={{ margin: "1rem 0 0", width: "100%" }}
30
+ size="small"
31
+ value={email}
32
+ onChange={(e) => setEmail(e.target.value)}
33
+ />
34
+
35
+ <TextField
36
+ required
37
+ label="Password"
38
+ type="password"
39
+ variant="outlined"
40
+ sx={{ margin: "1rem 0 1rem", width: "100%" }}
41
+ size="small"
42
+ value={password}
43
+ onChange={(e) => setPassword(e.target.value)}
44
+ />
45
+
46
+ <MuiLink
47
+ href="/console/login2"
48
+ variant="body2"
49
+ sx={{
50
+ textDecoration: "none",
51
+ alignSelf: "center",
52
+ justifySelf: "center",
53
+ }}
54
+ >
55
+ Forgot Password?
56
+ </MuiLink>
57
+
58
+ <Button
59
+ variant="contained"
60
+ color="primary"
61
+ sx={styles.signInButtonStyle}
62
+ type="submit"
63
+ >
64
+ Sign In
65
+ </Button>
66
+ </Box>
67
+ );
68
+
69
+ export default NucleoidLoginForm;
@@ -0,0 +1 @@
1
+ export { default } from "./NucleoidLoginForm.jsx";
@@ -0,0 +1,3 @@
1
+ const styles = {};
2
+
3
+ export default styles;
@@ -0,0 +1,76 @@
1
+ import { Box } from "@mui/material";
2
+ import Drawer from "@mui/material/Drawer";
3
+ import { Link } from "react-router-dom";
4
+ import List from "@mui/material/List";
5
+ import ListItemButton from "@mui/material/ListItemButton";
6
+ import ListItemText from "@mui/material/ListItemText";
7
+ import React from "react";
8
+ import styles from "./styles";
9
+
10
+ const Sidebar = ({ routes, isCollapsed, currentPage }) => {
11
+ const drawerWidth = isCollapsed ? 75 : 280;
12
+
13
+ return (
14
+ <>
15
+ <Box
16
+ sx={{
17
+ top: 0,
18
+ left: 0,
19
+ height: "4rem",
20
+ width: 75,
21
+ position: "absolute",
22
+ marginRight: -10.2,
23
+ }}
24
+ ></Box>
25
+ <Drawer
26
+ anchor="left"
27
+ variant="persistent"
28
+ open={true}
29
+ data-testid="sidebar"
30
+ sx={{
31
+ width: drawerWidth,
32
+ "& .MuiDrawer-paper": {
33
+ ...styles.paper,
34
+ width: drawerWidth,
35
+ transition: ".5s ease",
36
+ },
37
+ }}
38
+ >
39
+ <List sx={styles.list}>
40
+ {routes.map((page, index) => (
41
+ <div key={index}>
42
+ <Link to={page.url} style={{ textDecoration: "none" }}>
43
+ <ListItemButton sx={styles.listItemButton}>
44
+ <Box
45
+ sx={{
46
+ ...styles.box,
47
+ flexDirection: isCollapsed ? "column" : "row",
48
+ alignItems: isCollapsed ? "center" : "flex-start",
49
+ }}
50
+ >
51
+ <Box
52
+ sx={{
53
+ mb: isCollapsed ? 0 : 0,
54
+ mr: isCollapsed ? 0 : 3,
55
+ }}
56
+ >
57
+ {page.url === currentPage ? (
58
+ <page.activeIcon />
59
+ ) : (
60
+ <page.deactiveIcon />
61
+ )}
62
+ </Box>
63
+
64
+ {!isCollapsed && <ListItemText primary={page.name} />}
65
+ </Box>
66
+ </ListItemButton>
67
+ </Link>
68
+ </div>
69
+ ))}
70
+ </List>
71
+ </Drawer>
72
+ </>
73
+ );
74
+ };
75
+
76
+ export default Sidebar;
@@ -0,0 +1 @@
1
+ export { default } from "./Sidebar.jsx";
@@ -0,0 +1,25 @@
1
+ const styles = {
2
+ paper: {
3
+ top: "4rem",
4
+ backgroundColor: "custom.sidebarBG",
5
+ height: `calc(100% - 4rem)`,
6
+ zIndex: 1,
7
+ padding: "0 15px",
8
+
9
+ color: "text.secondary",
10
+ },
11
+ list: { padding: "15px 0" },
12
+ listItemButton: {
13
+ color: "primary.contrastText",
14
+ "&:hover": {
15
+ bgcolor: "text.secondary",
16
+ color: "primary.contrastText",
17
+ },
18
+ },
19
+ box: {
20
+ display: "flex",
21
+ width: "100%",
22
+ },
23
+ };
24
+
25
+ export default styles;
@@ -0,0 +1,55 @@
1
+ import { Button } from "@mui/material";
2
+ import React from "react";
3
+ import styles from "../../widgets/LoginForm/LoginFormStyles";
4
+
5
+ import { GitHub, Google, LinkedIn } from "@mui/icons-material";
6
+
7
+ const SocialLoginButtons = ({
8
+ googleEnable,
9
+ onGoogle,
10
+ githubEnable,
11
+ onGithub,
12
+ linkedinEnable,
13
+ onLinkedin,
14
+ }) => {
15
+ return (
16
+ <>
17
+ {githubEnable && (
18
+ <Button
19
+ startIcon={<GitHub />}
20
+ data-cy="github-login-button"
21
+ variant="contained"
22
+ color="primary"
23
+ sx={styles.githubButtonStyle}
24
+ onClick={onGithub}
25
+ >
26
+ Continue with GitHub
27
+ </Button>
28
+ )}
29
+
30
+ {googleEnable && (
31
+ <Button
32
+ startIcon={<Google style={{ color: "#DB4437" }} />}
33
+ variant="contained"
34
+ color="primary"
35
+ sx={styles.googleButtonStyle}
36
+ onClick={onGoogle}
37
+ >
38
+ Continue with Google
39
+ </Button>
40
+ )}
41
+ {linkedinEnable && (
42
+ <Button
43
+ startIcon={<LinkedIn />}
44
+ variant="contained"
45
+ sx={styles.linkedinButtonStyle}
46
+ onClick={onLinkedin}
47
+ >
48
+ Continue with LinkedIn
49
+ </Button>
50
+ )}
51
+ </>
52
+ );
53
+ };
54
+
55
+ export default SocialLoginButtons;
@@ -0,0 +1 @@
1
+ export { default } from "./SocialLoginButtons";
@@ -0,0 +1,3 @@
1
+ const styles = {};
2
+
3
+ export default styles;
@@ -0,0 +1,186 @@
1
+ import ArrowDropDownIcon from "@mui/icons-material/ArrowDropDown";
2
+ import { Link } from "react-router-dom";
3
+ import MenuIcon from "@mui/icons-material/Menu";
4
+ import React from "react";
5
+ import config from "../../config/config";
6
+ import styles from "./styles";
7
+ import { useContext } from "../../ContextProvider/ContextProvider";
8
+ import { useNavigate } from "react-router";
9
+
10
+ import {
11
+ AppBar,
12
+ Avatar,
13
+ Box,
14
+ Button,
15
+ IconButton,
16
+ Menu,
17
+ MenuItem,
18
+ Toolbar,
19
+ Tooltip,
20
+ Typography,
21
+ } from "@mui/material";
22
+
23
+ function TopNavBar({
24
+ anchorElUser,
25
+ handleOpenUserMenu,
26
+ handleCloseUserMenu,
27
+ itemsData,
28
+ onItemSelect,
29
+ routes,
30
+ sideBarToggle,
31
+ selectedItem,
32
+ setSelectedItem,
33
+ itemUrl,
34
+ itemName,
35
+ userData,
36
+ }) {
37
+ const [anchorElItem, setAnchorElItem] = React.useState(null);
38
+ const { largeIcon } = config().template.login;
39
+ const handleOpenItemMenu = (event) => {
40
+ setAnchorElItem(event.currentTarget);
41
+ };
42
+
43
+ const handleCloseItemMenu = () => {
44
+ setAnchorElItem(null);
45
+ };
46
+ const navigate = useNavigate();
47
+
48
+ const selectItem = (item) => {
49
+ dispatch({ type: "ITEM_SELECT", payload: item.id });
50
+ setSelectedItem(item);
51
+ onItemSelect(item);
52
+ handleCloseItemMenu();
53
+ };
54
+
55
+ const [state, dispatch] = useContext();
56
+ const settings = [
57
+ {
58
+ name: "Profile",
59
+ action: () => {
60
+ handleCloseUserMenu();
61
+ },
62
+ },
63
+ {
64
+ name: "Logout",
65
+ action: () => {
66
+ dispatch({ type: "LOGOUT" });
67
+ handleCloseUserMenu();
68
+ navigate("/login");
69
+ navigate(0);
70
+ },
71
+ },
72
+ ];
73
+
74
+ React.useEffect(() => {
75
+ // eslint-disable-next-line react-hooks/exhaustive-deps
76
+ }, [state.itemId]);
77
+
78
+ return (
79
+ <AppBar position="sticky" sx={{ ...styles.appBar, maxHeight: "4.25rem" }}>
80
+ <Toolbar disableGutters sx={styles.toolBar}>
81
+ <Box
82
+ component="img"
83
+ src={largeIcon}
84
+ onClick={() => navigate("/")}
85
+ sx={{ cursor: "pointer" }}
86
+ />
87
+ {selectedItem && (
88
+ <Box>
89
+ <IconButton size="large" onClick={sideBarToggle} color="inherit">
90
+ <MenuIcon />
91
+ </IconButton>
92
+ </Box>
93
+ )}
94
+ <Box
95
+ sx={{
96
+ flexGrow: 0,
97
+ pl: 2,
98
+ }}
99
+ >
100
+ <Button
101
+ onClick={handleOpenItemMenu}
102
+ sx={{ my: 2, color: "primary.contrastText" }}
103
+ >
104
+ {state.itemId ? selectedItem?.name : `Select a ${itemName}`}
105
+ <ArrowDropDownIcon />
106
+ </Button>
107
+ <Menu
108
+ id="item-menu"
109
+ anchorEl={anchorElItem}
110
+ keepMounted
111
+ open={Boolean(anchorElItem)}
112
+ onClose={handleCloseItemMenu}
113
+ sx={{ my: 2, color: "primary.contrastText" }}
114
+ >
115
+ {itemsData?.map((item) => (
116
+ <MenuItem
117
+ key={item.id}
118
+ component={Link}
119
+ to={itemUrl}
120
+ onClick={() => selectItem(item)}
121
+ >
122
+ <Typography textAlign="center">{item.name}</Typography>
123
+ </MenuItem>
124
+ ))}
125
+ </Menu>
126
+
127
+ {routes
128
+ .filter((route) => !route.hide)
129
+ .map((page, index) => (
130
+ <Button
131
+ key={index}
132
+ component={Link}
133
+ to={page.url}
134
+ sx={{ my: 2, color: "primary.contrastText" }}
135
+ >
136
+ {page.name}
137
+ </Button>
138
+ ))}
139
+ </Box>
140
+ <Box sx={{ position: "absolute", right: 30 }}>
141
+ <Tooltip title="Open settings">
142
+ <IconButton onClick={handleOpenUserMenu} sx={{ p: 0 }}>
143
+ <Avatar
144
+ sx={{ width: "2.2rem", height: "auto" }}
145
+ data-cy="user-avatar"
146
+ src={userData?.avatar_url || userData?.picture}
147
+ />
148
+ </IconButton>
149
+ </Tooltip>
150
+ <Menu
151
+ sx={{ mt: "45px" }}
152
+ id="menu-appbar"
153
+ anchorEl={anchorElUser}
154
+ anchorOrigin={{
155
+ vertical: "top",
156
+ horizontal: "right",
157
+ }}
158
+ keepMounted
159
+ transformOrigin={{
160
+ vertical: "top",
161
+ horizontal: "right",
162
+ }}
163
+ open={Boolean(anchorElUser)}
164
+ onClose={handleCloseUserMenu}
165
+ >
166
+ <Typography
167
+ sx={{
168
+ margin: "0.5rem",
169
+ }}
170
+ data-cy="user-name"
171
+ >
172
+ {userData?.name}
173
+ </Typography>
174
+ {settings.map((setting) => (
175
+ <MenuItem key={setting.name} onClick={setting.action}>
176
+ <Typography textAlign="center">{setting.name}</Typography>
177
+ </MenuItem>
178
+ ))}
179
+ </Menu>
180
+ </Box>
181
+ </Toolbar>
182
+ </AppBar>
183
+ );
184
+ }
185
+
186
+ export default TopNavBar;
@@ -0,0 +1 @@
1
+ export { default } from "./TopNavBar";
@@ -0,0 +1,7 @@
1
+ const styles = {
2
+ appBar: { zIndex: 1201 },
3
+ toolBar: { pr: 2, pl: 4, color: "primary.contrastText" },
4
+ imgBox: { height: "20px", marginX: "15px" },
5
+ };
6
+
7
+ export default styles;
@@ -0,0 +1,4 @@
1
+ export * from "./variants";
2
+
3
+ export { default as MotionViewport } from "./motion-viewport";
4
+ export { default as MotionContainer } from "./motion-container";
@@ -0,0 +1,38 @@
1
+ import Box from "@mui/material/Box";
2
+ import React from "react";
3
+ import { motion } from "framer-motion";
4
+ import { varContainer } from "./variants";
5
+
6
+ export default function MotionContainer({
7
+ animate,
8
+ action = false,
9
+ children,
10
+ ...other
11
+ }) {
12
+ if (action) {
13
+ return (
14
+ <Box
15
+ component={motion.div}
16
+ initial={false}
17
+ animate={animate ? "animate" : "exit"}
18
+ variants={varContainer()}
19
+ {...other}
20
+ >
21
+ {children}
22
+ </Box>
23
+ );
24
+ }
25
+
26
+ return (
27
+ <Box
28
+ component={motion.div}
29
+ initial="initial"
30
+ animate="animate"
31
+ exit="exit"
32
+ variants={varContainer()}
33
+ {...other}
34
+ >
35
+ {children}
36
+ </Box>
37
+ );
38
+ }
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+
3
+ import { LazyMotion, domMax, motion } from "framer-motion";
4
+
5
+ export function MotionLazy({ children }) {
6
+ return (
7
+ <LazyMotion strict features={domMax}>
8
+ <motion.div style={{ height: "100%" }}> {children} </motion.div>
9
+ </LazyMotion>
10
+ );
11
+ }
@@ -0,0 +1,30 @@
1
+ import Box from "@mui/material/Box";
2
+ import React from "react";
3
+ import { motion } from "framer-motion";
4
+ import { useResponsive } from "../../hooks/use-responsive";
5
+ import { varContainer } from "./variants";
6
+
7
+ export default function MotionViewport({
8
+ children,
9
+ disableAnimatedMobile = true,
10
+ ...other
11
+ }) {
12
+ const smDown = useResponsive("down", "sm");
13
+
14
+ if (smDown && disableAnimatedMobile) {
15
+ return <Box {...other}>{children}</Box>;
16
+ }
17
+
18
+ return (
19
+ <Box
20
+ component={motion.div}
21
+ initial="initial"
22
+ whileInView="animate"
23
+ viewport={{ once: true, amount: 0.3 }}
24
+ variants={varContainer()}
25
+ {...other}
26
+ >
27
+ {children}
28
+ </Box>
29
+ );
30
+ }
@@ -0,0 +1,4 @@
1
+ export const varHover = (hover = 1.09, tap = 0.97) => ({
2
+ hover: { scale: hover },
3
+ tap: { scale: tap },
4
+ });
@@ -0,0 +1,97 @@
1
+ export const varBgColor = (props) => {
2
+ const colors = props?.colors || ["#19dcea", "#b22cff"];
3
+ const duration = props?.duration || 5;
4
+ const ease = props?.ease || "linear";
5
+
6
+ return {
7
+ animate: {
8
+ background: colors,
9
+ transition: { duration, ease },
10
+ },
11
+ };
12
+ };
13
+
14
+ export const varBgKenburns = (props) => {
15
+ const duration = props?.duration || 5;
16
+ const ease = props?.ease || "easeOut";
17
+
18
+ return {
19
+ top: {
20
+ animate: {
21
+ scale: [1, 1.25],
22
+ y: [0, -15],
23
+ transformOrigin: ["50% 16%", "50% top"],
24
+ transition: { duration, ease },
25
+ },
26
+ },
27
+ bottom: {
28
+ animate: {
29
+ scale: [1, 1.25],
30
+ y: [0, 15],
31
+ transformOrigin: ["50% 84%", "50% bottom"],
32
+ transition: { duration, ease },
33
+ },
34
+ },
35
+ left: {
36
+ animate: {
37
+ scale: [1, 1.25],
38
+ x: [0, 20],
39
+ y: [0, 15],
40
+ transformOrigin: ["16% 50%", "0% left"],
41
+ transition: { duration, ease },
42
+ },
43
+ },
44
+ right: {
45
+ animate: {
46
+ scale: [1, 1.25],
47
+ x: [0, -20],
48
+ y: [0, -15],
49
+ transformOrigin: ["84% 50%", "0% right"],
50
+ transition: { duration, ease },
51
+ },
52
+ },
53
+ };
54
+ };
55
+
56
+ export const varBgPan = (props) => {
57
+ const colors = props?.colors || ["#ee7752", "#e73c7e", "#23a6d5", "#23d5ab"];
58
+ const duration = props?.duration || 5;
59
+ const ease = props?.ease || "linear";
60
+
61
+ const gradient = (deg) => `linear-gradient(${deg}deg, ${colors})`;
62
+
63
+ return {
64
+ top: {
65
+ animate: {
66
+ backgroundImage: [gradient(0), gradient(0)],
67
+ backgroundPosition: ["center 99%", "center 1%"],
68
+ backgroundSize: ["100% 600%", "100% 600%"],
69
+ transition: { duration, ease },
70
+ },
71
+ },
72
+ right: {
73
+ animate: {
74
+ backgroundPosition: ["1% center", "99% center"],
75
+ backgroundImage: [gradient(270), gradient(270)],
76
+ backgroundSize: ["600% 100%", "600% 100%"],
77
+ transition: { duration, ease },
78
+ },
79
+ },
80
+ bottom: {
81
+ animate: {
82
+ backgroundImage: [gradient(0), gradient(0)],
83
+ backgroundPosition: ["center 1%", "center 99%"],
84
+ backgroundSize: ["100% 600%", "100% 600%"],
85
+ transition: { duration, ease },
86
+ },
87
+ },
88
+ left: {
89
+ animate: {
90
+ backgroundPosition: ["99% center", "1% center"],
91
+ backgroundImage: [gradient(270), gradient(270)],
92
+ backgroundSize: ["600% 100%", "600% 100%"],
93
+ transition: { duration, ease },
94
+ },
95
+ },
96
+ };
97
+ };