zudoku 0.0.0-eb4182d → 0.0.0-eeace45
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 +121 -0
- package/cli.js +2 -2
- package/client.d.ts +7 -0
- package/dist/app/demo.js +1 -3
- package/dist/app/demo.js.map +1 -1
- package/dist/app/entry.client.d.ts +1 -0
- package/dist/app/entry.client.js +16 -3
- package/dist/app/entry.client.js.map +1 -1
- package/dist/app/entry.server.d.ts +1 -0
- package/dist/app/entry.server.js +11 -8
- package/dist/app/entry.server.js.map +1 -1
- package/dist/app/main.d.ts +3 -2
- package/dist/app/main.js +16 -32
- package/dist/app/main.js.map +1 -1
- package/dist/app/sentry.d.ts +3 -0
- package/dist/app/sentry.js +19 -0
- package/dist/app/sentry.js.map +1 -0
- package/dist/app/standalone.js +1 -3
- package/dist/app/standalone.js.map +1 -1
- package/dist/app/tailwind.d.ts +2 -1
- package/dist/app/tailwind.js +64 -52
- package/dist/app/tailwind.js.map +1 -1
- package/dist/cli/cli.js +1 -4
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/cmds/build.js +1 -0
- package/dist/cli/cmds/build.js.map +1 -1
- package/dist/cli/cmds/dev.js +5 -0
- package/dist/cli/cmds/dev.js.map +1 -1
- package/dist/cli/common/logger.js +9 -0
- package/dist/cli/common/logger.js.map +1 -1
- package/dist/cli/common/machine-id/lib.js.map +1 -1
- package/dist/cli/common/outdated.js +2 -1
- package/dist/cli/common/outdated.js.map +1 -1
- package/dist/cli/common/utils/box.js.map +1 -1
- package/dist/cli/dev/handler.d.ts +1 -0
- package/dist/cli/dev/handler.js +3 -3
- package/dist/cli/dev/handler.js.map +1 -1
- package/dist/codegen.d.ts +3 -0
- package/dist/codegen.js +45 -0
- package/dist/codegen.js.map +1 -0
- package/dist/config/common.d.ts +8 -0
- package/dist/config/common.js +2 -0
- package/dist/config/common.js.map +1 -0
- package/dist/config/config.d.ts +3 -2
- package/dist/config/loader.d.ts +20 -0
- package/dist/config/loader.js +154 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/validators/InputSidebarSchema.d.ts +35 -19
- package/dist/config/validators/InputSidebarSchema.js +7 -28
- package/dist/config/validators/InputSidebarSchema.js.map +1 -1
- package/dist/config/validators/SidebarSchema.d.ts +24 -1
- package/dist/config/validators/SidebarSchema.js +80 -44
- package/dist/config/validators/SidebarSchema.js.map +1 -1
- package/dist/config/validators/common.d.ts +4945 -0
- package/dist/config/validators/common.js +280 -0
- package/dist/config/validators/common.js.map +1 -0
- package/dist/config/validators/icon-types.d.ts +1 -0
- package/dist/config/validators/icon-types.js +2 -0
- package/dist/config/validators/icon-types.js.map +1 -0
- package/dist/config/validators/validate.d.ts +888 -453
- package/dist/config/validators/validate.js +14 -213
- package/dist/config/validators/validate.js.map +1 -1
- package/dist/index.d.ts +5 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/lib/authentication/AuthenticationPlugin.d.ts +4 -2
- package/dist/lib/authentication/AuthenticationPlugin.js +3 -0
- package/dist/lib/authentication/AuthenticationPlugin.js.map +1 -1
- package/dist/lib/authentication/authentication.d.ts +3 -3
- package/dist/lib/authentication/components/CallbackHandler.js +21 -31
- package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
- package/dist/lib/authentication/components/SignIn.js +1 -1
- package/dist/lib/authentication/components/SignIn.js.map +1 -1
- package/dist/lib/authentication/components/SignOut.js +1 -1
- package/dist/lib/authentication/components/SignOut.js.map +1 -1
- package/dist/lib/authentication/hook.d.ts +5 -4
- package/dist/lib/authentication/hook.js +1 -3
- package/dist/lib/authentication/hook.js.map +1 -1
- package/dist/lib/authentication/providers/auth0.js +12 -11
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +7 -1
- package/dist/lib/authentication/providers/openid.js +18 -27
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/state.d.ts +25 -4
- package/dist/lib/authentication/state.js +28 -3
- package/dist/lib/authentication/state.js.map +1 -1
- package/dist/lib/authentication/use-broadcast/shared.d.ts +48 -0
- package/dist/lib/authentication/use-broadcast/shared.js +243 -0
- package/dist/lib/authentication/use-broadcast/shared.js.map +1 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.d.ts +24 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.js +106 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.js.map +1 -0
- package/dist/lib/components/AnchorLink.d.ts +1 -1
- package/dist/lib/components/AnchorLink.js +1 -1
- package/dist/lib/components/AnchorLink.js.map +1 -1
- package/dist/lib/components/Banner.js +7 -1
- package/dist/lib/components/Banner.js.map +1 -1
- package/dist/lib/components/Bootstrap.d.ts +4 -3
- package/dist/lib/components/Bootstrap.js +12 -6
- package/dist/lib/components/Bootstrap.js.map +1 -1
- package/dist/lib/components/ClientOnly.d.ts +4 -2
- package/dist/lib/components/ClientOnly.js +1 -1
- package/dist/lib/components/ClientOnly.js.map +1 -1
- package/dist/lib/components/DeveloperHint.js +2 -1
- package/dist/lib/components/DeveloperHint.js.map +1 -1
- package/dist/lib/components/ErrorPage.js +1 -2
- package/dist/lib/components/ErrorPage.js.map +1 -1
- package/dist/lib/components/Header.js +21 -10
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Heading.d.ts +4 -4
- package/dist/lib/components/Heading.js +1 -1
- package/dist/lib/components/Heading.js.map +1 -1
- package/dist/lib/components/Layout.js +14 -5
- package/dist/lib/components/Layout.js.map +1 -1
- package/dist/lib/components/Markdown.js +1 -1
- package/dist/lib/components/Markdown.js.map +1 -1
- package/dist/lib/components/MobileTopNavigation.js +9 -6
- package/dist/lib/components/MobileTopNavigation.js.map +1 -1
- package/dist/lib/components/NotFoundPage.js +1 -1
- package/dist/lib/components/NotFoundPage.js.map +1 -1
- package/dist/lib/components/ReactMarkdown.d.ts +29 -0
- package/dist/lib/components/ReactMarkdown.js +182 -0
- package/dist/lib/components/ReactMarkdown.js.map +1 -0
- package/dist/lib/components/Search.d.ts +3 -1
- package/dist/lib/components/Search.js +3 -3
- package/dist/lib/components/Search.js.map +1 -1
- package/dist/lib/components/SlotletProvider.d.ts +11 -3
- package/dist/lib/components/SlotletProvider.js +4 -2
- package/dist/lib/components/SlotletProvider.js.map +1 -1
- package/dist/lib/components/SyntaxHighlight.js +19 -16
- package/dist/lib/components/SyntaxHighlight.js.map +1 -1
- package/dist/lib/components/ThemeSwitch.d.ts +1 -0
- package/dist/lib/components/ThemeSwitch.js +13 -0
- package/dist/lib/components/ThemeSwitch.js.map +1 -0
- package/dist/lib/components/TopNavigation.d.ts +5 -0
- package/dist/lib/components/TopNavigation.js +44 -5
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/{DevPortal.d.ts → Zudoku.d.ts} +3 -3
- package/dist/lib/components/{DevPortal.js → Zudoku.js} +14 -15
- package/dist/lib/components/Zudoku.js.map +1 -0
- package/dist/lib/components/context/ZudokuContext.d.ts +10 -14
- package/dist/lib/components/context/ZudokuContext.js +27 -26
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/context/ZudokuProvider.d.ts +2 -2
- package/dist/lib/components/context/ZudokuProvider.js.map +1 -1
- package/dist/lib/components/index.d.ts +38 -16
- package/dist/lib/components/index.js +16 -6
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
- package/dist/lib/components/navigation/Sidebar.js +4 -4
- package/dist/lib/components/navigation/Sidebar.js.map +1 -1
- package/dist/lib/components/navigation/SidebarBadge.d.ts +0 -9
- package/dist/lib/components/navigation/SidebarBadge.js +0 -9
- 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 +18 -10
- package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
- package/dist/lib/components/navigation/SidebarItem.d.ts +2 -4
- package/dist/lib/components/navigation/SidebarItem.js +12 -12
- package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.js +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
- package/dist/lib/components/navigation/utils.js +11 -15
- package/dist/lib/components/navigation/utils.js.map +1 -1
- package/dist/lib/core/{DevPortalContext.d.ts → ZudokuContext.d.ts} +7 -14
- package/dist/lib/core/{DevPortalContext.js → ZudokuContext.js} +2 -7
- package/dist/lib/core/ZudokuContext.js.map +1 -0
- package/dist/lib/core/plugins.d.ts +18 -13
- package/dist/lib/core/plugins.js.map +1 -1
- package/dist/lib/errors/ErrorAlert.d.ts +1 -1
- package/dist/lib/errors/ErrorAlert.js +8 -3
- package/dist/lib/errors/ErrorAlert.js.map +1 -1
- package/dist/lib/errors/RouterError.js +1 -1
- package/dist/lib/errors/RouterError.js.map +1 -1
- package/dist/lib/oas/graphql/index.js +10 -11
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/oas/parser/upgrade/index.d.ts +2 -2
- package/dist/lib/oas/parser/upgrade/index.js +2 -17
- package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
- package/dist/lib/plugins/api-catalog/Catalog.d.ts +2 -0
- package/dist/lib/plugins/api-catalog/Catalog.js +36 -0
- package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -0
- package/dist/lib/plugins/api-catalog/index.d.ts +30 -0
- package/dist/lib/plugins/api-catalog/index.js +15 -0
- package/dist/lib/plugins/api-catalog/index.js.map +1 -0
- package/dist/lib/plugins/api-keys/CreateApiKey.js +2 -2
- package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
- package/dist/lib/plugins/api-keys/ProtectedRoute.js +1 -1
- package/dist/lib/plugins/api-keys/ProtectedRoute.js.map +1 -1
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js +1 -1
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
- package/dist/lib/plugins/api-keys/index.d.ts +9 -9
- package/dist/lib/plugins/api-keys/index.js +3 -0
- package/dist/lib/plugins/api-keys/index.js.map +1 -1
- package/dist/lib/plugins/custom-pages/CustomPage.d.ts +2 -0
- package/dist/lib/plugins/custom-pages/CustomPage.js +11 -0
- package/dist/lib/plugins/custom-pages/CustomPage.js.map +1 -0
- package/dist/lib/plugins/custom-pages/index.d.ts +10 -0
- package/dist/lib/plugins/custom-pages/index.js +11 -0
- package/dist/lib/plugins/custom-pages/index.js.map +1 -0
- package/dist/lib/plugins/markdown/MdxPage.d.ts +9 -1
- package/dist/lib/plugins/markdown/MdxPage.js +16 -3
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/index.d.ts +8 -7
- package/dist/lib/plugins/markdown/index.js +31 -3
- package/dist/lib/plugins/markdown/index.js.map +1 -1
- package/dist/lib/plugins/markdown/resolver.d.ts +38 -0
- package/dist/lib/plugins/markdown/resolver.js +75 -0
- package/dist/lib/plugins/markdown/resolver.js.map +1 -0
- package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +5 -0
- package/dist/lib/plugins/openapi/CollapsibleCode.js +24 -0
- package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -0
- package/dist/lib/plugins/openapi/ColorizedParam.js +13 -9
- package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
- package/dist/lib/plugins/openapi/Endpoint.d.ts +1 -1
- package/dist/lib/plugins/openapi/Endpoint.js +5 -9
- package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
- package/dist/lib/plugins/openapi/OperationList.js +43 -23
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -1
- package/dist/lib/plugins/openapi/OperationListItem.js +14 -4
- package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js +6 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +7 -3
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
- package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +9 -2
- package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
- package/dist/lib/plugins/openapi/Route.d.ts +7 -5
- package/dist/lib/plugins/openapi/Route.js +23 -5
- package/dist/lib/plugins/openapi/Route.js.map +1 -1
- package/dist/lib/plugins/openapi/Sidecar.d.ts +1 -1
- package/dist/lib/plugins/openapi/Sidecar.js +38 -46
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +8 -0
- package/dist/lib/plugins/openapi/client/GraphQLClient.js +114 -0
- package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.d.ts +7 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.js +5 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.js.map +1 -0
- package/dist/lib/plugins/openapi/client/createServer.d.ts +1 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +5 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.js +24 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -0
- package/dist/lib/plugins/openapi/client/worker.d.ts +4 -1
- package/dist/lib/plugins/openapi/client/worker.js +23 -14
- package/dist/lib/plugins/openapi/client/worker.js.map +1 -1
- package/dist/lib/plugins/openapi/context.d.ts +3 -3
- package/dist/lib/plugins/openapi/graphql/fragment-masking.d.ts +3 -3
- package/dist/lib/plugins/openapi/graphql/fragment-masking.js +3 -4
- package/dist/lib/plugins/openapi/graphql/fragment-masking.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +5 -51
- package/dist/lib/plugins/openapi/graphql/gql.js +5 -3
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +34 -8
- package/dist/lib/plugins/openapi/graphql/graphql.js +195 -662
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.d.ts +2 -2
- package/dist/lib/plugins/openapi/index.js +56 -68
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +20 -1
- package/dist/lib/plugins/openapi/playground/PathParams.js +1 -1
- package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Playground.js +3 -2
- package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/ResponseTab.js +1 -1
- package/dist/lib/plugins/openapi/playground/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +6 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +14 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +125 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.d.ts +11 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.js +33 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +104 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.js +2 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.js.map +1 -0
- package/dist/lib/plugins/openapi/schema/SchemaView.js +2 -1
- package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
- package/dist/lib/plugins/openapi/util/generateSchemaExample.d.ts +0 -1
- package/dist/lib/plugins/openapi/util/generateSchemaExample.js +25 -36
- package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
- package/dist/lib/plugins/openapi/util/methodToColor.d.ts +20 -0
- package/dist/lib/plugins/openapi/util/methodToColor.js +24 -0
- package/dist/lib/plugins/openapi/util/methodToColor.js.map +1 -0
- package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.d.ts +1 -0
- package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js +27 -0
- package/dist/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.js.map +1 -0
- package/dist/lib/plugins/openapi-worker.d.ts +1 -1
- package/dist/lib/plugins/openapi-worker.js +7 -1
- package/dist/lib/plugins/openapi-worker.js.map +1 -1
- package/dist/lib/plugins/redirect/index.d.ts +4 -7
- package/dist/lib/plugins/redirect/index.js +2 -2
- package/dist/lib/plugins/redirect/index.js.map +1 -1
- package/dist/lib/plugins/search-inkeep/index.d.ts +24 -5
- package/dist/lib/plugins/search-inkeep/index.js +41 -5
- package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
- package/dist/lib/plugins/search-inkeep/inkeep.d.ts +3 -4
- package/dist/lib/plugins/search-inkeep/inkeep.js.map +1 -1
- package/dist/lib/ui/Accordion.d.ts +7 -0
- package/dist/lib/ui/Accordion.js +14 -0
- package/dist/lib/ui/Accordion.js.map +1 -0
- package/dist/lib/ui/ActionButton.d.ts +4 -0
- package/dist/lib/ui/ActionButton.js +10 -0
- package/dist/lib/ui/ActionButton.js.map +1 -0
- package/dist/lib/ui/Alert.d.ts +8 -0
- package/dist/lib/ui/Alert.js +23 -0
- package/dist/lib/ui/Alert.js.map +1 -0
- package/dist/lib/ui/AlertDialog.d.ts +20 -0
- package/dist/lib/ui/AlertDialog.js +27 -0
- package/dist/lib/ui/AlertDialog.js.map +1 -0
- package/dist/lib/ui/AspectRatio.d.ts +3 -0
- package/dist/lib/ui/AspectRatio.js +4 -0
- package/dist/lib/ui/AspectRatio.js.map +1 -0
- package/dist/lib/ui/Badge.d.ts +9 -0
- package/dist/lib/ui/Badge.js +21 -0
- package/dist/lib/ui/Badge.js.map +1 -0
- package/dist/lib/ui/Breadcrumb.d.ts +19 -0
- package/dist/lib/ui/Breadcrumb.js +24 -0
- package/dist/lib/ui/Breadcrumb.js.map +1 -0
- package/dist/lib/ui/Button.d.ts +2 -3
- package/dist/lib/ui/Button.js +1 -1
- package/dist/lib/ui/Button.js.map +1 -1
- package/dist/lib/ui/Callout.d.ts +36 -35
- package/dist/lib/ui/Callout.js.map +1 -1
- package/dist/lib/ui/Carousel.d.ts +18 -0
- package/dist/lib/ui/Carousel.js +99 -0
- package/dist/lib/ui/Carousel.js.map +1 -0
- package/dist/lib/ui/Checkbox.d.ts +4 -0
- package/dist/lib/ui/Checkbox.js +9 -0
- package/dist/lib/ui/Checkbox.js.map +1 -0
- package/dist/lib/ui/Collapsible.d.ts +5 -0
- package/dist/lib/ui/Collapsible.js +6 -0
- package/dist/lib/ui/Collapsible.js.map +1 -0
- package/dist/lib/ui/Command.d.ts +80 -0
- package/dist/lib/ui/Command.js +31 -0
- package/dist/lib/ui/Command.js.map +1 -0
- package/dist/lib/{components → ui}/Dialog.js +2 -2
- package/dist/lib/ui/Dialog.js.map +1 -0
- package/dist/lib/ui/Drawer.d.ts +8 -10
- package/dist/lib/ui/Drawer.js.map +1 -1
- package/dist/lib/ui/Form.d.ts +23 -0
- package/dist/lib/ui/Form.js +63 -0
- package/dist/lib/ui/Form.js.map +1 -0
- package/dist/lib/ui/HoverCard.d.ts +6 -0
- package/dist/lib/ui/HoverCard.js +10 -0
- package/dist/lib/ui/HoverCard.js.map +1 -0
- package/dist/lib/ui/Label.d.ts +5 -0
- package/dist/lib/ui/Label.js +10 -0
- package/dist/lib/ui/Label.js.map +1 -0
- package/dist/lib/ui/Pagination.d.ts +28 -0
- package/dist/lib/ui/Pagination.js +24 -0
- package/dist/lib/ui/Pagination.js.map +1 -0
- package/dist/lib/ui/Popover.d.ts +6 -0
- package/dist/lib/ui/Popover.js +10 -0
- package/dist/lib/ui/Popover.js.map +1 -0
- package/dist/lib/ui/Progress.d.ts +4 -0
- package/dist/lib/ui/Progress.js +8 -0
- package/dist/lib/ui/Progress.js.map +1 -0
- package/dist/lib/ui/RadioGroup.d.ts +5 -0
- package/dist/lib/ui/RadioGroup.js +15 -0
- package/dist/lib/ui/RadioGroup.js.map +1 -0
- package/dist/lib/ui/ScrollArea.d.ts +5 -0
- package/dist/lib/ui/ScrollArea.js +12 -0
- package/dist/lib/ui/ScrollArea.js.map +1 -0
- package/dist/lib/ui/Select.js.map +1 -0
- package/dist/lib/ui/Skeleton.d.ts +2 -0
- package/dist/lib/ui/Skeleton.js +7 -0
- package/dist/lib/ui/Skeleton.js.map +1 -0
- package/dist/lib/ui/Slider.d.ts +4 -0
- package/dist/lib/ui/Slider.js +8 -0
- package/dist/lib/ui/Slider.js.map +1 -0
- package/dist/lib/ui/Switch.d.ts +4 -0
- package/dist/lib/ui/Switch.js +8 -0
- package/dist/lib/ui/Switch.js.map +1 -0
- package/dist/lib/ui/Textarea.d.ts +4 -0
- package/dist/lib/ui/Textarea.js +9 -0
- package/dist/lib/ui/Textarea.js.map +1 -0
- package/dist/lib/ui/Toggle.d.ts +12 -0
- package/dist/lib/ui/Toggle.js +26 -0
- package/dist/lib/ui/Toggle.js.map +1 -0
- package/dist/lib/ui/ToggleGroup.d.ts +12 -0
- package/dist/lib/ui/ToggleGroup.js +21 -0
- package/dist/lib/ui/ToggleGroup.js.map +1 -0
- package/dist/lib/ui/Tooltip.d.ts +7 -0
- package/dist/lib/ui/Tooltip.js +11 -0
- package/dist/lib/ui/Tooltip.js.map +1 -0
- package/dist/lib/util/MdxComponents.d.ts +19 -20
- package/dist/lib/util/MdxComponents.js +1 -3
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/lib/util/createVariantComponent.d.ts +2 -2
- package/dist/lib/util/invariant.d.ts +9 -0
- package/dist/lib/util/invariant.js +7 -3
- package/dist/lib/util/invariant.js.map +1 -1
- package/dist/lib/util/traverse.d.ts +2 -0
- package/dist/lib/util/traverse.js +18 -0
- package/dist/lib/util/traverse.js.map +1 -0
- package/dist/lib/util/useExposedProps.d.ts +2 -0
- package/dist/lib/util/useExposedProps.js +9 -0
- package/dist/lib/util/useExposedProps.js.map +1 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.d.ts +3 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.js +4 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.js.map +1 -0
- package/dist/lib/util/useOnScreen.d.ts +4 -0
- package/dist/lib/util/useOnScreen.js +19 -0
- package/dist/lib/util/useOnScreen.js.map +1 -0
- package/dist/lib/util/useScrollToAnchor.js +1 -1
- package/dist/lib/util/useScrollToAnchor.js.map +1 -1
- package/dist/lib/util/useScrollToTop.js +1 -1
- package/dist/lib/util/useScrollToTop.js.map +1 -1
- package/dist/vite/build.js +26 -5
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.d.ts +6 -10
- package/dist/vite/config.js +91 -78
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/config.test.js +7 -5
- package/dist/vite/config.test.js.map +1 -1
- package/dist/vite/css/collect.d.ts +2 -0
- package/dist/vite/css/collect.js +27 -0
- package/dist/vite/css/collect.js.map +1 -0
- package/dist/vite/css/plugin.d.ts +5 -0
- package/dist/vite/css/plugin.js +79 -0
- package/dist/vite/css/plugin.js.map +1 -0
- package/dist/vite/debug.d.ts +1 -0
- package/dist/vite/debug.js +10 -0
- package/dist/vite/debug.js.map +1 -0
- package/dist/vite/dev-server.d.ts +7 -1
- package/dist/vite/dev-server.js +35 -8
- package/dist/vite/dev-server.js.map +1 -1
- package/dist/vite/html.js +0 -2
- package/dist/vite/html.js.map +1 -1
- package/dist/vite/output.d.ts +101 -0
- package/dist/vite/output.js +62 -0
- package/dist/vite/output.js.map +1 -0
- package/dist/vite/plugin-api.js +100 -20
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-component.js +17 -12
- package/dist/vite/plugin-component.js.map +1 -1
- package/dist/vite/plugin-config-reload.d.ts +1 -2
- package/dist/vite/plugin-config-reload.js +0 -2
- package/dist/vite/plugin-config-reload.js.map +1 -1
- package/dist/vite/plugin-config.d.ts +2 -3
- package/dist/vite/plugin-config.js +22 -3
- package/dist/vite/plugin-config.js.map +1 -1
- package/dist/vite/plugin-custom-pages.d.ts +4 -0
- package/dist/vite/plugin-custom-pages.js +30 -0
- package/dist/vite/plugin-custom-pages.js.map +1 -0
- package/dist/vite/plugin-docs.js +37 -26
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-docs.test.js +15 -23
- package/dist/vite/plugin-docs.test.js.map +1 -1
- package/dist/vite/plugin-frontmatter.d.ts +2 -1
- package/dist/vite/plugin-frontmatter.js +27 -24
- package/dist/vite/plugin-frontmatter.js.map +1 -1
- package/dist/vite/plugin-mdx.d.ts +0 -6
- package/dist/vite/plugin-mdx.js +80 -6
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/plugin-search.d.ts +3 -0
- package/dist/vite/plugin-search.js +26 -0
- package/dist/vite/plugin-search.js.map +1 -0
- package/dist/vite/plugin-sidebar.js +7 -6
- package/dist/vite/plugin-sidebar.js.map +1 -1
- package/dist/vite/{plugin-custom-css.d.ts → plugin-theme-css.d.ts} +2 -2
- package/dist/vite/plugin-theme-css.js +114 -0
- package/dist/vite/plugin-theme-css.js.map +1 -0
- package/dist/vite/plugin.d.ts +1 -2
- package/dist/vite/plugin.js +12 -6
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/prerender.d.ts +6 -1
- package/dist/vite/prerender.js +7 -5
- package/dist/vite/prerender.js.map +1 -1
- package/dist/vite/remarkStaticGeneration.d.ts +3 -0
- package/dist/vite/remarkStaticGeneration.js +125 -0
- package/dist/vite/remarkStaticGeneration.js.map +1 -0
- package/dist/vite/sitemap.d.ts +1 -1
- package/dist/zuplo/env.d.ts +6 -0
- package/dist/zuplo/env.js +9 -0
- package/dist/zuplo/env.js.map +1 -0
- package/dist/zuplo/with-zuplo.d.ts +3 -0
- package/dist/zuplo/with-zuplo.js +28 -0
- package/dist/zuplo/with-zuplo.js.map +1 -0
- package/lib/AnchorLink-DFZZbmvr.js +34 -0
- package/lib/AnchorLink-DFZZbmvr.js.map +1 -0
- package/lib/{AuthenticationPlugin-Bx9FK124.js → AuthenticationPlugin-DVLEc6cm.js} +23 -20
- package/lib/AuthenticationPlugin-DVLEc6cm.js.map +1 -0
- package/lib/Button-DeAoTouo.js +48 -0
- package/lib/Button-DeAoTouo.js.map +1 -0
- package/lib/CategoryHeading-CBconmtI.js +10 -0
- package/lib/{CategoryHeading-ovR-zHRq.js.map → CategoryHeading-CBconmtI.js.map} +1 -1
- package/lib/ClientOnly-E7hGysn1.js +11 -0
- package/lib/ClientOnly-E7hGysn1.js.map +1 -0
- package/lib/Dialog-Bxv1yEIg.js +67 -0
- package/lib/Dialog-Bxv1yEIg.js.map +1 -0
- package/lib/Markdown-CZDLNOFc.js +15202 -0
- package/lib/Markdown-CZDLNOFc.js.map +1 -0
- package/lib/MdxPage-DKMbBROv.js +188 -0
- package/lib/MdxPage-DKMbBROv.js.map +1 -0
- package/lib/OperationList-BKHUKlAL.js +5062 -0
- package/lib/OperationList-BKHUKlAL.js.map +1 -0
- package/lib/Route-DYwKZ_c_.js +35 -0
- package/lib/Route-DYwKZ_c_.js.map +1 -0
- package/lib/Select-B_IxRUUC.js +223 -0
- package/lib/Select-B_IxRUUC.js.map +1 -0
- package/lib/SlotletProvider-pfc9oejW.js +221 -0
- package/lib/SlotletProvider-pfc9oejW.js.map +1 -0
- package/lib/{Spinner-3cQDBVGr.js → Spinner-DuxJLLNE.js} +2 -2
- package/lib/{Spinner-3cQDBVGr.js.map → Spinner-DuxJLLNE.js.map} +1 -1
- package/lib/StaggeredRender-DgsamH_G.js +17 -0
- package/lib/StaggeredRender-DgsamH_G.js.map +1 -0
- package/lib/SyntaxHighlight-Bz-lOJtH.js +2979 -0
- package/lib/SyntaxHighlight-Bz-lOJtH.js.map +1 -0
- package/lib/ZudokuContext-hmLMUdf2.js +1217 -0
- package/lib/ZudokuContext-hmLMUdf2.js.map +1 -0
- package/lib/__vite-browser-external-BYRIRx8p.js +9 -0
- package/lib/__vite-browser-external-BYRIRx8p.js.map +1 -0
- package/lib/{index-CLd8ycZz.js → assets/index-C7jnHK4b.js} +1008 -957
- package/lib/assets/index-C7jnHK4b.js.map +1 -0
- package/lib/assets/{worker-Bcj4NA2p.js → worker-D2kRl-cG.js} +6035 -5375
- package/lib/assets/worker-D2kRl-cG.js.map +1 -0
- package/lib/chunk-D52XG6IA-Dl7HLe6j.js +1823 -0
- package/lib/chunk-D52XG6IA-Dl7HLe6j.js.map +1 -0
- package/lib/cn-qaFjX9_3.js +2279 -0
- package/lib/cn-qaFjX9_3.js.map +1 -0
- package/lib/context-h_UkBLvr.js +22 -0
- package/lib/context-h_UkBLvr.js.map +1 -0
- package/lib/createServer-69sLlmQA.js +15679 -0
- package/lib/createServer-69sLlmQA.js.map +1 -0
- package/lib/hook-CHq7pFyz.js +227 -0
- package/lib/hook-CHq7pFyz.js.map +1 -0
- package/lib/{assets/index-B9EWVYfo.js → index-CBXSgjaE.js} +1034 -983
- package/lib/index-CBXSgjaE.js.map +1 -0
- package/lib/index-CPNSgwSb.js +36 -0
- package/lib/index-CPNSgwSb.js.map +1 -0
- package/lib/index-CbrnMIak.js +1282 -0
- package/lib/index-CbrnMIak.js.map +1 -0
- package/lib/index-LNp6rxyU.js.map +1 -1
- package/lib/index.esm-BSV1C092.js +692 -0
- package/lib/index.esm-BSV1C092.js.map +1 -0
- package/lib/index.esm-BnnBRKJX.js +1214 -0
- package/lib/index.esm-BnnBRKJX.js.map +1 -0
- package/lib/invariant-Caa8-XvF.js +26 -0
- package/lib/invariant-Caa8-XvF.js.map +1 -0
- package/lib/jsx-runtime-Dx-03ztt.js +446 -0
- package/lib/jsx-runtime-Dx-03ztt.js.map +1 -0
- package/lib/object_hash-BNWPnMN9.js +787 -0
- package/lib/object_hash-BNWPnMN9.js.map +1 -0
- package/lib/post-processors/removeExtensions.js +11 -0
- package/lib/post-processors/removeExtensions.js.map +1 -0
- package/lib/post-processors/removePaths.js +28 -0
- package/lib/post-processors/removePaths.js.map +1 -0
- package/lib/post-processors/traverse.js +12 -0
- package/lib/post-processors/traverse.js.map +1 -0
- package/lib/prism-csharp.min-DUwvItt4.js +63 -0
- package/lib/{prism-csharp.min-Yizuc34Y.js.map → prism-csharp.min-DUwvItt4.js.map} +1 -1
- package/lib/prism-java.min-BtgBR4yd.js +35 -0
- package/lib/{prism-java.min-d5iT_mOd.js.map → prism-java.min-BtgBR4yd.js.map} +1 -1
- package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
- package/lib/prism-ruby.min-DeDXCp1r.js +38 -0
- package/lib/{prism-ruby.min-C7LwcKyz.js.map → prism-ruby.min-DeDXCp1r.js.map} +1 -1
- package/lib/prism-typescript.min-CD7H2IYQ.js +34 -0
- package/lib/{prism-typescript.min-oSVeWCAd.js.map → prism-typescript.min-CD7H2IYQ.js.map} +1 -1
- package/lib/state-CFQsUZUP.js +202 -0
- package/lib/state-CFQsUZUP.js.map +1 -0
- package/lib/ui/Accordion.js +47 -0
- package/lib/ui/Accordion.js.map +1 -0
- package/lib/ui/ActionButton.js +25 -0
- package/lib/ui/ActionButton.js.map +1 -0
- package/lib/ui/Alert.js +51 -0
- package/lib/ui/Alert.js.map +1 -0
- package/lib/ui/AlertDialog.js +114 -0
- package/lib/ui/AlertDialog.js.map +1 -0
- package/lib/ui/AspectRatio.js +6 -0
- package/lib/ui/AspectRatio.js.map +1 -0
- package/lib/ui/Badge.js +27 -0
- package/lib/ui/Badge.js.map +1 -0
- package/lib/ui/Breadcrumb.js +94 -0
- package/lib/ui/Breadcrumb.js.map +1 -0
- package/lib/ui/Button.js +49 -0
- package/lib/ui/Button.js.map +1 -0
- package/lib/ui/Callout.js +77 -0
- package/lib/ui/Callout.js.map +1 -0
- package/lib/ui/Card.js +62 -0
- package/lib/ui/Card.js.map +1 -0
- package/lib/ui/Carousel.js +1416 -0
- package/lib/ui/Carousel.js.map +1 -0
- package/lib/ui/Checkbox.js +28 -0
- package/lib/ui/Checkbox.js.map +1 -0
- package/lib/ui/Collapsible.js +8 -0
- package/lib/ui/Collapsible.js.map +1 -0
- package/lib/ui/Command.js +553 -0
- package/lib/ui/Command.js.map +1 -0
- package/lib/ui/Dialog.js +101 -0
- package/lib/ui/Dialog.js.map +1 -0
- package/lib/ui/Drawer.js +1153 -0
- package/lib/ui/Drawer.js.map +1 -0
- package/lib/ui/DropdownMenu.js +145 -0
- package/lib/ui/DropdownMenu.js.map +1 -0
- package/lib/ui/Form.js +95 -0
- package/lib/ui/Form.js.map +1 -0
- package/lib/ui/HoverCard.js +24 -0
- package/lib/ui/HoverCard.js.map +1 -0
- package/lib/ui/Input.js +22 -0
- package/lib/ui/Input.js.map +1 -0
- package/lib/ui/Label.js +20 -0
- package/lib/ui/Label.js.map +1 -0
- package/lib/ui/Pagination.js +106 -0
- package/lib/ui/Pagination.js.map +1 -0
- package/lib/ui/Popover.js +24 -0
- package/lib/ui/Popover.js.map +1 -0
- package/lib/ui/Progress.js +27 -0
- package/lib/ui/Progress.js.map +1 -0
- package/lib/ui/RadioGroup.js +32 -0
- package/lib/ui/RadioGroup.js.map +1 -0
- package/lib/ui/ScrollArea.js +39 -0
- package/lib/ui/ScrollArea.js.map +1 -0
- package/lib/ui/Select.js +122 -0
- package/lib/ui/Select.js.map +1 -0
- package/lib/ui/Skeleton.js +18 -0
- package/lib/ui/Skeleton.js.map +1 -0
- package/lib/ui/Slider.js +24 -0
- package/lib/ui/Slider.js.map +1 -0
- package/lib/ui/Switch.js +28 -0
- package/lib/ui/Switch.js.map +1 -0
- package/lib/ui/Tabs.js +47 -0
- package/lib/ui/Tabs.js.map +1 -0
- package/lib/ui/Textarea.js +21 -0
- package/lib/ui/Textarea.js.map +1 -0
- package/lib/ui/Toggle.js +38 -0
- package/lib/ui/Toggle.js.map +1 -0
- package/lib/ui/ToggleGroup.js +42 -0
- package/lib/ui/ToggleGroup.js.map +1 -0
- package/lib/ui/Tooltip.js +24 -0
- package/lib/ui/Tooltip.js.map +1 -0
- package/lib/useExposedProps-DE9lR6MF.js +9 -0
- package/lib/useExposedProps-DE9lR6MF.js.map +1 -0
- package/lib/zudoku.auth-auth0.js +24 -18
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +2 -2
- package/lib/zudoku.auth-clerk.js.map +1 -1
- package/lib/zudoku.auth-openid.js +620 -619
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +1064 -3006
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.openapi-worker.js +10 -16056
- package/lib/zudoku.openapi-worker.js.map +1 -1
- package/lib/zudoku.plugin-api-catalog.js +123 -0
- package/lib/zudoku.plugin-api-catalog.js.map +1 -0
- package/lib/zudoku.plugin-api-keys.js +72 -78
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +22 -0
- package/lib/zudoku.plugin-custom-pages.js.map +1 -0
- package/lib/zudoku.plugin-markdown.js +94 -27
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +7 -12
- package/lib/zudoku.plugin-openapi.js.map +1 -1
- package/lib/zudoku.plugin-redirect.js +2 -2
- package/lib/zudoku.plugin-redirect.js.map +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +53 -28
- package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
- package/package.json +135 -87
- package/src/app/demo.tsx +1 -4
- package/src/app/entry.client.tsx +20 -3
- package/src/app/entry.server.tsx +63 -52
- package/src/app/main.css +5 -2
- package/src/app/main.tsx +24 -38
- package/src/app/sentry.ts +24 -0
- package/src/app/standalone.tsx +2 -5
- package/src/app/tailwind.ts +67 -52
- package/src/lib/authentication/AuthenticationPlugin.tsx +4 -1
- package/src/lib/authentication/authentication.ts +3 -3
- package/src/lib/authentication/components/CallbackHandler.tsx +20 -51
- package/src/lib/authentication/components/SignIn.tsx +1 -1
- package/src/lib/authentication/components/SignOut.tsx +1 -1
- package/src/lib/authentication/hook.ts +1 -3
- package/src/lib/authentication/providers/auth0.tsx +17 -11
- package/src/lib/authentication/providers/openid.tsx +22 -33
- package/src/lib/authentication/state.ts +50 -9
- package/{LICENSE.md → src/lib/authentication/use-broadcast/LICENSE.md} +2 -2
- package/src/lib/authentication/use-broadcast/shared.ts +372 -0
- package/src/lib/authentication/use-broadcast/useBroadcast.ts +146 -0
- package/src/lib/components/AnchorLink.tsx +1 -1
- package/src/lib/components/Banner.tsx +12 -2
- package/src/lib/components/Bootstrap.tsx +36 -16
- package/src/lib/components/ClientOnly.tsx +6 -3
- package/src/lib/components/DeveloperHint.tsx +6 -1
- package/src/lib/components/ErrorPage.tsx +0 -2
- package/src/lib/components/Header.tsx +91 -46
- package/src/lib/components/Heading.tsx +13 -13
- package/src/lib/components/Layout.tsx +56 -38
- package/src/lib/components/Markdown.tsx +1 -1
- package/src/lib/components/MobileTopNavigation.tsx +31 -26
- package/src/lib/components/NotFoundPage.tsx +1 -1
- package/src/lib/components/ReactMarkdown.license.txt +21 -0
- package/src/lib/components/ReactMarkdown.tsx +264 -0
- package/src/lib/components/Search.tsx +4 -4
- package/src/lib/components/SlotletProvider.tsx +29 -4
- package/src/lib/components/SyntaxHighlight.tsx +85 -50
- package/src/lib/components/ThemeSwitch.tsx +26 -0
- package/src/lib/components/TopNavigation.tsx +78 -23
- package/src/lib/components/Zudoku.tsx +108 -0
- package/src/lib/components/context/ZudokuContext.ts +33 -30
- package/src/lib/components/context/ZudokuProvider.tsx +2 -2
- package/src/lib/components/index.ts +19 -7
- package/src/lib/components/navigation/Sidebar.tsx +22 -12
- package/src/lib/components/navigation/SidebarBadge.tsx +0 -10
- package/src/lib/components/navigation/SidebarCategory.tsx +39 -32
- package/src/lib/components/navigation/SidebarItem.tsx +24 -30
- package/src/lib/components/navigation/SidebarWrapper.tsx +1 -1
- package/src/lib/components/navigation/utils.ts +12 -17
- package/src/lib/core/{DevPortalContext.ts → ZudokuContext.ts} +7 -14
- package/src/lib/core/plugins.ts +19 -17
- package/src/lib/errors/ErrorAlert.tsx +20 -6
- package/src/lib/errors/RouterError.tsx +1 -1
- package/src/lib/oas/graphql/index.ts +11 -16
- package/src/lib/oas/parser/upgrade/index.ts +3 -24
- package/src/lib/plugins/api-catalog/Catalog.tsx +123 -0
- package/src/lib/plugins/api-catalog/index.tsx +64 -0
- package/src/lib/plugins/api-keys/CreateApiKey.tsx +3 -3
- package/src/lib/plugins/api-keys/ProtectedRoute.tsx +1 -1
- package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +1 -1
- package/src/lib/plugins/api-keys/index.tsx +13 -10
- package/src/lib/plugins/custom-pages/CustomPage.tsx +18 -0
- package/src/lib/plugins/custom-pages/index.tsx +24 -0
- package/src/lib/plugins/markdown/MdxPage.tsx +38 -10
- package/src/lib/plugins/markdown/index.tsx +53 -13
- package/src/lib/plugins/markdown/resolver.ts +90 -0
- package/src/lib/plugins/openapi/CollapsibleCode.tsx +80 -0
- package/src/lib/plugins/openapi/ColorizedParam.tsx +23 -14
- package/src/lib/plugins/openapi/Endpoint.tsx +7 -12
- package/src/lib/plugins/openapi/OperationList.tsx +81 -45
- package/src/lib/plugins/openapi/OperationListItem.tsx +31 -2
- package/src/lib/plugins/openapi/ParameterListItem.tsx +37 -31
- package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +18 -13
- package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +17 -12
- package/src/lib/plugins/openapi/Route.tsx +42 -12
- package/src/lib/plugins/openapi/Sidecar.tsx +75 -75
- package/src/lib/plugins/openapi/client/GraphQLClient.tsx +157 -0
- package/src/lib/plugins/openapi/client/GraphQLContext.tsx +16 -0
- package/src/lib/plugins/openapi/client/createServer.ts +2 -0
- package/src/lib/plugins/openapi/client/useCreateQuery.ts +33 -0
- package/src/lib/plugins/openapi/client/worker.ts +38 -24
- package/src/lib/plugins/openapi/context.tsx +2 -2
- package/src/lib/plugins/openapi/graphql/fragment-masking.ts +11 -18
- package/src/lib/plugins/openapi/graphql/gql.ts +12 -29
- package/src/lib/plugins/openapi/graphql/graphql.ts +236 -665
- package/src/lib/plugins/openapi/index.tsx +77 -97
- package/src/lib/plugins/openapi/interfaces.ts +22 -1
- package/src/lib/plugins/openapi/playground/PathParams.tsx +1 -0
- package/src/lib/plugins/openapi/playground/Playground.tsx +5 -4
- package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +1 -1
- package/src/lib/plugins/openapi/playground/ResponseTab.tsx +0 -1
- package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +144 -0
- package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +24 -0
- package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +126 -0
- package/src/lib/plugins/openapi/post-processors/removePaths.ts +55 -0
- package/src/lib/plugins/openapi/post-processors/traverse.ts +1 -0
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +5 -2
- package/src/lib/plugins/openapi/util/generateSchemaExample.ts +28 -42
- package/src/lib/plugins/openapi/util/methodToColor.ts +27 -0
- package/src/lib/plugins/openapi/util/sanitizeMarkdownForMetatag.tsx +32 -0
- package/src/lib/plugins/openapi-worker.ts +11 -1
- package/src/lib/plugins/redirect/index.tsx +6 -10
- package/src/lib/plugins/search-inkeep/index.tsx +80 -25
- package/src/lib/plugins/search-inkeep/inkeep.ts +3 -9
- package/src/lib/ui/Accordion.tsx +56 -0
- package/src/lib/ui/ActionButton.tsx +28 -0
- package/src/lib/ui/{Note.tsx → Alert.tsx} +11 -10
- package/src/lib/ui/AlertDialog.tsx +139 -0
- package/src/lib/ui/AspectRatio.tsx +5 -0
- package/src/lib/ui/Badge.tsx +36 -0
- package/src/lib/ui/Breadcrumb.tsx +115 -0
- package/src/lib/ui/Button.tsx +1 -1
- package/src/lib/ui/Callout.tsx +7 -6
- package/src/lib/ui/Carousel.tsx +260 -0
- package/src/lib/ui/Checkbox.tsx +28 -0
- package/src/lib/ui/Collapsible.tsx +9 -0
- package/src/lib/ui/Command.tsx +151 -0
- package/src/lib/{components → ui}/Dialog.tsx +4 -3
- package/src/lib/ui/Drawer.tsx +38 -36
- package/src/lib/ui/Form.tsx +177 -0
- package/src/lib/ui/HoverCard.tsx +27 -0
- package/src/lib/ui/Label.tsx +24 -0
- package/src/lib/ui/Pagination.tsx +117 -0
- package/src/lib/ui/Popover.tsx +29 -0
- package/src/lib/ui/Progress.tsx +26 -0
- package/src/lib/ui/RadioGroup.tsx +42 -0
- package/src/lib/ui/ScrollArea.tsx +46 -0
- package/src/lib/ui/Skeleton.tsx +15 -0
- package/src/lib/ui/Slider.tsx +26 -0
- package/src/lib/ui/Switch.tsx +27 -0
- package/src/lib/ui/Textarea.tsx +23 -0
- package/src/lib/ui/Toggle.tsx +43 -0
- package/src/lib/ui/ToggleGroup.tsx +59 -0
- package/src/lib/ui/Tooltip.tsx +28 -0
- package/src/lib/util/MdxComponents.tsx +3 -9
- package/src/lib/util/createVariantComponent.tsx +2 -2
- package/src/lib/util/invariant.ts +15 -3
- package/src/lib/util/traverse.ts +25 -0
- package/src/lib/util/useExposedProps.tsx +16 -0
- package/src/lib/util/useIsomorphicLayoutEffect.ts +5 -0
- package/src/lib/util/useOnScreen.ts +32 -0
- package/src/lib/util/useScrollToAnchor.ts +2 -2
- package/src/lib/util/useScrollToTop.ts +1 -1
- package/dist/internal.d.ts +0 -1
- package/dist/internal.js +0 -2
- package/dist/internal.js.map +0 -1
- package/dist/lib/components/DevPortal.js.map +0 -1
- package/dist/lib/components/Dialog.js.map +0 -1
- package/dist/lib/components/Select.js.map +0 -1
- package/dist/lib/components/context/ThemeContext.d.ts +0 -2
- package/dist/lib/components/context/ThemeContext.js +0 -7
- package/dist/lib/components/context/ThemeContext.js.map +0 -1
- package/dist/lib/components/context/ThemeProvider.d.ts +0 -4
- package/dist/lib/components/context/ThemeProvider.js +0 -23
- package/dist/lib/components/context/ThemeProvider.js.map +0 -1
- package/dist/lib/core/DevPortalContext.js.map +0 -1
- package/dist/lib/plugins/custom-page/index.d.ts +0 -8
- package/dist/lib/plugins/custom-page/index.js +0 -12
- package/dist/lib/plugins/custom-page/index.js.map +0 -1
- package/dist/lib/plugins/markdown/generateRoutes.d.ts +0 -3
- package/dist/lib/plugins/markdown/generateRoutes.js +0 -21
- package/dist/lib/plugins/markdown/generateRoutes.js.map +0 -1
- package/dist/lib/plugins/openapi/client/createMemoryClient.d.ts +0 -12
- package/dist/lib/plugins/openapi/client/createMemoryClient.js +0 -46
- package/dist/lib/plugins/openapi/client/createMemoryClient.js.map +0 -1
- package/dist/lib/plugins/openapi/client/createWorkerClient.d.ts +0 -10
- package/dist/lib/plugins/openapi/client/createWorkerClient.js +0 -61
- package/dist/lib/plugins/openapi/client/createWorkerClient.js.map +0 -1
- package/dist/lib/plugins/openapi/client/interfaces.d.ts +0 -4
- package/dist/lib/plugins/openapi/client/interfaces.js +0 -2
- package/dist/lib/plugins/openapi/client/interfaces.js.map +0 -1
- package/dist/lib/plugins/openapi/playground/Editor.d.ts +0 -1
- package/dist/lib/plugins/openapi/playground/Editor.js +0 -5
- package/dist/lib/plugins/openapi/playground/Editor.js.map +0 -1
- package/dist/lib/plugins/openapi/util/urql.d.ts +0 -7
- package/dist/lib/plugins/openapi/util/urql.js +0 -8
- package/dist/lib/plugins/openapi/util/urql.js.map +0 -1
- package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.d.ts +0 -2
- package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js +0 -3
- package/dist/lib/plugins/search-inkeep/InkeepCustomTrigger.js.map +0 -1
- package/dist/lib/themeToggle.d.ts +0 -1
- package/dist/lib/themeToggle.js +0 -7
- package/dist/lib/themeToggle.js.map +0 -1
- package/dist/lib/ui/Note.d.ts +0 -8
- package/dist/lib/ui/Note.js +0 -23
- package/dist/lib/ui/Note.js.map +0 -1
- package/dist/lib/util/createWaitForNotify.d.ts +0 -1
- package/dist/lib/util/createWaitForNotify.js +0 -15
- package/dist/lib/util/createWaitForNotify.js.map +0 -1
- package/dist/vite/plugin-custom-css.js +0 -55
- package/dist/vite/plugin-custom-css.js.map +0 -1
- package/dist/vite/plugin-html-transform.d.ts +0 -2
- package/dist/vite/plugin-html-transform.js +0 -15
- package/dist/vite/plugin-html-transform.js.map +0 -1
- package/lib/AuthenticationPlugin-Bx9FK124.js.map +0 -1
- package/lib/CategoryHeading-ovR-zHRq.js +0 -10
- package/lib/DeveloperHint-YeWHKvyr.js +0 -16
- package/lib/DeveloperHint-YeWHKvyr.js.map +0 -1
- package/lib/ErrorPage-Dri5_2lr.js +0 -18
- package/lib/ErrorPage-Dri5_2lr.js.map +0 -1
- package/lib/InkeepCustomTrigger-CE5-K5ex.js +0 -6
- package/lib/InkeepCustomTrigger-CE5-K5ex.js.map +0 -1
- package/lib/Input-CtVUl3eT.js +0 -2198
- package/lib/Input-CtVUl3eT.js.map +0 -1
- package/lib/Markdown-DapSf3wG.js +0 -20281
- package/lib/Markdown-DapSf3wG.js.map +0 -1
- package/lib/MdxPage-BqBWsXZ1.js +0 -172
- package/lib/MdxPage-BqBWsXZ1.js.map +0 -1
- package/lib/OperationList-JAQF5-tn.js +0 -602
- package/lib/OperationList-JAQF5-tn.js.map +0 -1
- package/lib/Route-DSANUy5e.js +0 -14
- package/lib/Route-DSANUy5e.js.map +0 -1
- package/lib/SidebarBadge-Dx7jtnoA.js +0 -498
- package/lib/SidebarBadge-Dx7jtnoA.js.map +0 -1
- package/lib/SlotletProvider-D3UD5Go3.js +0 -238
- package/lib/SlotletProvider-D3UD5Go3.js.map +0 -1
- package/lib/ZudokuContext-cr-pTRY1.js +0 -1084
- package/lib/ZudokuContext-cr-pTRY1.js.map +0 -1
- package/lib/assets/index-B9EWVYfo.js.map +0 -1
- package/lib/assets/worker-Bcj4NA2p.js.map +0 -1
- package/lib/index-BG0g4WW0.js +0 -1771
- package/lib/index-BG0g4WW0.js.map +0 -1
- package/lib/index-BngPzhKn.js +0 -124
- package/lib/index-BngPzhKn.js.map +0 -1
- package/lib/index-CLd8ycZz.js.map +0 -1
- package/lib/index-Dolisrci.js +0 -2814
- package/lib/index-Dolisrci.js.map +0 -1
- package/lib/index-DyJyULzS.js +0 -5816
- package/lib/index-DyJyULzS.js.map +0 -1
- package/lib/joinPath-B7kNnUX4.js +0 -8
- package/lib/joinPath-B7kNnUX4.js.map +0 -1
- package/lib/jsx-runtime-B6kdoens.js +0 -635
- package/lib/jsx-runtime-B6kdoens.js.map +0 -1
- package/lib/prism-csharp.min-Yizuc34Y.js +0 -35
- package/lib/prism-java.min-d5iT_mOd.js +0 -7
- package/lib/prism-markup-templating-DZrrEs0A.js +0 -62
- package/lib/prism-markup-templating-DZrrEs0A.js.map +0 -1
- package/lib/prism-php.min-o7FpoMP_.js +0 -11
- package/lib/prism-php.min-o7FpoMP_.js.map +0 -1
- package/lib/prism-ruby.min-C7LwcKyz.js +0 -10
- package/lib/prism-typescript.min-oSVeWCAd.js +0 -6
- package/lib/router-D2p7Olpn.js +0 -2971
- package/lib/router-D2p7Olpn.js.map +0 -1
- package/lib/state-hNe1dw4B.js +0 -548
- package/lib/state-hNe1dw4B.js.map +0 -1
- package/lib/urql-YhcsXYy8.js +0 -1591
- package/lib/urql-YhcsXYy8.js.map +0 -1
- package/lib/utils-ByIc_KIM.js +0 -749
- package/lib/utils-ByIc_KIM.js.map +0 -1
- package/lib/zudoku.plugin-custom-page.js +0 -13
- package/lib/zudoku.plugin-custom-page.js.map +0 -1
- package/src/lib/components/DevPortal.tsx +0 -111
- package/src/lib/components/context/ThemeContext.tsx +0 -8
- package/src/lib/components/context/ThemeProvider.tsx +0 -27
- package/src/lib/plugins/custom-page/index.tsx +0 -22
- package/src/lib/plugins/markdown/generateRoutes.tsx +0 -38
- package/src/lib/plugins/openapi/client/createMemoryClient.ts +0 -56
- package/src/lib/plugins/openapi/client/createWorkerClient.ts +0 -80
- package/src/lib/plugins/openapi/client/interfaces.ts +0 -5
- package/src/lib/plugins/openapi/playground/Editor.tsx +0 -4
- package/src/lib/plugins/openapi/util/urql.ts +0 -8
- package/src/lib/plugins/search-inkeep/InkeepCustomTrigger.tsx +0 -3
- package/src/lib/themeToggle.ts +0 -7
- package/src/lib/util/createWaitForNotify.ts +0 -18
- /package/dist/lib/{components → ui}/Dialog.d.ts +0 -0
- /package/dist/lib/{components → ui}/Select.d.ts +0 -0
- /package/dist/lib/{components → ui}/Select.js +0 -0
- /package/src/lib/{components → ui}/Select.tsx +0 -0
|
@@ -1,30 +1,23 @@
|
|
|
1
|
-
import { matchPath
|
|
2
|
-
import { type
|
|
1
|
+
import { matchPath } from "react-router";
|
|
2
|
+
import { type ZudokuPlugin } from "../../core/plugins.js";
|
|
3
3
|
import { graphql } from "./graphql/index.js";
|
|
4
|
-
import {
|
|
5
|
-
Client as UrqlClient,
|
|
6
|
-
cacheExchange,
|
|
7
|
-
fetchExchange,
|
|
8
|
-
} from "./util/urql.js";
|
|
9
4
|
|
|
10
5
|
import { useQuery } from "@tanstack/react-query";
|
|
11
6
|
import { CirclePlayIcon, LogInIcon } from "lucide-react";
|
|
12
|
-
import { createClient } from "zudoku/openapi-worker";
|
|
13
7
|
import type { SidebarItem } from "../../../config/validators/SidebarSchema.js";
|
|
14
8
|
import { useAuth } from "../../authentication/hook.js";
|
|
15
|
-
import { ErrorPage } from "../../components/ErrorPage.js";
|
|
16
9
|
import { ColorMap } from "../../components/navigation/SidebarBadge.js";
|
|
17
|
-
import { SyntaxHighlight } from "../../components/SyntaxHighlight.js";
|
|
18
10
|
import { Button } from "../../ui/Button.js";
|
|
19
11
|
import { joinPath } from "../../util/joinPath.js";
|
|
12
|
+
import { GraphQLClient } from "./client/GraphQLClient.js";
|
|
20
13
|
import { OasPluginConfig } from "./interfaces.js";
|
|
21
14
|
import type { PlaygroundContentProps } from "./playground/Playground.js";
|
|
22
15
|
import { PlaygroundDialog } from "./playground/PlaygroundDialog.js";
|
|
23
|
-
import { GetServerQuery } from "./Sidecar.js";
|
|
24
16
|
|
|
25
17
|
const GetCategoriesQuery = graphql(`
|
|
26
18
|
query GetCategories($input: JSON!, $type: SchemaType!) {
|
|
27
19
|
schema(input: $input, type: $type) {
|
|
20
|
+
url
|
|
28
21
|
tags {
|
|
29
22
|
__typename
|
|
30
23
|
name
|
|
@@ -42,20 +35,6 @@ const GetCategoriesQuery = graphql(`
|
|
|
42
35
|
}
|
|
43
36
|
`);
|
|
44
37
|
|
|
45
|
-
const OpenApiErrorPage = () => {
|
|
46
|
-
const error = useRouteError();
|
|
47
|
-
const message =
|
|
48
|
-
error instanceof Error ? (
|
|
49
|
-
<SyntaxHighlight code={error.message} />
|
|
50
|
-
) : (
|
|
51
|
-
"An unknown error occurred"
|
|
52
|
-
);
|
|
53
|
-
|
|
54
|
-
return (
|
|
55
|
-
<ErrorPage category="Error" title="An error occurred" message={message} />
|
|
56
|
-
);
|
|
57
|
-
};
|
|
58
|
-
|
|
59
38
|
type InternalOasPluginConfig = { inMemory?: boolean };
|
|
60
39
|
|
|
61
40
|
const MethodColorMap: Record<string, keyof typeof ColorMap> = {
|
|
@@ -70,17 +49,12 @@ const MethodColorMap: Record<string, keyof typeof ColorMap> = {
|
|
|
70
49
|
|
|
71
50
|
export type OpenApiPluginOptions = OasPluginConfig & InternalOasPluginConfig;
|
|
72
51
|
|
|
73
|
-
export const openApiPlugin = (
|
|
74
|
-
config: OpenApiPluginOptions,
|
|
75
|
-
): DevPortalPlugin => {
|
|
52
|
+
export const openApiPlugin = (config: OpenApiPluginOptions): ZudokuPlugin => {
|
|
76
53
|
const basePath = joinPath(config.navigationId ?? "/reference");
|
|
77
54
|
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
exchanges: [cacheExchange, fetchExchange],
|
|
82
|
-
})
|
|
83
|
-
: createClient({ useMemoryClient: config.inMemory ?? false });
|
|
55
|
+
const versions = config.type === "file" ? Object.keys(config.input) : [];
|
|
56
|
+
|
|
57
|
+
const client = new GraphQLClient(config);
|
|
84
58
|
|
|
85
59
|
return {
|
|
86
60
|
getHead: () => {
|
|
@@ -108,15 +82,13 @@ export const openApiPlugin = (
|
|
|
108
82
|
...props
|
|
109
83
|
}: Partial<PlaygroundContentProps> & { requireAuth: boolean }) => {
|
|
110
84
|
const auth = useAuth();
|
|
85
|
+
// We don't have the GraphQL context here
|
|
111
86
|
const serverQuery = useQuery({
|
|
112
|
-
queryFn:
|
|
113
|
-
|
|
87
|
+
queryFn: () =>
|
|
88
|
+
client.fetch(GetCategoriesQuery, {
|
|
114
89
|
type: config.type,
|
|
115
90
|
input: config.input,
|
|
116
|
-
})
|
|
117
|
-
|
|
118
|
-
return result.data;
|
|
119
|
-
},
|
|
91
|
+
}),
|
|
120
92
|
enabled: !server,
|
|
121
93
|
queryKey: ["playground-server"],
|
|
122
94
|
});
|
|
@@ -154,66 +126,74 @@ export const openApiPlugin = (
|
|
|
154
126
|
return [];
|
|
155
127
|
}
|
|
156
128
|
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
type: "category",
|
|
168
|
-
label: tag.name || "Other endpoints",
|
|
169
|
-
collapsible: true,
|
|
170
|
-
collapsed: false,
|
|
171
|
-
items: tag.operations.map((operation) => ({
|
|
172
|
-
type: "link",
|
|
173
|
-
label: operation.summary ?? operation.path,
|
|
174
|
-
href: `#${operation.slug}`,
|
|
175
|
-
badge: {
|
|
176
|
-
label: operation.method,
|
|
177
|
-
color: MethodColorMap[operation.method.toLowerCase()],
|
|
178
|
-
},
|
|
179
|
-
})),
|
|
180
|
-
}));
|
|
129
|
+
try {
|
|
130
|
+
const version =
|
|
131
|
+
versions.find((v) => path === joinPath(basePath, v)) ??
|
|
132
|
+
Object.keys(config.input).at(0);
|
|
133
|
+
|
|
134
|
+
const data = await client.fetch(GetCategoriesQuery, {
|
|
135
|
+
type: config.type,
|
|
136
|
+
input: config.type === "file" ? config.input[version!] : config.input,
|
|
137
|
+
version,
|
|
138
|
+
});
|
|
181
139
|
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
140
|
+
const categories = data.schema.tags
|
|
141
|
+
.filter((tag) => tag.operations.length > 0)
|
|
142
|
+
.map<SidebarItem>((tag) => ({
|
|
143
|
+
type: "category",
|
|
144
|
+
label: tag.name || "Other endpoints",
|
|
145
|
+
collapsible: true,
|
|
146
|
+
collapsed: false,
|
|
147
|
+
items: tag.operations.map((operation) => ({
|
|
148
|
+
type: "link",
|
|
149
|
+
label: operation.summary ?? operation.path,
|
|
150
|
+
href: `#${operation.slug}`,
|
|
151
|
+
badge: {
|
|
152
|
+
label: operation.method,
|
|
153
|
+
color: MethodColorMap[operation.method.toLowerCase()]!,
|
|
154
|
+
},
|
|
155
|
+
})),
|
|
156
|
+
}));
|
|
157
|
+
|
|
158
|
+
categories.unshift({
|
|
159
|
+
type: "link",
|
|
160
|
+
label: "Overview",
|
|
161
|
+
href: "#description",
|
|
162
|
+
});
|
|
187
163
|
|
|
188
|
-
|
|
164
|
+
return categories;
|
|
165
|
+
} catch {
|
|
166
|
+
return [];
|
|
167
|
+
}
|
|
189
168
|
},
|
|
190
|
-
getRoutes: () =>
|
|
191
|
-
[
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
const { OperationList } = await import(
|
|
208
|
-
"./OperationList.js"
|
|
209
|
-
);
|
|
210
|
-
return { element: <OperationList /> };
|
|
211
|
-
},
|
|
212
|
-
},
|
|
213
|
-
],
|
|
214
|
-
},
|
|
215
|
-
],
|
|
169
|
+
getRoutes: () => {
|
|
170
|
+
const versionsInPath = [null, ...versions];
|
|
171
|
+
|
|
172
|
+
return versionsInPath.map((version) => ({
|
|
173
|
+
path: basePath + (version ? `/${version}` : ""),
|
|
174
|
+
async lazy() {
|
|
175
|
+
const { OpenApiRoute } = await import("./Route.js");
|
|
176
|
+
return {
|
|
177
|
+
element: (
|
|
178
|
+
<OpenApiRoute
|
|
179
|
+
basePath={basePath}
|
|
180
|
+
versions={versions}
|
|
181
|
+
client={client}
|
|
182
|
+
config={config}
|
|
183
|
+
/>
|
|
184
|
+
),
|
|
185
|
+
};
|
|
216
186
|
},
|
|
217
|
-
|
|
187
|
+
children: [
|
|
188
|
+
{
|
|
189
|
+
index: true,
|
|
190
|
+
async lazy() {
|
|
191
|
+
const { OperationList } = await import("./OperationList.js");
|
|
192
|
+
return { element: <OperationList /> };
|
|
193
|
+
},
|
|
194
|
+
},
|
|
195
|
+
],
|
|
196
|
+
}));
|
|
197
|
+
},
|
|
218
198
|
};
|
|
219
199
|
};
|
|
@@ -1,6 +1,19 @@
|
|
|
1
1
|
type OasSource =
|
|
2
2
|
| { type: "url"; input: string }
|
|
3
|
-
| {
|
|
3
|
+
| {
|
|
4
|
+
type: "file";
|
|
5
|
+
input: {
|
|
6
|
+
[version: string]: () => Promise<unknown>;
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
| { type: "raw"; input: string };
|
|
10
|
+
|
|
11
|
+
export type ContextOasSource =
|
|
12
|
+
| { type: "url"; input: string }
|
|
13
|
+
| {
|
|
14
|
+
type: "file";
|
|
15
|
+
input: () => Promise<unknown>;
|
|
16
|
+
}
|
|
4
17
|
| { type: "raw"; input: string };
|
|
5
18
|
|
|
6
19
|
export type OasPluginConfig = {
|
|
@@ -8,3 +21,11 @@ export type OasPluginConfig = {
|
|
|
8
21
|
navigationId?: string;
|
|
9
22
|
skipPreload?: boolean;
|
|
10
23
|
} & OasSource;
|
|
24
|
+
|
|
25
|
+
export type OasPluginContext = {
|
|
26
|
+
server?: string;
|
|
27
|
+
navigationId?: string;
|
|
28
|
+
skipPreload?: boolean;
|
|
29
|
+
version?: string;
|
|
30
|
+
versions: Record<string, string>;
|
|
31
|
+
} & ContextOasSource;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { useMutation } from "@tanstack/react-query";
|
|
2
2
|
import { Fragment, useEffect, useRef, useTransition } from "react";
|
|
3
3
|
import { FormProvider, useForm } from "react-hook-form";
|
|
4
|
-
import { useSelectedServerStore } from "../../../authentication/state.js";
|
|
5
|
-
import { useApiIdentities } from "../../../components/context/ZudokuContext.js";
|
|
6
4
|
import {
|
|
7
5
|
Select,
|
|
8
6
|
SelectContent,
|
|
9
7
|
SelectItem,
|
|
10
8
|
SelectTrigger,
|
|
11
9
|
SelectValue,
|
|
12
|
-
} from "
|
|
10
|
+
} from "zudoku/ui/Select.js";
|
|
11
|
+
import { useSelectedServerStore } from "../../../authentication/state.js";
|
|
12
|
+
import { useApiIdentities } from "../../../components/context/ZudokuContext.js";
|
|
13
13
|
import { Spinner } from "../../../components/Spinner.js";
|
|
14
14
|
import { Button } from "../../../ui/Button.js";
|
|
15
15
|
import { Callout } from "../../../ui/Callout.js";
|
|
@@ -129,6 +129,7 @@ export const Playground = ({
|
|
|
129
129
|
.filter((h) => h.name)
|
|
130
130
|
.map((header) => [header.name, header.value]),
|
|
131
131
|
),
|
|
132
|
+
body: data.body ? data.body : undefined,
|
|
132
133
|
});
|
|
133
134
|
|
|
134
135
|
if (data.identity !== NO_IDENTITY) {
|
|
@@ -330,7 +331,7 @@ export const Playground = ({
|
|
|
330
331
|
</TabsContent>
|
|
331
332
|
</Tabs>
|
|
332
333
|
</div>
|
|
333
|
-
<div className="p-8 bg-muted/70">
|
|
334
|
+
<div className="min-w-0 p-8 bg-muted/70">
|
|
334
335
|
{queryMutation.error ? (
|
|
335
336
|
<div className="flex flex-col gap-2">
|
|
336
337
|
{formState.pathParams.some((p) => p.value === "") && (
|
|
@@ -5,7 +5,7 @@ import {
|
|
|
5
5
|
DialogContent,
|
|
6
6
|
DialogTitle,
|
|
7
7
|
DialogTrigger,
|
|
8
|
-
} from "
|
|
8
|
+
} from "zudoku/ui/Dialog.js";
|
|
9
9
|
import { Playground, type PlaygroundContentProps } from "./Playground.js";
|
|
10
10
|
|
|
11
11
|
export type PlaygroundDialogProps = PropsWithChildren<PlaygroundContentProps>;
|
|
@@ -54,7 +54,6 @@ export const ResponseTab = ({
|
|
|
54
54
|
view === "raw" ? (jsonContent ? "plain" : detectedLanguage) : "json"
|
|
55
55
|
}
|
|
56
56
|
noBackground
|
|
57
|
-
showLanguageIndicator
|
|
58
57
|
// playground dialog has h-5/6 ≈ 83.333vh
|
|
59
58
|
className="overflow-x-auto p-4 text-xs max-h-[calc(83.333vh-180px)]"
|
|
60
59
|
code={view === "raw" ? body : beautifiedBody}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { removeExtensions } from "./removeExtensions.js";
|
|
3
|
+
|
|
4
|
+
const baseDoc = {
|
|
5
|
+
openapi: "3.1.0",
|
|
6
|
+
"x-root-ext": "remove me",
|
|
7
|
+
info: {
|
|
8
|
+
title: "Test API",
|
|
9
|
+
version: "1.0.0",
|
|
10
|
+
"x-info-ext": "remove me",
|
|
11
|
+
},
|
|
12
|
+
paths: {
|
|
13
|
+
"/test": {
|
|
14
|
+
"x-path-ext": "remove me",
|
|
15
|
+
parameters: [
|
|
16
|
+
{
|
|
17
|
+
name: "param1",
|
|
18
|
+
in: "query",
|
|
19
|
+
schema: { type: "string" },
|
|
20
|
+
"x-param-ext": "remove me",
|
|
21
|
+
},
|
|
22
|
+
],
|
|
23
|
+
get: {
|
|
24
|
+
"x-operation-ext": "remove me",
|
|
25
|
+
responses: {
|
|
26
|
+
"200": {
|
|
27
|
+
description: "OK",
|
|
28
|
+
"x-response-ext": "remove me",
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
parameters: [
|
|
32
|
+
{
|
|
33
|
+
name: "opParam1",
|
|
34
|
+
in: "header",
|
|
35
|
+
schema: { type: "string" },
|
|
36
|
+
"x-op-param-ext": "remove me",
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
tags: [
|
|
43
|
+
{
|
|
44
|
+
name: "example",
|
|
45
|
+
"x-tag-ext": "remove me",
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
components: {
|
|
49
|
+
securitySchemes: {
|
|
50
|
+
ApiKeyAuth: {
|
|
51
|
+
type: "apiKey",
|
|
52
|
+
name: "api_key",
|
|
53
|
+
in: "header",
|
|
54
|
+
"x-security-ext": "remove me",
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
describe("removeExtensions", () => {
|
|
61
|
+
it("removes all x- extensions by default", () => {
|
|
62
|
+
const processed = removeExtensions()(baseDoc);
|
|
63
|
+
|
|
64
|
+
const removedExtensions = [
|
|
65
|
+
"x-root-ext",
|
|
66
|
+
"info.x-info-ext",
|
|
67
|
+
"paths./test.x-path-ext",
|
|
68
|
+
"paths./test.parameters[0].x-param-ext",
|
|
69
|
+
"paths./test.get.x-operation-ext",
|
|
70
|
+
"paths./test.get.responses.200.x-response-ext",
|
|
71
|
+
"paths./test.get.parameters[0].x-op-param-ext",
|
|
72
|
+
"tags[0].x-tag-ext",
|
|
73
|
+
"components.securitySchemes.ApiKeyAuth.x-security-ext",
|
|
74
|
+
];
|
|
75
|
+
|
|
76
|
+
removedExtensions.forEach((ext) => {
|
|
77
|
+
expect(processed).not.toHaveProperty(ext.split("."));
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// Assert that non-x- fields remain unchanged
|
|
81
|
+
expect(processed.openapi).toBe("3.1.0");
|
|
82
|
+
expect(processed.info.title).toBe("Test API");
|
|
83
|
+
expect(processed).toHaveProperty(
|
|
84
|
+
["paths", "/test", "get", "responses", "200", "description"],
|
|
85
|
+
"OK",
|
|
86
|
+
);
|
|
87
|
+
expect(processed.tags[0].name).toBe("example");
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it("removes only specified x- extensions when names are provided", () => {
|
|
91
|
+
const docWithExtraExtensions = {
|
|
92
|
+
...baseDoc,
|
|
93
|
+
info: { ...baseDoc.info, "x-other-ext": "keep me" },
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const processed = removeExtensions({
|
|
97
|
+
keys: ["x-path-ext", "x-param-ext"],
|
|
98
|
+
})(docWithExtraExtensions);
|
|
99
|
+
|
|
100
|
+
// Assert specified extensions are removed
|
|
101
|
+
expect(processed.paths["/test"]["x-path-ext"]).toBeUndefined();
|
|
102
|
+
expect(
|
|
103
|
+
processed.paths["/test"].parameters[0]["x-param-ext"],
|
|
104
|
+
).toBeUndefined();
|
|
105
|
+
|
|
106
|
+
// Assert other x- fields remain
|
|
107
|
+
expect(processed["x-root-ext"]).toBe("remove me");
|
|
108
|
+
expect(processed.info["x-info-ext"]).toBe("remove me");
|
|
109
|
+
expect(processed.info["x-other-ext"]).toBe("keep me");
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it("handles deeply nested extensions", () => {
|
|
113
|
+
const deeplyNested = {
|
|
114
|
+
a: {
|
|
115
|
+
b: {
|
|
116
|
+
c: {
|
|
117
|
+
"x-deep-ext": "remove me",
|
|
118
|
+
d: {
|
|
119
|
+
e: "value",
|
|
120
|
+
"x-another-ext": "remove me",
|
|
121
|
+
},
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
const processed = removeExtensions()(deeplyNested);
|
|
128
|
+
|
|
129
|
+
expect(processed.a.b.c["x-deep-ext"]).toBeUndefined();
|
|
130
|
+
expect(processed.a.b.c.d["x-another-ext"]).toBeUndefined();
|
|
131
|
+
expect(processed.a.b.c.d.e).toBe("value");
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
it("does nothing if no x- extensions are present", () => {
|
|
135
|
+
const docWithoutExtensions = {
|
|
136
|
+
openapi: "3.1.0",
|
|
137
|
+
info: { title: "API without extensions" },
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
const processed = removeExtensions()(docWithoutExtensions);
|
|
141
|
+
|
|
142
|
+
expect(processed).toEqual(docWithoutExtensions);
|
|
143
|
+
});
|
|
144
|
+
});
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { type RecordAny, traverse } from "./traverse.js";
|
|
2
|
+
|
|
3
|
+
interface RemoveExtensionsOptions {
|
|
4
|
+
keys?: string[];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
// Remove all `x-` prefixed key/value pairs, or filter by names if provided
|
|
8
|
+
export const removeExtensions =
|
|
9
|
+
({ keys }: RemoveExtensionsOptions = {}) =>
|
|
10
|
+
(doc: RecordAny): RecordAny =>
|
|
11
|
+
traverse(doc, (spec) => {
|
|
12
|
+
const result: RecordAny = {};
|
|
13
|
+
|
|
14
|
+
for (const [key, value] of Object.entries(spec)) {
|
|
15
|
+
const isExtension = key.startsWith("x-");
|
|
16
|
+
const shouldRemove =
|
|
17
|
+
isExtension && (keys === undefined || keys.includes(key));
|
|
18
|
+
|
|
19
|
+
if (shouldRemove) continue;
|
|
20
|
+
|
|
21
|
+
result[key] = value;
|
|
22
|
+
}
|
|
23
|
+
return result;
|
|
24
|
+
});
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { removePaths } from "./removePaths.js";
|
|
3
|
+
|
|
4
|
+
const baseDoc = {
|
|
5
|
+
openapi: "3.0.3",
|
|
6
|
+
paths: {
|
|
7
|
+
"/example": {
|
|
8
|
+
get: { summary: "Get example" },
|
|
9
|
+
post: { summary: "Post example" },
|
|
10
|
+
},
|
|
11
|
+
"/remove-me": {
|
|
12
|
+
delete: { summary: "Delete example" },
|
|
13
|
+
},
|
|
14
|
+
"/another": {
|
|
15
|
+
get: { summary: "Another example" },
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
describe("removePaths", () => {
|
|
21
|
+
it("removes paths specified in the paths option", () => {
|
|
22
|
+
const processed = removePaths({
|
|
23
|
+
paths: {
|
|
24
|
+
"/remove-me": true,
|
|
25
|
+
},
|
|
26
|
+
})(baseDoc);
|
|
27
|
+
|
|
28
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
29
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
30
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it("removes specific methods in the paths option", () => {
|
|
34
|
+
const processed = removePaths({
|
|
35
|
+
paths: {
|
|
36
|
+
"/example": ["get"],
|
|
37
|
+
},
|
|
38
|
+
})(baseDoc);
|
|
39
|
+
|
|
40
|
+
expect(processed.paths["/example"].get).toBeUndefined();
|
|
41
|
+
expect(processed.paths["/example"].post).toBeDefined();
|
|
42
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it("removes paths and methods using paths and shouldRemove together", () => {
|
|
46
|
+
const processed = removePaths({
|
|
47
|
+
paths: {
|
|
48
|
+
"/example": ["post"],
|
|
49
|
+
},
|
|
50
|
+
shouldRemove: ({ path }) => path.startsWith("/remove"),
|
|
51
|
+
})(baseDoc);
|
|
52
|
+
|
|
53
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
54
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
55
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
56
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it("removes paths based on shouldRemove callback", () => {
|
|
60
|
+
const processed = removePaths({
|
|
61
|
+
shouldRemove: ({ path }) => path.startsWith("/remove"),
|
|
62
|
+
})(baseDoc);
|
|
63
|
+
|
|
64
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
65
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
66
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it("removes methods based on shouldRemove callback", () => {
|
|
70
|
+
const processed = removePaths({
|
|
71
|
+
shouldRemove: ({ method }) => method === "post",
|
|
72
|
+
})(baseDoc);
|
|
73
|
+
|
|
74
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
75
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
76
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it("removes both paths and methods based on shouldRemove callback", () => {
|
|
80
|
+
const processed = removePaths({
|
|
81
|
+
shouldRemove: ({ path, method }) =>
|
|
82
|
+
path.startsWith("/remove") || method === "post",
|
|
83
|
+
})(baseDoc);
|
|
84
|
+
|
|
85
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
86
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
87
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
88
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it("does nothing if shouldRemove always returns false", () => {
|
|
92
|
+
const processed = removePaths({
|
|
93
|
+
shouldRemove: () => false,
|
|
94
|
+
})(baseDoc);
|
|
95
|
+
|
|
96
|
+
expect(processed).toEqual(baseDoc);
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it("removes everything if shouldRemove always returns true", () => {
|
|
100
|
+
const processed = removePaths({
|
|
101
|
+
shouldRemove: () => true,
|
|
102
|
+
})(baseDoc);
|
|
103
|
+
|
|
104
|
+
expect(processed.paths).toEqual({});
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it("removes entire paths via shouldRemove callback", () => {
|
|
108
|
+
const processed = removePaths({
|
|
109
|
+
shouldRemove: ({ path, method }) =>
|
|
110
|
+
method === true && path === "/remove-me",
|
|
111
|
+
})(baseDoc);
|
|
112
|
+
|
|
113
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
114
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
115
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it("removes specific methods while keeping paths", () => {
|
|
119
|
+
const processed = removePaths({
|
|
120
|
+
shouldRemove: ({ method }) => method === "delete",
|
|
121
|
+
})(baseDoc);
|
|
122
|
+
|
|
123
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
124
|
+
expect(processed.paths["/remove-me"].delete).toBeUndefined();
|
|
125
|
+
});
|
|
126
|
+
});
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { type RecordAny, traverse } from "./traverse.js";
|
|
2
|
+
|
|
3
|
+
interface RemovePathsOptions {
|
|
4
|
+
// Path definitions, e.g., { '/path': true, '/path-2': ['get'] }
|
|
5
|
+
paths?: Record<string, true | string[]>;
|
|
6
|
+
shouldRemove?: (options: {
|
|
7
|
+
path: string;
|
|
8
|
+
method: true | string;
|
|
9
|
+
operation: RecordAny;
|
|
10
|
+
}) => boolean;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export const removePaths =
|
|
14
|
+
({ paths = {}, shouldRemove }: RemovePathsOptions) =>
|
|
15
|
+
(doc: RecordAny): RecordAny =>
|
|
16
|
+
traverse(doc, (spec) => {
|
|
17
|
+
if (!spec.paths) return spec;
|
|
18
|
+
|
|
19
|
+
const updatedPaths: RecordAny = {};
|
|
20
|
+
|
|
21
|
+
for (const [path, methods] of Object.entries(spec.paths)) {
|
|
22
|
+
const operations = spec.paths[path];
|
|
23
|
+
|
|
24
|
+
// If the path is explicitly marked for removal in `paths`
|
|
25
|
+
if (paths[path] === true) continue;
|
|
26
|
+
|
|
27
|
+
// If the path should be removed via `shouldRemove`
|
|
28
|
+
if (shouldRemove?.({ path, method: true, operation: operations }))
|
|
29
|
+
continue;
|
|
30
|
+
|
|
31
|
+
if (typeof methods === "object" && methods !== null) {
|
|
32
|
+
const filteredPath = Object.fromEntries(
|
|
33
|
+
Object.entries(methods).filter(([method]) => {
|
|
34
|
+
const operations = spec.paths[path][method];
|
|
35
|
+
const isMethodToRemove =
|
|
36
|
+
Array.isArray(paths[path]) && paths[path].includes(method);
|
|
37
|
+
|
|
38
|
+
const isMethodFiltered = shouldRemove?.({
|
|
39
|
+
path,
|
|
40
|
+
method,
|
|
41
|
+
operation: operations,
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
return !isMethodToRemove && !isMethodFiltered;
|
|
45
|
+
}),
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
updatedPaths[path] = filteredPath;
|
|
49
|
+
} else {
|
|
50
|
+
updatedPaths[path] = methods;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return { ...spec, paths: updatedPaths };
|
|
55
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { traverse, type RecordAny } from "../../../util/traverse.js";
|