zudoku 0.0.0-ec30b50 → 0.0.0-ed94abf
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/README.md +1 -1
- package/cli.js +3 -0
- package/dist/app/entry.client.d.ts +5 -0
- package/dist/app/entry.client.js +3 -0
- package/dist/app/entry.client.js.map +1 -1
- package/dist/app/entry.server.d.ts +8 -6
- package/dist/app/entry.server.js +12 -8
- package/dist/app/entry.server.js.map +1 -1
- package/dist/app/main.js +10 -5
- package/dist/app/main.js.map +1 -1
- package/dist/app/tailwind.js +20 -0
- package/dist/app/tailwind.js.map +1 -1
- package/dist/cli/build/handler.d.ts +1 -3
- package/dist/cli/build/handler.js +9 -1
- package/dist/cli/build/handler.js.map +1 -1
- package/dist/cli/cli.js +5 -0
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/cmds/build.d.ts +11 -3
- package/dist/cli/cmds/build.js +20 -13
- package/dist/cli/cmds/build.js.map +1 -1
- package/dist/cli/cmds/dev.d.ts +1 -1
- package/dist/cli/cmds/dev.js.map +1 -1
- package/dist/cli/cmds/preview.d.ts +16 -0
- package/dist/cli/cmds/preview.js +25 -0
- package/dist/cli/cmds/preview.js.map +1 -0
- package/dist/cli/common/machine-id/lib.js +1 -0
- package/dist/cli/common/machine-id/lib.js.map +1 -1
- package/dist/cli/common/utils/ports.d.ts +1 -1
- package/dist/cli/common/utils/ports.js +16 -15
- package/dist/cli/common/utils/ports.js.map +1 -1
- package/dist/cli/dev/handler.js +10 -12
- package/dist/cli/dev/handler.js.map +1 -1
- package/dist/cli/preview/handler.d.ts +3 -0
- package/dist/cli/preview/handler.js +35 -0
- package/dist/cli/preview/handler.js.map +1 -0
- package/dist/config/ZuploBuildConfig.d.ts +155 -0
- package/dist/config/ZuploBuildConfig.js +29 -0
- package/dist/config/ZuploBuildConfig.js.map +1 -0
- package/dist/config/common.d.ts +5 -3
- package/dist/config/config.d.ts +18 -16
- package/dist/config/loader.d.ts +7 -6
- package/dist/config/loader.js +21 -29
- package/dist/config/loader.js.map +1 -1
- package/dist/config/validators/BuildSchema.d.ts +60 -0
- package/dist/config/validators/BuildSchema.js +31 -0
- package/dist/config/validators/BuildSchema.js.map +1 -0
- package/dist/config/validators/InputSidebarSchema.d.ts +15 -15
- package/dist/config/validators/InputSidebarSchema.js +10 -1
- package/dist/config/validators/InputSidebarSchema.js.map +1 -1
- package/dist/config/validators/common.d.ts +3205 -691
- package/dist/config/validators/common.js +132 -21
- package/dist/config/validators/common.js.map +1 -1
- package/dist/config/validators/icon-types.d.ts +1 -1
- package/dist/config/validators/validate.d.ts +1192 -305
- package/dist/index.d.ts +2 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/MissingIcon.d.ts +2 -0
- package/dist/lib/MissingIcon.js +7 -0
- package/dist/lib/MissingIcon.js.map +1 -0
- package/dist/lib/authentication/authentication.d.ts +1 -0
- package/dist/lib/authentication/hook.d.ts +1 -0
- package/dist/lib/authentication/hook.js +11 -1
- package/dist/lib/authentication/hook.js.map +1 -1
- package/dist/lib/authentication/providers/auth0.d.ts +2 -2
- package/dist/lib/authentication/providers/auth0.js +1 -0
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/clerk.d.ts +2 -2
- package/dist/lib/authentication/providers/clerk.js +25 -6
- package/dist/lib/authentication/providers/clerk.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +5 -3
- package/dist/lib/authentication/providers/openid.js +24 -10
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/providers/supabase.d.ts +4 -0
- package/dist/lib/authentication/providers/supabase.js +117 -0
- package/dist/lib/authentication/providers/supabase.js.map +1 -0
- package/dist/lib/authentication/state.d.ts +0 -26
- package/dist/lib/authentication/state.js +9 -18
- package/dist/lib/authentication/state.js.map +1 -1
- package/dist/lib/components/AnchorLink.d.ts +2 -2
- package/dist/lib/components/AnchorLink.js +5 -4
- package/dist/lib/components/AnchorLink.js.map +1 -1
- package/dist/lib/components/Banner.js +1 -1
- package/dist/lib/components/Banner.js.map +1 -1
- package/dist/lib/components/Bootstrap.d.ts +2 -1
- package/dist/lib/components/Bootstrap.js +3 -2
- package/dist/lib/components/Bootstrap.js.map +1 -1
- package/dist/lib/components/BuildCheck.d.ts +4 -0
- package/dist/lib/components/BuildCheck.js +22 -0
- package/dist/lib/components/BuildCheck.js.map +1 -0
- package/dist/lib/components/Footer.d.ts +1 -0
- package/dist/lib/components/Footer.js +32 -0
- package/dist/lib/components/Footer.js.map +1 -0
- package/dist/lib/components/Header.js +4 -4
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Heading.d.ts +2 -2
- package/dist/lib/components/InlineCode.d.ts +2 -1
- package/dist/lib/components/InlineCode.js +2 -9
- package/dist/lib/components/InlineCode.js.map +1 -1
- package/dist/lib/components/Layout.js +8 -28
- package/dist/lib/components/Layout.js.map +1 -1
- package/dist/lib/components/Main.d.ts +2 -0
- package/dist/lib/components/Main.js +17 -0
- package/dist/lib/components/Main.js.map +1 -0
- package/dist/lib/components/MobileTopNavigation.js +6 -3
- package/dist/lib/components/MobileTopNavigation.js.map +1 -1
- package/dist/lib/components/Pagination.d.ts +11 -0
- package/dist/lib/components/Pagination.js +10 -0
- package/dist/lib/components/Pagination.js.map +1 -0
- package/dist/lib/components/Search.js +7 -1
- package/dist/lib/components/Search.js.map +1 -1
- package/dist/lib/components/ThemeSwitch.js +8 -5
- package/dist/lib/components/ThemeSwitch.js.map +1 -1
- package/dist/lib/components/TopNavigation.d.ts +3 -2
- package/dist/lib/components/TopNavigation.js +28 -14
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/Zudoku.d.ts +1 -1
- package/dist/lib/components/Zudoku.js +13 -8
- package/dist/lib/components/Zudoku.js.map +1 -1
- package/dist/lib/components/cache.d.ts +7 -0
- package/dist/lib/components/cache.js +7 -0
- package/dist/lib/components/cache.js.map +1 -1
- package/dist/lib/components/context/BypassProtectedRoutesContext.d.ts +1 -0
- package/dist/lib/components/context/BypassProtectedRoutesContext.js +3 -0
- package/dist/lib/components/context/BypassProtectedRoutesContext.js.map +1 -0
- package/dist/lib/components/context/RouterEventsEmitter.d.ts +1 -0
- package/dist/lib/components/context/RouterEventsEmitter.js +17 -0
- package/dist/lib/components/context/RouterEventsEmitter.js.map +1 -0
- package/dist/lib/components/context/ViewportAnchorContext.d.ts +2 -4
- package/dist/lib/components/context/ViewportAnchorContext.js +5 -10
- package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
- package/dist/lib/components/context/ZudokuContext.d.ts +2 -2
- package/dist/lib/components/context/ZudokuContext.js +21 -9
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/index.d.ts +11 -3
- package/dist/lib/components/index.js +4 -0
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/PoweredByZudoku.d.ts +3 -0
- package/dist/lib/components/navigation/PoweredByZudoku.js +7 -0
- package/dist/lib/components/navigation/PoweredByZudoku.js.map +1 -0
- package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
- package/dist/lib/components/navigation/Sidebar.js +3 -12
- package/dist/lib/components/navigation/Sidebar.js.map +1 -1
- package/dist/lib/components/navigation/SidebarBadge.d.ts +2 -0
- package/dist/lib/components/navigation/SidebarBadge.js +3 -1
- package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
- package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
- package/dist/lib/components/navigation/SidebarCategory.js +10 -6
- package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
- package/dist/lib/components/navigation/SidebarItem.d.ts +1 -0
- package/dist/lib/components/navigation/SidebarItem.js +17 -11
- package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.d.ts +7 -6
- package/dist/lib/components/navigation/SidebarWrapper.js +18 -3
- package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
- package/dist/lib/{plugins/markdown → components/navigation}/Toc.js +5 -7
- package/dist/lib/components/navigation/Toc.js.map +1 -0
- package/dist/lib/components/navigation/ZudokuLogo.d.ts +6 -0
- package/dist/lib/components/navigation/ZudokuLogo.js +5 -0
- package/dist/lib/components/navigation/ZudokuLogo.js.map +1 -0
- package/dist/lib/components/navigation/ZuploLogo.d.ts +3 -0
- package/dist/lib/components/navigation/ZuploLogo.js +4 -0
- package/dist/lib/components/navigation/ZuploLogo.js.map +1 -0
- package/dist/lib/core/RouteGuard.d.ts +2 -1
- package/dist/lib/core/RouteGuard.js +35 -11
- package/dist/lib/core/RouteGuard.js.map +1 -1
- package/dist/lib/core/ZudokuContext.d.ts +33 -7
- package/dist/lib/core/ZudokuContext.js +29 -6
- package/dist/lib/core/ZudokuContext.js.map +1 -1
- package/dist/lib/core/plugins.d.ts +17 -7
- package/dist/lib/core/plugins.js +3 -0
- package/dist/lib/core/plugins.js.map +1 -1
- package/dist/lib/errors/ErrorAlert.js +6 -1
- package/dist/lib/errors/ErrorAlert.js.map +1 -1
- package/dist/lib/hooks/index.d.ts +3 -0
- package/dist/lib/hooks/index.js +5 -0
- package/dist/lib/hooks/index.js.map +1 -0
- package/dist/lib/hooks/useEvent.d.ts +11 -0
- package/dist/lib/hooks/useEvent.js +19 -0
- package/dist/lib/hooks/useEvent.js.map +1 -0
- package/dist/lib/hooks/useEvent.test.js +100 -0
- package/dist/lib/hooks/useEvent.test.js.map +1 -0
- package/dist/lib/icons.d.ts +1 -0
- package/dist/lib/icons.js +1 -0
- package/dist/lib/icons.js.map +1 -1
- package/dist/lib/oas/graphql/index.d.ts +17 -4
- package/dist/lib/oas/graphql/index.js +151 -38
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/oas/parser/dereference/index.js +2 -0
- package/dist/lib/oas/parser/dereference/index.js.map +1 -1
- package/dist/lib/oas/parser/index.d.ts +5 -3
- package/dist/lib/oas/parser/index.js +0 -22
- package/dist/lib/oas/parser/index.js.map +1 -1
- package/dist/lib/oas/parser/upgrade/index.js +2 -1
- package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
- package/dist/lib/plugins/api-catalog/Catalog.d.ts +4 -2
- package/dist/lib/plugins/api-catalog/Catalog.js +16 -26
- package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
- package/dist/lib/plugins/api-catalog/index.d.ts +1 -0
- package/dist/lib/plugins/api-catalog/index.js +39 -8
- package/dist/lib/plugins/api-catalog/index.js.map +1 -1
- package/dist/lib/plugins/api-keys/CreateApiKey.js +7 -3
- package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
- package/dist/lib/plugins/api-keys/index.d.ts +1 -0
- package/dist/lib/plugins/api-keys/index.js +1 -0
- package/dist/lib/plugins/api-keys/index.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.d.ts +1 -1
- package/dist/lib/plugins/markdown/MdxPage.js +3 -9
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/resolver.d.ts +0 -6
- package/dist/lib/plugins/markdown/resolver.js +0 -29
- package/dist/lib/plugins/markdown/resolver.js.map +1 -1
- package/dist/lib/plugins/openapi/ColorizedParam.js +1 -1
- package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
- package/dist/lib/plugins/openapi/Endpoint.js +1 -1
- package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
- package/dist/lib/plugins/openapi/{OpenApiRoute.d.ts → OasProvider.d.ts} +1 -2
- package/dist/lib/plugins/openapi/OasProvider.js +29 -0
- package/dist/lib/plugins/openapi/OasProvider.js.map +1 -0
- package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
- package/dist/lib/plugins/openapi/OperationList.js +63 -18
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.d.ts +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.js +7 -12
- package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/ParamInfos.d.ts +6 -0
- package/dist/lib/plugins/openapi/ParamInfos.js +42 -0
- package/dist/lib/plugins/openapi/ParamInfos.js.map +1 -0
- package/dist/lib/plugins/openapi/ParameterList.d.ts +2 -1
- package/dist/lib/plugins/openapi/ParameterList.js +3 -2
- package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js +9 -4
- package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +1 -1
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +3 -1
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
- package/dist/lib/plugins/openapi/SchemaList.d.ts +1 -0
- package/dist/lib/plugins/openapi/SchemaList.js +52 -0
- package/dist/lib/plugins/openapi/SchemaList.js.map +1 -0
- package/dist/lib/plugins/openapi/Sidecar.js +39 -10
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.js +2 -2
- package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
- package/dist/lib/plugins/openapi/SimpleSelect.js +1 -1
- package/dist/lib/plugins/openapi/SimpleSelect.js.map +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.js +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -1
- package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +6 -2
- package/dist/lib/plugins/openapi/client/useCreateQuery.js +6 -5
- package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -1
- package/dist/lib/plugins/openapi/components/EnumValues.d.ts +5 -0
- package/dist/lib/plugins/openapi/components/EnumValues.js +15 -0
- package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.d.ts +5 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.js +16 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.js.map +1 -0
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +9 -5
- package/dist/lib/plugins/openapi/graphql/gql.js +5 -15
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +108 -55
- package/dist/lib/plugins/openapi/graphql/graphql.js +59 -34
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.d.ts +10 -7
- package/dist/lib/plugins/openapi/index.js +56 -142
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +36 -10
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +2 -2
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -5
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Headers.js +1 -1
- package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/IdentityDialog.d.ts +11 -0
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js +14 -0
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js +10 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/PathParams.d.ts +3 -2
- package/dist/lib/plugins/openapi/playground/PathParams.js +3 -2
- package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Playground.d.ts +14 -3
- package/dist/lib/plugins/openapi/playground/Playground.js +84 -30
- package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/QueryParams.js +1 -1
- package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js +8 -0
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.d.ts +17 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.js +11 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +20 -14
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +6 -4
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +4 -3
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
- package/dist/lib/plugins/openapi/processors/removeExtensions.d.ts +8 -0
- package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.js +1 -1
- package/dist/lib/plugins/openapi/processors/removeExtensions.js.map +1 -0
- package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.js +26 -6
- package/dist/lib/plugins/openapi/processors/removeExtensions.test.js.map +1 -0
- package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.d.ts +3 -1
- package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.js +1 -1
- package/dist/lib/plugins/openapi/processors/removeParameters.js.map +1 -0
- package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.js +53 -25
- package/dist/lib/plugins/openapi/processors/removeParameters.test.js.map +1 -0
- package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.d.ts +3 -1
- package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.js +1 -1
- package/dist/lib/plugins/openapi/processors/removePaths.js.map +1 -0
- package/dist/lib/plugins/openapi/processors/removePaths.test.js +144 -0
- package/dist/lib/plugins/openapi/processors/removePaths.test.js.map +1 -0
- package/dist/lib/plugins/openapi/processors/traverse.js.map +1 -0
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.d.ts +1 -2
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.js +2 -2
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.d.ts +2 -1
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.js +2 -2
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.d.ts +0 -1
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.js +1 -1
- package/dist/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.d.ts +4 -0
- package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +12 -0
- package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -0
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.d.ts +2 -4
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +18 -13
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaView.d.ts +1 -2
- package/dist/lib/plugins/openapi/schema/SchemaView.js +33 -48
- package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/utils.d.ts +1 -0
- package/dist/lib/plugins/openapi/schema/utils.js +3 -1
- package/dist/lib/plugins/openapi/schema/utils.js.map +1 -1
- package/dist/lib/plugins/openapi/state.d.ts +25 -0
- package/dist/lib/plugins/openapi/state.js +18 -0
- package/dist/lib/plugins/openapi/state.js.map +1 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.d.ts +9 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.js +23 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.js.map +1 -0
- package/dist/lib/plugins/openapi/util/getRoutes.d.ts +10 -0
- package/dist/lib/plugins/openapi/util/getRoutes.js +80 -0
- package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.d.ts +2 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.js +10 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.d.ts +6 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js +80 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/ResultList.d.ts +8 -0
- package/dist/lib/plugins/search-pagefind/ResultList.js +32 -0
- package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/get-results.d.ts +10 -0
- package/dist/lib/plugins/search-pagefind/get-results.js +42 -0
- package/dist/lib/plugins/search-pagefind/get-results.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/index.d.ts +6 -0
- package/dist/lib/plugins/search-pagefind/index.js +9 -0
- package/dist/lib/plugins/search-pagefind/index.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/types.d.ts +85 -0
- package/dist/lib/plugins/search-pagefind/types.js +2 -0
- package/dist/lib/plugins/search-pagefind/types.js.map +1 -0
- package/dist/lib/ui/Badge.d.ts +1 -1
- package/dist/lib/ui/Button.d.ts +2 -2
- package/dist/lib/ui/Button.js +2 -1
- package/dist/lib/ui/Button.js.map +1 -1
- package/dist/lib/ui/Callout.d.ts +2 -1
- package/dist/lib/ui/Callout.js +3 -2
- package/dist/lib/ui/Callout.js.map +1 -1
- package/dist/lib/ui/Checkbox.d.ts +2 -8
- package/dist/lib/ui/Checkbox.js +1 -13
- package/dist/lib/ui/Checkbox.js.map +1 -1
- package/dist/lib/ui/Command.d.ts +7 -1
- package/dist/lib/ui/Command.js +2 -2
- package/dist/lib/ui/Command.js.map +1 -1
- package/dist/lib/ui/Form.d.ts +1 -1
- package/dist/lib/ui/Select.js +1 -1
- package/dist/lib/ui/Select.js.map +1 -1
- package/dist/lib/ui/Stepper.d.ts +3 -0
- package/dist/lib/ui/Stepper.js +7 -0
- package/dist/lib/ui/Stepper.js.map +1 -0
- package/dist/lib/ui/SyntaxHighlight.d.ts +15 -0
- package/dist/lib/ui/SyntaxHighlight.js +62 -0
- package/dist/lib/ui/SyntaxHighlight.js.map +1 -0
- package/dist/lib/ui/util.d.ts +2 -0
- package/dist/lib/ui/util.js +3 -0
- package/dist/lib/ui/util.js.map +1 -0
- package/dist/lib/util/MdxComponents.d.ts +6 -2
- package/dist/lib/util/MdxComponents.js +8 -3
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/lib/util/detectOS.d.ts +1 -0
- package/dist/lib/util/detectOS.js +11 -0
- package/dist/lib/util/detectOS.js.map +1 -0
- package/dist/lib/util/joinPath.d.ts +3 -0
- package/dist/lib/util/joinPath.js +3 -0
- package/dist/lib/util/joinPath.js.map +1 -1
- package/dist/lib/util/traverse.d.ts +2 -8
- package/dist/lib/util/traverse.js +2 -2
- package/dist/lib/util/traverse.js.map +1 -1
- package/dist/lib/util/types.d.ts +7 -0
- package/dist/lib/util/types.js +2 -0
- package/dist/lib/util/types.js.map +1 -0
- package/dist/lib/util/useLatest.d.ts +1 -0
- package/dist/lib/util/useLatest.js +15 -0
- package/dist/lib/util/useLatest.js.map +1 -0
- package/dist/lib/util/useOnScreen.d.ts +3 -2
- package/dist/lib/util/useOnScreen.js +3 -3
- package/dist/lib/util/useOnScreen.js.map +1 -1
- package/dist/lib/util/useScrollToAnchor.js +26 -20
- package/dist/lib/util/useScrollToAnchor.js.map +1 -1
- package/dist/vite/api/schema-codegen.d.ts +1 -1
- package/dist/vite/api/schema-codegen.js +34 -11
- package/dist/vite/api/schema-codegen.js.map +1 -1
- package/dist/vite/api/schema-codegen.test.js +66 -0
- package/dist/vite/api/schema-codegen.test.js.map +1 -1
- package/dist/vite/build.js +27 -16
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.d.ts +2 -5
- package/dist/vite/config.js +66 -70
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/config.test.js +1 -1
- package/dist/vite/config.test.js.map +1 -1
- package/dist/vite/create-pagefind-index.d.ts +4 -0
- package/dist/vite/create-pagefind-index.js +12 -0
- package/dist/vite/create-pagefind-index.js.map +1 -0
- package/dist/vite/css/plugin.d.ts +2 -2
- package/dist/vite/css/plugin.js.map +1 -1
- package/dist/vite/dev-server.d.ts +4 -2
- package/dist/vite/dev-server.js +42 -12
- package/dist/vite/dev-server.js.map +1 -1
- package/dist/vite/error-handler.d.ts +1 -1
- package/dist/vite/error-handler.js +1 -1
- package/dist/vite/error-handler.js.map +1 -1
- package/dist/vite/output.d.ts +14 -2
- package/dist/vite/output.js +12 -14
- package/dist/vite/output.js.map +1 -1
- package/dist/vite/plugin-api-keys.d.ts +2 -2
- package/dist/vite/plugin-api-keys.js +5 -5
- package/dist/vite/plugin-api-keys.js.map +1 -1
- package/dist/vite/plugin-api.d.ts +2 -2
- package/dist/vite/plugin-api.js +98 -54
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-auth.d.ts +2 -2
- package/dist/vite/plugin-auth.js +3 -3
- package/dist/vite/plugin-auth.js.map +1 -1
- package/dist/vite/plugin-component.d.ts +2 -2
- package/dist/vite/plugin-component.js +7 -2
- package/dist/vite/plugin-component.js.map +1 -1
- package/dist/vite/plugin-config-reload.d.ts +4 -3
- package/dist/vite/plugin-config-reload.js +13 -6
- package/dist/vite/plugin-config-reload.js.map +1 -1
- package/dist/vite/plugin-config.d.ts +2 -2
- package/dist/vite/plugin-config.js +9 -5
- package/dist/vite/plugin-config.js.map +1 -1
- package/dist/vite/plugin-custom-pages.d.ts +2 -2
- package/dist/vite/plugin-custom-pages.js +3 -3
- package/dist/vite/plugin-custom-pages.js.map +1 -1
- package/dist/vite/plugin-docs.d.ts +3 -3
- package/dist/vite/plugin-docs.js +23 -6
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-frontmatter.d.ts +2 -2
- package/dist/vite/plugin-frontmatter.js +5 -4
- package/dist/vite/plugin-frontmatter.js.map +1 -1
- package/dist/vite/plugin-mdx.d.ts +2 -2
- package/dist/vite/plugin-mdx.js +32 -27
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/plugin-redirect.d.ts +2 -2
- package/dist/vite/plugin-redirect.js +3 -3
- package/dist/vite/plugin-redirect.js.map +1 -1
- package/dist/vite/plugin-search.d.ts +2 -2
- package/dist/vite/plugin-search.js +5 -1
- package/dist/vite/plugin-search.js.map +1 -1
- package/dist/vite/plugin-sidebar.d.ts +3 -2
- package/dist/vite/plugin-sidebar.js +15 -6
- package/dist/vite/plugin-sidebar.js.map +1 -1
- package/dist/vite/plugin-theme-css.d.ts +2 -2
- package/dist/vite/plugin-theme-css.js.map +1 -1
- package/dist/vite/plugin.d.ts +2 -2
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/prerender/FileWritingResponse.d.ts +25 -0
- package/dist/vite/prerender/FileWritingResponse.js +51 -0
- package/dist/vite/prerender/FileWritingResponse.js.map +1 -0
- package/dist/vite/prerender/InMemoryResponse.d.ts +16 -0
- package/dist/vite/prerender/InMemoryResponse.js +32 -0
- package/dist/vite/prerender/InMemoryResponse.js.map +1 -0
- package/dist/vite/prerender/PrerenderResponse.d.ts +10 -0
- package/dist/vite/prerender/PrerenderResponse.js +2 -0
- package/dist/vite/prerender/PrerenderResponse.js.map +1 -0
- package/dist/vite/prerender/prerender.d.ts +15 -0
- package/dist/vite/prerender/prerender.js +109 -0
- package/dist/vite/prerender/prerender.js.map +1 -0
- package/dist/vite/prerender/worker.d.ts +13 -0
- package/dist/vite/prerender/worker.js +59 -0
- package/dist/vite/prerender/worker.js.map +1 -0
- package/dist/vite/reporter.d.ts +3 -0
- package/dist/vite/reporter.js +33 -0
- package/dist/vite/reporter.js.map +1 -0
- package/dist/vite/sitemap.js +2 -1
- package/dist/vite/sitemap.js.map +1 -1
- package/dist/zuplo/enrich-with-zuplo.d.ts +3 -3
- package/dist/zuplo/enrich-with-zuplo.js +18 -17
- package/dist/zuplo/enrich-with-zuplo.js.map +1 -1
- package/dist/zuplo/env.d.ts +26 -0
- package/dist/zuplo/env.js +17 -0
- package/dist/zuplo/env.js.map +1 -1
- package/dist/zuplo/with-zuplo-processors.d.ts +2 -2
- package/dist/zuplo/with-zuplo-processors.js +6 -6
- package/dist/zuplo/with-zuplo-processors.js.map +1 -1
- package/dist/zuplo/with-zuplo.d.ts +4 -1
- package/dist/zuplo/with-zuplo.js +6 -5
- package/dist/zuplo/with-zuplo.js.map +1 -1
- package/lib/{AuthenticationPlugin-DeEA69mE.js → AuthenticationPlugin-CJOFRBk3.js} +4 -4
- package/lib/{AuthenticationPlugin-DeEA69mE.js.map → AuthenticationPlugin-CJOFRBk3.js.map} +1 -1
- package/lib/Button-BBNrKpQd.js +49 -0
- package/lib/Button-BBNrKpQd.js.map +1 -0
- package/lib/Callout-D3Ja4OPX.js +230 -0
- package/lib/Callout-D3Ja4OPX.js.map +1 -0
- package/lib/{CategoryHeading-MYL1u_6K.js → CategoryHeading-D06WK_Wo.js} +3 -3
- package/lib/{CategoryHeading-MYL1u_6K.js.map → CategoryHeading-D06WK_Wo.js.map} +1 -1
- package/lib/Dialog-ByYz4ABw.js +98 -0
- package/lib/Dialog-ByYz4ABw.js.map +1 -0
- package/lib/Drawer-CEwbkLDb.js +1133 -0
- package/lib/Drawer-CEwbkLDb.js.map +1 -0
- package/lib/{Markdown-8mv9nhGd.js → Markdown-C5h6bxbE.js} +8031 -6095
- package/lib/Markdown-C5h6bxbE.js.map +1 -0
- package/lib/MdxPage-DhGqXQTK.js +85 -0
- package/lib/MdxPage-DhGqXQTK.js.map +1 -0
- package/lib/OasProvider-q0ncKgHr.js +34 -0
- package/lib/OasProvider-q0ncKgHr.js.map +1 -0
- package/lib/OperationList-CW4jENLV.js +5069 -0
- package/lib/OperationList-CW4jENLV.js.map +1 -0
- package/lib/Pagination-DsG3YIT_.js +48 -0
- package/lib/Pagination-DsG3YIT_.js.map +1 -0
- package/lib/{index.esm-9-TF9KQB.js → RouteGuard-BZ_VsiXc.js} +196 -144
- package/lib/RouteGuard-BZ_VsiXc.js.map +1 -0
- package/lib/SchemaList-n24-qSa5.js +148 -0
- package/lib/SchemaList-n24-qSa5.js.map +1 -0
- package/lib/SchemaView-DCSWtnYr.js +357 -0
- package/lib/SchemaView-DCSWtnYr.js.map +1 -0
- package/lib/{Select-BcAbBUmk.js → Select-Dg5R11Dx.js} +71 -71
- package/lib/{Select-BcAbBUmk.js.map → Select-Dg5R11Dx.js.map} +1 -1
- package/lib/SlotletProvider-VUmTNmLZ.js +340 -0
- package/lib/SlotletProvider-VUmTNmLZ.js.map +1 -0
- package/lib/Spinner-mNLZ6awP.js +7 -0
- package/lib/Spinner-mNLZ6awP.js.map +1 -0
- package/lib/{SyntaxHighlight-B0L4SC_N.js → SyntaxHighlight-CxhyyMkF.js} +500 -596
- package/lib/SyntaxHighlight-CxhyyMkF.js.map +1 -0
- package/lib/Toc-BK39DQvI.js +92 -0
- package/lib/Toc-BK39DQvI.js.map +1 -0
- package/lib/{_commonjsHelpers-BkfeUUK-.js → _commonjsHelpers-B4e78b8K.js} +2 -2
- package/lib/_commonjsHelpers-B4e78b8K.js.map +1 -0
- package/lib/{chunk-SYFQ2XB5-QijJrSf0.js → chunk-KNED5TY2-BUPjb3LQ.js} +584 -583
- package/lib/chunk-KNED5TY2-BUPjb3LQ.js.map +1 -0
- package/lib/{circular-DxaIIlWD.js → circular-ByJI6Mci.js} +5461 -4993
- package/lib/circular-ByJI6Mci.js.map +1 -0
- package/lib/context-Lrf2Y9bR.js +22 -0
- package/lib/{context-rwLGh-6_.js.map → context-Lrf2Y9bR.js.map} +1 -1
- package/lib/{createServer-E3cXjB0P.js → createServer-DLN7APz_.js} +4641 -4927
- package/lib/createServer-DLN7APz_.js.map +1 -0
- package/lib/hook-pPrHCB6G.js +1478 -0
- package/lib/hook-pPrHCB6G.js.map +1 -0
- package/lib/index-Bn6Lc9tq.js +9 -0
- package/lib/index-Bn6Lc9tq.js.map +1 -0
- package/lib/index-CBpciIfE.js +2054 -0
- package/lib/index-CBpciIfE.js.map +1 -0
- package/lib/index-CPNSgwSb.js +36 -0
- package/lib/{index-Djenk2Hj.js.map → index-CPNSgwSb.js.map} +1 -1
- package/lib/index-CuBIgTKC.js +316 -0
- package/lib/index-CuBIgTKC.js.map +1 -0
- package/lib/{index-Dl3Yl0yb.js → index-DcHeSvkE.js} +51 -38
- package/lib/index-DcHeSvkE.js.map +1 -0
- package/lib/index-DwT-v3zK.js +86 -0
- package/lib/index-DwT-v3zK.js.map +1 -0
- package/lib/{index-CjJS0l4l.js → index-LNp6rxyU.js} +2 -2
- package/lib/{index-CjJS0l4l.js.map → index-LNp6rxyU.js.map} +1 -1
- package/lib/index-bu-rfaLA.js +2227 -0
- package/lib/index-bu-rfaLA.js.map +1 -0
- package/lib/index.esm-D2ZUREQN.js +1216 -0
- package/lib/index.esm-D2ZUREQN.js.map +1 -0
- package/lib/jsx-runtime-C5mzlN2N.js +285 -0
- package/lib/jsx-runtime-C5mzlN2N.js.map +1 -0
- package/lib/mutation-Csa9eQDM.js +211 -0
- package/lib/mutation-Csa9eQDM.js.map +1 -0
- package/lib/objectEntries-yMIkr2mI.js +5 -0
- package/lib/objectEntries-yMIkr2mI.js.map +1 -0
- package/lib/prism-bash.min-HHIMdNJ_.js.map +1 -1
- package/lib/{prism-csharp.min-bQAo2pmx.js → prism-csharp.min-C43x1RY2.js} +2 -2
- package/lib/{prism-csharp.min-bQAo2pmx.js.map → prism-csharp.min-C43x1RY2.js.map} +1 -1
- package/lib/{prism-java.min-BpvsOuIa.js → prism-java.min-CQzr40NQ.js} +2 -2
- package/lib/{prism-java.min-BpvsOuIa.js.map → prism-java.min-CQzr40NQ.js.map} +1 -1
- package/lib/prism-javascript.min-CEqHqgbm.js.map +1 -1
- package/lib/prism-json.min-B1GJqK1k.js.map +1 -1
- package/lib/prism-jsstacktrace.min-BfobCF2F.js +2 -0
- package/lib/prism-jsstacktrace.min-BfobCF2F.js.map +1 -0
- package/lib/prism-markdown.min-C0Qn0m-5.js.map +1 -1
- package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
- package/lib/prism-objectivec.min-BXSWqpJJ.js.map +1 -1
- package/lib/{prism-ruby.min-Dx9KO9ds.js → prism-ruby.min-L9OdQ6tU.js} +2 -2
- package/lib/{prism-ruby.min-Dx9KO9ds.js.map → prism-ruby.min-L9OdQ6tU.js.map} +1 -1
- package/lib/{prism-typescript.min-CD7H2IYQ.js → prism-typescript.min-qTySPvCh.js} +2 -2
- package/lib/{prism-typescript.min-CD7H2IYQ.js.map → prism-typescript.min-qTySPvCh.js.map} +1 -1
- package/lib/processors/removeExtensions.js +11 -0
- package/lib/processors/removeExtensions.js.map +1 -0
- package/lib/{post-processors → processors}/removeParameters.js +1 -1
- package/lib/processors/removeParameters.js.map +1 -0
- package/lib/{post-processors → processors}/removePaths.js +1 -1
- package/lib/processors/removePaths.js.map +1 -0
- package/lib/{post-processors → processors}/traverse.js +2 -2
- package/lib/processors/traverse.js.map +1 -0
- package/lib/ui/Accordion.js +1 -1
- package/lib/ui/ActionButton.js +11 -10
- package/lib/ui/ActionButton.js.map +1 -1
- package/lib/ui/Alert.js +2 -2
- package/lib/ui/AlertDialog.js +1 -1
- package/lib/ui/Badge.js +2 -2
- package/lib/ui/Breadcrumb.js +4 -4
- package/lib/ui/Button.js +13 -12
- package/lib/ui/Button.js.map +1 -1
- package/lib/ui/Callout.js +40 -21
- package/lib/ui/Callout.js.map +1 -1
- package/lib/ui/Card.js +1 -1
- package/lib/ui/Carousel.js +207 -207
- package/lib/ui/Carousel.js.map +1 -1
- package/lib/ui/Checkbox.js +16 -26
- package/lib/ui/Checkbox.js.map +1 -1
- package/lib/ui/Command.js +105 -78
- package/lib/ui/Command.js.map +1 -1
- package/lib/ui/Dialog.js +1 -1
- package/lib/ui/Drawer.js +14 -1151
- package/lib/ui/Drawer.js.map +1 -1
- package/lib/ui/DropdownMenu.js +1 -1
- package/lib/ui/Form.js +5 -5
- package/lib/ui/HoverCard.js +1 -1
- package/lib/ui/Input.js +1 -1
- package/lib/ui/Label.js +2 -2
- package/lib/ui/Pagination.js +10 -10
- package/lib/ui/Popover.js +1 -1
- package/lib/ui/Progress.js +1 -1
- package/lib/ui/RadioGroup.js +1 -1
- package/lib/ui/ScrollArea.js +1 -1
- package/lib/ui/Select.js +2 -2
- package/lib/ui/Select.js.map +1 -1
- package/lib/ui/Skeleton.js +1 -1
- package/lib/ui/Slider.js +1 -1
- package/lib/ui/Stepper.js +6 -0
- package/lib/ui/Stepper.js.map +1 -0
- package/lib/ui/Switch.js +1 -1
- package/lib/ui/SyntaxHighlight.js +11 -0
- package/lib/ui/SyntaxHighlight.js.map +1 -0
- package/lib/ui/Tabs.js +1 -1
- package/lib/ui/Textarea.js +1 -1
- package/lib/ui/Toggle.js +2 -2
- package/lib/ui/ToggleGroup.js +1 -1
- package/lib/ui/Tooltip.js +1 -1
- package/lib/ui/util.js +6 -0
- package/lib/ui/util.js.map +1 -0
- package/lib/{useExposedProps-Bbf99zic.js → useExposedProps-Dq2yUQIG.js} +2 -2
- package/lib/{useExposedProps-Bbf99zic.js.map → useExposedProps-Dq2yUQIG.js.map} +1 -1
- package/lib/useLatest-hmRS46UF.js +11 -0
- package/lib/useLatest-hmRS46UF.js.map +1 -0
- package/lib/zudoku.auth-auth0.js +15 -14
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +67 -49
- package/lib/zudoku.auth-clerk.js.map +1 -1
- package/lib/zudoku.auth-openid.js +370 -405
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +33 -1303
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.hooks.js +19 -0
- package/lib/zudoku.hooks.js.map +1 -0
- package/lib/zudoku.icons.js +10 -0
- package/lib/zudoku.icons.js.map +1 -1
- package/lib/zudoku.plugin-api-catalog.js +106 -112
- package/lib/zudoku.plugin-api-catalog.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +108 -106
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +3 -3
- package/lib/zudoku.plugin-markdown.js +23 -44
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +6 -7
- package/lib/zudoku.plugin-openapi.js.map +1 -1
- package/lib/zudoku.plugin-redirect.js +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +9 -9
- package/lib/zudoku.plugin-search-pagefind.js +233 -0
- package/lib/zudoku.plugin-search-pagefind.js.map +1 -0
- package/lib/zudoku.plugins.js +14 -0
- package/lib/zudoku.plugins.js.map +1 -0
- package/package.json +100 -74
- package/src/app/entry.client.tsx +10 -0
- package/src/app/entry.server.tsx +23 -13
- package/src/app/main.css +106 -58
- package/src/app/main.tsx +15 -2
- package/src/app/tailwind.ts +20 -0
- package/src/lib/MissingIcon.tsx +22 -0
- package/src/lib/authentication/authentication.ts +2 -0
- package/src/lib/authentication/hook.ts +12 -1
- package/src/lib/authentication/providers/auth0.tsx +3 -2
- package/src/lib/authentication/providers/clerk.tsx +32 -8
- package/src/lib/authentication/providers/openid.tsx +31 -15
- package/src/lib/authentication/providers/supabase.tsx +157 -0
- package/src/lib/authentication/state.ts +9 -37
- package/src/lib/components/AnchorLink.tsx +9 -7
- package/src/lib/components/Banner.tsx +1 -0
- package/src/lib/components/Bootstrap.tsx +13 -6
- package/src/lib/components/BuildCheck.tsx +60 -0
- package/src/lib/components/Footer.tsx +139 -0
- package/src/lib/components/Header.tsx +12 -8
- package/src/lib/components/Heading.tsx +1 -1
- package/src/lib/components/InlineCode.tsx +13 -16
- package/src/lib/components/Layout.tsx +27 -65
- package/src/lib/components/Main.tsx +50 -0
- package/src/lib/components/MobileTopNavigation.tsx +27 -18
- package/src/lib/components/Pagination.tsx +50 -0
- package/src/lib/components/Search.tsx +14 -3
- package/src/lib/components/ThemeSwitch.tsx +28 -8
- package/src/lib/components/TopNavigation.tsx +51 -24
- package/src/lib/components/Zudoku.tsx +18 -7
- package/src/lib/components/cache.ts +8 -0
- package/src/lib/components/context/BypassProtectedRoutesContext.ts +3 -0
- package/src/lib/components/context/RouterEventsEmitter.tsx +19 -0
- package/src/lib/components/context/ViewportAnchorContext.tsx +6 -15
- package/src/lib/components/context/ZudokuContext.ts +30 -10
- package/src/lib/components/index.ts +4 -0
- package/src/lib/components/navigation/PoweredByZudoku.tsx +28 -0
- package/src/lib/components/navigation/Sidebar.tsx +37 -44
- package/src/lib/components/navigation/SidebarBadge.tsx +4 -1
- package/src/lib/components/navigation/SidebarCategory.tsx +15 -12
- package/src/lib/components/navigation/SidebarItem.tsx +22 -29
- package/src/lib/components/navigation/SidebarWrapper.tsx +42 -23
- package/src/lib/{plugins/markdown → components/navigation}/Toc.tsx +5 -14
- package/src/lib/components/navigation/ZudokuLogo.tsx +25 -0
- package/src/lib/components/navigation/ZuploLogo.tsx +14 -0
- package/src/lib/core/RouteGuard.tsx +73 -12
- package/src/lib/core/ZudokuContext.ts +64 -13
- package/src/lib/core/plugins.ts +29 -7
- package/src/lib/errors/ErrorAlert.tsx +24 -17
- package/src/lib/hooks/index.ts +5 -0
- package/src/lib/hooks/useEvent.test.tsx +149 -0
- package/src/lib/hooks/useEvent.ts +41 -0
- package/src/lib/icons.ts +1 -0
- package/src/lib/oas/graphql/index.ts +206 -54
- package/src/lib/oas/parser/dereference/index.ts +2 -0
- package/src/lib/oas/parser/index.ts +7 -29
- package/src/lib/oas/parser/upgrade/index.ts +2 -1
- package/src/lib/plugins/api-catalog/Catalog.tsx +50 -100
- package/src/lib/plugins/api-catalog/index.tsx +66 -15
- package/src/lib/plugins/api-keys/CreateApiKey.tsx +7 -3
- package/src/lib/plugins/api-keys/index.tsx +3 -0
- package/src/lib/plugins/markdown/MdxPage.tsx +15 -47
- package/src/lib/plugins/markdown/resolver.ts +0 -33
- package/src/lib/plugins/openapi/ColorizedParam.tsx +1 -1
- package/src/lib/plugins/openapi/Endpoint.tsx +1 -1
- package/src/lib/plugins/openapi/OasProvider.tsx +51 -0
- package/src/lib/plugins/openapi/OperationList.tsx +171 -81
- package/src/lib/plugins/openapi/OperationListItem.tsx +118 -104
- package/src/lib/plugins/openapi/ParamInfos.tsx +87 -0
- package/src/lib/plugins/openapi/ParameterList.tsx +4 -0
- package/src/lib/plugins/openapi/ParameterListItem.tsx +35 -23
- package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +8 -1
- package/src/lib/plugins/openapi/SchemaList.tsx +151 -0
- package/src/lib/plugins/openapi/Sidecar.tsx +50 -14
- package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -2
- package/src/lib/plugins/openapi/SimpleSelect.tsx +1 -1
- package/src/lib/plugins/openapi/client/GraphQLClient.tsx +1 -1
- package/src/lib/plugins/openapi/client/useCreateQuery.ts +13 -5
- package/src/lib/plugins/openapi/components/EnumValues.tsx +58 -0
- package/src/lib/plugins/openapi/components/SelectOnClick.tsx +29 -0
- package/src/lib/plugins/openapi/graphql/gql.ts +34 -17
- package/src/lib/plugins/openapi/graphql/graphql.ts +172 -86
- package/src/lib/plugins/openapi/index.tsx +82 -177
- package/src/lib/plugins/openapi/interfaces.ts +44 -15
- package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +30 -32
- package/src/lib/plugins/openapi/playground/Headers.tsx +0 -1
- package/src/lib/plugins/openapi/playground/IdentityDialog.tsx +74 -0
- package/src/lib/plugins/openapi/playground/IdentitySelector.tsx +54 -0
- package/src/lib/plugins/openapi/playground/PathParams.tsx +8 -2
- package/src/lib/plugins/openapi/playground/Playground.tsx +199 -110
- package/src/lib/plugins/openapi/playground/QueryParams.tsx +0 -1
- package/src/lib/plugins/openapi/playground/RequestLoginDialog.tsx +51 -0
- package/src/lib/plugins/openapi/playground/rememberedIdentity.ts +26 -0
- package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +1 -1
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +25 -5
- package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +67 -45
- package/src/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.ts +29 -9
- package/src/lib/plugins/openapi/{post-processors → processors}/removeExtensions.ts +5 -3
- package/src/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.ts +67 -33
- package/src/lib/plugins/openapi/{post-processors → processors}/removeParameters.ts +5 -3
- package/src/lib/plugins/openapi/processors/removePaths.test.ts +167 -0
- package/src/lib/plugins/openapi/{post-processors → processors}/removePaths.ts +5 -3
- package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroup.tsx +1 -8
- package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupConnector.tsx +3 -0
- package/src/lib/plugins/openapi/schema/LogicalGroup/LogicalGroupItem.tsx +6 -3
- package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +36 -0
- package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +47 -50
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +84 -138
- package/src/lib/plugins/openapi/schema/utils.ts +7 -1
- package/src/lib/plugins/openapi/state.ts +36 -0
- package/src/lib/plugins/openapi/util/createSidebarCategory.tsx +37 -0
- package/src/lib/plugins/openapi/util/getRoutes.tsx +126 -0
- package/src/lib/plugins/openapi/util/methodColorMap.tsx +11 -0
- package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +164 -0
- package/src/lib/plugins/search-pagefind/ResultList.tsx +105 -0
- package/src/lib/plugins/search-pagefind/get-results.tsx +75 -0
- package/src/lib/plugins/search-pagefind/index.tsx +21 -0
- package/src/lib/plugins/search-pagefind/types.ts +118 -0
- package/src/lib/ui/Button.tsx +4 -2
- package/src/lib/ui/Callout.tsx +29 -10
- package/src/lib/ui/Checkbox.tsx +8 -24
- package/src/lib/ui/Command.tsx +25 -3
- package/src/lib/ui/Select.tsx +1 -1
- package/src/lib/ui/Stepper.tsx +8 -0
- package/src/lib/ui/SyntaxHighlight.tsx +186 -0
- package/src/lib/ui/util.tsx +3 -0
- package/src/lib/util/MdxComponents.tsx +9 -4
- package/src/lib/util/detectOS.ts +9 -0
- package/src/lib/util/joinPath.tsx +3 -0
- package/src/lib/util/traverse.ts +4 -8
- package/src/lib/util/types.ts +7 -0
- package/src/lib/util/useLatest.ts +18 -0
- package/src/lib/util/useOnScreen.ts +6 -4
- package/src/lib/util/useScrollToAnchor.ts +30 -20
- package/client.d.ts +0 -8
- package/dist/lib/components/SyntaxHighlight.d.ts +0 -12
- package/dist/lib/components/SyntaxHighlight.js +0 -53
- package/dist/lib/components/SyntaxHighlight.js.map +0 -1
- package/dist/lib/components/context/PluginSystem.js +0 -2
- package/dist/lib/components/context/PluginSystem.js.map +0 -1
- package/dist/lib/plugins/markdown/Toc.js.map +0 -1
- package/dist/lib/plugins/openapi/OpenApiRoute.js +0 -25
- package/dist/lib/plugins/openapi/OpenApiRoute.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +0 -7
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removeParameters.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removeParameters.test.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +0 -104
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +0 -1
- package/dist/lib/plugins/openapi/post-processors/traverse.js.map +0 -1
- package/dist/vite/prerender.d.ts +0 -22
- package/dist/vite/prerender.js +0 -89
- package/dist/vite/prerender.js.map +0 -1
- package/lib/Markdown-8mv9nhGd.js.map +0 -1
- package/lib/MdxPage-BalfwlsD.js +0 -193
- package/lib/MdxPage-BalfwlsD.js.map +0 -1
- package/lib/OpenApiRoute-ULLXjfro.js +0 -36
- package/lib/OpenApiRoute-ULLXjfro.js.map +0 -1
- package/lib/OperationList-B3VX94x4.js +0 -5179
- package/lib/OperationList-B3VX94x4.js.map +0 -1
- package/lib/SlotletProvider-D0mFmGJu.js +0 -221
- package/lib/SlotletProvider-D0mFmGJu.js.map +0 -1
- package/lib/Spinner-BlzrEEk1.js +0 -51
- package/lib/Spinner-BlzrEEk1.js.map +0 -1
- package/lib/SyntaxHighlight-B0L4SC_N.js.map +0 -1
- package/lib/ZudokuContext-dUyBGMap.js +0 -1229
- package/lib/ZudokuContext-dUyBGMap.js.map +0 -1
- package/lib/__vite-browser-external-BYRIRx8p.js +0 -9
- package/lib/__vite-browser-external-BYRIRx8p.js.map +0 -1
- package/lib/_commonjsHelpers-BkfeUUK-.js.map +0 -1
- package/lib/chunk-SYFQ2XB5-QijJrSf0.js.map +0 -1
- package/lib/circular-DxaIIlWD.js.map +0 -1
- package/lib/context-rwLGh-6_.js +0 -22
- package/lib/createServer-E3cXjB0P.js.map +0 -1
- package/lib/hook-NIpDSpau.js +0 -227
- package/lib/hook-NIpDSpau.js.map +0 -1
- package/lib/index-B7mqiOei.js +0 -509
- package/lib/index-B7mqiOei.js.map +0 -1
- package/lib/index-Djenk2Hj.js +0 -36
- package/lib/index-Dl3Yl0yb.js.map +0 -1
- package/lib/index-P0YUtHIb.js +0 -2065
- package/lib/index-P0YUtHIb.js.map +0 -1
- package/lib/index.esm-9-TF9KQB.js.map +0 -1
- package/lib/index.esm-CrSoEshU.js +0 -1207
- package/lib/index.esm-CrSoEshU.js.map +0 -1
- package/lib/joinUrl-nLx9pD-Z.js +0 -20
- package/lib/joinUrl-nLx9pD-Z.js.map +0 -1
- package/lib/jsx-runtime-Bdg6XQ1m.js +0 -446
- package/lib/jsx-runtime-Bdg6XQ1m.js.map +0 -1
- package/lib/post-processors/removeExtensions.js +0 -11
- package/lib/post-processors/removeExtensions.js.map +0 -1
- package/lib/post-processors/removeParameters.js.map +0 -1
- package/lib/post-processors/removePaths.js.map +0 -1
- package/lib/post-processors/traverse.js.map +0 -1
- package/lib/state-bfQxaDxU.js +0 -211
- package/lib/state-bfQxaDxU.js.map +0 -1
- package/lib/useScrollToAnchor-BVCQSeKB.js +0 -286
- package/lib/useScrollToAnchor-BVCQSeKB.js.map +0 -1
- package/src/lib/components/SyntaxHighlight.tsx +0 -171
- package/src/lib/components/context/PluginSystem.ts +0 -0
- package/src/lib/plugins/openapi/OpenApiRoute.tsx +0 -51
- package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +0 -126
- /package/dist/lib/{plugins/markdown → components/navigation}/Toc.d.ts +0 -0
- /package/dist/lib/{components/context/PluginSystem.d.ts → hooks/useEvent.test.d.ts} +0 -0
- /package/dist/lib/plugins/openapi/{post-processors → processors}/removeExtensions.test.d.ts +0 -0
- /package/dist/lib/plugins/openapi/{post-processors → processors}/removeParameters.test.d.ts +0 -0
- /package/dist/lib/plugins/openapi/{post-processors → processors}/removePaths.test.d.ts +0 -0
- /package/dist/lib/plugins/openapi/{post-processors → processors}/traverse.d.ts +0 -0
- /package/dist/lib/plugins/openapi/{post-processors → processors}/traverse.js +0 -0
- /package/src/lib/plugins/openapi/{post-processors → processors}/traverse.ts +0 -0
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
import { useMutation } from "@tanstack/react-query";
|
|
2
2
|
import { InfoIcon } from "lucide-react";
|
|
3
|
-
import { Fragment, useEffect, useRef, useTransition } from "react";
|
|
3
|
+
import { Fragment, useEffect, useRef, useState, useTransition } from "react";
|
|
4
4
|
import { FormProvider, useForm } from "react-hook-form";
|
|
5
5
|
import { Alert, AlertDescription, AlertTitle } from "zudoku/ui/Alert.js";
|
|
6
6
|
import { PathRenderer } from "../../../components/PathRenderer.js";
|
|
7
7
|
|
|
8
|
-
import { Label } from "zudoku/ui/Label.js";
|
|
9
|
-
import { RadioGroup, RadioGroupItem } from "zudoku/ui/RadioGroup.js";
|
|
10
8
|
import {
|
|
11
9
|
Select,
|
|
12
10
|
SelectContent,
|
|
@@ -15,18 +13,23 @@ import {
|
|
|
15
13
|
SelectValue,
|
|
16
14
|
} from "zudoku/ui/Select.js";
|
|
17
15
|
import { Textarea } from "zudoku/ui/Textarea.js";
|
|
18
|
-
import { useSelectedServer } from "../../../authentication/state.js";
|
|
19
16
|
import { useApiIdentities } from "../../../components/context/ZudokuContext.js";
|
|
20
|
-
import { Card } from "../../../ui/Card.js";
|
|
21
17
|
import { Tabs, TabsContent, TabsList, TabsTrigger } from "../../../ui/Tabs.js";
|
|
22
18
|
import { cn } from "../../../util/cn.js";
|
|
19
|
+
import { objectEntries } from "../../../util/objectEntries.js";
|
|
20
|
+
import { useLatest } from "../../../util/useLatest.js";
|
|
23
21
|
import { ColorizedParam } from "../ColorizedParam.js";
|
|
24
|
-
import { Content } from "../SidecarExamples.js";
|
|
22
|
+
import { type Content } from "../SidecarExamples.js";
|
|
23
|
+
import { useSelectedServer } from "../state.js";
|
|
25
24
|
import { createUrl } from "./createUrl.js";
|
|
26
25
|
import ExamplesDropdown from "./ExamplesDropdown.js";
|
|
27
26
|
import { Headers } from "./Headers.js";
|
|
27
|
+
import { IdentityDialog } from "./IdentityDialog.js";
|
|
28
|
+
import IdentitySelector from "./IdentitySelector.js";
|
|
28
29
|
import { PathParams } from "./PathParams.js";
|
|
29
30
|
import { QueryParams } from "./QueryParams.js";
|
|
31
|
+
import { useIdentityStore } from "./rememberedIdentity.js";
|
|
32
|
+
import RequestLoginDialog from "./RequestLoginDialog.js";
|
|
30
33
|
import { ResultPanel } from "./result-panel/ResultPanel.js";
|
|
31
34
|
import SubmitButton from "./SubmitButton.js";
|
|
32
35
|
|
|
@@ -55,8 +58,17 @@ export type PathParam = {
|
|
|
55
58
|
isRequired?: boolean;
|
|
56
59
|
};
|
|
57
60
|
|
|
61
|
+
const bodyContentTypeMap = {
|
|
62
|
+
Plain: "text/plain",
|
|
63
|
+
JSON: "application/json",
|
|
64
|
+
XML: "application/xml",
|
|
65
|
+
YAML: "application/yaml",
|
|
66
|
+
CSV: "text/csv",
|
|
67
|
+
} as const;
|
|
68
|
+
|
|
58
69
|
export type PlaygroundForm = {
|
|
59
70
|
body: string;
|
|
71
|
+
bodyContentType: keyof typeof bodyContentTypeMap;
|
|
60
72
|
queryParams: Array<{
|
|
61
73
|
name: string;
|
|
62
74
|
value: string;
|
|
@@ -88,7 +100,7 @@ export type PlaygroundResult = {
|
|
|
88
100
|
};
|
|
89
101
|
|
|
90
102
|
export type PlaygroundContentProps = {
|
|
91
|
-
server
|
|
103
|
+
server?: string;
|
|
92
104
|
servers?: string[];
|
|
93
105
|
url: string;
|
|
94
106
|
method: string;
|
|
@@ -97,6 +109,9 @@ export type PlaygroundContentProps = {
|
|
|
97
109
|
pathParams?: PathParam[];
|
|
98
110
|
defaultBody?: string;
|
|
99
111
|
examples?: Content;
|
|
112
|
+
requiresLogin?: boolean;
|
|
113
|
+
onLogin?: () => void;
|
|
114
|
+
onSignUp?: () => void;
|
|
100
115
|
};
|
|
101
116
|
|
|
102
117
|
export const Playground = ({
|
|
@@ -109,15 +124,27 @@ export const Playground = ({
|
|
|
109
124
|
pathParams = [],
|
|
110
125
|
defaultBody = "",
|
|
111
126
|
examples,
|
|
127
|
+
requiresLogin = false,
|
|
128
|
+
onLogin,
|
|
129
|
+
onSignUp,
|
|
112
130
|
}: PlaygroundContentProps) => {
|
|
113
131
|
const { selectedServer, setSelectedServer } = useSelectedServer(
|
|
114
|
-
servers.map((
|
|
132
|
+
servers.map((url) => ({ url })),
|
|
115
133
|
);
|
|
134
|
+
const [showSelectIdentity, setShowSelectIdentity] = useState(false);
|
|
135
|
+
const identities = useApiIdentities();
|
|
136
|
+
const { setRememberedIdentity, getRememberedIdentity } = useIdentityStore();
|
|
116
137
|
const [, startTransition] = useTransition();
|
|
138
|
+
const [skipLogin, setSkipLogin] = useState(false);
|
|
139
|
+
const [showLongRunningWarning, setShowLongRunningWarning] = useState(false);
|
|
140
|
+
const abortControllerRef = useRef<AbortController | undefined>(undefined);
|
|
141
|
+
const latestSetRememberedIdentity = useLatest(setRememberedIdentity);
|
|
142
|
+
|
|
117
143
|
const { register, control, handleSubmit, watch, setValue, ...form } =
|
|
118
144
|
useForm<PlaygroundForm>({
|
|
119
145
|
defaultValues: {
|
|
120
146
|
body: defaultBody,
|
|
147
|
+
bodyContentType: "JSON",
|
|
121
148
|
queryParams: queryParams
|
|
122
149
|
.map((param) => ({
|
|
123
150
|
name: param.name,
|
|
@@ -150,54 +177,68 @@ export const Playground = ({
|
|
|
150
177
|
active: false,
|
|
151
178
|
},
|
|
152
179
|
]),
|
|
153
|
-
identity:
|
|
180
|
+
identity: getRememberedIdentity(
|
|
181
|
+
identities.data?.map((i) => i.id) ?? [],
|
|
182
|
+
),
|
|
154
183
|
},
|
|
155
184
|
});
|
|
156
185
|
const formState = watch();
|
|
157
|
-
const
|
|
186
|
+
const formRef = useRef<HTMLFormElement>(null);
|
|
158
187
|
|
|
159
|
-
const setOnce = useRef(false);
|
|
160
188
|
useEffect(() => {
|
|
161
|
-
if (
|
|
162
|
-
|
|
163
|
-
if (firstIdentity) {
|
|
164
|
-
setValue("identity", firstIdentity.id);
|
|
165
|
-
setOnce.current = true;
|
|
189
|
+
if (formState.identity) {
|
|
190
|
+
latestSetRememberedIdentity.current(formState.identity);
|
|
166
191
|
}
|
|
167
|
-
}, [
|
|
168
|
-
|
|
169
|
-
const formRef = useRef<HTMLFormElement>(null);
|
|
192
|
+
}, [latestSetRememberedIdentity, formState.identity]);
|
|
170
193
|
|
|
171
194
|
const queryMutation = useMutation({
|
|
172
195
|
mutationFn: async (data: PlaygroundForm) => {
|
|
173
196
|
const start = performance.now();
|
|
197
|
+
|
|
198
|
+
const shouldSetContentType = !data.headers.some(
|
|
199
|
+
(h) => h.active && h.name.toLowerCase() === "content-type",
|
|
200
|
+
);
|
|
201
|
+
|
|
202
|
+
const headers = Object.fromEntries([
|
|
203
|
+
...data.headers
|
|
204
|
+
.filter((h) => h.name && h.active)
|
|
205
|
+
.map((header) => [header.name, header.value]),
|
|
206
|
+
...(shouldSetContentType
|
|
207
|
+
? [["content-type", bodyContentTypeMap[data.bodyContentType]]]
|
|
208
|
+
: []),
|
|
209
|
+
]);
|
|
210
|
+
|
|
174
211
|
const request = new Request(
|
|
175
|
-
createUrl(
|
|
212
|
+
createUrl(server ?? selectedServer, url, data),
|
|
176
213
|
{
|
|
177
214
|
method: method.toUpperCase(),
|
|
178
|
-
headers
|
|
179
|
-
data.headers
|
|
180
|
-
.filter((h) => h.name && h.active)
|
|
181
|
-
.map((header) => [header.name, header.value]),
|
|
182
|
-
),
|
|
215
|
+
headers,
|
|
183
216
|
body: data.body ? data.body : undefined,
|
|
184
217
|
},
|
|
185
218
|
);
|
|
186
219
|
|
|
187
220
|
if (data.identity !== NO_IDENTITY) {
|
|
188
|
-
identities.data
|
|
221
|
+
await identities.data
|
|
189
222
|
?.find((i) => i.id === data.identity)
|
|
190
223
|
?.authorizeRequest(request);
|
|
191
224
|
}
|
|
225
|
+
|
|
226
|
+
const warningTimeout = setTimeout(
|
|
227
|
+
() => setShowLongRunningWarning(true),
|
|
228
|
+
3210,
|
|
229
|
+
);
|
|
230
|
+
abortControllerRef.current = new AbortController();
|
|
231
|
+
|
|
192
232
|
try {
|
|
193
233
|
const response = await fetch(request, {
|
|
194
|
-
signal:
|
|
234
|
+
signal: abortControllerRef.current.signal,
|
|
195
235
|
});
|
|
196
236
|
|
|
197
|
-
|
|
237
|
+
clearTimeout(warningTimeout);
|
|
238
|
+
setShowLongRunningWarning(false);
|
|
198
239
|
|
|
240
|
+
const time = performance.now() - start;
|
|
199
241
|
const body = await response.text();
|
|
200
|
-
|
|
201
242
|
const url = new URL(request.url);
|
|
202
243
|
|
|
203
244
|
return {
|
|
@@ -218,6 +259,8 @@ export const Playground = ({
|
|
|
218
259
|
},
|
|
219
260
|
} satisfies PlaygroundResult;
|
|
220
261
|
} catch (error) {
|
|
262
|
+
clearTimeout(warningTimeout);
|
|
263
|
+
setShowLongRunningWarning(false);
|
|
221
264
|
if (error instanceof TypeError) {
|
|
222
265
|
throw new Error(
|
|
223
266
|
"The request failed, possibly due to network issues or CORS policy.",
|
|
@@ -229,6 +272,12 @@ export const Playground = ({
|
|
|
229
272
|
},
|
|
230
273
|
});
|
|
231
274
|
|
|
275
|
+
useEffect(() => {
|
|
276
|
+
return () => {
|
|
277
|
+
abortControllerRef.current?.abort();
|
|
278
|
+
};
|
|
279
|
+
}, []);
|
|
280
|
+
|
|
232
281
|
const path = (
|
|
233
282
|
<PathRenderer
|
|
234
283
|
path={url}
|
|
@@ -263,39 +312,72 @@ export const Playground = ({
|
|
|
263
312
|
|
|
264
313
|
const serverSelect = (
|
|
265
314
|
<div className="inline-block opacity-50 hover:opacity-100 transition">
|
|
266
|
-
{
|
|
267
|
-
<
|
|
268
|
-
onValueChange={(value) => {
|
|
269
|
-
startTransition(() => setSelectedServer(value));
|
|
270
|
-
}}
|
|
271
|
-
value={selectedServer}
|
|
272
|
-
defaultValue={selectedServer}
|
|
273
|
-
>
|
|
274
|
-
<SelectTrigger className="p-0 border-none flex-row-reverse bg-transparent text-xs gap-0.5 h-auto">
|
|
275
|
-
<SelectValue />
|
|
276
|
-
</SelectTrigger>
|
|
277
|
-
<SelectContent>
|
|
278
|
-
{servers.map((s) => (
|
|
279
|
-
<SelectItem key={s} value={s}>
|
|
280
|
-
{s.replace(/^https?:\/\//, "")}
|
|
281
|
-
</SelectItem>
|
|
282
|
-
))}
|
|
283
|
-
</SelectContent>
|
|
284
|
-
</Select>
|
|
315
|
+
{server ? (
|
|
316
|
+
<span>{server.replace(/^https?:\/\//, "").replace(/\/$/, "")}</span>
|
|
285
317
|
) : (
|
|
286
|
-
|
|
318
|
+
servers.length > 1 && (
|
|
319
|
+
<Select
|
|
320
|
+
onValueChange={(value) => {
|
|
321
|
+
startTransition(() => setSelectedServer(value));
|
|
322
|
+
}}
|
|
323
|
+
value={selectedServer}
|
|
324
|
+
defaultValue={selectedServer}
|
|
325
|
+
>
|
|
326
|
+
<SelectTrigger className="p-0 border-none flex-row-reverse bg-transparent text-xs gap-0.5 h-auto translate-y-[4px]">
|
|
327
|
+
<SelectValue />
|
|
328
|
+
</SelectTrigger>
|
|
329
|
+
<SelectContent>
|
|
330
|
+
{servers.map((s) => (
|
|
331
|
+
<SelectItem key={s} value={s}>
|
|
332
|
+
{s.replace(/^https?:\/\//, "").replace(/\/$/, "")}
|
|
333
|
+
</SelectItem>
|
|
334
|
+
))}
|
|
335
|
+
</SelectContent>
|
|
336
|
+
</Select>
|
|
337
|
+
)
|
|
287
338
|
)}
|
|
288
339
|
</div>
|
|
289
340
|
);
|
|
290
341
|
|
|
342
|
+
const showLogin = requiresLogin && !skipLogin;
|
|
343
|
+
const isBodySupported = ["POST", "PUT", "PATCH", "DELETE"].includes(
|
|
344
|
+
method.toUpperCase(),
|
|
345
|
+
);
|
|
346
|
+
|
|
291
347
|
return (
|
|
292
348
|
<FormProvider
|
|
293
349
|
{...{ register, control, handleSubmit, watch, setValue, ...form }}
|
|
294
350
|
>
|
|
295
351
|
<form
|
|
296
|
-
onSubmit={handleSubmit((data) =>
|
|
352
|
+
onSubmit={handleSubmit((data) => {
|
|
353
|
+
if (identities.data?.length === 0 || data.identity) {
|
|
354
|
+
queryMutation.mutate(data);
|
|
355
|
+
} else {
|
|
356
|
+
setShowSelectIdentity(true);
|
|
357
|
+
}
|
|
358
|
+
})}
|
|
297
359
|
ref={formRef}
|
|
360
|
+
className="relative"
|
|
298
361
|
>
|
|
362
|
+
<IdentityDialog
|
|
363
|
+
identities={identities.data ?? []}
|
|
364
|
+
open={showSelectIdentity}
|
|
365
|
+
onOpenChange={setShowSelectIdentity}
|
|
366
|
+
onSubmit={({ rememberedIdentity, identity }) => {
|
|
367
|
+
if (rememberedIdentity) {
|
|
368
|
+
setValue("identity", identity ?? NO_IDENTITY);
|
|
369
|
+
}
|
|
370
|
+
setShowSelectIdentity(false);
|
|
371
|
+
queryMutation.mutate({ ...formState, identity });
|
|
372
|
+
}}
|
|
373
|
+
/>
|
|
374
|
+
<RequestLoginDialog
|
|
375
|
+
open={showLogin}
|
|
376
|
+
setOpen={(open) => setSkipLogin(!open)}
|
|
377
|
+
onSignUp={onSignUp}
|
|
378
|
+
onLogin={onLogin}
|
|
379
|
+
/>
|
|
380
|
+
|
|
299
381
|
<div className="grid grid-cols-2 text-sm h-full">
|
|
300
382
|
<div className="flex flex-col gap-4 p-4 after:bg-muted-foreground/20 relative after:absolute after:w-px after:inset-0 after:left-auto">
|
|
301
383
|
<div className="flex gap-2 items-stretch">
|
|
@@ -303,7 +385,7 @@ export const Playground = ({
|
|
|
303
385
|
<div className="border-r p-2 bg-muted rounded-l-md self-stretch font-semibold font-mono flex items-center">
|
|
304
386
|
{method.toUpperCase()}
|
|
305
387
|
</div>
|
|
306
|
-
<div className="items-center
|
|
388
|
+
<div className="items-center px-2 py-0.5 font-mono text-xs break-all leading-6">
|
|
307
389
|
{serverSelect}
|
|
308
390
|
{path}
|
|
309
391
|
{urlQueryParams.length > 0 ? "?" : ""}
|
|
@@ -314,7 +396,7 @@ export const Playground = ({
|
|
|
314
396
|
<SubmitButton
|
|
315
397
|
identities={identities.data ?? []}
|
|
316
398
|
formRef={formRef}
|
|
317
|
-
disabled={form.formState.isSubmitting}
|
|
399
|
+
disabled={identities.isLoading || form.formState.isSubmitting}
|
|
318
400
|
/>
|
|
319
401
|
</div>
|
|
320
402
|
<Tabs defaultValue="parameters">
|
|
@@ -339,7 +421,12 @@ export const Playground = ({
|
|
|
339
421
|
<div className="w-2 h-2 rounded-full bg-blue-400 ml-2" />
|
|
340
422
|
)}
|
|
341
423
|
</TabsTrigger>
|
|
342
|
-
<TabsTrigger value="body">
|
|
424
|
+
<TabsTrigger value="body">
|
|
425
|
+
Body
|
|
426
|
+
{formState.body && (
|
|
427
|
+
<div className="w-2 h-2 rounded-full bg-blue-400 ml-2" />
|
|
428
|
+
)}
|
|
429
|
+
</TabsTrigger>
|
|
343
430
|
</TabsList>
|
|
344
431
|
</div>
|
|
345
432
|
<TabsContent value="headers">
|
|
@@ -349,7 +436,7 @@ export const Playground = ({
|
|
|
349
436
|
{pathParams.length > 0 && (
|
|
350
437
|
<div className="flex flex-col gap-4 my-4">
|
|
351
438
|
<span className="font-semibold">Path Parameters</span>
|
|
352
|
-
<PathParams control={control} />
|
|
439
|
+
<PathParams url={url} control={control} />
|
|
353
440
|
</div>
|
|
354
441
|
)}
|
|
355
442
|
<div className="flex flex-col gap-4 my-4">
|
|
@@ -373,31 +460,58 @@ export const Playground = ({
|
|
|
373
460
|
<Textarea
|
|
374
461
|
{...register("body")}
|
|
375
462
|
className={cn(
|
|
376
|
-
"border w-full rounded-lg p-2
|
|
377
|
-
!
|
|
378
|
-
method.toUpperCase(),
|
|
379
|
-
) && "h-20",
|
|
463
|
+
"border w-full rounded-lg bg-muted/40 p-2 h-64 font-mono text-[13px]",
|
|
464
|
+
!isBodySupported && "h-20 bg-muted",
|
|
380
465
|
)}
|
|
381
466
|
placeholder={
|
|
382
|
-
!
|
|
383
|
-
method.toUpperCase(),
|
|
384
|
-
)
|
|
467
|
+
!isBodySupported
|
|
385
468
|
? "This request does not support a body"
|
|
386
469
|
: undefined
|
|
387
470
|
}
|
|
388
|
-
disabled={
|
|
389
|
-
!["POST", "PUT", "PATCH", "DELETE"].includes(
|
|
390
|
-
method.toUpperCase(),
|
|
391
|
-
)
|
|
392
|
-
}
|
|
471
|
+
disabled={!isBodySupported}
|
|
393
472
|
/>
|
|
394
|
-
{
|
|
395
|
-
<
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
473
|
+
{isBodySupported && (
|
|
474
|
+
<div className="flex items-center gap-2 mt-2 justify-between">
|
|
475
|
+
<Select
|
|
476
|
+
value={formState.bodyContentType}
|
|
477
|
+
onValueChange={(value) =>
|
|
478
|
+
setValue(
|
|
479
|
+
"bodyContentType",
|
|
480
|
+
value as keyof typeof bodyContentTypeMap,
|
|
481
|
+
)
|
|
482
|
+
}
|
|
483
|
+
>
|
|
484
|
+
<SelectTrigger className="w-[100px]">
|
|
485
|
+
<SelectValue />
|
|
486
|
+
</SelectTrigger>
|
|
487
|
+
<SelectContent>
|
|
488
|
+
{Object.keys(bodyContentTypeMap).map((format) => (
|
|
489
|
+
<SelectItem key={format} value={format}>
|
|
490
|
+
{format}
|
|
491
|
+
</SelectItem>
|
|
492
|
+
))}
|
|
493
|
+
</SelectContent>
|
|
494
|
+
</Select>
|
|
495
|
+
{examples && examples.length > 0 && (
|
|
496
|
+
<ExamplesDropdown
|
|
497
|
+
examples={examples}
|
|
498
|
+
onSelect={(example, mediaType) => {
|
|
499
|
+
setValue(
|
|
500
|
+
"body",
|
|
501
|
+
JSON.stringify(example.value, null, 2),
|
|
502
|
+
);
|
|
503
|
+
|
|
504
|
+
const format = objectEntries(bodyContentTypeMap).find(
|
|
505
|
+
([_, contentType]) => contentType === mediaType,
|
|
506
|
+
)?.[0];
|
|
507
|
+
|
|
508
|
+
if (format) {
|
|
509
|
+
setValue("bodyContentType", format);
|
|
510
|
+
}
|
|
511
|
+
}}
|
|
512
|
+
/>
|
|
513
|
+
)}
|
|
514
|
+
</div>
|
|
401
515
|
)}
|
|
402
516
|
</TabsContent>
|
|
403
517
|
<TabsContent value="auth">
|
|
@@ -412,43 +526,11 @@ export const Playground = ({
|
|
|
412
526
|
</Alert>
|
|
413
527
|
)}
|
|
414
528
|
<div className="flex flex-col items-center gap-2">
|
|
415
|
-
<
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
className="gap-0"
|
|
421
|
-
disabled={identities.data?.length === 0}
|
|
422
|
-
>
|
|
423
|
-
<Label
|
|
424
|
-
className="h-12 border-b items-center flex p-4 cursor-pointer hover:bg-accent"
|
|
425
|
-
htmlFor="none"
|
|
426
|
-
>
|
|
427
|
-
<RadioGroupItem value={NO_IDENTITY} id="none">
|
|
428
|
-
None
|
|
429
|
-
</RadioGroupItem>
|
|
430
|
-
<Label htmlFor="none" className="ml-2">
|
|
431
|
-
None
|
|
432
|
-
</Label>
|
|
433
|
-
</Label>
|
|
434
|
-
{identities.data?.map((identity) => (
|
|
435
|
-
<Label
|
|
436
|
-
key={identity.id}
|
|
437
|
-
className="h-12 border-b items-center flex p-4 cursor-pointer hover:bg-accent"
|
|
438
|
-
>
|
|
439
|
-
<RadioGroupItem
|
|
440
|
-
value={identity.id}
|
|
441
|
-
id={identity.id}
|
|
442
|
-
>
|
|
443
|
-
{identity.label}
|
|
444
|
-
</RadioGroupItem>
|
|
445
|
-
<Label htmlFor={identity.id} className="ml-2">
|
|
446
|
-
{identity.label}
|
|
447
|
-
</Label>
|
|
448
|
-
</Label>
|
|
449
|
-
))}
|
|
450
|
-
</RadioGroup>
|
|
451
|
-
</Card>
|
|
529
|
+
<IdentitySelector
|
|
530
|
+
value={formState.identity}
|
|
531
|
+
identities={identities.data ?? []}
|
|
532
|
+
setValue={(value) => setValue("identity", value)}
|
|
533
|
+
/>
|
|
452
534
|
</div>
|
|
453
535
|
</div>
|
|
454
536
|
</TabsContent>
|
|
@@ -459,6 +541,13 @@ export const Playground = ({
|
|
|
459
541
|
showPathParamsWarning={formState.pathParams.some(
|
|
460
542
|
(p) => p.value === "",
|
|
461
543
|
)}
|
|
544
|
+
showLongRunningWarning={showLongRunningWarning}
|
|
545
|
+
onCancel={() => {
|
|
546
|
+
abortControllerRef.current?.abort(
|
|
547
|
+
"Request cancelled by the user",
|
|
548
|
+
);
|
|
549
|
+
setShowLongRunningWarning(false);
|
|
550
|
+
}}
|
|
462
551
|
/>
|
|
463
552
|
</div>
|
|
464
553
|
</form>
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Button } from "zudoku/ui/Button.js";
|
|
2
|
+
import {
|
|
3
|
+
Dialog,
|
|
4
|
+
DialogContent,
|
|
5
|
+
DialogDescription,
|
|
6
|
+
DialogFooter,
|
|
7
|
+
DialogTitle,
|
|
8
|
+
} from "zudoku/ui/Dialog.js";
|
|
9
|
+
|
|
10
|
+
const RequestLoginDialog = ({
|
|
11
|
+
open,
|
|
12
|
+
setOpen,
|
|
13
|
+
onSignUp,
|
|
14
|
+
onLogin,
|
|
15
|
+
}: {
|
|
16
|
+
open: boolean;
|
|
17
|
+
onSignUp?: () => void;
|
|
18
|
+
onLogin?: () => void;
|
|
19
|
+
setOpen: (open: boolean) => void;
|
|
20
|
+
}) => {
|
|
21
|
+
return (
|
|
22
|
+
<Dialog open={open} onOpenChange={setOpen}>
|
|
23
|
+
<DialogContent>
|
|
24
|
+
<DialogTitle>Welcome to the Playground!</DialogTitle>
|
|
25
|
+
<DialogDescription>
|
|
26
|
+
The Playground is a tool for developers to test and explore our APIs.
|
|
27
|
+
To use the Playground, you need to login.
|
|
28
|
+
</DialogDescription>
|
|
29
|
+
<DialogFooter className="flex gap-2 sm:justify-between">
|
|
30
|
+
<Button type="button" variant="ghost" onClick={() => setOpen(false)}>
|
|
31
|
+
Skip
|
|
32
|
+
</Button>
|
|
33
|
+
<div className="flex gap-2">
|
|
34
|
+
{onSignUp && (
|
|
35
|
+
<Button type="button" variant="outline" onClick={onSignUp}>
|
|
36
|
+
Sign Up
|
|
37
|
+
</Button>
|
|
38
|
+
)}
|
|
39
|
+
{onLogin && (
|
|
40
|
+
<Button type="button" variant="default" onClick={onLogin}>
|
|
41
|
+
Login
|
|
42
|
+
</Button>
|
|
43
|
+
)}
|
|
44
|
+
</div>
|
|
45
|
+
</DialogFooter>
|
|
46
|
+
</DialogContent>
|
|
47
|
+
</Dialog>
|
|
48
|
+
);
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export default RequestLoginDialog;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { create } from "zustand";
|
|
2
|
+
import { createJSONStorage, persist } from "zustand/middleware";
|
|
3
|
+
|
|
4
|
+
interface IdentityState {
|
|
5
|
+
rememberedIdentity: string | null;
|
|
6
|
+
setRememberedIdentity: (identity: string | null) => void;
|
|
7
|
+
getRememberedIdentity: (availableIdentities: string[]) => string | undefined;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export const useIdentityStore = create<IdentityState>()(
|
|
11
|
+
persist(
|
|
12
|
+
(set, get) => ({
|
|
13
|
+
rememberedIdentity: null,
|
|
14
|
+
setRememberedIdentity: (identity: string | null) =>
|
|
15
|
+
set({ rememberedIdentity: identity }),
|
|
16
|
+
getRememberedIdentity: (availableIdentities: string[]) =>
|
|
17
|
+
availableIdentities.find(
|
|
18
|
+
(identity) => identity === get().rememberedIdentity,
|
|
19
|
+
),
|
|
20
|
+
}),
|
|
21
|
+
{
|
|
22
|
+
name: "identity-storage",
|
|
23
|
+
storage: createJSONStorage(() => sessionStorage),
|
|
24
|
+
},
|
|
25
|
+
),
|
|
26
|
+
);
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { useQuery } from "@tanstack/react-query";
|
|
2
2
|
import { ChevronRightIcon } from "lucide-react";
|
|
3
3
|
import { Fragment, useState } from "react";
|
|
4
|
+
import { Callout } from "zudoku/ui/Callout.js";
|
|
4
5
|
import {
|
|
5
6
|
Collapsible,
|
|
6
7
|
CollapsibleContent,
|
|
@@ -13,8 +14,8 @@ import {
|
|
|
13
14
|
SelectTrigger,
|
|
14
15
|
SelectValue,
|
|
15
16
|
} from "zudoku/ui/Select.js";
|
|
16
|
-
import { SyntaxHighlight } from "../../../../components/SyntaxHighlight.js";
|
|
17
17
|
import { Card } from "../../../../ui/Card.js";
|
|
18
|
+
import { SyntaxHighlight } from "../../../../ui/SyntaxHighlight.js";
|
|
18
19
|
import { convertToTypes } from "./convertToTypes.js";
|
|
19
20
|
|
|
20
21
|
const statusCodeMap: Record<number, string> = {
|
|
@@ -30,6 +31,14 @@ const statusCodeMap: Record<number, string> = {
|
|
|
30
31
|
500: "Internal Server Error",
|
|
31
32
|
};
|
|
32
33
|
|
|
34
|
+
const humanFileSize = (bytes: number) => {
|
|
35
|
+
const exponent = Math.floor(Math.log(bytes) / Math.log(1000.0));
|
|
36
|
+
const decimal = (bytes / Math.pow(1000.0, exponent)).toFixed(
|
|
37
|
+
exponent ? 2 : 0,
|
|
38
|
+
);
|
|
39
|
+
return `${decimal} ${exponent ? `${"kMGTPEZY"[exponent - 1]}B` : "B"}`;
|
|
40
|
+
};
|
|
41
|
+
|
|
33
42
|
const mimeTypeToLanguage = (mimeType: string) => {
|
|
34
43
|
const mimeTypeMapping = {
|
|
35
44
|
"application/json": "json",
|
|
@@ -83,6 +92,8 @@ const sortHeadersByRelevance = (
|
|
|
83
92
|
});
|
|
84
93
|
};
|
|
85
94
|
|
|
95
|
+
const SYNTAX_HIGHLIGHT_MAX_SIZE_THRESHOLD = 64_000;
|
|
96
|
+
|
|
86
97
|
export const ResponseTab = ({
|
|
87
98
|
body = "",
|
|
88
99
|
headers,
|
|
@@ -114,9 +125,10 @@ export const ResponseTab = ({
|
|
|
114
125
|
});
|
|
115
126
|
|
|
116
127
|
const sortedHeaders = sortHeadersByRelevance([...headers]);
|
|
128
|
+
const shouldDisableHighlighting = size > SYNTAX_HIGHLIGHT_MAX_SIZE_THRESHOLD;
|
|
117
129
|
|
|
118
130
|
return (
|
|
119
|
-
<div className="flex flex-col gap-2 h-full overflow-
|
|
131
|
+
<div className="flex flex-col gap-2 h-full overflow-auto max-h-[calc(100vh-220px)] ">
|
|
120
132
|
<Collapsible defaultOpen>
|
|
121
133
|
<CollapsibleTrigger className="flex items-center gap-2 hover:text-primary group">
|
|
122
134
|
<ChevronRightIcon className="h-4 w-4 transition-transform duration-200 group-data-[state=open]:rotate-[90deg]" />
|
|
@@ -151,6 +163,12 @@ export const ResponseTab = ({
|
|
|
151
163
|
</Collapsible>
|
|
152
164
|
|
|
153
165
|
<Card className="shadow-none">
|
|
166
|
+
{shouldDisableHighlighting && (
|
|
167
|
+
<Callout type="info" className="my-0 p-2">
|
|
168
|
+
Code highlight is disabled for responses larger than{" "}
|
|
169
|
+
{humanFileSize(SYNTAX_HIGHLIGHT_MAX_SIZE_THRESHOLD)}
|
|
170
|
+
</Callout>
|
|
171
|
+
)}
|
|
154
172
|
<SyntaxHighlight
|
|
155
173
|
language={
|
|
156
174
|
view === "types"
|
|
@@ -161,8 +179,9 @@ export const ResponseTab = ({
|
|
|
161
179
|
: detectedLanguage
|
|
162
180
|
: "json"
|
|
163
181
|
}
|
|
182
|
+
showCopy="always"
|
|
183
|
+
disabled={shouldDisableHighlighting}
|
|
164
184
|
noBackground
|
|
165
|
-
// playground dialog has h-5/6 ≈ 83.333vh
|
|
166
185
|
className="overflow-x-auto p-4 text-xs max-h-[calc(83.333vh-180px)]"
|
|
167
186
|
code={
|
|
168
187
|
(view === "raw"
|
|
@@ -173,7 +192,7 @@ export const ResponseTab = ({
|
|
|
173
192
|
}
|
|
174
193
|
/>
|
|
175
194
|
</Card>
|
|
176
|
-
<div className="flex gap-2 justify-between">
|
|
195
|
+
<div className="flex gap-2 justify-between items-center">
|
|
177
196
|
<div className="flex text-xs gap-2 border bg-muted rounded-md p-2 items-center h-8 font-mono divide-x">
|
|
178
197
|
<div>
|
|
179
198
|
<span className="text-muted-foreground">Status</span> {status}{" "}
|
|
@@ -184,7 +203,8 @@ export const ResponseTab = ({
|
|
|
184
203
|
{time.toFixed(0)}ms
|
|
185
204
|
</div>
|
|
186
205
|
<div>
|
|
187
|
-
<span className="text-muted-foreground">Size</span>
|
|
206
|
+
<span className="text-muted-foreground">Size</span>{" "}
|
|
207
|
+
{humanFileSize(size)}
|
|
188
208
|
</div>
|
|
189
209
|
</div>
|
|
190
210
|
{jsonContent && (
|