@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,211 @@
1
+ import Dialog from "@mui/material/Dialog";
2
+ import DialogContent from "@mui/material/DialogContent";
3
+ import DialogTitle from "@mui/material/DialogTitle";
4
+ import ItemsSummary from "../ItemSummary/ItemsSummary";
5
+ import React from "react";
6
+ import SelectAvatar from "../IconSelector/IconSelector";
7
+ import SparkleInput from "../SparkleInput/SparkleInput";
8
+ import StepComponent from "../StepComponent/StepComponent";
9
+
10
+ import { Grid, Stack, Switch, Typography } from "@mui/material";
11
+ import { publish, useEvent } from "@nucleoidai/react-event";
12
+
13
+ function AddItemWizard({ onSubmit, items, steps, stepExp }) {
14
+ const [activeStep, setActiveStep] = React.useState(0);
15
+ const [newItems, setNewItems] = React.useState(items);
16
+ const [platformDialog] = useEvent("PLATFORM_DIALOG", { open: false });
17
+
18
+ const handleNext = () => {
19
+ setActiveStep((prevActiveStep) => prevActiveStep + 1);
20
+ };
21
+
22
+ const handleBack = () => {
23
+ setActiveStep((prevActiveStep) => prevActiveStep - 1);
24
+ };
25
+
26
+ const handleEmojiSelect = (index) => (emoji) => {
27
+ setNewItems((prevItems) =>
28
+ prevItems.map((item, i) =>
29
+ i === index
30
+ ? {
31
+ ...item,
32
+ details: { ...item.details, icon: emoji.shortcodes },
33
+ }
34
+ : item
35
+ )
36
+ );
37
+ };
38
+ const handleSave = () => {
39
+ onSubmit(newItems);
40
+ publish("PLATFORM_DIALOG", { open: false });
41
+ setActiveStep(0);
42
+ };
43
+
44
+ const handleSwitchChange = (index) => (event) => {
45
+ // eslint-disable-next-line no-unused-vars
46
+ const serviceType = !event.target.checked ? "multiple" : "single";
47
+ setNewItems((prevItems) =>
48
+ prevItems.map((item, i) =>
49
+ i === index
50
+ ? {
51
+ ...item,
52
+ details: { ...item.details },
53
+ }
54
+ : item
55
+ )
56
+ );
57
+ };
58
+
59
+ const handleInputChange = (index, prop) => (event) => {
60
+ setNewItems((prevItems) =>
61
+ prevItems.map((item, i) =>
62
+ i === index
63
+ ? {
64
+ ...item,
65
+ details: { ...item.details, [prop]: event.target.value },
66
+ }
67
+ : item
68
+ )
69
+ );
70
+ };
71
+ const Project = () => {
72
+ return (
73
+ <Stack
74
+ container
75
+ direction="column"
76
+ alignItems="center"
77
+ justifyContent="center"
78
+ spacing={2}
79
+ >
80
+ <SparkleInput
81
+ prop="name"
82
+ value={newItems[0].details.name}
83
+ onChange={handleInputChange(0, "name")}
84
+ sparkle={false}
85
+ />
86
+ <Typography variant="subtitle1" color={"gray"}>
87
+ Select an Icon
88
+ </Typography>
89
+ <SelectAvatar
90
+ handleEmojiSelect={handleEmojiSelect(0)}
91
+ iconCategories={"project_icons"}
92
+ avatar={newItems[0].details.icon?.replace(/:/g, "").replace("/", ":")}
93
+ />
94
+ <Typography variant="subtitle1" color={"gray"} sx={{ mb: -2 }}>
95
+ Service Type
96
+ </Typography>
97
+ <Stack direction="row" alignItems="center">
98
+ <Typography>Single</Typography>
99
+ <Switch
100
+ data-cy="type-switch"
101
+ defaultChecked
102
+ onChange={handleSwitchChange(0)}
103
+ />
104
+ <Typography>Multiple</Typography>
105
+ </Stack>
106
+ </Stack>
107
+ );
108
+ };
109
+
110
+ const Service = () => {
111
+ return (
112
+ <Grid container justifyContent="center" mt={1} spacing={2}>
113
+ <Grid item xs={5}>
114
+ <Stack
115
+ sx={{
116
+ borderStyle: "none dotted none none",
117
+ borderWidth: 2,
118
+ padding: 2,
119
+ borderColor: (theme) => theme.palette.divider,
120
+ }}
121
+ >
122
+ <SparkleInput
123
+ prop="name"
124
+ value={newItems[1].details.name}
125
+ onChange={handleInputChange(1, "name")}
126
+ sparkle={false}
127
+ />
128
+ <Typography
129
+ variant="subtitle1"
130
+ color={"gray"}
131
+ textAlign={"center"}
132
+ sx={{ marginTop: 2, marginBottom: 1 }}
133
+ >
134
+ Select an Icon
135
+ </Typography>
136
+ <SelectAvatar
137
+ handleEmojiSelect={handleEmojiSelect(1)}
138
+ iconCategories={"service_icons"}
139
+ avatar={newItems[1]?.details.icon
140
+ ?.replace(/:/g, "")
141
+ .replace("/", ":")}
142
+ />
143
+ </Stack>
144
+ </Grid>
145
+ <Grid item xs={7}>
146
+ <SparkleInput
147
+ prop="description"
148
+ value={newItems[1].details.description}
149
+ onChange={handleInputChange(1, "description")}
150
+ multiline
151
+ rows={11}
152
+ />
153
+ </Grid>
154
+ </Grid>
155
+ );
156
+ };
157
+ const Summary = () => {
158
+ return <ItemsSummary newItems={newItems} />;
159
+ };
160
+
161
+ const StepPages = () => {
162
+ switch (activeStep) {
163
+ case 0:
164
+ return Project();
165
+ case 1:
166
+ return Service();
167
+ case 2:
168
+ return <Summary />;
169
+ }
170
+ };
171
+ return (
172
+ <Dialog
173
+ fullWidth={true}
174
+ maxWidth="sm"
175
+ open={platformDialog.open}
176
+ onClose={() => {
177
+ publish("ADD_NEW_DIALOG_OPENED", { open: false });
178
+ setActiveStep(0);
179
+ }}
180
+ >
181
+ <>
182
+ <DialogTitle
183
+ sx={{
184
+ backgroundColor: (theme) => theme.palette.background.default,
185
+ }}
186
+ ></DialogTitle>
187
+ <StepComponent
188
+ activeStep={activeStep}
189
+ steps={steps}
190
+ stepExp={stepExp}
191
+ handleNext={handleNext}
192
+ handleBack={handleBack}
193
+ handleSave={handleSave}
194
+ >
195
+ <DialogContent
196
+ sx={{
197
+ height: "100%",
198
+ alignContent: "center",
199
+ justifyContent: "center",
200
+ backgroundColor: (theme) => theme.palette.background.default,
201
+ }}
202
+ >
203
+ {StepPages()}
204
+ </DialogContent>
205
+ </StepComponent>
206
+ </>
207
+ </Dialog>
208
+ );
209
+ }
210
+
211
+ export default AddItemWizard;
@@ -0,0 +1 @@
1
+ export { default } from "./AddItemWizard";
@@ -0,0 +1,88 @@
1
+ import Box from "@mui/material/Box";
2
+ import Breadcrumbs from "@mui/material/Breadcrumbs";
3
+ import Link from "@mui/material/Link";
4
+ import LinkItem from "./link-item";
5
+ import PropTypes from "prop-types";
6
+ import Stack from "@mui/material/Stack";
7
+ import Typography from "@mui/material/Typography";
8
+
9
+ export default function CustomBreadcrumbs({
10
+ links,
11
+ action,
12
+ heading,
13
+ moreLink,
14
+ activeLast,
15
+ sx,
16
+ ...other
17
+ }) {
18
+ const lastLink = links[links.length - 1].name;
19
+
20
+ return (
21
+ <Box sx={{ ...sx }}>
22
+ <Stack direction="row" alignItems="center">
23
+ <Box sx={{ flexGrow: 1 }}>
24
+ {heading && (
25
+ <Typography variant="h4" gutterBottom>
26
+ {heading}
27
+ </Typography>
28
+ )}
29
+
30
+ {!!links.length && (
31
+ <Breadcrumbs separator={<Separator />} {...other}>
32
+ {links.map((link) => (
33
+ <LinkItem
34
+ key={link.name || ""}
35
+ link={link}
36
+ activeLast={activeLast}
37
+ disabled={link.name === lastLink}
38
+ />
39
+ ))}
40
+ </Breadcrumbs>
41
+ )}
42
+ </Box>
43
+
44
+ {action && <Box sx={{ flexShrink: 0 }}> {action} </Box>}
45
+ </Stack>
46
+
47
+ {!!moreLink && (
48
+ <Box sx={{ mt: 2 }}>
49
+ {moreLink.map((href) => (
50
+ <Link
51
+ key={href}
52
+ href={href}
53
+ variant="body2"
54
+ target="_blank"
55
+ rel="noopener"
56
+ sx={{ display: "table" }}
57
+ >
58
+ {href}
59
+ </Link>
60
+ ))}
61
+ </Box>
62
+ )}
63
+ </Box>
64
+ );
65
+ }
66
+
67
+ CustomBreadcrumbs.propTypes = {
68
+ sx: PropTypes.object,
69
+ action: PropTypes.node,
70
+ links: PropTypes.array,
71
+ heading: PropTypes.string,
72
+ moreLink: PropTypes.array,
73
+ activeLast: PropTypes.bool,
74
+ };
75
+
76
+ function Separator() {
77
+ return (
78
+ <Box
79
+ component="span"
80
+ sx={{
81
+ width: 4,
82
+ height: 4,
83
+ borderRadius: "50%",
84
+ bgcolor: "text.disabled",
85
+ }}
86
+ />
87
+ );
88
+ }
@@ -0,0 +1 @@
1
+ export { default } from "./CustomBreadcrumbs";
@@ -0,0 +1,58 @@
1
+ import Box from "@mui/material/Box";
2
+ import Link from "@mui/material/Link";
3
+ import PropTypes from "prop-types";
4
+ import RouterLink from "../../routes/components/router-link";
5
+
6
+ export default function BreadcrumbsLink({ link, activeLast, disabled }) {
7
+ const styles = {
8
+ typography: "body2",
9
+ alignItems: "center",
10
+ color: "text.primary",
11
+ display: "inline-flex",
12
+ ...(disabled &&
13
+ !activeLast && {
14
+ cursor: "default",
15
+ pointerEvents: "none",
16
+ color: "text.disabled",
17
+ }),
18
+ };
19
+
20
+ const renderContent = (
21
+ <>
22
+ {link.icon && (
23
+ <Box
24
+ component="span"
25
+ sx={{
26
+ mr: 1,
27
+ display: "inherit",
28
+ "& svg": { width: 20, height: 20 },
29
+ }}
30
+ >
31
+ {link.icon}
32
+ </Box>
33
+ )}
34
+
35
+ {link.name}
36
+ </>
37
+ );
38
+
39
+ if (link.href) {
40
+ return (
41
+ <Link component={RouterLink} href={link.href} sx={styles}>
42
+ {renderContent}
43
+ </Link>
44
+ );
45
+ }
46
+
47
+ return <Box sx={styles}> {renderContent} </Box>;
48
+ }
49
+
50
+ BreadcrumbsLink.propTypes = {
51
+ activeLast: PropTypes.bool,
52
+ disabled: PropTypes.bool,
53
+ link: PropTypes.shape({
54
+ href: PropTypes.string,
55
+ icon: PropTypes.node,
56
+ name: PropTypes.string,
57
+ }),
58
+ };
@@ -0,0 +1,46 @@
1
+ import Popover from "@mui/material/Popover";
2
+ import React from "react";
3
+ import { StyledArrow } from "./styles";
4
+ import { getPosition } from "./utils";
5
+ import { menuItemClasses } from "@mui/material/MenuItem";
6
+
7
+ export default function CustomPopover({
8
+ open,
9
+ children,
10
+ arrow = "top-right",
11
+ hiddenArrow,
12
+ sx,
13
+ ...other
14
+ }) {
15
+ const { style, anchorOrigin, transformOrigin } = getPosition(arrow);
16
+
17
+ return (
18
+ <Popover
19
+ open={Boolean(open)}
20
+ anchorEl={open}
21
+ anchorOrigin={anchorOrigin}
22
+ transformOrigin={transformOrigin}
23
+ slotProps={{
24
+ paper: {
25
+ sx: {
26
+ width: "auto",
27
+ overflow: "inherit",
28
+ ...style,
29
+ [`& .${menuItemClasses.root}`]: {
30
+ "& svg": {
31
+ mr: 2,
32
+ flexShrink: 0,
33
+ },
34
+ },
35
+ ...sx,
36
+ },
37
+ },
38
+ }}
39
+ {...other}
40
+ >
41
+ {!hiddenArrow && <StyledArrow arrow={arrow} />}
42
+
43
+ {children}
44
+ </Popover>
45
+ );
46
+ }
@@ -0,0 +1,3 @@
1
+ export { default } from "./CustomPopover";
2
+
3
+ export { default as usePopover } from "./usePopover";
@@ -0,0 +1,82 @@
1
+ import { alpha, styled } from "@mui/material/styles";
2
+
3
+ import { bgBlur } from "../../theme/css";
4
+
5
+ export const StyledArrow = styled("span")(({ arrow, theme }) => {
6
+ const SIZE = 14;
7
+
8
+ const POSITION = -(SIZE / 2) + 0.5;
9
+
10
+ const topStyle = {
11
+ top: POSITION,
12
+ transform: "rotate(135deg)",
13
+ };
14
+
15
+ const bottomStyle = {
16
+ bottom: POSITION,
17
+ transform: "rotate(-45deg)",
18
+ };
19
+
20
+ const leftStyle = {
21
+ left: POSITION,
22
+ transform: "rotate(45deg)",
23
+ };
24
+
25
+ const rightStyle = {
26
+ right: POSITION,
27
+ transform: "rotate(-135deg)",
28
+ };
29
+
30
+ return {
31
+ width: SIZE,
32
+ height: SIZE,
33
+ position: "absolute",
34
+ borderBottomLeftRadius: SIZE / 4,
35
+ clipPath: "polygon(0% 0%, 100% 100%, 0% 100%)",
36
+ border: `solid 1px ${alpha(
37
+ theme.palette.mode === "light"
38
+ ? theme.palette.grey[500]
39
+ : theme.palette.common.black,
40
+ 0.12
41
+ )}`,
42
+ ...bgBlur({
43
+ color: theme.palette.background.paper,
44
+ }),
45
+ // Top
46
+ ...(arrow === "top-left" && { ...topStyle, left: 20 }),
47
+ ...(arrow === "top-center" && {
48
+ ...topStyle,
49
+ left: 0,
50
+ right: 0,
51
+ margin: "auto",
52
+ }),
53
+ ...(arrow === "top-right" && { ...topStyle, right: 20 }),
54
+ // Bottom
55
+ ...(arrow === "bottom-left" && { ...bottomStyle, left: 20 }),
56
+ ...(arrow === "bottom-center" && {
57
+ ...bottomStyle,
58
+ left: 0,
59
+ right: 0,
60
+ margin: "auto",
61
+ }),
62
+ ...(arrow === "bottom-right" && { ...bottomStyle, right: 20 }),
63
+ // Left
64
+ ...(arrow === "left-top" && { ...leftStyle, top: 20 }),
65
+ ...(arrow === "left-center" && {
66
+ ...leftStyle,
67
+ top: 0,
68
+ bottom: 0,
69
+ margin: "auto",
70
+ }),
71
+ ...(arrow === "left-bottom" && { ...leftStyle, bottom: 20 }),
72
+ // Right
73
+ ...(arrow === "right-top" && { ...rightStyle, top: 20 }),
74
+ ...(arrow === "right-center" && {
75
+ ...rightStyle,
76
+ top: 0,
77
+ bottom: 0,
78
+ margin: "auto",
79
+ }),
80
+ ...(arrow === "right-bottom" && { ...rightStyle, bottom: 20 }),
81
+ };
82
+ });
@@ -0,0 +1,20 @@
1
+ import { useCallback, useState } from "react";
2
+
3
+ export default function usePopover() {
4
+ const [open, setOpen] = useState(null);
5
+
6
+ const onOpen = useCallback((event) => {
7
+ setOpen(event.currentTarget);
8
+ }, []);
9
+
10
+ const onClose = useCallback(() => {
11
+ setOpen(null);
12
+ }, []);
13
+
14
+ return {
15
+ open,
16
+ onOpen,
17
+ onClose,
18
+ setOpen,
19
+ };
20
+ }
@@ -0,0 +1,100 @@
1
+ export function getPosition(arrow) {
2
+ let props;
3
+
4
+ switch (arrow) {
5
+ case "top-left":
6
+ props = {
7
+ style: { ml: -0.75 },
8
+ anchorOrigin: { vertical: "bottom", horizontal: "left" },
9
+ transformOrigin: { vertical: "top", horizontal: "left" },
10
+ };
11
+ break;
12
+ case "top-center":
13
+ props = {
14
+ style: {},
15
+ anchorOrigin: { vertical: "bottom", horizontal: "center" },
16
+ transformOrigin: { vertical: "top", horizontal: "center" },
17
+ };
18
+ break;
19
+ case "top-right":
20
+ props = {
21
+ style: { ml: 0.75 },
22
+ anchorOrigin: { vertical: "bottom", horizontal: "right" },
23
+ transformOrigin: { vertical: "top", horizontal: "right" },
24
+ };
25
+ break;
26
+ case "bottom-left":
27
+ props = {
28
+ style: { ml: -0.75 },
29
+ anchorOrigin: { vertical: "top", horizontal: "left" },
30
+ transformOrigin: { vertical: "bottom", horizontal: "left" },
31
+ };
32
+ break;
33
+ case "bottom-center":
34
+ props = {
35
+ style: {},
36
+ anchorOrigin: { vertical: "top", horizontal: "center" },
37
+ transformOrigin: { vertical: "bottom", horizontal: "center" },
38
+ };
39
+ break;
40
+ case "bottom-right":
41
+ props = {
42
+ style: { ml: 0.75 },
43
+ anchorOrigin: { vertical: "top", horizontal: "right" },
44
+ transformOrigin: { vertical: "bottom", horizontal: "right" },
45
+ };
46
+ break;
47
+ case "left-top":
48
+ props = {
49
+ style: { mt: -0.75 },
50
+ anchorOrigin: { vertical: "top", horizontal: "right" },
51
+ transformOrigin: { vertical: "top", horizontal: "left" },
52
+ };
53
+ break;
54
+ case "left-center":
55
+ props = {
56
+ style: {},
57
+ anchorOrigin: { vertical: "center", horizontal: "right" },
58
+ transformOrigin: { vertical: "center", horizontal: "left" },
59
+ };
60
+ break;
61
+ case "left-bottom":
62
+ props = {
63
+ style: { mt: 0.75 },
64
+ anchorOrigin: { vertical: "bottom", horizontal: "right" },
65
+ transformOrigin: { vertical: "bottom", horizontal: "left" },
66
+ };
67
+ break;
68
+ case "right-top":
69
+ props = {
70
+ style: { mt: -0.75 },
71
+ anchorOrigin: { vertical: "top", horizontal: "left" },
72
+ transformOrigin: { vertical: "top", horizontal: "right" },
73
+ };
74
+ break;
75
+ case "right-center":
76
+ props = {
77
+ style: {},
78
+ anchorOrigin: { vertical: "center", horizontal: "left" },
79
+ transformOrigin: { vertical: "center", horizontal: "right" },
80
+ };
81
+ break;
82
+ case "right-bottom":
83
+ props = {
84
+ style: { mt: 0.75 },
85
+ anchorOrigin: { vertical: "bottom", horizontal: "left" },
86
+ transformOrigin: { vertical: "bottom", horizontal: "right" },
87
+ };
88
+ break;
89
+
90
+ // top-right
91
+ default:
92
+ props = {
93
+ style: { ml: 0.75 },
94
+ anchorOrigin: { vertical: "bottom", horizontal: "right" },
95
+ transformOrigin: { vertical: "top", horizontal: "right" },
96
+ };
97
+ }
98
+
99
+ return props;
100
+ }