@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,155 @@
1
+ import axios from "axios";
2
+ import config from "../config/config";
3
+ import createAuthRefreshInterceptor from "axios-auth-refresh";
4
+ import { jwtDecode } from "jwt-decode";
5
+ import oauth from "./oauth";
6
+ import { publish } from "@nucleoidai/react-event";
7
+ import { storage } from "@nucleoidjs/webstorage";
8
+
9
+ const instance = axios.create({
10
+ headers: {
11
+ common: {
12
+ "Content-Type": "application/json",
13
+ },
14
+ },
15
+ });
16
+
17
+ instance.interceptors.request.use((request) => {
18
+ const { base } = config();
19
+ const accessToken = storage.get("link", "accessToken");
20
+
21
+ if (!accessToken) {
22
+ window.location.href = base === "/" ? "/login" : `${base}/login`;
23
+ }
24
+
25
+ request.headers["Authorization"] = `Bearer ${accessToken}`;
26
+
27
+ publish("LOADED", { loading: true });
28
+
29
+ return request;
30
+ });
31
+
32
+ instance.interceptors.response.use(
33
+ (response) => {
34
+ if (response.headers["content-type"] === "application/json") {
35
+ response.data = JSON.parse(response.data);
36
+ }
37
+ publish("LOADED", { loading: false });
38
+ return response;
39
+ },
40
+ async (error) => {
41
+ publish("LOADED", { loading: false });
42
+ const statusCode = error.response?.status;
43
+ switch (statusCode) {
44
+ case 400:
45
+ publish("GLOBAL_MESSAGE_POSTED", {
46
+ status: true,
47
+ message: "BAD REQUEST",
48
+ severity: "warning",
49
+ });
50
+ break;
51
+ case 403:
52
+ publish("GLOBAL_MESSAGE_POSTED", {
53
+ status: true,
54
+ message: "ERROR",
55
+ severity: "warning",
56
+ });
57
+ break;
58
+ case 404:
59
+ publish("GLOBAL_MESSAGE_POSTED", {
60
+ status: true,
61
+ message: "NOT FOUND",
62
+ severity: "warning",
63
+ });
64
+ break;
65
+ case 500:
66
+ publish("GLOBAL_MESSAGE_POSTED", {
67
+ status: true,
68
+ message: "INTERNAL SERVER ERROR",
69
+ severity: "warning",
70
+ });
71
+ break;
72
+ case 502:
73
+ publish("GLOBAL_MESSAGE_POSTED", {
74
+ status: true,
75
+ message: "BAD GATEWAY",
76
+ severity: "warning",
77
+ });
78
+ break;
79
+ }
80
+ return Promise.reject(error);
81
+ }
82
+ );
83
+
84
+ export const fetcher = (url) => instance.get(url).then((res) => res.data);
85
+
86
+ const refreshAuthLogic = async (failedRequest) => {
87
+ try {
88
+ const { appId } = config();
89
+
90
+ const projectId = storage.get("projectId");
91
+
92
+ const identityProvider = storage.get("link", "identityProvider");
93
+
94
+ const { data } = await oauth.post("/oauth", {
95
+ refreshToken: storage.get("link", "refreshToken"),
96
+ appId,
97
+ projectId,
98
+ identityProvider,
99
+ });
100
+
101
+ const accessToken = data.accessToken;
102
+
103
+ failedRequest.response.config.headers["Authorization"] =
104
+ "Bearer " + accessToken;
105
+
106
+ storage.set("link", "accessToken", accessToken);
107
+ return Promise.resolve();
108
+ } catch (error) {
109
+ const { name, base } = config();
110
+
111
+ storage.remove("link", "accessToken");
112
+ storage.remove("link", "refreshToken");
113
+
114
+ window.location.href = `${window.location.origin}${base}/login`;
115
+ return Promise.reject(error);
116
+ }
117
+ };
118
+
119
+ const refreshInterceptor =
120
+ typeof createAuthRefreshInterceptor === "function"
121
+ ? createAuthRefreshInterceptor
122
+ : createAuthRefreshInterceptor.default;
123
+
124
+ refreshInterceptor(instance, refreshAuthLogic, {
125
+ statusCodes: [401, 403],
126
+ shouldRefresh: () => {
127
+ const { name, base } = config();
128
+ const token = storage.get("link", "accessToken");
129
+
130
+ if (!token) {
131
+ window.location.href = `${window.location.origin}${base}/login`;
132
+ return false;
133
+ }
134
+
135
+ try {
136
+ const decodedToken = jwtDecode(token);
137
+ if (decodedToken.exp * 1000 < Date.now()) {
138
+ return true;
139
+ } else {
140
+ publish("GLOBAL_MESSAGE_POSTED", {
141
+ status: true,
142
+ message: "UNAUTHORIZED",
143
+ severity: "warning",
144
+ });
145
+ }
146
+ } catch (err) {
147
+ window.location.href = `${window.location.origin}${base}/login`;
148
+ return false;
149
+ }
150
+
151
+ return false;
152
+ },
153
+ });
154
+
155
+ export default instance;
@@ -0,0 +1,27 @@
1
+ import axios from "axios";
2
+ import axiosRetry from "axios-retry";
3
+ import config from "../config/config.js";
4
+ import qs from "qs";
5
+
6
+ const instance = axios.create({
7
+ baseURL: config().api,
8
+ headers: {
9
+ common: {
10
+ "Content-Type": "application/json",
11
+ },
12
+ },
13
+ });
14
+
15
+ axiosRetry(instance, { retries: 3 });
16
+
17
+ instance.interceptors.response.use(
18
+ (response) => {
19
+ response.data = qs.parse(response.data);
20
+ return response;
21
+ },
22
+ (error) => {
23
+ return Promise.reject(error);
24
+ }
25
+ );
26
+
27
+ export default instance;
@@ -0,0 +1,110 @@
1
+ import axios from "axios";
2
+ import config from "../config/config.js";
3
+ import http from "./index";
4
+ import { jwtDecode } from "jwt-decode";
5
+ import oauth from "./oauth";
6
+ import { storage } from "@nucleoidjs/webstorage";
7
+
8
+ const instance = axios.create({
9
+ headers: {
10
+ common: {
11
+ "Content-Type": "application/json",
12
+ },
13
+ },
14
+ });
15
+
16
+ instance.interceptors.request.use(async (request) => {
17
+ const refreshToken = await storage.get("link", "refreshToken");
18
+ if (refreshToken) {
19
+ request.headers["Authorization"] = `Bearer ${refreshToken}`;
20
+ }
21
+ return request;
22
+ });
23
+
24
+ instance.getUserDetails = async () => {
25
+ try {
26
+ const refreshToken = await storage.get("link", "refreshToken");
27
+
28
+ if (!refreshToken) {
29
+ console.log("No refresh token found");
30
+ return null;
31
+ }
32
+
33
+ let accessToken = await storage.get("link", "accessToken");
34
+
35
+ if (!accessToken) {
36
+ console.log("No access token found");
37
+ return null;
38
+ }
39
+
40
+ try {
41
+ const decodedToken = jwtDecode(accessToken);
42
+ const isExpired = decodedToken.exp * 1000 < Date.now();
43
+
44
+ if (isExpired) {
45
+ console.log(
46
+ "Access token expired, refreshing before fetching user details..."
47
+ );
48
+ const { appId } = config();
49
+ const projectId = storage.get("projectId");
50
+ const identityProvider = storage.get("link", "identityProvider");
51
+
52
+ const { data } = await oauth.post("/oauth", {
53
+ refreshToken,
54
+ appId,
55
+ projectId,
56
+ identityProvider,
57
+ });
58
+
59
+ accessToken = data.accessToken;
60
+ storage.set("link", "accessToken", accessToken);
61
+ console.log(
62
+ "Access token refreshed successfully, now fetching user details"
63
+ );
64
+ }
65
+ } catch (error) {
66
+ console.error("Error checking or refreshing token:", error);
67
+ return null;
68
+ }
69
+
70
+ const response = await http.get("/oauth/user", {
71
+ headers: {
72
+ "X-Refresh-Token": refreshToken,
73
+ },
74
+ });
75
+
76
+ if (response.data && response.data.user) {
77
+ return response.data.user;
78
+ }
79
+
80
+ console.log("No user data received from server");
81
+ return null;
82
+ } catch (error) {
83
+ console.error("Error fetching user details from server:", error);
84
+ return null;
85
+ }
86
+ };
87
+
88
+ instance.getPermittedUsers = async () => {
89
+ const userIds = [];
90
+ const refreshToken = await storage.get("link", "refreshToken");
91
+ const response = await http.get("/permissions");
92
+
93
+ response.data.forEach((permission) => {
94
+ userIds.push(permission.userId);
95
+ });
96
+
97
+ const users = await Promise.all(
98
+ userIds.map(async (userId) => {
99
+ const response = await axios.get(
100
+ `https://api.github.com/user/${userId}`,
101
+ { headers: { Authorization: `Bearer ${refreshToken}` } }
102
+ );
103
+ return response.data;
104
+ })
105
+ );
106
+
107
+ return users;
108
+ };
109
+
110
+ export default instance;
@@ -0,0 +1,113 @@
1
+ import { Box } from "@mui/material";
2
+ import MiniTopBar from "../components/MiniTopBar";
3
+ import Sidebar from "../components/Sidebar";
4
+ import TopNavBar from "../components/TopNavBar";
5
+ import config from "../config/config";
6
+ import { useContext } from "../ContextProvider/ContextProvider";
7
+ import user from "../http/user";
8
+
9
+ import { Outlet, useLocation } from "react-router-dom";
10
+ import React, { useEffect, useState } from "react";
11
+
12
+ function AppLayout() {
13
+ const [anchorElUser, setAnchorElUser] = useState(null);
14
+ const [isCollapsed, setIsCollapsed] = useState(false);
15
+ const [isSubmenuOpen, setSubmenuOpen] = useState(false);
16
+ const [selectedItem, setSelectedItem] = useState();
17
+ const [state, dispatch] = useContext();
18
+ const [miniTopMenu, setMiniTopMenu] = useState(false);
19
+ const [userData, setUserData] = useState(null);
20
+ const location = useLocation();
21
+ const globalConfig = useConfig();
22
+
23
+ const toggleCollapse = () => {
24
+ setIsCollapsed(!isCollapsed);
25
+ if (isSubmenuOpen) {
26
+ setSubmenuOpen(false);
27
+ }
28
+ };
29
+
30
+ const handleOpenUserMenu = (event) => {
31
+ setAnchorElUser(event.currentTarget);
32
+ };
33
+
34
+ const handleCloseUserMenu = () => {
35
+ setAnchorElUser(null);
36
+ };
37
+
38
+ const handleItemSelect = (item) => {
39
+ dispatch({ type: "ITEM_SELECT", payload: item.id });
40
+ };
41
+
42
+ useEffect(() => {
43
+ const foundItem = globalConfig.itemsData.find(
44
+ (item) => item.id === state.itemId
45
+ );
46
+
47
+ if (foundItem) {
48
+ setSelectedItem(foundItem);
49
+ }
50
+ selectedItem && setSubmenuOpen(false);
51
+
52
+ // eslint-disable-next-line react-hooks/exhaustive-deps
53
+ }, []);
54
+
55
+ useEffect(() => {
56
+ user.get("https://api.github.com/user").then((response) => {
57
+ setUserData(response.data);
58
+ });
59
+ // eslint-disable-next-line react-hooks/exhaustive-deps
60
+ }, [state.login]);
61
+
62
+ useEffect(() => {
63
+ const targetPage = globalConfig.topMenu.find(
64
+ (target) => target.url === location.pathname
65
+ );
66
+
67
+ targetPage?.hideTopBar
68
+ ? (setMiniTopMenu(true), setIsCollapsed(true))
69
+ : (setMiniTopMenu(false), setIsCollapsed(false));
70
+ // eslint-disable-next-line react-hooks/exhaustive-deps
71
+ }, [location]);
72
+
73
+ return (
74
+ <Box>
75
+ {state.login &&
76
+ (miniTopMenu ? (
77
+ <MiniTopBar />
78
+ ) : (
79
+ <TopNavBar
80
+ sx={{ flexShrink: 0 }}
81
+ anchorElUser={anchorElUser}
82
+ handleOpenUserMenu={handleOpenUserMenu}
83
+ handleCloseUserMenu={handleCloseUserMenu}
84
+ routes={globalConfig.topMenu}
85
+ itemsData={globalConfig.itemsData}
86
+ onItemSelect={handleItemSelect}
87
+ sideBarToggle={toggleCollapse}
88
+ selectedItem={selectedItem}
89
+ setSelectedItem={setSelectedItem}
90
+ itemUrl="/"
91
+ itemName="ITEEEEEM"
92
+ userData={userData}
93
+ />
94
+ ))}
95
+
96
+ <Box sx={{ display: "flex", flexGrow: 1 }}>
97
+ {state.itemId ? (
98
+ <Sidebar
99
+ sx={{ flexShrink: 0 }}
100
+ routes={globalConfig.sideMenu}
101
+ isCollapsed={isCollapsed}
102
+ currentPage={location.pathname}
103
+ />
104
+ ) : null}
105
+ <Box sx={{ flexGrow: 1, overflow: "auto" }}>
106
+ <Outlet />
107
+ </Box>
108
+ </Box>
109
+ </Box>
110
+ );
111
+ }
112
+
113
+ export default AppLayout;
@@ -0,0 +1,32 @@
1
+ import Container from "@mui/material/Container";
2
+ import Header from "../common/header-simple";
3
+ import { Outlet } from "react-router";
4
+ import React from "react";
5
+ import Stack from "@mui/material/Stack";
6
+
7
+ // ----------------------------------------------------------------------
8
+
9
+ const CompactLayout = () => {
10
+ return (
11
+ <>
12
+ <Header />
13
+
14
+ <Container component="main">
15
+ <Stack
16
+ sx={{
17
+ py: 12,
18
+ m: "auto",
19
+ maxWidth: 400,
20
+ minHeight: "100vh",
21
+ textAlign: "center",
22
+ justifyContent: "center",
23
+ }}
24
+ >
25
+ <Outlet />
26
+ </Stack>
27
+ </Container>
28
+ </>
29
+ );
30
+ };
31
+
32
+ export default CompactLayout;
@@ -0,0 +1 @@
1
+ export { default } from "./CompactLayout";
@@ -0,0 +1,87 @@
1
+ import Box from "@mui/material/Box";
2
+ import Header from "./header";
3
+ import Main from "./main";
4
+ import NavHorizontal from "./nav-horizontal";
5
+ import NavMini from "./nav-mini";
6
+ import NavVertical from "./nav-vertical";
7
+ import { Outlet } from "react-router";
8
+ import React from "react";
9
+ import { useBoolean } from "../../hooks/use-boolean";
10
+ import { useResponsive } from "../../hooks/use-responsive";
11
+ import { useSettingsContext } from "../../components/settings";
12
+
13
+ // ----------------------------------------------------------------------
14
+
15
+ export default function DashboardLayout() {
16
+ const settings = useSettingsContext();
17
+
18
+ const lgUp = useResponsive("up", "lg");
19
+
20
+ const nav = useBoolean();
21
+ const isHorizontal = settings.themeLayout === "horizontal";
22
+
23
+ const isMini = settings.themeLayout === "mini";
24
+
25
+ const renderNavMini = <NavMini />;
26
+
27
+ const renderHorizontal = <NavHorizontal />;
28
+
29
+ const renderNavVertical = (
30
+ <>
31
+ <NavVertical openNav={nav.value} onCloseNav={nav.onFalse} />
32
+ </>
33
+ );
34
+ if (isHorizontal) {
35
+ return (
36
+ <>
37
+ <Header onOpenNav={nav.onTrue} />
38
+
39
+ {lgUp ? renderHorizontal : renderNavVertical}
40
+
41
+ <Main>
42
+ <Outlet />
43
+ </Main>
44
+ </>
45
+ );
46
+ }
47
+
48
+ if (isMini) {
49
+ return (
50
+ <>
51
+ <Header onOpenNav={nav.onTrue} />
52
+
53
+ <Box
54
+ sx={{
55
+ minHeight: 1,
56
+ display: "flex",
57
+ flexDirection: { xs: "column", lg: "row" },
58
+ }}
59
+ >
60
+ {lgUp ? renderNavMini : renderNavVertical}
61
+
62
+ <Main>
63
+ <Outlet />
64
+ </Main>
65
+ </Box>
66
+ </>
67
+ );
68
+ }
69
+ return (
70
+ <>
71
+ <Header onOpenNav={nav.onTrue} />
72
+
73
+ <Box
74
+ sx={{
75
+ minHeight: 1,
76
+ display: "flex",
77
+ flexDirection: { xs: "column", lg: "row" },
78
+ }}
79
+ >
80
+ {renderNavVertical}
81
+ <Main>
82
+ <Outlet />
83
+ </Main>
84
+ </Box>
85
+ </>
86
+ );
87
+ }
@@ -0,0 +1,104 @@
1
+ import { HEADER, NAV } from "../config-layout";
2
+
3
+ import AccountPopover from "../common/account-popover";
4
+ import AppBar from "@mui/material/AppBar";
5
+ import IconButton from "@mui/material/IconButton";
6
+ import Iconify from "../../components/Iconify";
7
+ import Logo from "../../components/logo";
8
+ import NotificationsPopover from "../common/notifications-popover";
9
+ import ProjectBar from "../common/ProjectBar";
10
+ import React from "react";
11
+ import SettingsButton from "../common/settings-button";
12
+ import Stack from "@mui/material/Stack";
13
+ import Toolbar from "@mui/material/Toolbar";
14
+ import { bgBlur } from "../../theme/css";
15
+ import config from "../../config/config";
16
+ import { useOffSetTop } from "../../hooks/use-off-set-top";
17
+ import { useResponsive } from "../../hooks/use-responsive";
18
+ import { useSettingsContext } from "../../components/settings";
19
+ import { useTheme } from "@mui/material/styles";
20
+
21
+ export default function Header({ onOpenNav }) {
22
+ const theme = useTheme();
23
+ const settings = useSettingsContext();
24
+
25
+ const projectBar = config().template?.projectBar;
26
+
27
+ const isNavHorizontal = settings.themeLayout === "horizontal";
28
+
29
+ const isNavMini = settings.themeLayout === "mini";
30
+
31
+ const lgUp = useResponsive("up", "lg");
32
+
33
+ const offset = useOffSetTop(HEADER.H_DESKTOP);
34
+
35
+ const offsetTop = offset && !isNavHorizontal;
36
+
37
+ const renderContent = (
38
+ <>
39
+ {lgUp && isNavHorizontal && <Logo sx={{ mr: 2.5 }} />}
40
+
41
+ {!lgUp && (
42
+ <IconButton data-cy="open-nav-button" onClick={onOpenNav}>
43
+ <Iconify icon="mingcute:menu-fill" sx={{ width: 28, height: 28 }} />
44
+ </IconButton>
45
+ )}
46
+ {projectBar && <ProjectBar />}
47
+
48
+ <Stack
49
+ flexGrow={1}
50
+ direction="row"
51
+ alignItems="center"
52
+ justifyContent="flex-end"
53
+ spacing={{ xs: 0.5, sm: 1 }}
54
+ >
55
+ <NotificationsPopover />
56
+
57
+ <SettingsButton />
58
+
59
+ <AccountPopover />
60
+ </Stack>
61
+ </>
62
+ );
63
+
64
+ return (
65
+ <AppBar
66
+ data-cy="dashboard-layout-header"
67
+ sx={{
68
+ height: HEADER.H_MOBILE,
69
+ zIndex: 0,
70
+ ...bgBlur({
71
+ color: theme.palette.background.default,
72
+ }),
73
+ transition: theme.transitions.create(["height"], {
74
+ duration: theme.transitions.duration.shorter,
75
+ }),
76
+ ...(lgUp && {
77
+ width: `calc(100% - ${NAV.W_VERTICAL + 1}px)`,
78
+ height: HEADER.H_DESKTOP,
79
+ ...(offsetTop && {
80
+ height: HEADER.H_DESKTOP_OFFSET,
81
+ }),
82
+ ...(isNavHorizontal && {
83
+ width: 1,
84
+ bgcolor: "background.default",
85
+ height: HEADER.H_DESKTOP_OFFSET,
86
+ borderBottom: `dashed 1px ${theme.palette.divider}`,
87
+ }),
88
+ ...(isNavMini && {
89
+ width: `calc(100% - ${NAV.W_MINI + 1}px)`,
90
+ }),
91
+ }),
92
+ }}
93
+ >
94
+ <Toolbar
95
+ sx={{
96
+ height: 1,
97
+ px: { lg: 5 },
98
+ }}
99
+ >
100
+ {renderContent}
101
+ </Toolbar>
102
+ </AppBar>
103
+ );
104
+ }
@@ -0,0 +1,2 @@
1
+ "use client";
2
+ export { default } from "./DashboardLayout";
@@ -0,0 +1,64 @@
1
+ import Box from "@mui/material/Box";
2
+ import React from "react";
3
+ import { useResponsive } from "../../hooks/use-responsive";
4
+ import { useSettingsContext } from "../../components/settings";
5
+
6
+ import { HEADER, NAV } from "../config-layout";
7
+
8
+ // ----------------------------------------------------------------------
9
+
10
+ const SPACING = 8;
11
+
12
+ export default function Main({ children, sx, ...other }) {
13
+ const settings = useSettingsContext();
14
+ const lgUp = useResponsive("up", "lg");
15
+ const isNavHorizontal = settings.themeLayout === "horizontal";
16
+
17
+ const isNavMini = settings.themeLayout === "mini";
18
+
19
+ if (isNavHorizontal) {
20
+ return (
21
+ <Box
22
+ component="main"
23
+ sx={{
24
+ minHeight: 1,
25
+ display: "flex",
26
+ flexDirection: "column",
27
+ pt: `${HEADER.H_MOBILE + 24}px`,
28
+ pb: 10,
29
+ ...(lgUp && {
30
+ pt: `${HEADER.H_MOBILE * 2 + 40}px`,
31
+ pb: 15,
32
+ }),
33
+ }}
34
+ >
35
+ {children}
36
+ </Box>
37
+ );
38
+ }
39
+
40
+ return (
41
+ <Box
42
+ component="main"
43
+ sx={{
44
+ flexGrow: 1,
45
+ minHeight: 1,
46
+ display: "flex",
47
+ flexDirection: "column",
48
+ py: `${HEADER.H_MOBILE + SPACING}px`,
49
+ ...(lgUp && {
50
+ px: 2,
51
+ py: `${HEADER.H_DESKTOP + SPACING}px`,
52
+ width: `calc(100% - ${NAV.W_VERTICAL}px)`,
53
+ ...(isNavMini && {
54
+ width: `calc(100% - ${NAV.W_MINI}px)`,
55
+ }),
56
+ }),
57
+ ...sx,
58
+ }}
59
+ {...other}
60
+ >
61
+ {children}
62
+ </Box>
63
+ );
64
+ }