test-nucleoid 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 (458) 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 +795 -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 +47 -0
  199. package/src/config/schemas.js +148 -0
  200. package/src/context/Context.js +98 -0
  201. package/src/context/reducer.js +632 -0
  202. package/src/global.css +2 -0
  203. package/src/hooks/index.js +2 -0
  204. package/src/hooks/use-boolean.js +27 -0
  205. package/src/hooks/use-event-listener.js +34 -0
  206. package/src/hooks/use-local-storage.js +89 -0
  207. package/src/hooks/use-off-set-top.js +37 -0
  208. package/src/hooks/use-responsive.js +47 -0
  209. package/src/hooks/use-scroll-to-top.js +14 -0
  210. package/src/hooks/use-user.js +58 -0
  211. package/src/hooks/useApi.js +25 -0
  212. package/src/hooks/useItemsState.js +23 -0
  213. package/src/hooks/useProjects.js +24 -0
  214. package/src/hooks/useSettings.jsx +51 -0
  215. package/src/http/index.js +166 -0
  216. package/src/http/oauth.js +27 -0
  217. package/src/http/user.js +110 -0
  218. package/src/layouts/AppLayout.jsx +113 -0
  219. package/src/layouts/CompactLayout/CompactLayout.jsx +32 -0
  220. package/src/layouts/CompactLayout/index.js +1 -0
  221. package/src/layouts/DashboardLayout/DashboardLayout.jsx +87 -0
  222. package/src/layouts/DashboardLayout/config-navigation.jsx +0 -0
  223. package/src/layouts/DashboardLayout/header.jsx +104 -0
  224. package/src/layouts/DashboardLayout/index.js +2 -0
  225. package/src/layouts/DashboardLayout/main.jsx +64 -0
  226. package/src/layouts/DashboardLayout/nav-horizontal.jsx +62 -0
  227. package/src/layouts/DashboardLayout/nav-mini.jsx +99 -0
  228. package/src/layouts/DashboardLayout/nav-vertical.jsx +201 -0
  229. package/src/layouts/FullScreenLayout/FullScreenLayout.jsx +101 -0
  230. package/src/layouts/FullScreenLayout/index.js +1 -0
  231. package/src/layouts/FullScreenLayout/nav-horizontal.jsx +50 -0
  232. package/src/layouts/FullScreenLayout/nav-vertical.jsx +136 -0
  233. package/src/layouts/MainLayout/MainLayout.jsx +21 -0
  234. package/src/layouts/MainLayout/footer.jsx +153 -0
  235. package/src/layouts/MainLayout/header.jsx +81 -0
  236. package/src/layouts/MainLayout/index.js +1 -0
  237. package/src/layouts/MainLayout/nav/desktop/index.jsx +20 -0
  238. package/src/layouts/MainLayout/nav/desktop/nav-item.jsx +186 -0
  239. package/src/layouts/MainLayout/nav/desktop/nav-list.jsx +145 -0
  240. package/src/layouts/MainLayout/nav/mobile/index.jsx +60 -0
  241. package/src/layouts/MainLayout/nav/mobile/nav-item.jsx +90 -0
  242. package/src/layouts/MainLayout/nav/mobile/nav-list.jsx +72 -0
  243. package/src/layouts/Page.jsx +16 -0
  244. package/src/layouts/SimpleLayout/SimpleLayout.jsx +8 -0
  245. package/src/layouts/SimpleLayout/index.js +1 -0
  246. package/src/layouts/TwoSideLayout/TwoSideLayout.jsx +31 -0
  247. package/src/layouts/TwoSideLayout/index.js +1 -0
  248. package/src/layouts/auth/classic.jsx +95 -0
  249. package/src/layouts/auth/modern-compact.jsx +51 -0
  250. package/src/layouts/auth/modern.jsx +110 -0
  251. package/src/layouts/common/ProjectBar/index.jsx +338 -0
  252. package/src/layouts/common/ProjectBar/result-item.jsx +90 -0
  253. package/src/layouts/common/ProjectBar/utils.js +86 -0
  254. package/src/layouts/common/account-popover.jsx +119 -0
  255. package/src/layouts/common/header-shadow.jsx +26 -0
  256. package/src/layouts/common/header-sim.jsx +52 -0
  257. package/src/layouts/common/header-simple.jsx +76 -0
  258. package/src/layouts/common/nav-toggle-button.jsx +57 -0
  259. package/src/layouts/common/notifications-popover/index.jsx +177 -0
  260. package/src/layouts/common/notifications-popover/notification-item.jsx +252 -0
  261. package/src/layouts/common/settings-button.jsx +48 -0
  262. package/src/layouts/config-layout.js +12 -0
  263. package/src/layouts/index.js +7 -0
  264. package/src/lib/APIDialogAction/APIDialogAction.jsx +109 -0
  265. package/src/lib/APIDialogAction/index.js +1 -0
  266. package/src/lib/APIDialogAction/styles.js +6 -0
  267. package/src/lib/APIParams/APIParams.jsx +57 -0
  268. package/src/lib/APIParams/index.js +1 -0
  269. package/src/lib/APIPath/APIPath.jsx +82 -0
  270. package/src/lib/APIPath/index.js +1 -0
  271. package/src/lib/APIPath/styles.js +19 -0
  272. package/src/lib/APITree/APITree.jsx +418 -0
  273. package/src/lib/APITree/Arrow.jsx +21 -0
  274. package/src/lib/APITree/DeleteMethodDialog.jsx +41 -0
  275. package/src/lib/APITree/index.js +1 -0
  276. package/src/lib/APITree/styles.js +19 -0
  277. package/src/lib/APITypes/APITypes.jsx +151 -0
  278. package/src/lib/APITypes/TypeEditor.jsx +46 -0
  279. package/src/lib/APITypes/TypeList.jsx +178 -0
  280. package/src/lib/APITypes/index.js +1 -0
  281. package/src/lib/AddItemWizard/AddItemWizard.jsx +211 -0
  282. package/src/lib/AddItemWizard/index.js +1 -0
  283. package/src/lib/BlankTreeMessage/BlankTreeMessage.jsx +39 -0
  284. package/src/lib/BlankTreeMessage/index.js +1 -0
  285. package/src/lib/CustomBreadcrumbs/CustomBreadcrumbs.jsx +88 -0
  286. package/src/lib/CustomBreadcrumbs/index.js +1 -0
  287. package/src/lib/CustomBreadcrumbs/link-item.jsx +58 -0
  288. package/src/lib/CustomPopover/CustomPopover.jsx +46 -0
  289. package/src/lib/CustomPopover/index.js +3 -0
  290. package/src/lib/CustomPopover/styles.js +82 -0
  291. package/src/lib/CustomPopover/usePopover.js +20 -0
  292. package/src/lib/CustomPopover/utils.js +100 -0
  293. package/src/lib/DialogTootip/DialogTooltip.jsx +67 -0
  294. package/src/lib/DialogTootip/index.js +1 -0
  295. package/src/lib/DialogTootip/styles.js +9 -0
  296. package/src/lib/Flow/connectors/DynamicConnector.jsx +319 -0
  297. package/src/lib/Flow/core/Flow.jsx +79 -0
  298. package/src/lib/Flow/core/FlowNode.jsx +68 -0
  299. package/src/lib/Flow/core/FlowViewport.jsx +259 -0
  300. package/src/lib/Flow/graph/FloatingGraph.jsx +44 -0
  301. package/src/lib/Flow/hooks/useGraphOperations.js +362 -0
  302. package/src/lib/Flow/hooks/useNodeStyle.js +70 -0
  303. package/src/lib/Flow/index.js +1 -0
  304. package/src/lib/Flow/layouts/ActionNode.jsx +78 -0
  305. package/src/lib/Flow/layouts/AnimatedNode.jsx +22 -0
  306. package/src/lib/Flow/layouts/CardLayout.jsx +397 -0
  307. package/src/lib/Flow/layouts/InfoNode.jsx +255 -0
  308. package/src/lib/Flow/layouts/LoadingNode.jsx +37 -0
  309. package/src/lib/Flow/nodes/DefaultCard.jsx +107 -0
  310. package/src/lib/Flow/nodes/DraggableNode.jsx +162 -0
  311. package/src/lib/Flow/nodes/FlowNodeView.jsx +298 -0
  312. package/src/lib/Flow/selection/SelectionContext.jsx +259 -0
  313. package/src/lib/Flow/selection/SelectionOverlay.jsx +31 -0
  314. package/src/lib/Flow/styles.js +158 -0
  315. package/src/lib/Flow/utils/flowUtils.js +268 -0
  316. package/src/lib/FormProvider/FormProvider.jsx +16 -0
  317. package/src/lib/FormProvider/index.js +1 -0
  318. package/src/lib/IconSelector/IconSelector.jsx +89 -0
  319. package/src/lib/Iconify/Iconify.jsx +17 -0
  320. package/src/lib/Iconify/index.js +1 -0
  321. package/src/lib/Image/Image.jsx +116 -0
  322. package/src/lib/Image/index.js +1 -0
  323. package/src/lib/Image/utils.js +15 -0
  324. package/src/lib/ItemSummary/ItemSummary.jsx +78 -0
  325. package/src/lib/ItemSummary/ItemsSummary.jsx +164 -0
  326. package/src/lib/Label/Label.jsx +51 -0
  327. package/src/lib/Label/index.js +1 -0
  328. package/src/lib/Label/styles.js +76 -0
  329. package/src/lib/NewApiBody/NewAPIBody.jsx +97 -0
  330. package/src/lib/NewApiBody/ParamView.jsx +38 -0
  331. package/src/lib/NucDialog/NucDialog.jsx +108 -0
  332. package/src/lib/NucDialog/index.js +1 -0
  333. package/src/lib/ParamTable/ParamTable.jsx +133 -0
  334. package/src/lib/ParamTable/TypeMenu.jsx +102 -0
  335. package/src/lib/ParamTable/defaults.js +47 -0
  336. package/src/lib/ParamTable/index.js +1 -0
  337. package/src/lib/ParamTable/styles.js +12 -0
  338. package/src/lib/ProjectWizard.jsx +137 -0
  339. package/src/lib/RHFTextfield/RHFTextfield.jsx +40 -0
  340. package/src/lib/RHFTextfield/index.js +1 -0
  341. package/src/lib/ResourceMenu/AlertMassage.jsx +28 -0
  342. package/src/lib/ResourceMenu/DeleteResourceDialog.jsx +60 -0
  343. package/src/lib/ResourceMenu/ResourceMenu.jsx +165 -0
  344. package/src/lib/ResourceMenu/index.js +1 -0
  345. package/src/lib/ResourceMenu/styles.js +5 -0
  346. package/src/lib/Schema/Schema.jsx +204 -0
  347. package/src/lib/Schema/index.js +1 -0
  348. package/src/lib/SchemaEditor/SchemaEditor.jsx +258 -0
  349. package/src/lib/SchemaEditor/SchemaEditor.test.js +193 -0
  350. package/src/lib/SchemaEditor/SchemaPropertyEditor.jsx +135 -0
  351. package/src/lib/SchemaEditor/SchemaUtils.js +152 -0
  352. package/src/lib/SchemaEditor/index.js +1 -0
  353. package/src/lib/Scrollbar/Scrollbar.jsx +39 -0
  354. package/src/lib/Scrollbar/index.js +1 -0
  355. package/src/lib/Scrollbar/styles.js +27 -0
  356. package/src/lib/SearchNotFound/SearchNotFound.jsx +29 -0
  357. package/src/lib/SearchNotFound/index.js +1 -0
  358. package/src/lib/SparkleInput/SparkleInput.jsx +51 -0
  359. package/src/lib/StepComponent/StepComponent.jsx +98 -0
  360. package/src/lib/SvgColor/SvgColor.jsx +29 -0
  361. package/src/lib/SvgColor/index.js +1 -0
  362. package/src/lib/TableHeadCustom/TableHeadCustom.jsx +87 -0
  363. package/src/lib/TableHeadCustom/index.js +1 -0
  364. package/src/lib/TableSelectedAction/TableSelectedAction.jsx +72 -0
  365. package/src/lib/TableSelectedAction/index.js +1 -0
  366. package/src/lib/ToggleableMenu/ToggleableMenu.jsx +35 -0
  367. package/src/lib/ToggleableMenu/index.js +1 -0
  368. package/src/lib/index.js +50 -0
  369. package/src/lib/lib/Icons.js +40 -0
  370. package/src/lib/lib/context.json +272 -0
  371. package/src/lib/useChart/useChart.js +180 -0
  372. package/src/lib/useTable/useTable.js +121 -0
  373. package/src/pages/404.jsx +17 -0
  374. package/src/pages/Callback.jsx +126 -0
  375. package/src/pages/ConfigError.jsx +49 -0
  376. package/src/pages/LoginPage.jsx +52 -0
  377. package/src/routes/components/index.js +1 -0
  378. package/src/routes/components/router-link.jsx +11 -0
  379. package/src/routes/hooks/index.js +4 -0
  380. package/src/routes/hooks/use-active-link.js +15 -0
  381. package/src/routes/hooks/use-pathname.js +10 -0
  382. package/src/routes/hooks/use-router.js +21 -0
  383. package/src/stories/APITree.stories.jsx +332 -0
  384. package/src/stories/FlowChart.stories.jsx +333 -0
  385. package/src/stories/Iconify.stories.jsx +183 -0
  386. package/src/stories/Label.stories.jsx +447 -0
  387. package/src/stories/Navbar.stories.jsx +588 -0
  388. package/src/templates/ActionTemplate.js +24 -0
  389. package/src/theme/css.js +152 -0
  390. package/src/theme/custom-shadows.js +47 -0
  391. package/src/theme/index.jsx +100 -0
  392. package/src/theme/options/contrast.js +34 -0
  393. package/src/theme/options/presets.js +89 -0
  394. package/src/theme/options/right-to-left.jsx +26 -0
  395. package/src/theme/overrides/components/accordion.js +43 -0
  396. package/src/theme/overrides/components/alert.js +69 -0
  397. package/src/theme/overrides/components/appbar.js +13 -0
  398. package/src/theme/overrides/components/autocomplete.js +44 -0
  399. package/src/theme/overrides/components/avatar.js +111 -0
  400. package/src/theme/overrides/components/backdrop.js +18 -0
  401. package/src/theme/overrides/components/badge.js +90 -0
  402. package/src/theme/overrides/components/breadcrumbs.js +21 -0
  403. package/src/theme/overrides/components/button-group.js +90 -0
  404. package/src/theme/overrides/components/button.js +145 -0
  405. package/src/theme/overrides/components/card.js +30 -0
  406. package/src/theme/overrides/components/checkbox.js +13 -0
  407. package/src/theme/overrides/components/chip.js +129 -0
  408. package/src/theme/overrides/components/css-baseline.js +48 -0
  409. package/src/theme/overrides/components/data-grid.js +94 -0
  410. package/src/theme/overrides/components/date-picker.jsx +94 -0
  411. package/src/theme/overrides/components/dialog.js +49 -0
  412. package/src/theme/overrides/components/drawer.js +39 -0
  413. package/src/theme/overrides/components/fab.js +165 -0
  414. package/src/theme/overrides/components/list.js +33 -0
  415. package/src/theme/overrides/components/loading-button.js +30 -0
  416. package/src/theme/overrides/components/menu.js +15 -0
  417. package/src/theme/overrides/components/pagination.js +81 -0
  418. package/src/theme/overrides/components/paper.js +18 -0
  419. package/src/theme/overrides/components/popover.js +20 -0
  420. package/src/theme/overrides/components/progress.js +40 -0
  421. package/src/theme/overrides/components/radio.js +22 -0
  422. package/src/theme/overrides/components/rating.js +40 -0
  423. package/src/theme/overrides/components/select.js +26 -0
  424. package/src/theme/overrides/components/skeleton.js +16 -0
  425. package/src/theme/overrides/components/slider.js +30 -0
  426. package/src/theme/overrides/components/stepper.js +13 -0
  427. package/src/theme/overrides/components/svg-icon.js +15 -0
  428. package/src/theme/overrides/components/switch.js +66 -0
  429. package/src/theme/overrides/components/table.js +79 -0
  430. package/src/theme/overrides/components/tabs.js +39 -0
  431. package/src/theme/overrides/components/textfield.js +146 -0
  432. package/src/theme/overrides/components/timeline.js +20 -0
  433. package/src/theme/overrides/components/toggle-button.js +70 -0
  434. package/src/theme/overrides/components/tooltip.js +18 -0
  435. package/src/theme/overrides/components/tree-view.js +16 -0
  436. package/src/theme/overrides/components/typography.js +16 -0
  437. package/src/theme/overrides/default-props.jsx +238 -0
  438. package/src/theme/overrides/index.js +100 -0
  439. package/src/theme/palette.js +144 -0
  440. package/src/theme/shadows.js +41 -0
  441. package/src/theme/typography.js +107 -0
  442. package/src/utils/flatten-array.js +16 -0
  443. package/src/utils/format-number.js +37 -0
  444. package/src/utils/format-time.js +27 -0
  445. package/src/utils/storage-available.js +24 -0
  446. package/src/widgets/Login/CognitoLogin.jsx +45 -0
  447. package/src/widgets/Login/DemoLogin.jsx +178 -0
  448. package/src/widgets/Login/Login.jsx +58 -0
  449. package/src/widgets/Login/cognitoAuth.jsx +44 -0
  450. package/src/widgets/LoginForm/LoginForm.jsx +87 -0
  451. package/src/widgets/LoginForm/LoginFormStyles.js +43 -0
  452. package/src/widgets/LoginForm/index.js +1 -0
  453. package/src/widgets/SettingsDialog.jsx +433 -0
  454. package/src/widgets/error/index.js +1 -0
  455. package/src/widgets/error/not-found-view.jsx +42 -0
  456. package/vite/vite.js +86 -0
  457. package/vite.config.js +7 -0
  458. package/vitest.config.js +32 -0
