@env-hopper/frontend-core 2.0.1-alpha
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.
- package/LICENSE +21 -0
- package/dist/apple-touch-180x180.png +0 -0
- package/dist/disable.well-known/appspecific/com.chrome.devtools.json +6 -0
- package/dist/env-hopper-16x16.png +0 -0
- package/dist/env-hopper-192x192.png +0 -0
- package/dist/env-hopper-32x32.png +0 -0
- package/dist/env-hopper-48x48.png +0 -0
- package/dist/env-hopper-512x512.png +0 -0
- package/dist/env-hopper-square.svg +114 -0
- package/dist/esm/App.d.ts +12 -0
- package/dist/esm/App.js +12 -0
- package/dist/esm/App.js.map +1 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/autoCompleteFilter.test.d.ts +1 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/features/prefixFracTokenMiddles.test.d.ts +1 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/fixLayout.test.d.ts +1 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/postFiltration.test.d.ts +1 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/testUtils.d.ts +2 -0
- package/dist/esm/__tests__/modules/fuzzyMatchLogic/tokenize.test.d.ts +1 -0
- package/dist/esm/__tests__/modules/resouceJump/findBestMatchByUrl.test.d.ts +1 -0
- package/dist/esm/__tests__/setupTests.d.ts +0 -0
- package/dist/esm/__tests__/util/availabilityMatrixUtils.test.d.ts +1 -0
- package/dist/esm/api/ApiQueryMagazine.d.ts +12 -0
- package/dist/esm/api/ApiQueryMagazine.js +16 -0
- package/dist/esm/api/ApiQueryMagazine.js.map +1 -0
- package/dist/esm/api/data/useQueryBootstrapConfig.d.ts +3 -0
- package/dist/esm/api/data/useQueryBootstrapConfig.js +14 -0
- package/dist/esm/api/data/useQueryBootstrapConfig.js.map +1 -0
- package/dist/esm/api/infra/createQueryClient.d.ts +7 -0
- package/dist/esm/api/infra/createQueryClient.js +23 -0
- package/dist/esm/api/infra/createQueryClient.js.map +1 -0
- package/dist/esm/api/infra/trpc.d.ts +93 -0
- package/dist/esm/api/infra/trpc.js +8 -0
- package/dist/esm/api/infra/trpc.js.map +1 -0
- package/dist/esm/api/unsorted/indexDataFetcher.d.ts +11 -0
- package/dist/esm/api/unsorted/indexDataFetcher.js +35 -0
- package/dist/esm/api/unsorted/indexDataFetcher.js.map +1 -0
- package/dist/esm/appPropsFactory.d.ts +2 -0
- package/dist/esm/appPropsFactory.js +32 -0
- package/dist/esm/appPropsFactory.js.map +1 -0
- package/dist/esm/assets/env-hopper-logo.svg.js +16 -0
- package/dist/esm/assets/env-hopper-logo.svg.js.map +1 -0
- package/dist/esm/components/ThemeSwitcher.d.ts +1 -0
- package/dist/esm/components/ThemeSwitcher.js +25 -0
- package/dist/esm/components/ThemeSwitcher.js.map +1 -0
- package/dist/esm/components/theme-provider.d.ts +2 -0
- package/dist/esm/components/theme-provider.js +10 -0
- package/dist/esm/components/theme-provider.js.map +1 -0
- package/dist/esm/components/ui/badge.d.ts +9 -0
- package/dist/esm/components/ui/breadcrumb.d.ts +46 -0
- package/dist/esm/components/ui/button.d.ts +16 -0
- package/dist/esm/components/ui/button.js +52 -0
- package/dist/esm/components/ui/button.js.map +1 -0
- package/dist/esm/components/ui/card.d.ts +38 -0
- package/dist/esm/components/ui/collapsible.d.ts +5 -0
- package/dist/esm/components/ui/dialog.d.ts +21 -0
- package/dist/esm/components/ui/dropdown-menu.d.ts +25 -0
- package/dist/esm/components/ui/input.d.ts +10 -0
- package/dist/esm/components/ui/popover.d.ts +7 -0
- package/dist/esm/components/ui/popover.js +14 -0
- package/dist/esm/components/ui/popover.js.map +1 -0
- package/dist/esm/components/ui/scroll-area.d.ts +5 -0
- package/dist/esm/components/ui/separator.d.ts +4 -0
- package/dist/esm/components/ui/separator.js +27 -0
- package/dist/esm/components/ui/separator.js.map +1 -0
- package/dist/esm/components/ui/tabs.d.ts +7 -0
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/utils.d.ts +2 -0
- package/dist/esm/lib/utils.js +9 -0
- package/dist/esm/lib/utils.js.map +1 -0
- package/dist/esm/main.d.ts +0 -0
- package/dist/esm/modules/config/BootstrapConfigContext.d.ts +9 -0
- package/dist/esm/modules/config/BootstrapConfigContext.js +25 -0
- package/dist/esm/modules/config/BootstrapConfigContext.js.map +1 -0
- package/dist/esm/modules/config/GlobalConfigContext.d.ts +14 -0
- package/dist/esm/modules/config/GlobalConfigContext.js +21 -0
- package/dist/esm/modules/config/GlobalConfigContext.js.map +1 -0
- package/dist/esm/modules/environment/ApiQueryMagazineEnvironment.d.ts +12 -0
- package/dist/esm/modules/environment/ApiQueryMagazineEnvironment.js +13 -0
- package/dist/esm/modules/environment/ApiQueryMagazineEnvironment.js.map +1 -0
- package/dist/esm/modules/environment/EnvironmentContext.d.ts +15 -0
- package/dist/esm/modules/environment/EnvironmentContext.js +67 -0
- package/dist/esm/modules/environment/EnvironmentContext.js.map +1 -0
- package/dist/esm/modules/environment/types.d.ts +4 -0
- package/dist/esm/modules/environment/ui/EhEnvSelector.d.ts +9 -0
- package/dist/esm/modules/environment/ui/EhEnvSelector.js +167 -0
- package/dist/esm/modules/environment/ui/EhEnvSelector.js.map +1 -0
- package/dist/esm/modules/fuzzyMatchLogic/autoCompleteFilter.d.ts +3 -0
- package/dist/esm/modules/fuzzyMatchLogic/autoCompleteFilter.js +43 -0
- package/dist/esm/modules/fuzzyMatchLogic/autoCompleteFilter.js.map +1 -0
- package/dist/esm/modules/fuzzyMatchLogic/features/prefixFrac.d.ts +1 -0
- package/dist/esm/modules/fuzzyMatchLogic/features/prefixFrac.js +12 -0
- package/dist/esm/modules/fuzzyMatchLogic/features/prefixFrac.js.map +1 -0
- package/dist/esm/modules/fuzzyMatchLogic/features/prefixFracTokenMiddles.d.ts +2 -0
- package/dist/esm/modules/fuzzyMatchLogic/fixLayout.d.ts +2 -0
- package/dist/esm/modules/fuzzyMatchLogic/postFiltration.d.ts +2 -0
- package/dist/esm/modules/fuzzyMatchLogic/scoring.d.ts +2 -0
- package/dist/esm/modules/fuzzyMatchLogic/scoring.js +23 -0
- package/dist/esm/modules/fuzzyMatchLogic/scoring.js.map +1 -0
- package/dist/esm/modules/fuzzyMatchLogic/tokenize.d.ts +3 -0
- package/dist/esm/modules/fuzzyMatchLogic/types.d.ts +25 -0
- package/dist/esm/modules/fuzzyMatchLogic/utils.d.ts +2 -0
- package/dist/esm/modules/fuzzyMatchLogic/utils.js +12 -0
- package/dist/esm/modules/fuzzyMatchLogic/utils.js.map +1 -0
- package/dist/esm/modules/pluginCore/PluginManagerContext.d.ts +24 -0
- package/dist/esm/modules/pluginCore/PluginManagerContext.js +62 -0
- package/dist/esm/modules/pluginCore/PluginManagerContext.js.map +1 -0
- package/dist/esm/modules/pluginCore/makePluginManagerContext.d.ts +7 -0
- package/dist/esm/modules/pluginCore/makePluginManagerContext.js +27 -0
- package/dist/esm/modules/pluginCore/makePluginManagerContext.js.map +1 -0
- package/dist/esm/modules/pluginCore/types.d.ts +36 -0
- package/dist/esm/modules/pluginCore/types.js +7 -0
- package/dist/esm/modules/pluginCore/types.js.map +1 -0
- package/dist/esm/modules/resourceJump/ApiQueryMagazineResourceJump.d.ts +27 -0
- package/dist/esm/modules/resourceJump/ApiQueryMagazineResourceJump.js +26 -0
- package/dist/esm/modules/resourceJump/ApiQueryMagazineResourceJump.js.map +1 -0
- package/dist/esm/modules/resourceJump/ResourceJumpContext.d.ts +17 -0
- package/dist/esm/modules/resourceJump/ResourceJumpContext.js +88 -0
- package/dist/esm/modules/resourceJump/ResourceJumpContext.js.map +1 -0
- package/dist/esm/modules/resourceJump/buildJumpUrl.d.ts +2 -0
- package/dist/esm/modules/resourceJump/buildJumpUrl.js +32 -0
- package/dist/esm/modules/resourceJump/buildJumpUrl.js.map +1 -0
- package/dist/esm/modules/resourceJump/findBestMatchByUrl.d.ts +17 -0
- package/dist/esm/modules/resourceJump/findBestMatchByUrl.js +85 -0
- package/dist/esm/modules/resourceJump/findBestMatchByUrl.js.map +1 -0
- package/dist/esm/modules/resourceJump/helpers.d.ts +28 -0
- package/dist/esm/modules/resourceJump/helpers.js +19 -0
- package/dist/esm/modules/resourceJump/helpers.js.map +1 -0
- package/dist/esm/modules/resourceJump/routeLoader.d.ts +11 -0
- package/dist/esm/modules/resourceJump/routeLoader.js +43 -0
- package/dist/esm/modules/resourceJump/routeLoader.js.map +1 -0
- package/dist/esm/modules/resourceJump/types.d.ts +18 -0
- package/dist/esm/modules/resourceJump/ui/EhJumpResourceSelector.d.ts +20 -0
- package/dist/esm/modules/resourceJump/ui/EhJumpResourceSelector.js +209 -0
- package/dist/esm/modules/resourceJump/ui/EhJumpResourceSelector.js.map +1 -0
- package/dist/esm/modules/resourceJump/ui/JumpALink.d.ts +14 -0
- package/dist/esm/modules/resourceJump/ui/JumpALink.js +38 -0
- package/dist/esm/modules/resourceJump/ui/JumpALink.js.map +1 -0
- package/dist/esm/modules/resourceJump/ui/JumpMainButton.d.ts +5 -0
- package/dist/esm/modules/resourceJump/ui/JumpMainButton.js +66 -0
- package/dist/esm/modules/resourceJump/ui/JumpMainButton.js.map +1 -0
- package/dist/esm/modules/resourceJump/ui/ResouceJumpLayout.d.ts +5 -0
- package/dist/esm/modules/resourceJump/ui/ResouceJumpLayout.js +42 -0
- package/dist/esm/modules/resourceJump/ui/ResouceJumpLayout.js.map +1 -0
- package/dist/esm/plugins/builtin/pageUrl/PageUrlPluginContext.d.ts +9 -0
- package/dist/esm/plugins/builtin/pageUrl/PageUrlPluginContext.js +36 -0
- package/dist/esm/plugins/builtin/pageUrl/PageUrlPluginContext.js.map +1 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlAutoCompletePlugin.d.ts +11 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlAutoCompletePlugin.js +44 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlAutoCompletePlugin.js.map +1 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlJumpPlugin.d.ts +7 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlJumpPlugin.js +29 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlJumpPlugin.js.map +1 -0
- package/dist/esm/plugins/builtin/pageUrl/pageUrlTypes.d.ts +11 -0
- package/dist/esm/routeTree.gen.d.ts +142 -0
- package/dist/esm/routeTree.gen.js +77 -0
- package/dist/esm/routeTree.gen.js.map +1 -0
- package/dist/esm/routes/__root.d.ts +2 -0
- package/dist/esm/routes/__root.js +22 -0
- package/dist/esm/routes/__root.js.map +1 -0
- package/dist/esm/routes/_layout/app/$appSlug/sub/$subValue.d.ts +1 -0
- package/dist/esm/routes/_layout/app/$appSlug.d.ts +1 -0
- package/dist/esm/routes/_layout/app/_appSlug/sub/_subValue.js +18 -0
- package/dist/esm/routes/_layout/app/_appSlug/sub/_subValue.js.map +1 -0
- package/dist/esm/routes/_layout/app/_appSlug.js +18 -0
- package/dist/esm/routes/_layout/app/_appSlug.js.map +1 -0
- package/dist/esm/routes/_layout/env/$envSlug/app/$appSlug/sub/$subValue.d.ts +1 -0
- package/dist/esm/routes/_layout/env/$envSlug/app/$appSlug.d.ts +1 -0
- package/dist/esm/routes/_layout/env/$envSlug/sub/$subValue.d.ts +1 -0
- package/dist/esm/routes/_layout/env/$envSlug.d.ts +1 -0
- package/dist/esm/routes/_layout/env/_envSlug/app/_appSlug/sub/_subValue.js +20 -0
- package/dist/esm/routes/_layout/env/_envSlug/app/_appSlug/sub/_subValue.js.map +1 -0
- package/dist/esm/routes/_layout/env/_envSlug/app/_appSlug.js +18 -0
- package/dist/esm/routes/_layout/env/_envSlug/app/_appSlug.js.map +1 -0
- package/dist/esm/routes/_layout/env/_envSlug/sub/_subValue.js +18 -0
- package/dist/esm/routes/_layout/env/_envSlug/sub/_subValue.js.map +1 -0
- package/dist/esm/routes/_layout/env/_envSlug.js +18 -0
- package/dist/esm/routes/_layout/env/_envSlug.js.map +1 -0
- package/dist/esm/routes/_layout/index.d.ts +1 -0
- package/dist/esm/routes/_layout/index.js +18 -0
- package/dist/esm/routes/_layout/index.js.map +1 -0
- package/dist/esm/routes/_layout.d.ts +1 -0
- package/dist/esm/routes/_layout.js +12 -0
- package/dist/esm/routes/_layout.js.map +1 -0
- package/dist/esm/types/ehTypes.d.ts +31 -0
- package/dist/esm/types/slateTypes.d.ts +28 -0
- package/dist/esm/types/tanstackQuery.d.ts +11 -0
- package/dist/esm/types/types.d.ts +16 -0
- package/dist/esm/types/userBehaviourTypes.d.ts +76 -0
- package/dist/esm/types/utilityTypes.d.ts +1 -0
- package/dist/esm/ui/components/ActionCard.d.ts +9 -0
- package/dist/esm/ui/components/AppIcon.d.ts +7 -0
- package/dist/esm/ui/components/commandInput/EhBaseSelector.d.ts +6 -0
- package/dist/esm/ui/components/commandInput/EhBaseSelector.js +22 -0
- package/dist/esm/ui/components/commandInput/EhBaseSelector.js.map +1 -0
- package/dist/esm/ui/components/commandInput/types.d.ts +13 -0
- package/dist/esm/ui/components/contextDebug.d.ts +2 -0
- package/dist/esm/ui/components/contextDebug.js +12 -0
- package/dist/esm/ui/components/contextDebug.js.map +1 -0
- package/dist/esm/ui/components/controlPanel/BaseDropdownSelector.d.ts +11 -0
- package/dist/esm/ui/components/controlPanel/env/EnvDropdownContent.d.ts +5 -0
- package/dist/esm/ui/components/controlPanel/env/EnvDropdownSelector.d.ts +1 -0
- package/dist/esm/ui/components/error/DefaultErrorComponent.d.ts +2 -0
- package/dist/esm/ui/components/error/DefaultErrorComponent.js +13 -0
- package/dist/esm/ui/components/error/DefaultErrorComponent.js.map +1 -0
- package/dist/esm/ui/components/error/RooutErrorPage.d.ts +2 -0
- package/dist/esm/ui/components/error/RooutErrorPage.js +12 -0
- package/dist/esm/ui/components/error/RooutErrorPage.js.map +1 -0
- package/dist/esm/ui/components/footer/Footer.d.ts +1 -0
- package/dist/esm/ui/components/footer/Footer.js +38 -0
- package/dist/esm/ui/components/footer/Footer.js.map +1 -0
- package/dist/esm/ui/components/header/PlaygroundHeader.d.ts +1 -0
- package/dist/esm/ui/components/header/PlaygroundHeader.js +23 -0
- package/dist/esm/ui/components/header/PlaygroundHeader.js.map +1 -0
- package/dist/esm/ui/components/leftPanel/LeftPanel.d.ts +5 -0
- package/dist/esm/ui/components/quickBar/EnvQuickJumpBar.d.ts +5 -0
- package/dist/esm/ui/components/quickBar/EnvQuickJumpBar.js +52 -0
- package/dist/esm/ui/components/quickBar/EnvQuickJumpBar.js.map +1 -0
- package/dist/esm/ui/components/quickBar/QuickJumpBar.d.ts +5 -0
- package/dist/esm/ui/components/widgetPanel/AddWidgetCard.d.ts +5 -0
- package/dist/esm/ui/components/widgetPanel/WidgetGrid.d.ts +6 -0
- package/dist/esm/ui/components/widgets/CredentialsWidget.d.ts +11 -0
- package/dist/esm/ui/components/widgets/VersionWidget.d.ts +7 -0
- package/dist/esm/ui/error/NotFoundError.d.ts +1 -0
- package/dist/esm/ui/error/NotFoundError.js +16 -0
- package/dist/esm/ui/error/NotFoundError.js.map +1 -0
- package/dist/esm/ui/layout/Footer.d.ts +1 -0
- package/dist/esm/ui/layout/Header.d.ts +1 -0
- package/dist/esm/ui/layout/LoadingScreen.d.ts +4 -0
- package/dist/esm/ui/layout/LoadingScreen.js +14 -0
- package/dist/esm/ui/layout/LoadingScreen.js.map +1 -0
- package/dist/esm/ui/layout/MainLayout.d.ts +5 -0
- package/dist/esm/ui/layout/MainLayout.js +18 -0
- package/dist/esm/ui/layout/MainLayout.js.map +1 -0
- package/dist/esm/ui/layout/SideColumn.d.ts +1 -0
- package/dist/esm/ui/layout/TopLevelProviders.d.ts +5 -0
- package/dist/esm/ui/layout/TopLevelProviders.js +42 -0
- package/dist/esm/ui/layout/TopLevelProviders.js.map +1 -0
- package/dist/esm/ui/main/JumpTabContent.d.ts +1 -0
- package/dist/esm/ui/main/Tabs.d.ts +4 -0
- package/dist/esm/userDb/DbContext.d.ts +9 -0
- package/dist/esm/userDb/DbContext.js +18 -0
- package/dist/esm/userDb/DbContext.js.map +1 -0
- package/dist/esm/userDb/EhDb.d.ts +12 -0
- package/dist/esm/userDb/EhDb.js +20 -0
- package/dist/esm/userDb/EhDb.js.map +1 -0
- package/dist/esm/util/availabilityMatrixUtils.d.ts +12 -0
- package/dist/esm/util/availabilityMatrixUtils.js +57 -0
- package/dist/esm/util/availabilityMatrixUtils.js.map +1 -0
- package/dist/esm/util/createEhRouter.d.ts +7 -0
- package/dist/esm/util/createEhRouter.js +16 -0
- package/dist/esm/util/createEhRouter.js.map +1 -0
- package/dist/esm/util/highlightMatches.d.ts +2 -0
- package/dist/esm/util/highlightMatches.js +19 -0
- package/dist/esm/util/highlightMatches.js.map +1 -0
- package/dist/esm/util/reactQueryUtils.d.ts +6 -0
- package/dist/esm/util/reactQueryUtils.js +10 -0
- package/dist/esm/util/reactQueryUtils.js.map +1 -0
- package/dist/esm/util/route-utils.d.ts +6 -0
- package/dist/esm/util/route-utils.js +72 -0
- package/dist/esm/util/route-utils.js.map +1 -0
- package/dist/favicon.ico +0 -0
- package/dist/robots.txt +2 -0
- package/package.json +110 -0
- package/src/App.tsx +28 -0
- package/src/__tests__/modules/fuzzyMatchLogic/autoCompleteFilter.test.ts +185 -0
- package/src/__tests__/modules/fuzzyMatchLogic/features/prefixFracTokenMiddles.test.ts +23 -0
- package/src/__tests__/modules/fuzzyMatchLogic/fixLayout.test.ts +11 -0
- package/src/__tests__/modules/fuzzyMatchLogic/postFiltration.test.ts +15 -0
- package/src/__tests__/modules/fuzzyMatchLogic/testUtils.ts +8 -0
- package/src/__tests__/modules/fuzzyMatchLogic/tokenize.test.ts +65 -0
- package/src/__tests__/modules/resouceJump/findBestMatchByUrl.test.ts +234 -0
- package/src/__tests__/setupTests.tsx +0 -0
- package/src/__tests__/util/availabilityMatrixUtils.test.ts +61 -0
- package/src/api/ApiQueryMagazine.ts +15 -0
- package/src/api/data/useQueryBootstrapConfig.ts +17 -0
- package/src/api/infra/createQueryClient.ts +25 -0
- package/src/api/infra/trpc.ts +6 -0
- package/src/api/unsorted/indexDataFetcher.ts +46 -0
- package/src/appPropsFactory.ts +35 -0
- package/src/assets/env-hopper-logo.svg +114 -0
- package/src/components/ThemeSwitcher.tsx +22 -0
- package/src/components/theme-provider.tsx +8 -0
- package/src/components/ui/badge.tsx +37 -0
- package/src/components/ui/breadcrumb.tsx +128 -0
- package/src/components/ui/button.tsx +60 -0
- package/src/components/ui/card.tsx +95 -0
- package/src/components/ui/collapsible.tsx +31 -0
- package/src/components/ui/dialog.tsx +182 -0
- package/src/components/ui/dropdown-menu.tsx +257 -0
- package/src/components/ui/input.tsx +28 -0
- package/src/components/ui/popover.tsx +48 -0
- package/src/components/ui/scroll-area.tsx +58 -0
- package/src/components/ui/separator.tsx +26 -0
- package/src/components/ui/tabs.tsx +65 -0
- package/src/index.css +211 -0
- package/src/index.tsx +3 -0
- package/src/lib/utils.ts +7 -0
- package/src/main.tsx +53 -0
- package/src/modules/config/BootstrapConfigContext.tsx +33 -0
- package/src/modules/config/GlobalConfigContext.tsx +42 -0
- package/src/modules/environment/ApiQueryMagazineEnvironment.ts +12 -0
- package/src/modules/environment/EnvironmentContext.tsx +115 -0
- package/src/modules/environment/types.ts +4 -0
- package/src/modules/environment/ui/EhEnvSelector.tsx +191 -0
- package/src/modules/fuzzyMatchLogic/autoCompleteFilter.ts +186 -0
- package/src/modules/fuzzyMatchLogic/features/prefixFrac.ts +13 -0
- package/src/modules/fuzzyMatchLogic/features/prefixFracTokenMiddles.ts +29 -0
- package/src/modules/fuzzyMatchLogic/fixLayout.ts +24 -0
- package/src/modules/fuzzyMatchLogic/postFiltration.ts +35 -0
- package/src/modules/fuzzyMatchLogic/scoring.ts +42 -0
- package/src/modules/fuzzyMatchLogic/tokenize.ts +32 -0
- package/src/modules/fuzzyMatchLogic/types.ts +33 -0
- package/src/modules/fuzzyMatchLogic/utils.ts +18 -0
- package/src/modules/pluginCore/PluginManagerContext.tsx +107 -0
- package/src/modules/pluginCore/makePluginManagerContext.ts +35 -0
- package/src/modules/pluginCore/types.ts +54 -0
- package/src/modules/resourceJump/ApiQueryMagazineResourceJump.ts +31 -0
- package/src/modules/resourceJump/ResourceJumpContext.tsx +142 -0
- package/src/modules/resourceJump/buildJumpUrl.ts +40 -0
- package/src/modules/resourceJump/findBestMatchByUrl.ts +121 -0
- package/src/modules/resourceJump/helpers.ts +117 -0
- package/src/modules/resourceJump/routeLoader.ts +58 -0
- package/src/modules/resourceJump/types.ts +21 -0
- package/src/modules/resourceJump/ui/EhJumpResourceSelector.tsx +259 -0
- package/src/modules/resourceJump/ui/JumpALink.tsx +54 -0
- package/src/modules/resourceJump/ui/JumpMainButton.tsx +97 -0
- package/src/modules/resourceJump/ui/ResouceJumpLayout.tsx +73 -0
- package/src/plugins/builtin/pageUrl/PageUrlPluginContext.tsx +55 -0
- package/src/plugins/builtin/pageUrl/pageUrlAutoCompletePlugin.ts +66 -0
- package/src/plugins/builtin/pageUrl/pageUrlJumpPlugin.ts +36 -0
- package/src/plugins/builtin/pageUrl/pageUrlTypes.ts +17 -0
- package/src/routeTree.gen.ts +249 -0
- package/src/routes/__root.tsx +23 -0
- package/src/routes/_layout/app/$appSlug/sub/$subValue.tsx +15 -0
- package/src/routes/_layout/app/$appSlug.tsx +15 -0
- package/src/routes/_layout/env/$envSlug/app/$appSlug/sub/$subValue.tsx +17 -0
- package/src/routes/_layout/env/$envSlug/app/$appSlug.tsx +15 -0
- package/src/routes/_layout/env/$envSlug/sub/$subValue.tsx +15 -0
- package/src/routes/_layout/env/$envSlug.tsx +15 -0
- package/src/routes/_layout/index.tsx +16 -0
- package/src/routes/_layout.tsx +9 -0
- package/src/types/ehTypes.ts +40 -0
- package/src/types/slateTypes.ts +22 -0
- package/src/types/tanstackQuery.ts +14 -0
- package/src/types/types.ts +20 -0
- package/src/types/userBehaviourTypes.ts +100 -0
- package/src/types/utilityTypes.ts +1 -0
- package/src/types/vite-env.d.ts +1 -0
- package/src/ui/components/ActionCard.tsx +30 -0
- package/src/ui/components/AppIcon.tsx +48 -0
- package/src/ui/components/commandInput/EhBaseSelector.tsx +51 -0
- package/src/ui/components/commandInput/types.ts +22 -0
- package/src/ui/components/contextDebug.tsx +13 -0
- package/src/ui/components/controlPanel/BaseDropdownSelector.tsx +163 -0
- package/src/ui/components/controlPanel/env/EnvDropdownContent.tsx +114 -0
- package/src/ui/components/controlPanel/env/EnvDropdownSelector.tsx +21 -0
- package/src/ui/components/error/DefaultErrorComponent.tsx +38 -0
- package/src/ui/components/error/RooutErrorPage.tsx +10 -0
- package/src/ui/components/footer/Footer.tsx +32 -0
- package/src/ui/components/header/PlaygroundHeader.tsx +26 -0
- package/src/ui/components/leftPanel/LeftPanel.tsx +194 -0
- package/src/ui/components/quickBar/EnvQuickJumpBar.tsx +65 -0
- package/src/ui/components/quickBar/QuickJumpBar.tsx +101 -0
- package/src/ui/components/widgetPanel/AddWidgetCard.tsx +17 -0
- package/src/ui/components/widgetPanel/WidgetGrid.tsx +18 -0
- package/src/ui/components/widgets/CredentialsWidget.tsx +55 -0
- package/src/ui/components/widgets/VersionWidget.tsx +29 -0
- package/src/ui/error/NotFoundError.tsx +13 -0
- package/src/ui/layout/Footer.tsx +16 -0
- package/src/ui/layout/Header.tsx +14 -0
- package/src/ui/layout/LoadingScreen.tsx +17 -0
- package/src/ui/layout/MainLayout.tsx +27 -0
- package/src/ui/layout/SideColumn.tsx +3 -0
- package/src/ui/layout/TopLevelProviders.tsx +52 -0
- package/src/ui/main/JumpTabContent.tsx +12 -0
- package/src/ui/main/Tabs.tsx +29 -0
- package/src/userDb/DbContext.tsx +22 -0
- package/src/userDb/EhDb.ts +22 -0
- package/src/util/availabilityMatrixUtils.ts +80 -0
- package/src/util/createEhRouter.ts +20 -0
- package/src/util/highlightMatches.tsx +29 -0
- package/src/util/reactQueryUtils.ts +12 -0
- package/src/util/route-utils.ts +71 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { queryOptions } from "@tanstack/react-query";
|
|
2
|
+
import { getTrpcFromMeta } from "../../util/reactQueryUtils.js";
|
|
3
|
+
class ApiQueryMagazineResouceJump {
|
|
4
|
+
static getNameMigration(params) {
|
|
5
|
+
return queryOptions({
|
|
6
|
+
queryKey: ["nameMigrations"],
|
|
7
|
+
queryFn: (ctx) => getTrpcFromMeta(ctx).tryFindRenameRule.query(params)
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
static getAvailabilityMatrix() {
|
|
11
|
+
return queryOptions({
|
|
12
|
+
queryKey: ["availabilityMatrix"],
|
|
13
|
+
queryFn: (ctx) => getTrpcFromMeta(ctx).availabilityMatrix.query()
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
static getResourceJumps() {
|
|
17
|
+
return queryOptions({
|
|
18
|
+
queryKey: ["resourceJumps"],
|
|
19
|
+
queryFn: (ctx) => getTrpcFromMeta(ctx).resourceJumps.query()
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export {
|
|
24
|
+
ApiQueryMagazineResouceJump
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=ApiQueryMagazineResourceJump.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ApiQueryMagazineResourceJump.js","sources":["../../../../src/modules/resourceJump/ApiQueryMagazineResourceJump.ts"],"sourcesContent":["import { queryOptions } from '@tanstack/react-query'\nimport type {\n AvailiabilityMatrixData,\n RenameRule,\n RenameRuleParams,\n ResourceJumpsData,\n} from '@env-hopper/backend-core'\nimport { getTrpcFromMeta } from '~/util/reactQueryUtils'\n\nexport class ApiQueryMagazineResouceJump {\n static getNameMigration(params: RenameRuleParams) {\n return queryOptions<RenameRule | false, Error>({\n queryKey: ['nameMigrations'],\n queryFn: (ctx) => getTrpcFromMeta(ctx).tryFindRenameRule.query(params),\n })\n }\n\n static getAvailabilityMatrix() {\n return queryOptions<AvailiabilityMatrixData, Error>({\n queryKey: ['availabilityMatrix'],\n queryFn: (ctx) => getTrpcFromMeta(ctx).availabilityMatrix.query(),\n })\n }\n\n static getResourceJumps() {\n return queryOptions<ResourceJumpsData, Error>({\n queryKey: ['resourceJumps'],\n queryFn: (ctx) => getTrpcFromMeta(ctx).resourceJumps.query(),\n })\n }\n}\n"],"names":[],"mappings":";;AASO,MAAM,4BAA4B;AAAA,EACvC,OAAO,iBAAiB,QAA0B;AAChD,WAAO,aAAwC;AAAA,MAC7C,UAAU,CAAC,gBAAgB;AAAA,MAC3B,SAAS,CAAC,QAAQ,gBAAgB,GAAG,EAAE,kBAAkB,MAAM,MAAM;AAAA,IAAA,CACtE;AAAA,EACH;AAAA,EAEA,OAAO,wBAAwB;AAC7B,WAAO,aAA6C;AAAA,MAClD,UAAU,CAAC,oBAAoB;AAAA,MAC/B,SAAS,CAAC,QAAQ,gBAAgB,GAAG,EAAE,mBAAmB,MAAA;AAAA,IAAM,CACjE;AAAA,EACH;AAAA,EAEA,OAAO,mBAAmB;AACxB,WAAO,aAAuC;AAAA,MAC5C,UAAU,CAAC,eAAe;AAAA,MAC1B,SAAS,CAAC,QAAQ,gBAAgB,GAAG,EAAE,cAAc,MAAA;AAAA,IAAM,CAC5D;AAAA,EACH;AACF;"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { EnvSlug, JumpResouceSlug } from '@env-hopper/backend-core';
|
|
3
|
+
import { ResourceJumpItem, ResourceJumpLoaderReturn } from './types.js';
|
|
4
|
+
export interface ResourceJumpContextIface {
|
|
5
|
+
setCurrentResourceJumpSlug: (slug: JumpResouceSlug | undefined) => void;
|
|
6
|
+
currentResourceJump: ResourceJumpItem | undefined;
|
|
7
|
+
jumpResources: Array<ResourceJumpItem>;
|
|
8
|
+
getJumpUrl: (jumpResourceSlug: JumpResouceSlug | undefined, envSlug: EnvSlug | undefined) => string;
|
|
9
|
+
}
|
|
10
|
+
interface ResouceJumpProviderProps {
|
|
11
|
+
children: ReactNode;
|
|
12
|
+
initialJumpLinkSlug?: string;
|
|
13
|
+
resourceJumpLoader: ResourceJumpLoaderReturn;
|
|
14
|
+
}
|
|
15
|
+
export declare function ResourceJumpProvider({ children, resourceJumpLoader, }: ResouceJumpProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
16
|
+
export declare function useResourceJumpContext(): ResourceJumpContextIface;
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useNavigate } from "@tanstack/react-router";
|
|
3
|
+
import { useState, useCallback, useEffect, useMemo, createContext, use } from "react";
|
|
4
|
+
import { useEnvironmentContext } from "../environment/EnvironmentContext.js";
|
|
5
|
+
import { usePluginManager } from "../pluginCore/PluginManagerContext.js";
|
|
6
|
+
import { buildJumpUrl } from "./buildJumpUrl.js";
|
|
7
|
+
import { getEhToOptions } from "../../util/route-utils.js";
|
|
8
|
+
import { useBootstrapConfig } from "../config/BootstrapConfigContext.js";
|
|
9
|
+
const ResourceJumpContext = createContext(
|
|
10
|
+
void 0
|
|
11
|
+
);
|
|
12
|
+
function ResourceJumpProvider({
|
|
13
|
+
children,
|
|
14
|
+
resourceJumpLoader
|
|
15
|
+
}) {
|
|
16
|
+
const { autocompleteFactoryItems } = usePluginManager();
|
|
17
|
+
const indexData = useBootstrapConfig();
|
|
18
|
+
const { currentEnv } = useEnvironmentContext();
|
|
19
|
+
const navigate = useNavigate();
|
|
20
|
+
const [currentResourceJumpSlug, setCurrentResourceJumpSlug] = useState(resourceJumpLoader.resourceSlug);
|
|
21
|
+
const [jumpResources, setJumpResources] = useState(
|
|
22
|
+
() => autocompleteFactoryItems({
|
|
23
|
+
bootstrapConfig: indexData
|
|
24
|
+
})
|
|
25
|
+
);
|
|
26
|
+
const fixUrlBasedOnSelection = useCallback(
|
|
27
|
+
async (state, replace = false) => {
|
|
28
|
+
await navigate({
|
|
29
|
+
...getEhToOptions(state),
|
|
30
|
+
replace
|
|
31
|
+
});
|
|
32
|
+
},
|
|
33
|
+
[navigate]
|
|
34
|
+
);
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
setJumpResources(autocompleteFactoryItems({ bootstrapConfig: indexData }));
|
|
37
|
+
}, [indexData, autocompleteFactoryItems]);
|
|
38
|
+
const currentResourceJump = useMemo(() => {
|
|
39
|
+
return jumpResources.find((item) => item.slug === currentResourceJumpSlug);
|
|
40
|
+
}, [currentResourceJumpSlug, jumpResources]);
|
|
41
|
+
useEffect(() => {
|
|
42
|
+
if (resourceJumpLoader.envSlug !== (currentEnv == null ? void 0 : currentEnv.slug) || resourceJumpLoader.resourceSlug !== (currentResourceJump == null ? void 0 : currentResourceJump.slug)) {
|
|
43
|
+
void fixUrlBasedOnSelection(
|
|
44
|
+
{ envId: currentEnv == null ? void 0 : currentEnv.slug, appId: currentResourceJump == null ? void 0 : currentResourceJump.slug },
|
|
45
|
+
true
|
|
46
|
+
);
|
|
47
|
+
}
|
|
48
|
+
}, [
|
|
49
|
+
currentResourceJump,
|
|
50
|
+
currentEnv,
|
|
51
|
+
resourceJumpLoader,
|
|
52
|
+
fixUrlBasedOnSelection
|
|
53
|
+
]);
|
|
54
|
+
const getJumpUrl = useCallback(
|
|
55
|
+
(jumpResourceSlug, envSlug) => {
|
|
56
|
+
return buildJumpUrl(
|
|
57
|
+
jumpResourceSlug,
|
|
58
|
+
envSlug,
|
|
59
|
+
resourceJumpLoader.resourceJumps
|
|
60
|
+
);
|
|
61
|
+
},
|
|
62
|
+
[resourceJumpLoader]
|
|
63
|
+
);
|
|
64
|
+
const value = useMemo(
|
|
65
|
+
() => ({
|
|
66
|
+
currentResourceJump,
|
|
67
|
+
setCurrentResourceJumpSlug,
|
|
68
|
+
jumpResources,
|
|
69
|
+
getJumpUrl
|
|
70
|
+
}),
|
|
71
|
+
[currentResourceJump, jumpResources, getJumpUrl]
|
|
72
|
+
);
|
|
73
|
+
return /* @__PURE__ */ jsx(ResourceJumpContext, { value, children });
|
|
74
|
+
}
|
|
75
|
+
function useResourceJumpContext() {
|
|
76
|
+
const context = use(ResourceJumpContext);
|
|
77
|
+
if (context === void 0) {
|
|
78
|
+
throw new Error(
|
|
79
|
+
"useResourceJumpContext must be used within an ResourceJumpContext"
|
|
80
|
+
);
|
|
81
|
+
}
|
|
82
|
+
return context;
|
|
83
|
+
}
|
|
84
|
+
export {
|
|
85
|
+
ResourceJumpProvider,
|
|
86
|
+
useResourceJumpContext
|
|
87
|
+
};
|
|
88
|
+
//# sourceMappingURL=ResourceJumpContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResourceJumpContext.js","sources":["../../../../src/modules/resourceJump/ResourceJumpContext.tsx"],"sourcesContent":["import { useNavigate } from '@tanstack/react-router'\nimport {\n createContext,\n use,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from 'react'\nimport { useEnvironmentContext } from '../environment/EnvironmentContext'\nimport { usePluginManager } from '../pluginCore/PluginManagerContext'\nimport { buildJumpUrl } from './buildJumpUrl'\nimport type { EhUrlParams } from '~/types/ehTypes'\nimport type { ReactNode } from 'react'\nimport type { EnvSlug, JumpResouceSlug } from '@env-hopper/backend-core'\nimport type { ResourceJumpItem, ResourceJumpLoaderReturn } from './types'\nimport { getEhToOptions } from '~/util/route-utils'\nimport { useBootstrapConfig } from '~/modules/config/BootstrapConfigContext'\n\nexport interface ResourceJumpContextIface {\n setCurrentResourceJumpSlug: (slug: JumpResouceSlug | undefined) => void\n currentResourceJump: ResourceJumpItem | undefined\n jumpResources: Array<ResourceJumpItem>\n getJumpUrl: (\n jumpResourceSlug: JumpResouceSlug | undefined,\n envSlug: EnvSlug | undefined,\n ) => string\n}\n\nconst ResourceJumpContext = createContext<ResourceJumpContextIface | undefined>(\n undefined,\n)\n\ninterface ResouceJumpProviderProps {\n children: ReactNode\n initialJumpLinkSlug?: string\n resourceJumpLoader: ResourceJumpLoaderReturn\n}\n\nexport function ResourceJumpProvider({\n children,\n resourceJumpLoader,\n}: ResouceJumpProviderProps) {\n const { autocompleteFactoryItems } = usePluginManager()\n const indexData = useBootstrapConfig()\n const { currentEnv } = useEnvironmentContext()\n const navigate = useNavigate()\n const [currentResourceJumpSlug, setCurrentResourceJumpSlug] = useState<\n string | undefined\n >(resourceJumpLoader.resourceSlug)\n\n const [jumpResources, setJumpResources] = useState<Array<ResourceJumpItem>>(\n () =>\n autocompleteFactoryItems({\n bootstrapConfig: indexData,\n }),\n )\n\n // const [initialEnvAppSubBased] = useState(() => {\n // return parseUrlParams({\n // rawUrlParams: urlParams,\n // config: {\n // envs: indexData.envs,\n // apps: indexData.apps,\n // },\n // lastUsedAppSlug: undefined,\n // lastUsedEnvSlug: undefined,\n // })\n // })\n\n const fixUrlBasedOnSelection = useCallback(\n async (state: EhUrlParams, replace = false) => {\n await navigate({\n ...getEhToOptions(state),\n replace,\n })\n },\n [navigate],\n )\n\n useEffect(() => {\n // eslint-disable-next-line @eslint-react/hooks-extra/no-direct-set-state-in-use-effect\n setJumpResources(autocompleteFactoryItems({ bootstrapConfig: indexData }))\n }, [indexData, autocompleteFactoryItems])\n\n const currentResourceJump = useMemo(() => {\n return jumpResources.find((item) => item.slug === currentResourceJumpSlug)\n }, [currentResourceJumpSlug, jumpResources])\n\n useEffect(() => {\n if (\n resourceJumpLoader.envSlug !== currentEnv?.slug ||\n resourceJumpLoader.resourceSlug !== currentResourceJump?.slug\n ) {\n void fixUrlBasedOnSelection(\n { envId: currentEnv?.slug, appId: currentResourceJump?.slug },\n true,\n )\n }\n }, [\n currentResourceJump,\n currentEnv,\n resourceJumpLoader,\n fixUrlBasedOnSelection,\n ])\n\n const getJumpUrl = useCallback(\n (\n jumpResourceSlug: JumpResouceSlug | undefined,\n envSlug: EnvSlug | undefined,\n ) => {\n return buildJumpUrl(\n jumpResourceSlug,\n envSlug,\n resourceJumpLoader.resourceJumps,\n )\n },\n [resourceJumpLoader],\n )\n\n const value: ResourceJumpContextIface = useMemo(\n () => ({\n currentResourceJump,\n setCurrentResourceJumpSlug,\n jumpResources,\n getJumpUrl,\n }),\n [currentResourceJump, jumpResources, getJumpUrl],\n )\n\n return <ResourceJumpContext value={value}>{children}</ResourceJumpContext>\n}\n\nexport function useResourceJumpContext(): ResourceJumpContextIface {\n const context = use(ResourceJumpContext)\n if (context === undefined) {\n throw new Error(\n 'useResourceJumpContext must be used within an ResourceJumpContext',\n )\n }\n return context\n}\n"],"names":[],"mappings":";;;;;;;;AA6BA,MAAM,sBAAsB;AAAA,EAC1B;AACF;AAQO,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AACF,GAA6B;AAC3B,QAAM,EAAE,yBAAA,IAA6B,iBAAA;AACrC,QAAM,YAAY,mBAAA;AAClB,QAAM,EAAE,WAAA,IAAe,sBAAA;AACvB,QAAM,WAAW,YAAA;AACjB,QAAM,CAAC,yBAAyB,0BAA0B,IAAI,SAE5D,mBAAmB,YAAY;AAEjC,QAAM,CAAC,eAAe,gBAAgB,IAAI;AAAA,IACxC,MACE,yBAAyB;AAAA,MACvB,iBAAiB;AAAA,IAAA,CAClB;AAAA,EAAA;AAeL,QAAM,yBAAyB;AAAA,IAC7B,OAAO,OAAoB,UAAU,UAAU;AAC7C,YAAM,SAAS;AAAA,QACb,GAAG,eAAe,KAAK;AAAA,QACvB;AAAA,MAAA,CACD;AAAA,IACH;AAAA,IACA,CAAC,QAAQ;AAAA,EAAA;AAGX,YAAU,MAAM;AAEd,qBAAiB,yBAAyB,EAAE,iBAAiB,UAAA,CAAW,CAAC;AAAA,EAC3E,GAAG,CAAC,WAAW,wBAAwB,CAAC;AAExC,QAAM,sBAAsB,QAAQ,MAAM;AACxC,WAAO,cAAc,KAAK,CAAC,SAAS,KAAK,SAAS,uBAAuB;AAAA,EAC3E,GAAG,CAAC,yBAAyB,aAAa,CAAC;AAE3C,YAAU,MAAM;AACd,QACE,mBAAmB,aAAY,yCAAY,SAC3C,mBAAmB,kBAAiB,2DAAqB,OACzD;AACA,WAAK;AAAA,QACH,EAAE,OAAO,yCAAY,MAAM,OAAO,2DAAqB,KAAA;AAAA,QACvD;AAAA,MAAA;AAAA,IAEJ;AAAA,EACF,GAAG;AAAA,IACD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACD;AAED,QAAM,aAAa;AAAA,IACjB,CACE,kBACA,YACG;AACH,aAAO;AAAA,QACL;AAAA,QACA;AAAA,QACA,mBAAmB;AAAA,MAAA;AAAA,IAEvB;AAAA,IACA,CAAC,kBAAkB;AAAA,EAAA;AAGrB,QAAM,QAAkC;AAAA,IACtC,OAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA;AAAA,IAEF,CAAC,qBAAqB,eAAe,UAAU;AAAA,EAAA;AAGjD,SAAO,oBAAC,qBAAA,EAAoB,OAAe,SAAA,CAAS;AACtD;AAEO,SAAS,yBAAmD;AACjE,QAAM,UAAU,IAAI,mBAAmB;AACvC,MAAI,YAAY,QAAW;AACzB,UAAM,IAAI;AAAA,MACR;AAAA,IAAA;AAAA,EAEJ;AACA,SAAO;AACT;"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
function buildJumpUrl(jumpResourceSlug, envSlug, resourceJumps) {
|
|
2
|
+
const { baseResouceJumpUrls, resourceJumpsData, envData } = resourceJumps;
|
|
3
|
+
const baseUrl = baseResouceJumpUrls[jumpResourceSlug || ""] || "";
|
|
4
|
+
let finalUrl = baseUrl;
|
|
5
|
+
let prevUrl = "";
|
|
6
|
+
while (finalUrl !== prevUrl) {
|
|
7
|
+
prevUrl = finalUrl;
|
|
8
|
+
finalUrl = finalUrl.replace(/{{(.+?)}}/g, function(match, contents) {
|
|
9
|
+
var _a, _b;
|
|
10
|
+
if (contents.startsWith("app.meta.")) {
|
|
11
|
+
const varName = contents.replace("app.meta.", "");
|
|
12
|
+
const r = (_a = resourceJumpsData[jumpResourceSlug || ""]) == null ? void 0 : _a[varName];
|
|
13
|
+
if (r !== void 0) {
|
|
14
|
+
return r;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
if (contents.startsWith("env.meta.")) {
|
|
18
|
+
const varName = contents.replace("env.meta.", "");
|
|
19
|
+
const r = (_b = envData[envSlug || ""]) == null ? void 0 : _b[varName];
|
|
20
|
+
if (r !== void 0) {
|
|
21
|
+
return r;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
return match;
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return finalUrl || `not found ${jumpResourceSlug}`;
|
|
28
|
+
}
|
|
29
|
+
export {
|
|
30
|
+
buildJumpUrl
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=buildJumpUrl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildJumpUrl.js","sources":["../../../../src/modules/resourceJump/buildJumpUrl.ts"],"sourcesContent":["import type {\n EnvSlug,\n JumpResouceSlug,\n ResourceJumpsData,\n} from '@env-hopper/backend-core'\n\nexport function buildJumpUrl(\n jumpResourceSlug: JumpResouceSlug | undefined,\n envSlug: EnvSlug | undefined,\n resourceJumps: ResourceJumpsData,\n): string {\n const { baseResouceJumpUrls, resourceJumpsData, envData } = resourceJumps\n\n const baseUrl = baseResouceJumpUrls[jumpResourceSlug || ''] || ''\n let finalUrl = baseUrl\n let prevUrl = ''\n\n while (finalUrl !== prevUrl) {\n prevUrl = finalUrl\n finalUrl = finalUrl.replace(/{{(.+?)}}/g, function (match, contents) {\n if (contents.startsWith('app.meta.')) {\n const varName = contents.replace('app.meta.', '')\n const r = resourceJumpsData[jumpResourceSlug || '']?.[varName]\n if (r !== undefined) {\n return r\n }\n }\n if (contents.startsWith('env.meta.')) {\n const varName = contents.replace('env.meta.', '')\n const r = envData[envSlug || '']?.[varName]\n if (r !== undefined) {\n return r\n }\n }\n return match\n })\n }\n\n return finalUrl || `not found ${jumpResourceSlug}`\n}\n"],"names":[],"mappings":"AAMO,SAAS,aACd,kBACA,SACA,eACQ;AACR,QAAM,EAAE,qBAAqB,mBAAmB,QAAA,IAAY;AAE5D,QAAM,UAAU,oBAAoB,oBAAoB,EAAE,KAAK;AAC/D,MAAI,WAAW;AACf,MAAI,UAAU;AAEd,SAAO,aAAa,SAAS;AAC3B,cAAU;AACV,eAAW,SAAS,QAAQ,cAAc,SAAU,OAAO,UAAU;AAblE;AAcD,UAAI,SAAS,WAAW,WAAW,GAAG;AACpC,cAAM,UAAU,SAAS,QAAQ,aAAa,EAAE;AAChD,cAAM,KAAI,uBAAkB,oBAAoB,EAAE,MAAxC,mBAA4C;AACtD,YAAI,MAAM,QAAW;AACnB,iBAAO;AAAA,QACT;AAAA,MACF;AACA,UAAI,SAAS,WAAW,WAAW,GAAG;AACpC,cAAM,UAAU,SAAS,QAAQ,aAAa,EAAE;AAChD,cAAM,KAAI,aAAQ,WAAW,EAAE,MAArB,mBAAyB;AACnC,YAAI,MAAM,QAAW;AACnB,iBAAO;AAAA,QACT;AAAA,MACF;AACA,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AAEA,SAAO,YAAY,aAAa,gBAAgB;AAClD;"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AvailiabilityMatrixData, EhEnvIndexed, RenameRule, RenameRuleParams } from '@env-hopper/backend-core';
|
|
2
|
+
import { EnvironmentHistoryItem } from '../environment/types.js';
|
|
3
|
+
import { ResourceJumpItem } from './types.js';
|
|
4
|
+
export interface FindBestMatchingResourceJumpParams {
|
|
5
|
+
urlEnvSlug: string | undefined;
|
|
6
|
+
urlAppSlug: string | undefined;
|
|
7
|
+
envs: Record<string, EhEnvIndexed>;
|
|
8
|
+
resourceJumps: Record<string, ResourceJumpItem>;
|
|
9
|
+
getEnvHistory: () => Promise<Array<EnvironmentHistoryItem>>;
|
|
10
|
+
getAvailabilityMatrix: () => Promise<AvailiabilityMatrixData>;
|
|
11
|
+
getNameMigrations: (params: RenameRuleParams) => Promise<RenameRule | false>;
|
|
12
|
+
}
|
|
13
|
+
export interface BestMatchByUrlReturn {
|
|
14
|
+
env: EhEnvIndexed | undefined;
|
|
15
|
+
resourceJump: ResourceJumpItem | undefined;
|
|
16
|
+
}
|
|
17
|
+
export declare function findBestMatchByUrl({ urlAppSlug, urlEnvSlug, envs, resourceJumps, getEnvHistory, getAvailabilityMatrix, getNameMigrations, }: FindBestMatchingResourceJumpParams): Promise<BestMatchByUrlReturn>;
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { sort } from "radashi";
|
|
2
|
+
import { findAvailableResources } from "../../util/availabilityMatrixUtils.js";
|
|
3
|
+
async function findBestMatchByUrl({
|
|
4
|
+
urlAppSlug,
|
|
5
|
+
urlEnvSlug,
|
|
6
|
+
envs,
|
|
7
|
+
resourceJumps,
|
|
8
|
+
getEnvHistory,
|
|
9
|
+
getAvailabilityMatrix,
|
|
10
|
+
getNameMigrations
|
|
11
|
+
}) {
|
|
12
|
+
var _a;
|
|
13
|
+
let envFound = void 0;
|
|
14
|
+
let resourceJumpFound = void 0;
|
|
15
|
+
if (urlAppSlug !== void 0) {
|
|
16
|
+
resourceJumpFound = resourceJumps[urlAppSlug];
|
|
17
|
+
if (!resourceJumpFound) {
|
|
18
|
+
const migrationRule = await getNameMigrations({
|
|
19
|
+
envSlug: void 0,
|
|
20
|
+
resourceSlug: urlAppSlug
|
|
21
|
+
});
|
|
22
|
+
if (migrationRule !== false && migrationRule.type === "resourceRename") {
|
|
23
|
+
resourceJumpFound = resourceJumps[migrationRule.targetSlug];
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
if (urlEnvSlug !== void 0) {
|
|
28
|
+
envFound = envs[urlEnvSlug];
|
|
29
|
+
}
|
|
30
|
+
if (!envFound) {
|
|
31
|
+
const migrationRule = await getNameMigrations({
|
|
32
|
+
envSlug: urlEnvSlug,
|
|
33
|
+
resourceSlug: void 0
|
|
34
|
+
});
|
|
35
|
+
if (migrationRule !== false && migrationRule.type === "envRename") {
|
|
36
|
+
envFound = envs[migrationRule.targetSlug];
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
const hasEnvOrResource = envFound !== void 0 || resourceJumpFound !== void 0;
|
|
40
|
+
if (hasEnvOrResource) {
|
|
41
|
+
if (envFound === void 0) {
|
|
42
|
+
const [history, availabilityMatrix] = await Promise.all([
|
|
43
|
+
getEnvHistory(),
|
|
44
|
+
getAvailabilityMatrix()
|
|
45
|
+
]);
|
|
46
|
+
const historyEnvSlugs = history.map(
|
|
47
|
+
(historyItem) => {
|
|
48
|
+
var _a2;
|
|
49
|
+
return envs[historyItem.envSlug] && ((_a2 = envs[historyItem.envSlug]) == null ? void 0 : _a2.slug);
|
|
50
|
+
}
|
|
51
|
+
).filter((e) => e !== void 0);
|
|
52
|
+
const alreadyCheckedSlugs = /* @__PURE__ */ new Set();
|
|
53
|
+
const candidates = [];
|
|
54
|
+
for (const envSlug of historyEnvSlugs) {
|
|
55
|
+
if (alreadyCheckedSlugs.has(envSlug)) {
|
|
56
|
+
continue;
|
|
57
|
+
}
|
|
58
|
+
alreadyCheckedSlugs.add(envSlug);
|
|
59
|
+
const jumpResourcePairs = findAvailableResources({
|
|
60
|
+
envSlug,
|
|
61
|
+
resourceJumpSlug: resourceJumpFound ? resourceJumpFound.slug : void 0,
|
|
62
|
+
availabilityMatrix
|
|
63
|
+
});
|
|
64
|
+
candidates.push(...jumpResourcePairs);
|
|
65
|
+
}
|
|
66
|
+
const sortedByRelevance = sort(
|
|
67
|
+
candidates,
|
|
68
|
+
({ availabilityVariant: { isDeployed, hasData, isHealthy } }) => (isDeployed && isHealthy && hasData ? 1 : 0) * 4 + (isHealthy ? 1 : 0) * 3 + (hasData ? 1 : 0) * 2 + (isDeployed ? 1 : 0),
|
|
69
|
+
true
|
|
70
|
+
);
|
|
71
|
+
const mostRelevantEnvSlug = sortedByRelevance.length > 0 ? (_a = sortedByRelevance[0]) == null ? void 0 : _a.envSlug : void 0;
|
|
72
|
+
if (mostRelevantEnvSlug) {
|
|
73
|
+
envFound = envs[mostRelevantEnvSlug];
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
resourceJump: resourceJumpFound,
|
|
79
|
+
env: envFound
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
export {
|
|
83
|
+
findBestMatchByUrl
|
|
84
|
+
};
|
|
85
|
+
//# sourceMappingURL=findBestMatchByUrl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findBestMatchByUrl.js","sources":["../../../../src/modules/resourceJump/findBestMatchByUrl.ts"],"sourcesContent":["import { sort } from 'radashi'\nimport type {\n AvailiabilityMatrixData,\n EhEnvIndexed,\n RenameRule,\n RenameRuleParams,\n} from '@env-hopper/backend-core'\nimport type { EnvironmentHistoryItem } from '../environment/types'\nimport type { ResourceJumpItem } from './types'\nimport type { AvailabilitySlugPair } from '~/util/availabilityMatrixUtils'\nimport { findAvailableResources } from '~/util/availabilityMatrixUtils'\n\nexport interface FindBestMatchingResourceJumpParams {\n urlEnvSlug: string | undefined\n urlAppSlug: string | undefined\n envs: Record<string, EhEnvIndexed>\n resourceJumps: Record<string, ResourceJumpItem>\n getEnvHistory: () => Promise<Array<EnvironmentHistoryItem>>\n getAvailabilityMatrix: () => Promise<AvailiabilityMatrixData>\n getNameMigrations: (params: RenameRuleParams) => Promise<RenameRule | false>\n}\n\nexport interface BestMatchByUrlReturn {\n env: EhEnvIndexed | undefined\n resourceJump: ResourceJumpItem | undefined\n}\n\nexport async function findBestMatchByUrl({\n urlAppSlug,\n urlEnvSlug,\n envs,\n resourceJumps,\n getEnvHistory,\n getAvailabilityMatrix,\n getNameMigrations,\n}: FindBestMatchingResourceJumpParams): Promise<BestMatchByUrlReturn> {\n let envFound: EhEnvIndexed | undefined = undefined\n let resourceJumpFound: ResourceJumpItem | undefined = undefined\n\n if (urlAppSlug !== undefined) {\n resourceJumpFound = resourceJumps[urlAppSlug]\n if (!resourceJumpFound) {\n const migrationRule = await getNameMigrations({\n envSlug: undefined,\n resourceSlug: urlAppSlug,\n })\n if (migrationRule !== false && migrationRule.type === 'resourceRename') {\n resourceJumpFound = resourceJumps[migrationRule.targetSlug]\n }\n }\n }\n\n if (urlEnvSlug !== undefined) {\n envFound = envs[urlEnvSlug]\n }\n if (!envFound) {\n const migrationRule = await getNameMigrations({\n envSlug: urlEnvSlug,\n resourceSlug: undefined,\n })\n if (migrationRule !== false && migrationRule.type === 'envRename') {\n envFound = envs[migrationRule.targetSlug]\n }\n }\n\n const hasEnvOrResource =\n envFound !== undefined || resourceJumpFound !== undefined\n if (hasEnvOrResource) {\n if (envFound === undefined) {\n const [history, availabilityMatrix] = await Promise.all([\n getEnvHistory(),\n getAvailabilityMatrix(),\n ])\n\n const historyEnvSlugs = history\n .map(\n (historyItem) =>\n envs[historyItem.envSlug] && envs[historyItem.envSlug]?.slug,\n )\n .filter((e) => e !== undefined)\n const alreadyCheckedSlugs = new Set<string>()\n\n const candidates: Array<AvailabilitySlugPair> = []\n for (const envSlug of historyEnvSlugs) {\n if (alreadyCheckedSlugs.has(envSlug)) {\n continue\n }\n alreadyCheckedSlugs.add(envSlug)\n\n const jumpResourcePairs = findAvailableResources({\n envSlug,\n resourceJumpSlug: resourceJumpFound\n ? resourceJumpFound.slug\n : undefined,\n availabilityMatrix: availabilityMatrix,\n })\n\n candidates.push(...jumpResourcePairs)\n }\n const sortedByRelevance = sort(\n candidates,\n ({ availabilityVariant: { isDeployed, hasData, isHealthy } }) =>\n (isDeployed && isHealthy && hasData ? 1 : 0) * 4 +\n (isHealthy ? 1 : 0) * 3 +\n (hasData ? 1 : 0) * 2 +\n (isDeployed ? 1 : 0),\n true,\n )\n const mostRelevantEnvSlug =\n sortedByRelevance.length > 0 ? sortedByRelevance[0]?.envSlug : undefined\n if (mostRelevantEnvSlug) {\n envFound = envs[mostRelevantEnvSlug]\n }\n }\n }\n\n return {\n resourceJump: resourceJumpFound,\n env: envFound,\n }\n}\n"],"names":["_a"],"mappings":";;AA2BA,eAAsB,mBAAmB;AAAA,EACvC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAsE;;AACpE,MAAI,WAAqC;AACzC,MAAI,oBAAkD;AAEtD,MAAI,eAAe,QAAW;AAC5B,wBAAoB,cAAc,UAAU;AAC5C,QAAI,CAAC,mBAAmB;AACtB,YAAM,gBAAgB,MAAM,kBAAkB;AAAA,QAC5C,SAAS;AAAA,QACT,cAAc;AAAA,MAAA,CACf;AACD,UAAI,kBAAkB,SAAS,cAAc,SAAS,kBAAkB;AACtE,4BAAoB,cAAc,cAAc,UAAU;AAAA,MAC5D;AAAA,IACF;AAAA,EACF;AAEA,MAAI,eAAe,QAAW;AAC5B,eAAW,KAAK,UAAU;AAAA,EAC5B;AACA,MAAI,CAAC,UAAU;AACb,UAAM,gBAAgB,MAAM,kBAAkB;AAAA,MAC5C,SAAS;AAAA,MACT,cAAc;AAAA,IAAA,CACf;AACD,QAAI,kBAAkB,SAAS,cAAc,SAAS,aAAa;AACjE,iBAAW,KAAK,cAAc,UAAU;AAAA,IAC1C;AAAA,EACF;AAEA,QAAM,mBACJ,aAAa,UAAa,sBAAsB;AAClD,MAAI,kBAAkB;AACpB,QAAI,aAAa,QAAW;AAC1B,YAAM,CAAC,SAAS,kBAAkB,IAAI,MAAM,QAAQ,IAAI;AAAA,QACtD,cAAA;AAAA,QACA,sBAAA;AAAA,MAAsB,CACvB;AAED,YAAM,kBAAkB,QACrB;AAAA,QACC,CAAC;;AACC,sBAAK,YAAY,OAAO,OAAKA,MAAA,KAAK,YAAY,OAAO,MAAxB,gBAAAA,IAA2B;AAAA;AAAA,MAAA,EAE3D,OAAO,CAAC,MAAM,MAAM,MAAS;AAChC,YAAM,0CAA0B,IAAA;AAEhC,YAAM,aAA0C,CAAA;AAChD,iBAAW,WAAW,iBAAiB;AACrC,YAAI,oBAAoB,IAAI,OAAO,GAAG;AACpC;AAAA,QACF;AACA,4BAAoB,IAAI,OAAO;AAE/B,cAAM,oBAAoB,uBAAuB;AAAA,UAC/C;AAAA,UACA,kBAAkB,oBACd,kBAAkB,OAClB;AAAA,UACJ;AAAA,QAAA,CACD;AAED,mBAAW,KAAK,GAAG,iBAAiB;AAAA,MACtC;AACA,YAAM,oBAAoB;AAAA,QACxB;AAAA,QACA,CAAC,EAAE,qBAAqB,EAAE,YAAY,SAAS,UAAA,SAC5C,cAAc,aAAa,UAAU,IAAI,KAAK,KAC9C,YAAY,IAAI,KAAK,KACrB,UAAU,IAAI,KAAK,KACnB,aAAa,IAAI;AAAA,QACpB;AAAA,MAAA;AAEF,YAAM,sBACJ,kBAAkB,SAAS,KAAI,uBAAkB,CAAC,MAAnB,mBAAsB,UAAU;AACjE,UAAI,qBAAqB;AACvB,mBAAW,KAAK,mBAAmB;AAAA,MACrC;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,cAAc;AAAA,IACd,KAAK;AAAA,EAAA;AAET;"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { EhAppIndexed, EhEnvIndexed } from '@env-hopper/backend-core';
|
|
2
|
+
import { BaseAutoCompletableItem } from '~/modules/pluginCore/types';
|
|
3
|
+
import { EhUrlParams } from '~/types/ehTypes';
|
|
4
|
+
import { ResourceJumpItem } from './types.js';
|
|
5
|
+
export declare function mapDisplayedItems(displayedItems: Array<BaseAutoCompletableItem>): Generator<{
|
|
6
|
+
item: import('../../plugins/builtin/pageUrl/pageUrlTypes.js').PluginPageUrlAutocompleteItem;
|
|
7
|
+
itemRenderData: import('~/modules/pluginCore/types').BaseAutoCompleteItemRender;
|
|
8
|
+
isChild: boolean;
|
|
9
|
+
}, void, unknown>;
|
|
10
|
+
export declare function formatResourceTitle(resouceJump: ResourceJumpItem | undefined): string;
|
|
11
|
+
export declare function getByIdRelaxed<T extends {
|
|
12
|
+
slug: string;
|
|
13
|
+
}>(primarySearch: (slug: string | undefined) => T | undefined, id: string | undefined): [T | undefined, boolean];
|
|
14
|
+
export interface PreselectedBasedOnParams {
|
|
15
|
+
rawUrlParams: EhUrlParams;
|
|
16
|
+
config: {
|
|
17
|
+
envs: Record<string, EhEnvIndexed>;
|
|
18
|
+
apps: Record<string, EhAppIndexed>;
|
|
19
|
+
};
|
|
20
|
+
lastUsedEnvSlug: string | undefined;
|
|
21
|
+
lastUsedAppSlug: string | undefined;
|
|
22
|
+
}
|
|
23
|
+
export interface PreselectedBasedOnParamsReturn {
|
|
24
|
+
urlWasFixed: boolean;
|
|
25
|
+
env: EhEnvIndexed | undefined;
|
|
26
|
+
app: EhAppIndexed | undefined;
|
|
27
|
+
}
|
|
28
|
+
export declare function loadEnvAndResouceByRawUrlParams({ rawUrlParams: urlParams, config, lastUsedEnvSlug: lastUsedEnvSlug, lastUsedAppSlug: lastUsedAppSlug, }: PreselectedBasedOnParams): PreselectedBasedOnParamsReturn;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { isAutocompleteItem, getRenderData } from "../../plugins/builtin/pageUrl/pageUrlAutoCompletePlugin.js";
|
|
2
|
+
function* mapDisplayedItems(displayedItems) {
|
|
3
|
+
let lastParent = void 0;
|
|
4
|
+
for (const item of displayedItems) {
|
|
5
|
+
if (isAutocompleteItem(item)) {
|
|
6
|
+
const itemRenderData = getRenderData(item);
|
|
7
|
+
yield {
|
|
8
|
+
item,
|
|
9
|
+
itemRenderData,
|
|
10
|
+
isChild: item.parent === lastParent
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
lastParent = item.parent;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export {
|
|
17
|
+
mapDisplayedItems
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sources":["../../../../src/modules/resourceJump/helpers.ts"],"sourcesContent":["import type { EhAppIndexed, EhEnvIndexed } from '@env-hopper/backend-core'\nimport type {\n BaseAppAutoCompletableParent,\n BaseAutoCompletableItem,\n} from '~/modules/pluginCore/types'\nimport type { EhUrlParams } from '~/types/ehTypes'\nimport type { ResourceJumpItem } from './types'\nimport {\n getRenderData,\n isAutocompleteItem,\n} from '~/plugins/builtin/pageUrl/pageUrlAutoCompletePlugin'\n\nexport function* mapDisplayedItems(\n displayedItems: Array<BaseAutoCompletableItem>,\n) {\n let lastParent: BaseAppAutoCompletableParent | undefined = undefined\n\n for (const item of displayedItems) {\n if (isAutocompleteItem(item)) {\n const itemRenderData = getRenderData(item)\n yield {\n item,\n itemRenderData,\n isChild: item.parent === lastParent,\n }\n }\n lastParent = item.parent\n }\n}\n\nexport function formatResourceTitle(resouceJump: ResourceJumpItem | undefined) {\n if (resouceJump === undefined) {\n return ''\n }\n return [resouceJump.parent?.displayName, resouceJump.slug]\n .filter(Boolean)\n .join(' :: ')\n}\n\nexport function getByIdRelaxed<T extends { slug: string }>(\n primarySearch: (slug: string | undefined) => T | undefined,\n id: string | undefined,\n): [T | undefined, boolean] {\n if (id !== undefined) {\n const exactMatchResult = primarySearch(id)\n if (exactMatchResult !== undefined) {\n return [exactMatchResult, true]\n }\n\n // const items: SourceItem[] = options.map((e) => ({ title: e.slug, slug: e.slug }));\n // const found = makeAutoCompleteFilter(items)(id.toLowerCase(), items);\n // if (found.length === 1) {\n // return [primarySearch(found[0].id, options), false];\n // }\n }\n return [undefined, false]\n}\n\nexport interface PreselectedBasedOnParams {\n rawUrlParams: EhUrlParams\n config: {\n envs: Record<string, EhEnvIndexed>\n apps: Record<string, EhAppIndexed>\n }\n lastUsedEnvSlug: string | undefined\n lastUsedAppSlug: string | undefined\n}\n\nexport interface PreselectedBasedOnParamsReturn {\n urlWasFixed: boolean\n env: EhEnvIndexed | undefined\n app: EhAppIndexed | undefined\n}\n\nexport function loadEnvAndResouceByRawUrlParams({\n rawUrlParams: urlParams,\n config,\n lastUsedEnvSlug: lastUsedEnvSlug,\n lastUsedAppSlug: lastUsedAppSlug,\n}: PreselectedBasedOnParams): PreselectedBasedOnParamsReturn {\n let selectedEnv: EhEnvIndexed | undefined = undefined\n let selectedApp: EhAppIndexed | undefined = undefined\n let urlWasFixed = false\n\n const doGetEnvById = (envId: string | undefined) =>\n envId ? config.envs[envId] : undefined\n const doGetAppById = (appId: string | undefined) =>\n appId ? config.apps[appId] : undefined\n\n if (urlParams.envId !== undefined) {\n let strictMatch\n ;[selectedEnv, strictMatch] = getByIdRelaxed<EhEnvIndexed>(\n doGetEnvById,\n urlParams.envId,\n )\n if (!strictMatch) {\n urlWasFixed = true\n }\n } else if (lastUsedEnvSlug !== undefined) {\n ;[selectedEnv] = getByIdRelaxed(doGetEnvById, lastUsedEnvSlug)\n }\n\n if (urlParams.appId !== undefined) {\n let strictMatch\n ;[selectedApp, strictMatch] = getByIdRelaxed<EhAppIndexed>(\n (appId) => (appId ? config.apps[appId] : undefined),\n urlParams.appId,\n )\n if (!strictMatch) {\n urlWasFixed = true\n }\n } else if (lastUsedAppSlug !== undefined) {\n ;[selectedApp] = getByIdRelaxed(doGetAppById, lastUsedAppSlug)\n }\n\n return { urlWasFixed, env: selectedEnv, app: selectedApp }\n}\n"],"names":[],"mappings":";AAYO,UAAU,kBACf,gBACA;AACA,MAAI,aAAuD;AAE3D,aAAW,QAAQ,gBAAgB;AACjC,QAAI,mBAAmB,IAAI,GAAG;AAC5B,YAAM,iBAAiB,cAAc,IAAI;AACzC,YAAM;AAAA,QACJ;AAAA,QACA;AAAA,QACA,SAAS,KAAK,WAAW;AAAA,MAAA;AAAA,IAE7B;AACA,iBAAa,KAAK;AAAA,EACpB;AACF;"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { EhRouterContext } from '~/types/types';
|
|
2
|
+
import { ResourceJumpLoaderReturn } from './types.js';
|
|
3
|
+
export interface RouteLoaderCtx {
|
|
4
|
+
params: {
|
|
5
|
+
envSlug?: string;
|
|
6
|
+
appSlug?: string;
|
|
7
|
+
subValue?: string;
|
|
8
|
+
};
|
|
9
|
+
context: EhRouterContext;
|
|
10
|
+
}
|
|
11
|
+
export declare function routeLoader({ params, context, }: RouteLoaderCtx): Promise<ResourceJumpLoaderReturn>;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { ApiQueryMagazineHistory } from "../environment/ApiQueryMagazineEnvironment.js";
|
|
2
|
+
import { makePluginInterfaceForCore } from "../pluginCore/makePluginManagerContext.js";
|
|
3
|
+
import { ApiQueryMagazineResouceJump } from "./ApiQueryMagazineResourceJump.js";
|
|
4
|
+
import { findBestMatchByUrl } from "./findBestMatchByUrl.js";
|
|
5
|
+
import { ApiQueryMagazine } from "../../api/ApiQueryMagazine.js";
|
|
6
|
+
async function routeLoader({
|
|
7
|
+
params,
|
|
8
|
+
context
|
|
9
|
+
}) {
|
|
10
|
+
const [bootstrapConfig, resourceJumps] = await Promise.all([
|
|
11
|
+
context.queryClient.ensureQueryData(ApiQueryMagazine.getConfig(context)),
|
|
12
|
+
context.queryClient.ensureQueryData(
|
|
13
|
+
ApiQueryMagazineResouceJump.getResourceJumps()
|
|
14
|
+
)
|
|
15
|
+
]);
|
|
16
|
+
const pluginInterfaceForCore = makePluginInterfaceForCore(context.plugins);
|
|
17
|
+
const resourceJumpItems = await pluginInterfaceForCore.getResourceJumpsItems(bootstrapConfig);
|
|
18
|
+
const { env, resourceJump } = await findBestMatchByUrl({
|
|
19
|
+
urlEnvSlug: params.envSlug,
|
|
20
|
+
urlAppSlug: params.appSlug,
|
|
21
|
+
envs: bootstrapConfig.envs,
|
|
22
|
+
resourceJumps: resourceJumpItems,
|
|
23
|
+
getEnvHistory: () => context.queryClient.ensureQueryData(
|
|
24
|
+
ApiQueryMagazineHistory.getEnvSelectionHistory(context)
|
|
25
|
+
),
|
|
26
|
+
getNameMigrations: (migrationParams) => context.queryClient.ensureQueryData(
|
|
27
|
+
ApiQueryMagazineResouceJump.getNameMigration(migrationParams)
|
|
28
|
+
),
|
|
29
|
+
getAvailabilityMatrix: () => context.queryClient.ensureQueryData(
|
|
30
|
+
ApiQueryMagazineResouceJump.getAvailabilityMatrix()
|
|
31
|
+
)
|
|
32
|
+
});
|
|
33
|
+
return {
|
|
34
|
+
envSlug: env == null ? void 0 : env.slug,
|
|
35
|
+
resourceSlug: resourceJump == null ? void 0 : resourceJump.slug,
|
|
36
|
+
resourceJumps,
|
|
37
|
+
pluginInterfaceForCore
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export {
|
|
41
|
+
routeLoader
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=routeLoader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routeLoader.js","sources":["../../../../src/modules/resourceJump/routeLoader.ts"],"sourcesContent":["import { ApiQueryMagazineHistory } from '../environment/ApiQueryMagazineEnvironment'\nimport { makePluginInterfaceForCore } from '../pluginCore/makePluginManagerContext'\nimport { ApiQueryMagazineResouceJump } from './ApiQueryMagazineResourceJump'\nimport { findBestMatchByUrl } from './findBestMatchByUrl'\nimport type { EhRouterContext } from '~/types/types'\nimport type { ResourceJumpLoaderReturn } from './types'\nimport { ApiQueryMagazine } from '~/api/ApiQueryMagazine'\n\nexport interface RouteLoaderCtx {\n params: {\n envSlug?: string\n appSlug?: string\n subValue?: string\n }\n context: EhRouterContext\n}\n\nexport async function routeLoader({\n params,\n context,\n}: RouteLoaderCtx): Promise<ResourceJumpLoaderReturn> {\n const [bootstrapConfig, resourceJumps] = await Promise.all([\n context.queryClient.ensureQueryData(ApiQueryMagazine.getConfig(context)),\n context.queryClient.ensureQueryData(\n ApiQueryMagazineResouceJump.getResourceJumps(),\n ),\n ])\n\n const pluginInterfaceForCore = makePluginInterfaceForCore(context.plugins)\n const resourceJumpItems =\n await pluginInterfaceForCore.getResourceJumpsItems(bootstrapConfig)\n\n const { env, resourceJump } = await findBestMatchByUrl({\n urlEnvSlug: params.envSlug,\n urlAppSlug: params.appSlug,\n envs: bootstrapConfig.envs,\n resourceJumps: resourceJumpItems,\n getEnvHistory: () =>\n context.queryClient.ensureQueryData(\n ApiQueryMagazineHistory.getEnvSelectionHistory(context),\n ),\n getNameMigrations: (migrationParams) =>\n context.queryClient.ensureQueryData(\n ApiQueryMagazineResouceJump.getNameMigration(migrationParams),\n ),\n getAvailabilityMatrix: () =>\n context.queryClient.ensureQueryData(\n ApiQueryMagazineResouceJump.getAvailabilityMatrix(),\n ),\n })\n\n return {\n envSlug: env?.slug,\n resourceSlug: resourceJump?.slug,\n resourceJumps,\n pluginInterfaceForCore,\n }\n}\n"],"names":[],"mappings":";;;;;AAiBA,eAAsB,YAAY;AAAA,EAChC;AAAA,EACA;AACF,GAAsD;AACpD,QAAM,CAAC,iBAAiB,aAAa,IAAI,MAAM,QAAQ,IAAI;AAAA,IACzD,QAAQ,YAAY,gBAAgB,iBAAiB,UAAU,OAAO,CAAC;AAAA,IACvE,QAAQ,YAAY;AAAA,MAClB,4BAA4B,iBAAA;AAAA,IAAiB;AAAA,EAC/C,CACD;AAED,QAAM,yBAAyB,2BAA2B,QAAQ,OAAO;AACzE,QAAM,oBACJ,MAAM,uBAAuB,sBAAsB,eAAe;AAEpE,QAAM,EAAE,KAAK,aAAA,IAAiB,MAAM,mBAAmB;AAAA,IACrD,YAAY,OAAO;AAAA,IACnB,YAAY,OAAO;AAAA,IACnB,MAAM,gBAAgB;AAAA,IACtB,eAAe;AAAA,IACf,eAAe,MACb,QAAQ,YAAY;AAAA,MAClB,wBAAwB,uBAAuB,OAAO;AAAA,IAAA;AAAA,IAE1D,mBAAmB,CAAC,oBAClB,QAAQ,YAAY;AAAA,MAClB,4BAA4B,iBAAiB,eAAe;AAAA,IAAA;AAAA,IAEhE,uBAAuB,MACrB,QAAQ,YAAY;AAAA,MAClB,4BAA4B,sBAAA;AAAA,IAAsB;AAAA,EACpD,CACH;AAED,SAAO;AAAA,IACL,SAAS,2BAAK;AAAA,IACd,cAAc,6CAAc;AAAA,IAC5B;AAAA,IACA;AAAA,EAAA;AAEJ;"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ResourceJumpsData } from '@env-hopper/backend-core';
|
|
2
|
+
import { PluginInterfaceForCore } from '../pluginCore/makePluginManagerContext.js';
|
|
3
|
+
export interface ResouceJumpItemParent {
|
|
4
|
+
type: string;
|
|
5
|
+
displayName: string;
|
|
6
|
+
hasSingleChild: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface ResourceJumpItem {
|
|
9
|
+
type: string;
|
|
10
|
+
slug: string;
|
|
11
|
+
parent?: ResouceJumpItemParent;
|
|
12
|
+
}
|
|
13
|
+
export interface ResourceJumpLoaderReturn {
|
|
14
|
+
envSlug?: string;
|
|
15
|
+
resourceSlug?: string;
|
|
16
|
+
pluginInterfaceForCore: PluginInterfaceForCore;
|
|
17
|
+
resourceJumps: ResourceJumpsData;
|
|
18
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { default as React } from 'react';
|
|
2
|
+
import { BaseAutoCompletableItem, BaseAutoCompleteItemRender } from '~/modules/pluginCore/types';
|
|
3
|
+
import { AppAutoCompleteAmend, AutoCompleteContext } from '../../../ui/components/commandInput/types.js';
|
|
4
|
+
interface EhJumpResourceSelectorProps {
|
|
5
|
+
className?: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function EhJumpResourceSelector({ className, }: EhJumpResourceSelectorProps): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export interface DisplayItemProps extends React.ComponentPropsWithoutRef<'div'>, AppAutoCompleteAmend {
|
|
9
|
+
item: BaseAutoCompletableItem;
|
|
10
|
+
itemRenderData: BaseAutoCompleteItemRender;
|
|
11
|
+
isChild?: boolean;
|
|
12
|
+
selected: boolean;
|
|
13
|
+
highlighted: boolean;
|
|
14
|
+
getItemProps: (props: {
|
|
15
|
+
item: BaseAutoCompletableItem;
|
|
16
|
+
}) => any;
|
|
17
|
+
ctx: AutoCompleteContext;
|
|
18
|
+
}
|
|
19
|
+
export declare function DisplayItem({ item, itemRenderData, selected, isChild, highlighted, ctx, getItemProps, ...props }: DisplayItemProps): import("react/jsx-runtime").JSX.Element;
|
|
20
|
+
export {};
|