@@ -0,0 +1,126 @@
1
+ import Page from "../layouts/Page";
2
+ import React from "react";
3
+ import config from "../config/config";
4
+ import oauth from "../http/oauth";
5
+ import qs from "qs";
6
+ import { storage } from "@nucleoidjs/webstorage";
7
+ import { useContext } from "../ContextProvider/ContextProvider";
8
+ import { useLocation } from "react-router-dom";
9
+ import { useNavigate } from "react-router-dom";
10
+
11
+ import { useEffect, useRef } from "react";
12
+
13
+ function Callback() {
14
+ const { project: appConfig, name, appId } = config();
15
+ const projectBar = config().template?.projectBar;
16
+
17
+ const { google, github, linkedin } = appConfig;
18
+ const [, dispatch] = useContext();
19
+ const location = useLocation();
20
+ const navigate = useNavigate();
21
+ const hasProcessed = useRef(false);
22
+
23
+ useEffect(() => {
24
+ if (hasProcessed.current) {
25
+ return;
26
+ }
27
+
28
+ const parsedQuery = qs.parse(location.search, { ignoreQueryPrefix: true });
29
+ const { code, error, error_description, state } = parsedQuery;
30
+
31
+ let identityProvider;
32
+ let stateData = {};
33
+
34
+ if (state) {
35
+ stateData = JSON.parse(decodeURIComponent(state));
36
+ identityProvider = stateData.identityProvider;
37
+ }
38
+
39
+ if (error) {
40
+ console.error("OAuth error:", error, error_description);
41
+ navigate(
42
+ "/login?error=" + encodeURIComponent(error_description || error)
43
+ );
44
+ return;
45
+ }
46
+
47
+ if (!code) {
48
+ console.error("No authorization code received");
49
+ navigate(
50
+ "/login?error=" + encodeURIComponent("No authorization code received")
51
+ );
52
+ return;
53
+ }
54
+ hasProcessed.current = true;
55
+
56
+ const providerConfigs = {
57
+ github,
58
+ linkedin,
59
+ google,
60
+ };
61
+
62
+ const providerConfig = providerConfigs[identityProvider];
63
+
64
+ if (!providerConfig) {
65
+ console.error("Could not determine OAuth provider or redirect URI");
66
+ navigate("/login?error=" + encodeURIComponent("Invalid OAuth provider"));
67
+ return;
68
+ }
69
+
70
+ const redirectUri = providerConfig.redirectUri;
71
+
72
+ let projectId;
73
+ const defaultProjectId = "05708cf7-b9bf-4209-95fe-68d9138d2032";
74
+
75
+ if (projectBar) {
76
+ projectId = storage.get("projectId");
77
+ } else {
78
+ projectId = defaultProjectId;
79
+ storage.set("projectId", projectId);
80
+ }
81
+
82
+ oauth
83
+ .post("/oauth", {
84
+ ...(projectId && { projectId }),
85
+ appId,
86
+ code,
87
+ redirectUri,
88
+ identityProvider: identityProvider,
89
+ grant_type: "authorization_code",
90
+ })
91
+ .then(({ data }) => {
92
+ const accessToken = data.accessToken;
93
+ const refreshToken = data.refreshToken;
94
+ const userInfo = data.user;
95
+
96
+ storage.set("link", "accessToken", accessToken);
97
+ storage.set("link", "refreshToken", refreshToken);
98
+ // TODO - update provider info
99
+ storage.set("link", "identityProvider", identityProvider);
100
+
101
+ dispatch({ type: "LOGIN", payload: { user: userInfo } });
102
+
103
+ window.history.replaceState(
104
+ {},
105
+ document.title,
106
+ window.location.pathname
107
+ );
108
+
109
+ navigate("/");
110
+ })
111
+ .catch((error) => {
112
+ console.error("OAuth error:", error);
113
+ const errorMessage =
114
+ error.response?.data?.message ||
115
+ error.response?.data ||
116
+ error.message ||
117
+ "Authentication failed";
118
+
119
+ navigate("/login?error=" + encodeURIComponent(errorMessage));
120
+ });
121
+ }, [location.search, navigate]);
122
+
123
+ return <Page title={`${name} - Callback`}></Page>;
124
+ }
125
+
126
+ export default Callback;
@@ -0,0 +1,49 @@
1
+ import Iconify from "../components/Iconify";
2
+ import React from "react";
3
+ import { useLocation } from "react-router-dom";
4
+
5
+ import {
6
+ Box,
7
+ Dialog,
8
+ DialogContent,
9
+ DialogContentText,
10
+ DialogTitle,
11
+ Stack,
12
+ Typography,
13
+ } from "@mui/material";
14
+
15
+ const ConfigErrorDialog = () => {
16
+ const location = useLocation();
17
+
18
+ const { error, file } = location.state || { error: "", file: "" };
19
+
20
+ return (
21
+ <Dialog fullWidth open>
22
+ <DialogTitle>
23
+ <Stack direction="row" alignItems="center">
24
+ <Box
25
+ component="span"
26
+ sx={{ display: "flex", alignItems: "center", mr: 1 }}
27
+ >
28
+ <Iconify
29
+ sx={{ color: (theme) => theme.palette.error.main }}
30
+ width={24}
31
+ icon="icon-park-twotone:error"
32
+ />
33
+ </Box>
34
+ Config Validation Error
35
+ </Stack>
36
+ </DialogTitle>
37
+ <DialogContent
38
+ sx={{ padding: "10px", display: "flex", justifyContent: "center" }}
39
+ >
40
+ <DialogContentText>
41
+ <Typography variant="body1">{error}</Typography>
42
+ <Typography variant="body2">{`- ${file}`}</Typography>
43
+ </DialogContentText>
44
+ </DialogContent>
45
+ </Dialog>
46
+ );
47
+ };
48
+
49
+ export default ConfigErrorDialog;
@@ -0,0 +1,52 @@
1
+ import CognitoLogin from "../widgets/Login/CognitoLogin";
2
+ import DemoLogin from "../widgets/Login/DemoLogin";
3
+ import LoginForm from "../widgets/LoginForm/LoginForm";
4
+ import Page from "../layouts/Page";
5
+ import React from "react";
6
+ import config from "../config/config";
7
+ import { storage } from "@nucleoidjs/webstorage";
8
+ import { useEffect } from "react";
9
+ import { useNavigate } from "react-router-dom";
10
+ function LoginPage() {
11
+ const { name, template, credentials } = config();
12
+ const formColor = "#a8a9ad";
13
+ const navigate = useNavigate();
14
+
15
+ function token() {
16
+ if (
17
+ storage.get("link", "refreshToken") &&
18
+ storage.get("link", "accessToken")
19
+ ) {
20
+ return true;
21
+ } else {
22
+ return false;
23
+ }
24
+ }
25
+
26
+ useEffect(() => {
27
+ if (token()) {
28
+ navigate("/");
29
+ }
30
+ // eslint-disable-next-line react-hooks/exhaustive-deps
31
+ }, [navigate]);
32
+
33
+ if (credentials?.provider === "COGNITO") {
34
+ return <CognitoLogin />;
35
+ }
36
+
37
+ if (credentials?.provider === "DEMO") {
38
+ return (
39
+ <Page title={`Sign in to ${name}`}>
40
+ <DemoLogin />
41
+ </Page>
42
+ );
43
+ }
44
+
45
+ return (
46
+ <Page title={`Sign in to ${name}`}>
47
+ <LoginForm icon={template.login.icon} name={name} formColor={formColor} />
48
+ </Page>
49
+ );
50
+ }
51
+
52
+ export default LoginPage;
@@ -0,0 +1 @@
1
+ export { default as RouterLink } from "./router-link";
@@ -0,0 +1,11 @@
1
+ import { Link } from "react-router-dom";
2
+ import React from "react";
3
+ import { forwardRef } from "react";
4
+
5
+ // ----------------------------------------------------------------------
6
+
7
+ const RouterLink = forwardRef(({ href, ...other }, ref) => (
8
+ <Link ref={ref} to={href} {...other} />
9
+ ));
10
+
11
+ export default RouterLink;
@@ -0,0 +1,4 @@
1
+ //
2
+ export { useRouter } from "./use-router";
3
+ export { usePathname } from "./use-pathname";
4
+ export { useActiveLink } from "./use-active-link";
@@ -0,0 +1,15 @@
1
+ import { matchPath, useLocation } from "react-router-dom";
2
+
3
+ // ----------------------------------------------------------------------
4
+
5
+ export function useActiveLink(path, deep = true) {
6
+ const { pathname } = useLocation();
7
+
8
+ const normalActive = path
9
+ ? !!matchPath({ path, end: true }, pathname)
10
+ : false;
11
+
12
+ const deepActive = path ? !!matchPath({ path, end: false }, pathname) : false;
13
+
14
+ return deep ? deepActive : normalActive;
15
+ }
@@ -0,0 +1,10 @@
1
+ import { useLocation } from "react-router-dom";
2
+ import { useMemo } from "react";
3
+
4
+ // ----------------------------------------------------------------------
5
+
6
+ export function usePathname() {
7
+ const { pathname } = useLocation();
8
+
9
+ return useMemo(() => pathname, [pathname]);
10
+ }
@@ -0,0 +1,21 @@
1
+ import { useMemo } from "react";
2
+ import { useNavigate } from "react-router-dom";
3
+
4
+ // ----------------------------------------------------------------------
5
+
6
+ export function useRouter() {
7
+ const navigate = useNavigate();
8
+
9
+ const router = useMemo(
10
+ () => ({
11
+ back: () => navigate(-1),
12
+ forward: () => navigate(1),
13
+ reload: () => window.location.reload(),
14
+ push: (href) => navigate(href),
15
+ replace: (href) => navigate(href, { replace: true }),
16
+ }),
17
+ [navigate]
18
+ );
19
+
20
+ return router;
21
+ }
@@ -0,0 +1,332 @@
1
+ import APIDialogAction from "../lib/APIDialogAction/APIDialogAction";
2
+ import APIParams from "../lib/APIParams/APIParams";
3
+ import APIPath from "../lib/APIPath/APIPath";
4
+ import APITree from "../lib/APITree/APITree";
5
+ import APITypes from "../lib/APITypes/APITypes";
6
+ import Context from "../context/Context";
7
+ import ContextProvider from "../ContextProvider/ContextProvider";
8
+ import CssBaseline from "@mui/material/CssBaseline";
9
+ import NewAPIBody from "../lib/NewApiBody/NewAPIBody";
10
+ import NucDialog from "../lib/NucDialog/NucDialog";
11
+ import { reducer } from "../context/reducer";
12
+ import { useContext } from "../ContextProvider/ContextProvider";
13
+
14
+ import { Box, Divider } from "@mui/material";
15
+ import React, { useEffect, useRef, useState } from "react";
16
+ import { ThemeProvider, createTheme } from "@mui/material/styles";
17
+
18
+ const theme = createTheme({
19
+ palette: {
20
+ mode: "dark",
21
+ custom: {
22
+ apiTreeRightClick: "rgba(255, 255, 255, 0.08)",
23
+ },
24
+ },
25
+ custom: {
26
+ apiTreeItem: {
27
+ fontSize: 12,
28
+ color: "#666",
29
+ fontWeight: "bold",
30
+ backgroundColor: "#fdfdfd",
31
+ border: "1px solid #c3c5c8",
32
+ width: 44,
33
+ borderRadius: 8,
34
+ mt: 1 / 4,
35
+ mb: 1 / 4,
36
+ boxShadow: "1px 1px #b8b8b8",
37
+ },
38
+ },
39
+ });
40
+
41
+ const resolve = (context, param) => {
42
+ try {
43
+ const parts = param.split(".");
44
+ parts[0] = context[parts[0]];
45
+ return parts.reduce((obj, part) => obj[part]);
46
+ } catch (error) {
47
+ return undefined;
48
+ }
49
+ };
50
+
51
+ const sampleApi = [
52
+ {
53
+ path: "/",
54
+ method: "GET",
55
+ summary: "Hello World",
56
+ description: "Hello World",
57
+ params: [],
58
+ action: 'function action(req) {\n return { message: "Hello World" };\n}',
59
+ },
60
+ {
61
+ path: "/items",
62
+ method: "GET",
63
+ summary: "List items",
64
+ description: "List all items",
65
+ params: [{ in: "query", type: "string", required: true, name: "name" }],
66
+ action:
67
+ "function action(req) {\n return Item.filter(i => i.name === req.query.name);\n}",
68
+ },
69
+ {
70
+ path: "/items",
71
+ method: "POST",
72
+ summary: "Create item",
73
+ description: "Create a new item",
74
+ params: [],
75
+ action:
76
+ "function action(req) {\n return new Item(req.body.name, req.body.barcode);\n}",
77
+ },
78
+ {
79
+ path: "/items",
80
+ method: "DELETE",
81
+ summary: "Delete item",
82
+ description: "Delete an item",
83
+ params: [],
84
+ action: "function action(req) {\n // delete logic\n}",
85
+ },
86
+ ];
87
+
88
+ export default {
89
+ title: "Components/APITree",
90
+ component: APITree,
91
+ parameters: {
92
+ docs: {
93
+ description: {
94
+ component:
95
+ "APITree displays API endpoints in a tree structure grouped by path segments. " +
96
+ "It supports context menus for editing/deleting methods and a resource menu for adding new endpoints.",
97
+ },
98
+ },
99
+ layout: "centered",
100
+ },
101
+ };
102
+
103
+ const ALL_METHODS = ["GET", "POST", "PUT", "DELETE", "PATCH"];
104
+
105
+ const APIWorkspace = () => {
106
+ const [state, dispatch] = useContext();
107
+ const [view, setView] = useState("PARAMS");
108
+ const [dialogKey, setDialogKey] = useState(0);
109
+
110
+ const methodRef = useRef("GET");
111
+ const pathRef = useRef("/");
112
+ const paramsRef = useRef([]);
113
+ const addParams = useRef(null);
114
+ const requestSchemaRef = useRef();
115
+ const responseSchemaRef = useRef();
116
+ const typesRef = useRef({});
117
+
118
+ const dialog = state.pages.api.dialog;
119
+ const selected = state.pages.api.selected;
120
+ const types = state.specification.types || [];
121
+
122
+ const isEdit = dialog.type === "method" && dialog.action === "edit";
123
+ const isAddMethod = dialog.type === "method" && dialog.action === "add";
124
+
125
+ const selectedEndpoint = state.specification.api.find(
126
+ (ep) =>
127
+ ep.path === selected?.path &&
128
+ ep.method?.toLowerCase() === selected?.method?.toLowerCase()
129
+ );
130
+
131
+ useEffect(() => {
132
+ if (!dialog.open) return;
133
+
134
+ setView("PARAMS");
135
+ setDialogKey((k) => k + 1);
136
+
137
+ if (isEdit && selectedEndpoint) {
138
+ methodRef.current = selectedEndpoint.method?.toUpperCase() || "GET";
139
+ pathRef.current = selectedEndpoint.path || "/";
140
+ paramsRef.current = Array.isArray(selectedEndpoint.params)
141
+ ? [...selectedEndpoint.params]
142
+ : [];
143
+ } else {
144
+ methodRef.current = "GET";
145
+ pathRef.current = selected?.path || "/";
146
+ paramsRef.current = [];
147
+ }
148
+ // eslint-disable-next-line react-hooks/exhaustive-deps
149
+ }, [dialog.open]);
150
+
151
+ const usedMethods = state.specification.api
152
+ .filter((ep) => ep.path === selected?.path)
153
+ .map((ep) => ep.method?.toUpperCase());
154
+
155
+ const allowedMethods = isEdit
156
+ ? [selectedEndpoint?.method?.toUpperCase() || "GET"]
157
+ : isAddMethod
158
+ ? ALL_METHODS.filter((m) => !usedMethods.includes(m))
159
+ : ALL_METHODS;
160
+
161
+ const basePath = isEdit
162
+ ? selectedEndpoint?.path || selected?.path || "/"
163
+ : selected?.path || "/";
164
+
165
+ const isPathDisabled = isAddMethod || isEdit;
166
+ const isMethodDisabled = isEdit;
167
+
168
+ const dialogTitle = isEdit
169
+ ? "Edit API Endpoint"
170
+ : isAddMethod
171
+ ? "Add Method"
172
+ : "Add Resource";
173
+
174
+ const handleClose = () => dispatch({ type: "CLOSE_API_DIALOG" });
175
+
176
+ const handleSave = () => {
177
+ if (isEdit) {
178
+ dispatch({
179
+ type: "UPDATE_API_SCHEMAS",
180
+ payload: {
181
+ path: selected.path,
182
+ method: selected.method,
183
+ requestSchema: requestSchemaRef.current?.schemaOutput?.() || [],
184
+ responseSchema: responseSchemaRef.current?.schemaOutput?.() || [],
185
+ },
186
+ });
187
+ dispatch({
188
+ type: "SAVE_API_PARAMS",
189
+ payload: {
190
+ path: selected.path,
191
+ method: selected.method,
192
+ params: paramsRef.current,
193
+ },
194
+ });
195
+ dispatch({ type: "CLOSE_API_DIALOG" });
196
+ } else {
197
+ dispatch({
198
+ type: "SAVE_API_DIALOG",
199
+ payload: {
200
+ path: pathRef.current,
201
+ method: methodRef.current,
202
+ request: requestSchemaRef.current?.schemaOutput?.() || {},
203
+ response: responseSchemaRef.current?.schemaOutput?.() || {},
204
+ params: paramsRef.current,
205
+ types,
206
+ summary: `${methodRef.current} ${pathRef.current}`,
207
+ description: `API endpoint for ${pathRef.current}`,
208
+ },
209
+ });
210
+ }
211
+ };
212
+
213
+ const handleDelete = () => dispatch({ type: "DELETE_API" });
214
+
215
+ return (
216
+ <Box sx={{ display: "flex", height: "100%", gap: 2 }}>
217
+ <Box sx={{ width: 280, flexShrink: 0, height: "100%" }}>
218
+ <APITree />
219
+ </Box>
220
+
221
+ <NucDialog
222
+ title={dialogTitle}
223
+ open={dialog.open}
224
+ handleClose={handleClose}
225
+ maximizedDimensions={{ width: "75rem", height: "60rem" }}
226
+ minimizedDimensions={{ width: "65rem", height: "50rem" }}
227
+ action={
228
+ <APIDialogAction
229
+ view={view}
230
+ setApiDialogView={setView}
231
+ saveApiDialog={handleSave}
232
+ saveDisable={false}
233
+ deleteDisable={!isEdit}
234
+ deleteMethod={handleDelete}
235
+ />
236
+ }
237
+ >
238
+ <Box
239
+ key={dialogKey}
240
+ sx={{ display: "flex", flexDirection: "column", height: "100%" }}
241
+ >
242
+ <APIPath
243
+ method={allowedMethods[0] || "GET"}
244
+ path={basePath}
245
+ methodRef={methodRef}
246
+ pathRef={pathRef}
247
+ onTypesButtonClick={() => setView("TYPES")}
248
+ allowedMethods={allowedMethods.length ? allowedMethods : ["GET"]}
249
+ isMethodDisabled={isMethodDisabled}
250
+ isPathDisabled={isPathDisabled}
251
+ validatePath={() => {}}
252
+ />
253
+ <Divider sx={{ my: 2 }} />
254
+ {view === "PARAMS" && (
255
+ <APIParams
256
+ types={types}
257
+ paramsRef={paramsRef}
258
+ addParams={addParams}
259
+ />
260
+ )}
261
+ {view === "BODY" && (
262
+ <NewAPIBody
263
+ types={types}
264
+ api={{
265
+ path: basePath,
266
+ method: methodRef.current,
267
+ params: paramsRef.current,
268
+ request: selectedEndpoint?.request || { schema: [] },
269
+ response: selectedEndpoint?.response || { schema: [] },
270
+ }}
271
+ requestSchemaRef={requestSchemaRef}
272
+ responseSchemaRef={responseSchemaRef}
273
+ />
274
+ )}
275
+ {view === "TYPES" && (
276
+ <APITypes tstypes={[]} nuctypes={types} typesRef={typesRef} />
277
+ )}
278
+ </Box>
279
+ </NucDialog>
280
+ </Box>
281
+ );
282
+ };
283
+
284
+ const integratedContext = new Context({
285
+ specification: {
286
+ api: sampleApi,
287
+ types: [],
288
+ functions: [],
289
+ declarations: [],
290
+ },
291
+ pages: {
292
+ api: {
293
+ selected: { path: "/", method: "GET" },
294
+ dialog: {
295
+ type: null,
296
+ action: null,
297
+ open: false,
298
+ view: null,
299
+ map: {},
300
+ params: {},
301
+ },
302
+ resourceMenu: { open: false, anchor: null, path: null },
303
+ },
304
+ },
305
+ });
306
+
307
+ export const APITreeWorkspace = {
308
+ render: () => <APIWorkspace />,
309
+ decorators: [
310
+ (Story) => (
311
+ <ThemeProvider theme={theme}>
312
+ <CssBaseline />
313
+ <ContextProvider state={integratedContext} reducer={reducer}>
314
+ <div style={{ width: 900, height: 600 }}>
315
+ <Story />
316
+ </div>
317
+ </ContextProvider>
318
+ </ThemeProvider>
319
+ ),
320
+ ],
321
+ parameters: {
322
+ layout: "centered",
323
+ docs: {
324
+ description: {
325
+ story:
326
+ "Full workspace: right-click a path node or click the + FAB to open the ResourceMenu, " +
327
+ "then choose Resource, Method, or Delete. Adding a resource or method opens the API dialog " +
328
+ "where you can configure the path, method, params, and body before saving.",
329
+ },
330
+ },
331
+ },
332
+ };