zudoku 0.1.1-dev.3 → 0.1.1-dev.31
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/cli.js +2 -0
- package/dist/app/App.js +11 -39
- package/dist/app/App.js.map +1 -1
- package/dist/app/main.js +3 -15
- package/dist/app/main.js.map +1 -1
- package/dist/cli/build/handler.js +3 -1
- package/dist/cli/build/handler.js.map +1 -1
- package/dist/cli/cmds/dev.js +0 -1
- package/dist/cli/cmds/dev.js.map +1 -1
- package/dist/cli/common/logger.d.ts +1 -2
- package/dist/cli/common/logger.js +3 -3
- package/dist/cli/common/logger.js.map +1 -1
- package/dist/cli/common/outdated.js +4 -4
- package/dist/cli/common/outdated.js.map +1 -1
- package/dist/cli/common/output.js +4 -4
- package/dist/cli/common/output.js.map +1 -1
- package/dist/cli/common/utils/box.js +2 -2
- package/dist/cli/common/utils/box.js.map +1 -1
- package/dist/cli/dev/handler.d.ts +1 -1
- package/dist/cli/dev/handler.js +14 -3
- package/dist/cli/dev/handler.js.map +1 -1
- package/dist/config/config.d.ts +13 -7
- package/dist/index.d.ts +2 -6
- package/dist/index.js +1 -5
- package/dist/index.js.map +1 -1
- package/dist/lib/authentication/authentication.js.map +1 -0
- package/dist/{app → lib}/authentication/clerk.d.ts +2 -2
- package/dist/{app → lib}/authentication/clerk.js +9 -5
- package/dist/lib/authentication/clerk.js.map +1 -0
- package/dist/{app → lib}/authentication/openid.js.map +1 -1
- package/dist/{app → lib}/components/AnchorLink.js.map +1 -1
- package/dist/{app → lib}/components/CategoryHeading.js.map +1 -1
- package/dist/{app → lib/components}/DevPortal.d.ts +7 -7
- package/dist/lib/components/DevPortal.js +28 -0
- package/dist/lib/components/DevPortal.js.map +1 -0
- package/dist/{app → lib}/components/Dialog.js +1 -1
- package/dist/lib/components/Dialog.js.map +1 -0
- package/dist/{app → lib}/components/DynamicIcon.js.map +1 -1
- package/dist/{app → lib}/components/Header.js +1 -1
- package/dist/{app → lib}/components/Header.js.map +1 -1
- package/dist/{app → lib/components}/Heading.js +2 -2
- package/dist/lib/components/Heading.js.map +1 -0
- package/dist/{app → lib}/components/Input.js.map +1 -1
- package/dist/{app → lib}/components/Layout.js.map +1 -1
- package/dist/lib/components/Link.d.ts +1 -0
- package/dist/lib/components/Link.js +2 -0
- package/dist/lib/components/Link.js.map +1 -0
- package/dist/{app → lib}/components/Markdown.js.map +1 -1
- package/dist/lib/components/Router.d.ts +4 -0
- package/dist/lib/components/Router.js +20 -0
- package/dist/lib/components/Router.js.map +1 -0
- package/dist/{app → lib}/components/SyntaxHighlight.d.ts +1 -1
- package/dist/{app → lib}/components/SyntaxHighlight.js +3 -0
- package/dist/lib/components/SyntaxHighlight.js.map +1 -0
- package/dist/{app → lib}/components/TopNavigation.js.map +1 -1
- package/dist/{app → lib}/components/context/ComponentsContext.js.map +1 -1
- package/dist/{app → lib}/components/context/DevPortalProvider.js.map +1 -1
- package/dist/lib/components/context/PluginSystem.js.map +1 -0
- package/dist/{app → lib}/components/context/ThemeContext.js.map +1 -1
- package/dist/{app → lib}/components/context/ViewportAnchorContext.js.map +1 -1
- package/dist/lib/components/index.d.ts +3 -0
- package/dist/lib/components/index.js +4 -0
- package/dist/lib/components/index.js.map +1 -0
- package/dist/{app → lib}/components/navigation/SideNavigation.js.map +1 -1
- package/dist/{app → lib}/components/navigation/SideNavigationCategory.js.map +1 -1
- package/dist/{app → lib}/components/navigation/SideNavigationItem.js.map +1 -1
- package/dist/{app → lib}/components/navigation/SideNavigationWrapper.js.map +1 -1
- package/dist/{app → lib}/components/navigation/useNavigationCollapsibleState.js.map +1 -1
- package/dist/{app → lib}/components/navigation/util.js.map +1 -1
- package/dist/{app → lib}/core/DevPortalContext.d.ts +1 -1
- package/dist/{app → lib}/core/DevPortalContext.js.map +1 -1
- package/dist/{app → lib}/core/helmet.js.map +1 -1
- package/dist/lib/core/icons.js.map +1 -0
- package/dist/{app → lib}/core/plugins.js.map +1 -1
- package/dist/lib/core/router.js.map +1 -0
- package/dist/lib/core/types/combine.js.map +1 -0
- package/dist/{app → lib}/oas/graphql/index.js.map +1 -1
- package/dist/{app → lib}/oas/graphql/server.js.map +1 -1
- package/dist/{app → lib}/oas/parser/dereference/index.js.map +1 -1
- package/dist/{app → lib}/oas/parser/dereference/resolveRef.js.map +1 -1
- package/dist/{app → lib}/oas/parser/index.js.map +1 -1
- package/dist/{app → lib}/oas/parser/upgrade/index.js.map +1 -1
- package/dist/{app → lib}/plugins/api-key/SettingsApiKeys.js.map +1 -1
- package/dist/{app → lib}/plugins/api-key/index.js +1 -1
- package/dist/{app → lib}/plugins/api-key/index.js.map +1 -1
- package/dist/lib/plugins/index.d.ts +4 -0
- package/dist/lib/plugins/index.js +6 -0
- package/dist/lib/plugins/index.js.map +1 -0
- package/dist/{app → lib}/plugins/markdown/MdxPage.js +2 -2
- package/dist/{app → lib}/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/{app → lib}/plugins/markdown/Toc.js.map +1 -1
- package/dist/{app → lib}/plugins/markdown/generateRoutes.js +1 -1
- package/dist/{app → lib}/plugins/markdown/generateRoutes.js.map +1 -1
- package/dist/{app → lib}/plugins/markdown/index.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/ColorizedParam.d.ts +1 -2
- package/dist/{app → lib}/plugins/openapi/ColorizedParam.js +1 -1
- package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -0
- package/dist/{app → lib}/plugins/openapi/MakeRequest.js +1 -1
- package/dist/{app → lib}/plugins/openapi/MakeRequest.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/MethodBadge.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/OperationList.js +3 -4
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -0
- package/dist/{app → lib}/plugins/openapi/OperationListItem.js +1 -1
- package/dist/{app → lib}/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/ParameterList.js +1 -1
- package/dist/{app → lib}/plugins/openapi/ParameterList.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/ParameterListItem.js +1 -1
- package/dist/{app → lib}/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/Select.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/SidecarBox.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/graphql/fragment-masking.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/graphql/graphql.d.ts +2 -11
- package/dist/{app → lib}/plugins/openapi/graphql/graphql.js +0 -13
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -0
- package/dist/lib/plugins/openapi/graphql/index.js.map +1 -0
- package/dist/{app → lib}/plugins/openapi/index.js +2 -3
- package/dist/lib/plugins/openapi/index.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/Editor.d.ts +1 -0
- package/dist/lib/plugins/openapi/playground/Editor.js +5 -0
- package/dist/lib/plugins/openapi/playground/Editor.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/Headers.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/Headers.js +26 -0
- package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/InlineInput.d.ts +3 -0
- package/dist/lib/plugins/openapi/playground/InlineInput.js +3 -0
- package/dist/lib/plugins/openapi/playground/InlineInput.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/Playground.d.ts +25 -0
- package/dist/lib/plugins/openapi/playground/Playground.js +87 -0
- package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/QueryParams.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/QueryParams.js +30 -0
- package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/UrlParts.d.ts +6 -0
- package/dist/lib/plugins/openapi/playground/UrlParts.js +21 -0
- package/dist/lib/plugins/openapi/playground/UrlParts.js.map +1 -0
- package/dist/{app → lib}/plugins/openapi/util/generateSchemaExample.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/util/urql.js.map +1 -1
- package/dist/{app → lib}/plugins/openapi/worker/createSharedWorkerClient.js +1 -1
- package/dist/{app → lib}/plugins/openapi/worker/createSharedWorkerClient.js.map +1 -1
- package/dist/lib/plugins/openapi/worker/shared-worker.d.ts +1 -0
- package/dist/lib/plugins/openapi/worker/shared-worker.js +6 -0
- package/dist/lib/plugins/openapi/worker/shared-worker.js.map +1 -0
- package/dist/{app → lib}/plugins/openapi/worker/worker.js.map +1 -1
- package/dist/lib/plugins/openapi-worker.d.ts +1 -0
- package/dist/lib/plugins/openapi-worker.js +2 -0
- package/dist/lib/plugins/openapi-worker.js.map +1 -0
- package/dist/{app → lib}/plugins/redirect/index.js.map +1 -1
- package/dist/{app → lib}/ui/Button.d.ts +1 -1
- package/dist/{app → lib}/ui/Button.js.map +1 -1
- package/dist/{app → lib}/ui/Callout.js.map +1 -1
- package/dist/{app → lib}/ui/Card.js.map +1 -1
- package/dist/{app → lib}/ui/Note.js.map +1 -1
- package/dist/{app → lib}/ui/Tabs.js.map +1 -1
- package/dist/{app → lib}/util/MdxComponents.js +1 -1
- package/dist/lib/util/MdxComponents.js.map +1 -0
- package/dist/{app → lib}/util/cn.js.map +1 -1
- package/dist/{app → lib}/util/createVariantComponent.d.ts +3 -10
- package/dist/{app → lib}/util/createVariantComponent.js +3 -2
- package/dist/lib/util/createVariantComponent.js.map +1 -0
- package/dist/{app → lib}/util/createWaitForNotify.js.map +1 -1
- package/dist/{app → lib}/util/groupBy.js.map +1 -1
- package/dist/{app → lib}/util/joinPath.js.map +1 -1
- package/dist/{app → lib}/util/pastellize.js.map +1 -1
- package/dist/lib/util/slugify.js.map +1 -0
- package/dist/{app → lib}/util/traverseNavigation.js.map +1 -1
- package/dist/{app → lib}/util/useScrollToAnchor.js.map +1 -1
- package/dist/{app → lib}/util/useScrollToTop.js.map +1 -1
- package/dist/ts.d.ts +6 -0
- package/dist/ts.js +62 -0
- package/dist/ts.js.map +1 -0
- package/dist/vite/build.js +2 -8
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/common.d.ts +1 -0
- package/dist/vite/common.js +2 -0
- package/dist/vite/common.js.map +1 -0
- package/dist/vite/config.d.ts +10 -3
- package/dist/vite/config.js +108 -58
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/config.test.js +4 -3
- package/dist/vite/config.test.js.map +1 -1
- package/dist/vite/dev-server.d.ts +2 -0
- package/dist/vite/dev-server.js +28 -8
- package/dist/vite/dev-server.js.map +1 -1
- package/dist/vite/html.d.ts +1 -1
- package/dist/vite/html.js +2 -3
- package/dist/vite/html.js.map +1 -1
- package/dist/vite/plugin-api.d.ts +4 -0
- package/dist/vite/plugin-api.js +49 -0
- package/dist/vite/plugin-api.js.map +1 -0
- package/dist/vite/plugin-auth.d.ts +4 -0
- package/dist/vite/plugin-auth.js +30 -0
- package/dist/vite/plugin-auth.js.map +1 -0
- package/dist/vite/plugin-component.d.ts +4 -0
- package/dist/vite/plugin-component.js +16 -0
- package/dist/vite/plugin-component.js.map +1 -0
- package/dist/vite/plugin-config.d.ts +7 -0
- package/dist/vite/plugin-config.js +25 -0
- package/dist/vite/plugin-config.js.map +1 -0
- package/dist/vite/plugin-docs.d.ts +4 -0
- package/dist/vite/plugin-docs.js +45 -0
- package/dist/vite/plugin-docs.js.map +1 -0
- package/dist/vite/plugin-docs.test.d.ts +1 -0
- package/dist/vite/plugin-docs.test.js +30 -0
- package/dist/vite/plugin-docs.test.js.map +1 -0
- package/dist/vite/plugin-html.d.ts +3 -0
- package/dist/vite/plugin-html.js +47 -0
- package/dist/vite/plugin-html.js.map +1 -0
- package/dist/vite/plugin-mdx.d.ts +8 -0
- package/dist/vite/plugin-mdx.js +61 -0
- package/dist/vite/plugin-mdx.js.map +1 -0
- package/dist/vite/plugin-metadata.d.ts +6 -0
- package/dist/vite/plugin-metadata.js +24 -0
- package/dist/vite/plugin-metadata.js.map +1 -0
- package/dist/vite/plugin-openapi-worker.d.ts +4 -0
- package/dist/vite/plugin-openapi-worker.js +28 -0
- package/dist/vite/plugin-openapi-worker.js.map +1 -0
- package/dist/vite/plugin.d.ts +2 -6
- package/dist/vite/plugin.js +18 -104
- package/dist/vite/plugin.js.map +1 -1
- package/lib/DevPortal-Dh66z5c3.js +12671 -0
- package/lib/assets/index-BPdJm2ty.js +4764 -0
- package/lib/assets/worker-W78u54MC.js +14473 -0
- package/lib/prism-bash.min-DadFsM4Z.js +6 -0
- package/lib/prism-java.min-d5iT_mOd.js +6 -0
- package/lib/prism-json.min-B1GJqK1k.js +1 -0
- package/lib/prism-markup-templating-DZrrEs0A.js +61 -0
- package/lib/prism-php.min-o7FpoMP_.js +10 -0
- package/lib/prism-ruby.min-C7LwcKyz.js +9 -0
- package/lib/urql-B7mLfVog.js +1611 -0
- package/lib/zudoku.auth-clerk.js +32 -0
- package/lib/zudoku.components.js +6 -0
- package/lib/zudoku.openapi-worker.js +225 -0
- package/lib/zudoku.plugins.js +16944 -0
- package/package.json +69 -50
- package/src/app/App.tsx +14 -44
- package/src/app/main.tsx +5 -18
- package/src/{app → lib}/authentication/clerk.ts +11 -9
- package/src/{app → lib/components}/DevPortal.tsx +22 -41
- package/src/{app → lib}/components/Dialog.tsx +32 -32
- package/src/{app → lib}/components/Header.tsx +1 -1
- package/src/{app → lib/components}/Heading.tsx +2 -2
- package/src/lib/components/Link.tsx +1 -0
- package/src/lib/components/Router.tsx +28 -0
- package/src/{app → lib}/components/SyntaxHighlight.tsx +4 -0
- package/src/lib/components/index.ts +3 -0
- package/src/{app → lib}/core/DevPortalContext.ts +4 -1
- package/src/{app → lib}/plugins/api-key/index.tsx +1 -1
- package/src/lib/plugins/index.ts +5 -0
- package/src/{app → lib}/plugins/markdown/MdxPage.tsx +3 -3
- package/src/{app → lib}/plugins/markdown/generateRoutes.tsx +1 -1
- package/src/{app → lib}/plugins/openapi/ColorizedParam.tsx +0 -2
- package/src/{app → lib}/plugins/openapi/MakeRequest.tsx +1 -1
- package/src/{app → lib}/plugins/openapi/OperationList.tsx +4 -5
- package/src/{app → lib}/plugins/openapi/OperationListItem.tsx +1 -1
- package/src/{app → lib}/plugins/openapi/ParameterList.tsx +1 -1
- package/src/{app → lib}/plugins/openapi/ParameterListItem.tsx +4 -1
- package/src/{app → lib}/plugins/openapi/graphql/graphql.ts +2 -11
- package/src/{app → lib}/plugins/openapi/index.tsx +7 -4
- package/src/lib/plugins/openapi/playground/Editor.tsx +6 -0
- package/src/lib/plugins/openapi/playground/Headers.tsx +66 -0
- package/src/lib/plugins/openapi/playground/InlineInput.tsx +6 -0
- package/src/lib/plugins/openapi/playground/Playground.tsx +274 -0
- package/src/lib/plugins/openapi/playground/QueryParams.tsx +79 -0
- package/src/lib/plugins/openapi/playground/UrlParts.tsx +67 -0
- package/src/{app → lib}/plugins/openapi/worker/createSharedWorkerClient.ts +1 -1
- package/src/lib/plugins/openapi/worker/shared-worker.ts +5 -0
- package/src/lib/plugins/openapi-worker.ts +1 -0
- package/src/{app → lib}/util/MdxComponents.tsx +1 -1
- package/src/{app → lib}/util/createVariantComponent.tsx +7 -5
- package/dist/app/DevPortal.js +0 -41
- package/dist/app/DevPortal.js.map +0 -1
- package/dist/app/Heading.js.map +0 -1
- package/dist/app/authentication/authentication.js.map +0 -1
- package/dist/app/authentication/clerk.js.map +0 -1
- package/dist/app/components/Dialog.js.map +0 -1
- package/dist/app/components/SyntaxHighlight.js.map +0 -1
- package/dist/app/components/context/PluginSystem.js.map +0 -1
- package/dist/app/config.d.ts +0 -3
- package/dist/app/config.js +0 -9
- package/dist/app/config.js.map +0 -1
- package/dist/app/core/icons.js.map +0 -1
- package/dist/app/core/router.js.map +0 -1
- package/dist/app/core/types/combine.js.map +0 -1
- package/dist/app/markdowns.d.ts +0 -3
- package/dist/app/markdowns.js +0 -5
- package/dist/app/markdowns.js.map +0 -1
- package/dist/app/plugins/openapi/ColorizedParam.js.map +0 -1
- package/dist/app/plugins/openapi/OperationList.js.map +0 -1
- package/dist/app/plugins/openapi/graphql/graphql.js.map +0 -1
- package/dist/app/plugins/openapi/graphql/index.js.map +0 -1
- package/dist/app/plugins/openapi/index.js.map +0 -1
- package/dist/app/plugins/openapi/playground/Playground.d.ts +0 -8
- package/dist/app/plugins/openapi/playground/Playground.js +0 -98
- package/dist/app/plugins/openapi/playground/Playground.js.map +0 -1
- package/dist/app/util/MdxComponents.js.map +0 -1
- package/dist/app/util/createVariantComponent.js.map +0 -1
- package/dist/app/util/slugify.js.map +0 -1
- package/dist/auth.d.ts +0 -2
- package/dist/auth.js +0 -3
- package/dist/auth.js.map +0 -1
- package/dist/plugins.d.ts +0 -4
- package/dist/plugins.js +0 -6
- package/dist/plugins.js.map +0 -1
- package/src/app/config.ts +0 -20
- package/src/app/markdowns.ts +0 -7
- package/src/app/plugins/openapi/playground/Playground.tsx +0 -309
- /package/dist/{app → lib}/authentication/authentication.d.ts +0 -0
- /package/dist/{app → lib}/authentication/authentication.js +0 -0
- /package/dist/{app → lib}/authentication/openid.d.ts +0 -0
- /package/dist/{app → lib}/authentication/openid.js +0 -0
- /package/dist/{app → lib}/components/AnchorLink.d.ts +0 -0
- /package/dist/{app → lib}/components/AnchorLink.js +0 -0
- /package/dist/{app → lib}/components/CategoryHeading.d.ts +0 -0
- /package/dist/{app → lib}/components/CategoryHeading.js +0 -0
- /package/dist/{app → lib}/components/Dialog.d.ts +0 -0
- /package/dist/{app → lib}/components/DynamicIcon.d.ts +0 -0
- /package/dist/{app → lib}/components/DynamicIcon.js +0 -0
- /package/dist/{app → lib}/components/Header.d.ts +0 -0
- /package/dist/{app → lib/components}/Heading.d.ts +0 -0
- /package/dist/{app → lib}/components/Input.d.ts +0 -0
- /package/dist/{app → lib}/components/Input.js +0 -0
- /package/dist/{app → lib}/components/Layout.d.ts +0 -0
- /package/dist/{app → lib}/components/Layout.js +0 -0
- /package/dist/{app → lib}/components/Markdown.d.ts +0 -0
- /package/dist/{app → lib}/components/Markdown.js +0 -0
- /package/dist/{app → lib}/components/TopNavigation.d.ts +0 -0
- /package/dist/{app → lib}/components/TopNavigation.js +0 -0
- /package/dist/{app → lib}/components/context/ComponentsContext.d.ts +0 -0
- /package/dist/{app → lib}/components/context/ComponentsContext.js +0 -0
- /package/dist/{app → lib}/components/context/DevPortalProvider.d.ts +0 -0
- /package/dist/{app → lib}/components/context/DevPortalProvider.js +0 -0
- /package/dist/{app → lib}/components/context/PluginSystem.d.ts +0 -0
- /package/dist/{app → lib}/components/context/PluginSystem.js +0 -0
- /package/dist/{app → lib}/components/context/ThemeContext.d.ts +0 -0
- /package/dist/{app → lib}/components/context/ThemeContext.js +0 -0
- /package/dist/{app → lib}/components/context/ViewportAnchorContext.d.ts +0 -0
- /package/dist/{app → lib}/components/context/ViewportAnchorContext.js +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigation.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigation.js +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationCategory.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationCategory.js +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationItem.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationItem.js +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationWrapper.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/SideNavigationWrapper.js +0 -0
- /package/dist/{app → lib}/components/navigation/useNavigationCollapsibleState.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/useNavigationCollapsibleState.js +0 -0
- /package/dist/{app → lib}/components/navigation/util.d.ts +0 -0
- /package/dist/{app → lib}/components/navigation/util.js +0 -0
- /package/dist/{app → lib}/core/DevPortalContext.js +0 -0
- /package/dist/{app → lib}/core/helmet.d.ts +0 -0
- /package/dist/{app → lib}/core/helmet.js +0 -0
- /package/dist/{app → lib}/core/icons.d.ts +0 -0
- /package/dist/{app → lib}/core/icons.js +0 -0
- /package/dist/{app → lib}/core/plugins.d.ts +0 -0
- /package/dist/{app → lib}/core/plugins.js +0 -0
- /package/dist/{app → lib}/core/router.d.ts +0 -0
- /package/dist/{app → lib}/core/router.js +0 -0
- /package/dist/{app → lib}/core/types/combine.d.ts +0 -0
- /package/dist/{app → lib}/core/types/combine.js +0 -0
- /package/dist/{app → lib}/oas/graphql/index.d.ts +0 -0
- /package/dist/{app → lib}/oas/graphql/index.js +0 -0
- /package/dist/{app → lib}/oas/graphql/server.d.ts +0 -0
- /package/dist/{app → lib}/oas/graphql/server.js +0 -0
- /package/dist/{app → lib}/oas/parser/dereference/index.d.ts +0 -0
- /package/dist/{app → lib}/oas/parser/dereference/index.js +0 -0
- /package/dist/{app → lib}/oas/parser/dereference/resolveRef.d.ts +0 -0
- /package/dist/{app → lib}/oas/parser/dereference/resolveRef.js +0 -0
- /package/dist/{app → lib}/oas/parser/index.d.ts +0 -0
- /package/dist/{app → lib}/oas/parser/index.js +0 -0
- /package/dist/{app → lib}/oas/parser/upgrade/index.d.ts +0 -0
- /package/dist/{app → lib}/oas/parser/upgrade/index.js +0 -0
- /package/dist/{app → lib}/plugins/api-key/SettingsApiKeys.d.ts +0 -0
- /package/dist/{app → lib}/plugins/api-key/SettingsApiKeys.js +0 -0
- /package/dist/{app → lib}/plugins/api-key/index.d.ts +0 -0
- /package/dist/{app → lib}/plugins/markdown/MdxPage.d.ts +0 -0
- /package/dist/{app → lib}/plugins/markdown/Toc.d.ts +0 -0
- /package/dist/{app → lib}/plugins/markdown/Toc.js +0 -0
- /package/dist/{app → lib}/plugins/markdown/generateRoutes.d.ts +0 -0
- /package/dist/{app → lib}/plugins/markdown/index.d.ts +0 -0
- /package/dist/{app → lib}/plugins/markdown/index.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/MakeRequest.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/MethodBadge.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/MethodBadge.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/OperationList.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/OperationListItem.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/ParameterList.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/ParameterListItem.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/RequestBodySidecarBox.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/RequestBodySidecarBox.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/ResponsesSidecarBox.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/ResponsesSidecarBox.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/Select.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/Select.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/Sidecar.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/Sidecar.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/SidecarBox.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/SidecarBox.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/fragment-masking.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/fragment-masking.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/gql.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/gql.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/index.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/graphql/index.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/index.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/util/generateSchemaExample.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/util/generateSchemaExample.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/util/urql.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/util/urql.js +0 -0
- /package/dist/{app → lib}/plugins/openapi/worker/createSharedWorkerClient.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/worker/worker.d.ts +0 -0
- /package/dist/{app → lib}/plugins/openapi/worker/worker.js +0 -0
- /package/dist/{app → lib}/plugins/redirect/index.d.ts +0 -0
- /package/dist/{app → lib}/plugins/redirect/index.js +0 -0
- /package/dist/{app → lib}/ui/Button.js +0 -0
- /package/dist/{app → lib}/ui/Callout.d.ts +0 -0
- /package/dist/{app → lib}/ui/Callout.js +0 -0
- /package/dist/{app → lib}/ui/Card.d.ts +0 -0
- /package/dist/{app → lib}/ui/Card.js +0 -0
- /package/dist/{app → lib}/ui/Note.d.ts +0 -0
- /package/dist/{app → lib}/ui/Note.js +0 -0
- /package/dist/{app → lib}/ui/Tabs.d.ts +0 -0
- /package/dist/{app → lib}/ui/Tabs.js +0 -0
- /package/dist/{app → lib}/util/MdxComponents.d.ts +0 -0
- /package/dist/{app → lib}/util/cn.d.ts +0 -0
- /package/dist/{app → lib}/util/cn.js +0 -0
- /package/dist/{app → lib}/util/createWaitForNotify.d.ts +0 -0
- /package/dist/{app → lib}/util/createWaitForNotify.js +0 -0
- /package/dist/{app → lib}/util/groupBy.d.ts +0 -0
- /package/dist/{app → lib}/util/groupBy.js +0 -0
- /package/dist/{app → lib}/util/joinPath.d.ts +0 -0
- /package/dist/{app → lib}/util/joinPath.js +0 -0
- /package/dist/{app → lib}/util/pastellize.d.ts +0 -0
- /package/dist/{app → lib}/util/pastellize.js +0 -0
- /package/dist/{app → lib}/util/slugify.d.ts +0 -0
- /package/dist/{app → lib}/util/slugify.js +0 -0
- /package/dist/{app → lib}/util/traverseNavigation.d.ts +0 -0
- /package/dist/{app → lib}/util/traverseNavigation.js +0 -0
- /package/dist/{app → lib}/util/useScrollToAnchor.d.ts +0 -0
- /package/dist/{app → lib}/util/useScrollToAnchor.js +0 -0
- /package/dist/{app → lib}/util/useScrollToTop.d.ts +0 -0
- /package/dist/{app → lib}/util/useScrollToTop.js +0 -0
- /package/src/{app → lib}/authentication/authentication.ts +0 -0
- /package/src/{app → lib}/authentication/openid.ts +0 -0
- /package/src/{app → lib}/components/AnchorLink.tsx +0 -0
- /package/src/{app → lib}/components/CategoryHeading.tsx +0 -0
- /package/src/{app → lib}/components/DynamicIcon.tsx +0 -0
- /package/src/{app → lib}/components/Input.tsx +0 -0
- /package/src/{app → lib}/components/Layout.tsx +0 -0
- /package/src/{app → lib}/components/Markdown.tsx +0 -0
- /package/src/{app → lib}/components/TopNavigation.tsx +0 -0
- /package/src/{app → lib}/components/context/ComponentsContext.tsx +0 -0
- /package/src/{app → lib}/components/context/DevPortalProvider.ts +0 -0
- /package/src/{app → lib}/components/context/PluginSystem.ts +0 -0
- /package/src/{app → lib}/components/context/ThemeContext.tsx +0 -0
- /package/src/{app → lib}/components/context/ViewportAnchorContext.tsx +0 -0
- /package/src/{app → lib}/components/navigation/SideNavigation.tsx +0 -0
- /package/src/{app → lib}/components/navigation/SideNavigationCategory.tsx +0 -0
- /package/src/{app → lib}/components/navigation/SideNavigationItem.tsx +0 -0
- /package/src/{app → lib}/components/navigation/SideNavigationWrapper.tsx +0 -0
- /package/src/{app → lib}/components/navigation/useNavigationCollapsibleState.ts +0 -0
- /package/src/{app → lib}/components/navigation/util.ts +0 -0
- /package/src/{app → lib}/core/helmet.ts +0 -0
- /package/src/{app → lib}/core/icons.tsx +0 -0
- /package/src/{app → lib}/core/plugins.ts +0 -0
- /package/src/{app → lib}/core/router.tsx +0 -0
- /package/src/{app → lib}/core/types/combine.ts +0 -0
- /package/src/{app → lib}/oas/graphql/index.ts +0 -0
- /package/src/{app → lib}/oas/graphql/server.ts +0 -0
- /package/src/{app → lib}/oas/parser/dereference/index.ts +0 -0
- /package/src/{app → lib}/oas/parser/dereference/resolveRef.ts +0 -0
- /package/src/{app → lib}/oas/parser/index.ts +0 -0
- /package/src/{app → lib}/oas/parser/schemas/v3.0.json +0 -0
- /package/src/{app → lib}/oas/parser/schemas/v3.1.json +0 -0
- /package/src/{app → lib}/oas/parser/upgrade/index.ts +0 -0
- /package/src/{app → lib}/plugins/api-key/SettingsApiKeys.tsx +0 -0
- /package/src/{app → lib}/plugins/markdown/Toc.tsx +0 -0
- /package/src/{app → lib}/plugins/markdown/index.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/MethodBadge.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/RequestBodySidecarBox.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/ResponsesSidecarBox.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/Select.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/Sidecar.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/SidecarBox.tsx +0 -0
- /package/src/{app → lib}/plugins/openapi/graphql/fragment-masking.ts +0 -0
- /package/src/{app → lib}/plugins/openapi/graphql/gql.ts +0 -0
- /package/src/{app → lib}/plugins/openapi/graphql/index.ts +0 -0
- /package/src/{app → lib}/plugins/openapi/queries.graphql +0 -0
- /package/src/{app → lib}/plugins/openapi/util/generateSchemaExample.ts +0 -0
- /package/src/{app → lib}/plugins/openapi/util/urql.ts +0 -0
- /package/src/{app → lib}/plugins/openapi/worker/worker.ts +0 -0
- /package/src/{app → lib}/plugins/redirect/index.tsx +0 -0
- /package/src/{app → lib}/ui/Button.tsx +0 -0
- /package/src/{app → lib}/ui/Callout.tsx +0 -0
- /package/src/{app → lib}/ui/Card.tsx +0 -0
- /package/src/{app → lib}/ui/Note.tsx +0 -0
- /package/src/{app → lib}/ui/Tabs.tsx +0 -0
- /package/src/{app → lib}/util/cn.ts +0 -0
- /package/src/{app → lib}/util/createWaitForNotify.ts +0 -0
- /package/src/{app → lib}/util/groupBy.ts +0 -0
- /package/src/{app → lib}/util/joinPath.tsx +0 -0
- /package/src/{app → lib}/util/pastellize.ts +0 -0
- /package/src/{app → lib}/util/slugify.ts +0 -0
- /package/src/{app → lib}/util/traverseNavigation.ts +0 -0
- /package/src/{app → lib}/util/useScrollToAnchor.ts +0 -0
- /package/src/{app → lib}/util/useScrollToTop.ts +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Heading } from "../../Heading.js";
|
|
1
|
+
import { Heading } from "../../components/Heading.js";
|
|
2
2
|
import { useTopNavigationItem } from "../../components/context/DevPortalProvider.js";
|
|
3
3
|
import { isPathItem } from "../../components/navigation/util.js";
|
|
4
4
|
import { Navigate, type RouteObject } from "../../core/router.js";
|
|
@@ -15,7 +15,6 @@ export const usePastellizedColor = (name: string) => {
|
|
|
15
15
|
|
|
16
16
|
export const ColorizedParam = ({
|
|
17
17
|
name,
|
|
18
|
-
value,
|
|
19
18
|
className,
|
|
20
19
|
backgroundOpacity = "100%",
|
|
21
20
|
slug,
|
|
@@ -23,7 +22,6 @@ export const ColorizedParam = ({
|
|
|
23
22
|
onClick,
|
|
24
23
|
}: {
|
|
25
24
|
name: string;
|
|
26
|
-
value?: string;
|
|
27
25
|
className?: string;
|
|
28
26
|
backgroundOpacity?: string;
|
|
29
27
|
slug?: string;
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ResultOf } from "@graphql-typed-document-node/core";
|
|
2
2
|
import { CategoryHeading } from "../../components/CategoryHeading.js";
|
|
3
|
+
import { Heading } from "../../components/Heading.js";
|
|
3
4
|
import { Markdown, ProseClasses } from "../../components/Markdown.js";
|
|
4
5
|
import { cn } from "../../util/cn.js";
|
|
5
6
|
import { OperationListItem } from "./OperationListItem.js";
|
|
6
|
-
import { useOasConfig } from "./index.js";
|
|
7
7
|
import { graphql } from "./graphql/index.js";
|
|
8
|
-
import {
|
|
8
|
+
import { useOasConfig } from "./index.js";
|
|
9
9
|
import { useQuery } from "./util/urql.js";
|
|
10
|
-
import { ResultOf } from "@graphql-typed-document-node/core";
|
|
11
10
|
|
|
12
11
|
export const OperationsFragment = graphql(/* GraphQL */ `
|
|
13
12
|
fragment OperationsFragment on OperationItem {
|
|
@@ -78,7 +77,7 @@ export const OperationList = () => {
|
|
|
78
77
|
|
|
79
78
|
const [result] = useQuery({
|
|
80
79
|
query: AllOperationsQuery,
|
|
81
|
-
variables: { type
|
|
80
|
+
variables: { type, input },
|
|
82
81
|
});
|
|
83
82
|
|
|
84
83
|
if (!result.data) return null;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Heading } from "../../Heading.js";
|
|
1
|
+
import { Heading } from "../../components/Heading.js";
|
|
2
2
|
import { Markdown, ProseClasses } from "../../components/Markdown.js";
|
|
3
3
|
import { groupBy } from "../../util/groupBy.js";
|
|
4
4
|
import { OperationsFragment } from "./OperationList.js";
|
|
@@ -54,7 +54,10 @@ export const ParameterListItem = ({
|
|
|
54
54
|
)}
|
|
55
55
|
</div>
|
|
56
56
|
{parameter.description && (
|
|
57
|
-
<Markdown
|
|
57
|
+
<Markdown
|
|
58
|
+
content={parameter.description}
|
|
59
|
+
className="text-sm prose-p:my-1"
|
|
60
|
+
/>
|
|
58
61
|
)}
|
|
59
62
|
</li>
|
|
60
63
|
);
|
|
@@ -76,12 +76,7 @@ export type OperationItem = {
|
|
|
76
76
|
tags?: Maybe<Array<TagItem>>;
|
|
77
77
|
};
|
|
78
78
|
|
|
79
|
-
export
|
|
80
|
-
Cookie = "cookie",
|
|
81
|
-
Header = "header",
|
|
82
|
-
Path = "path",
|
|
83
|
-
Query = "query",
|
|
84
|
-
}
|
|
79
|
+
export type ParameterIn = "cookie" | "header" | "path" | "query";
|
|
85
80
|
|
|
86
81
|
export type ParameterItem = {
|
|
87
82
|
__typename?: "ParameterItem";
|
|
@@ -160,11 +155,7 @@ export type SchemaTag = {
|
|
|
160
155
|
operations: Array<OperationItem>;
|
|
161
156
|
};
|
|
162
157
|
|
|
163
|
-
export
|
|
164
|
-
Json = "json",
|
|
165
|
-
Url = "url",
|
|
166
|
-
Yaml = "yaml",
|
|
167
|
-
}
|
|
158
|
+
export type SchemaType = "json" | "url" | "yaml";
|
|
168
159
|
|
|
169
160
|
export type TagItem = {
|
|
170
161
|
__typename?: "TagItem";
|
|
@@ -13,8 +13,9 @@ import {
|
|
|
13
13
|
cacheExchange,
|
|
14
14
|
fetchExchange,
|
|
15
15
|
} from "./util/urql.js";
|
|
16
|
-
|
|
17
|
-
import {
|
|
16
|
+
|
|
17
|
+
import { createSharedWorkerClient } from "virtual:zudoku-openapi-worker";
|
|
18
|
+
import type { createSharedWorkerClient as createSharedWorkerClientType } from "./worker/createSharedWorkerClient.js";
|
|
18
19
|
|
|
19
20
|
const OasContext = createContext<{ config: OasPluginConfig } | undefined>(
|
|
20
21
|
undefined,
|
|
@@ -83,7 +84,9 @@ export const openApiPlugin = (config: OasPluginConfig): DevPortalPlugin => {
|
|
|
83
84
|
url: config.server,
|
|
84
85
|
exchanges: [cacheExchange, fetchExchange],
|
|
85
86
|
})
|
|
86
|
-
: createSharedWorkerClient()
|
|
87
|
+
: (createSharedWorkerClient() as ReturnType<
|
|
88
|
+
typeof createSharedWorkerClientType
|
|
89
|
+
>);
|
|
87
90
|
|
|
88
91
|
return {
|
|
89
92
|
getNavigation: async (path: string) => {
|
|
@@ -93,7 +96,7 @@ export const openApiPlugin = (config: OasPluginConfig): DevPortalPlugin => {
|
|
|
93
96
|
|
|
94
97
|
const { data } = await client.query(GetCategoriesQuery, {
|
|
95
98
|
input: config.input,
|
|
96
|
-
type:
|
|
99
|
+
type: config.type,
|
|
97
100
|
});
|
|
98
101
|
|
|
99
102
|
if (!data) return [];
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Control, useFieldArray, UseFormRegister } from "react-hook-form";
|
|
2
|
+
import { TrashIcon } from "lucide-react";
|
|
3
|
+
import { InlineInput } from "./InlineInput.js";
|
|
4
|
+
import type { PlaygroundForm, Header } from "./Playground.js";
|
|
5
|
+
import { useEffect } from "react";
|
|
6
|
+
|
|
7
|
+
export const Headers = ({
|
|
8
|
+
control,
|
|
9
|
+
register,
|
|
10
|
+
headers,
|
|
11
|
+
}: {
|
|
12
|
+
register: UseFormRegister<PlaygroundForm>;
|
|
13
|
+
control: Control<PlaygroundForm>;
|
|
14
|
+
headers: Header[];
|
|
15
|
+
}) => {
|
|
16
|
+
const { fields, append, remove } = useFieldArray<PlaygroundForm>({
|
|
17
|
+
control,
|
|
18
|
+
name: "headers",
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
const headersCount = headers.length;
|
|
22
|
+
const headersLastName = headers.at(-1)?.name;
|
|
23
|
+
const headersValue = headers.at(-1)?.value;
|
|
24
|
+
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
if (headersCount === 0) {
|
|
27
|
+
append({ name: "", value: "" });
|
|
28
|
+
}
|
|
29
|
+
if (headersLastName !== "" || headersValue !== "") {
|
|
30
|
+
append({ name: "", value: "" });
|
|
31
|
+
}
|
|
32
|
+
}, [append, headersCount, headersLastName, headersValue]);
|
|
33
|
+
|
|
34
|
+
return (
|
|
35
|
+
<div className="grid grid-cols-[1fr_1fr_auto]">
|
|
36
|
+
{fields.map((header, i) => (
|
|
37
|
+
<div
|
|
38
|
+
key={header.id}
|
|
39
|
+
className="grid-cols-subgrid col-span-full grid items-center gap-x-2 has-[:focus]:bg-muted hover:bg-muted rounded overflow-hidden group"
|
|
40
|
+
>
|
|
41
|
+
{/*<input type="checkbox" />*/}
|
|
42
|
+
<InlineInput
|
|
43
|
+
{...register(`headers.${i}.name`)}
|
|
44
|
+
placeholder="Name"
|
|
45
|
+
className="peer"
|
|
46
|
+
/>
|
|
47
|
+
<InlineInput
|
|
48
|
+
placeholder={"Value"}
|
|
49
|
+
className="peer"
|
|
50
|
+
{...register(`headers.${i}.value`)}
|
|
51
|
+
/>
|
|
52
|
+
<button
|
|
53
|
+
className="hover:bg-black/5 p-1 rounded mr-2 text-muted-foreground invisible group-hover:visible peer-focus:visible"
|
|
54
|
+
onClick={() => {
|
|
55
|
+
remove(i);
|
|
56
|
+
}}
|
|
57
|
+
disabled={fields.length === 1}
|
|
58
|
+
>
|
|
59
|
+
<TrashIcon size={16} />
|
|
60
|
+
</button>
|
|
61
|
+
<div className="col-span-full border-b border-border"></div>
|
|
62
|
+
</div>
|
|
63
|
+
))}
|
|
64
|
+
</div>
|
|
65
|
+
);
|
|
66
|
+
};
|
|
@@ -0,0 +1,274 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Dialog,
|
|
3
|
+
DialogContent,
|
|
4
|
+
DialogDescription,
|
|
5
|
+
DialogHeader,
|
|
6
|
+
DialogTitle,
|
|
7
|
+
DialogTrigger,
|
|
8
|
+
} from "../../../components/Dialog.js";
|
|
9
|
+
import { Card, CardContent } from "../../../ui/Card.js";
|
|
10
|
+
import { Button } from "../../../ui/Button.js";
|
|
11
|
+
import { Tabs, TabsContent, TabsList, TabsTrigger } from "../../../ui/Tabs.js";
|
|
12
|
+
import { Fragment } from "react";
|
|
13
|
+
import { SyntaxHighlight } from "../../../components/SyntaxHighlight.js";
|
|
14
|
+
import { ColorizedParam } from "../ColorizedParam.js";
|
|
15
|
+
import { useMutation } from "@tanstack/react-query";
|
|
16
|
+
import { useForm } from "react-hook-form";
|
|
17
|
+
import { Headers } from "./Headers.js";
|
|
18
|
+
import { QueryParams } from "./QueryParams.js";
|
|
19
|
+
import { UrlParts } from "./UrlParts.js";
|
|
20
|
+
import { LoaderCircle } from "lucide-react";
|
|
21
|
+
|
|
22
|
+
function mimeTypeToLanguage(mimeType: string) {
|
|
23
|
+
const mimeTypeMapping = {
|
|
24
|
+
"application/json": "json",
|
|
25
|
+
"text/json": "json",
|
|
26
|
+
"text/html": "html",
|
|
27
|
+
"text/css": "css",
|
|
28
|
+
"text/javascript": "javascript",
|
|
29
|
+
"application/xml": "xml",
|
|
30
|
+
"application/xhtml+xml": "xhtml",
|
|
31
|
+
"text/plain": "plain",
|
|
32
|
+
} as const;
|
|
33
|
+
|
|
34
|
+
return Object.entries(mimeTypeMapping).find(([mime]) =>
|
|
35
|
+
mimeType.includes(mime),
|
|
36
|
+
)?.[0][1];
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export type Header = {
|
|
40
|
+
name: string;
|
|
41
|
+
value: string;
|
|
42
|
+
};
|
|
43
|
+
export type QueryParam = {
|
|
44
|
+
name: string;
|
|
45
|
+
value: string;
|
|
46
|
+
};
|
|
47
|
+
export type UrlPart = {
|
|
48
|
+
name: string;
|
|
49
|
+
value: string;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
export type PlaygroundForm = {
|
|
53
|
+
body: string;
|
|
54
|
+
queryParams: QueryParam[];
|
|
55
|
+
urlParts: UrlPart[];
|
|
56
|
+
headers: Header[];
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
const Playground = ({
|
|
60
|
+
url,
|
|
61
|
+
host,
|
|
62
|
+
method,
|
|
63
|
+
defaultHeaders,
|
|
64
|
+
}: {
|
|
65
|
+
host: string;
|
|
66
|
+
url: string;
|
|
67
|
+
method: string;
|
|
68
|
+
defaultHeaders?: Header[];
|
|
69
|
+
}) => {
|
|
70
|
+
const { register, control, handleSubmit, watch } = useForm<PlaygroundForm>({
|
|
71
|
+
defaultValues: {
|
|
72
|
+
body: "",
|
|
73
|
+
queryParams: [{ name: "", value: "" }],
|
|
74
|
+
headers: defaultHeaders ?? [{ name: "", value: "" }],
|
|
75
|
+
urlParts: url
|
|
76
|
+
.split("/")
|
|
77
|
+
.filter((part) => part.startsWith("{") && part.endsWith("}"))
|
|
78
|
+
.map((part) => ({ name: part.slice(1, -1), value: "" })),
|
|
79
|
+
},
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
const formState = watch();
|
|
83
|
+
|
|
84
|
+
const x = useMutation({
|
|
85
|
+
mutationFn: async (data: PlaygroundForm) => {
|
|
86
|
+
const fullUrl =
|
|
87
|
+
host +
|
|
88
|
+
url
|
|
89
|
+
.split("/")
|
|
90
|
+
.map((v) =>
|
|
91
|
+
v.startsWith("{") && v.endsWith("}")
|
|
92
|
+
? data.urlParts.find((part) => part.name === v.slice(1, -1))
|
|
93
|
+
?.value ?? v
|
|
94
|
+
: v,
|
|
95
|
+
)
|
|
96
|
+
.join("/");
|
|
97
|
+
|
|
98
|
+
const response = await fetch(fullUrl, {
|
|
99
|
+
method: method.toUpperCase(),
|
|
100
|
+
headers: Object.fromEntries(
|
|
101
|
+
data.urlParts
|
|
102
|
+
.filter((h) => h.name)
|
|
103
|
+
.map((header) => [header.name, header.value]),
|
|
104
|
+
),
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
return {
|
|
108
|
+
status: response.status,
|
|
109
|
+
headers: response.headers,
|
|
110
|
+
body: await response.text(),
|
|
111
|
+
};
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
const path = url.split("/").map((part) => (
|
|
116
|
+
<Fragment key={part}>
|
|
117
|
+
{part.startsWith("{") && part.endsWith("}") ? (
|
|
118
|
+
<ColorizedParam
|
|
119
|
+
name={part.slice(1, -1)}
|
|
120
|
+
backgroundOpacity="0"
|
|
121
|
+
onClick={() => {
|
|
122
|
+
console.log("asd");
|
|
123
|
+
}}
|
|
124
|
+
slug={part.slice(1, -1)}
|
|
125
|
+
>
|
|
126
|
+
{
|
|
127
|
+
formState.urlParts.find((p) => {
|
|
128
|
+
console.log(
|
|
129
|
+
p.name,
|
|
130
|
+
part.slice(1, -1),
|
|
131
|
+
p.name === part.slice(1, -1),
|
|
132
|
+
p.value,
|
|
133
|
+
);
|
|
134
|
+
return p.name === part.slice(1, -1);
|
|
135
|
+
})?.value
|
|
136
|
+
}
|
|
137
|
+
</ColorizedParam>
|
|
138
|
+
) : (
|
|
139
|
+
part
|
|
140
|
+
)}
|
|
141
|
+
{"/"}
|
|
142
|
+
<wbr />
|
|
143
|
+
</Fragment>
|
|
144
|
+
));
|
|
145
|
+
|
|
146
|
+
const lang = mimeTypeToLanguage(x.data?.headers.get("Content-Type") ?? "");
|
|
147
|
+
|
|
148
|
+
return (
|
|
149
|
+
<Dialog>
|
|
150
|
+
<DialogTrigger>Open</DialogTrigger>
|
|
151
|
+
|
|
152
|
+
<DialogContent className="max-w-screen-xl w-full h-5/6">
|
|
153
|
+
<form
|
|
154
|
+
onSubmit={handleSubmit((data) => {
|
|
155
|
+
x.mutateAsync(data);
|
|
156
|
+
})}
|
|
157
|
+
>
|
|
158
|
+
<DialogHeader>
|
|
159
|
+
<DialogTitle className="mb-4">API Playground</DialogTitle>
|
|
160
|
+
<DialogDescription>
|
|
161
|
+
<div className="grid grid-cols-2 gap-2">
|
|
162
|
+
<Card>
|
|
163
|
+
<CardContent className="border-b border-border pt-4">
|
|
164
|
+
<div className="font-bold mb-1">URL</div>
|
|
165
|
+
<div className="flex gap-2 items-center">
|
|
166
|
+
<div className="border rounded border-border flex justify-stretch w-full">
|
|
167
|
+
<div className="border-r border-border p-2 bg-muted font-mono">
|
|
168
|
+
{method.toUpperCase()}
|
|
169
|
+
</div>
|
|
170
|
+
<div className="p-2 whitespace-nowrap overflow-scroll flex-1">
|
|
171
|
+
{path}
|
|
172
|
+
</div>
|
|
173
|
+
</div>
|
|
174
|
+
<Button type="submit">Send</Button>
|
|
175
|
+
</div>
|
|
176
|
+
</CardContent>
|
|
177
|
+
<Tabs defaultValue="parameters">
|
|
178
|
+
<CardContent className="border-b border-border py-4">
|
|
179
|
+
<TabsList>
|
|
180
|
+
<TabsTrigger value="parameters">Parameters</TabsTrigger>
|
|
181
|
+
<TabsTrigger value="headers">
|
|
182
|
+
Headers ({formState.headers.length - 1})
|
|
183
|
+
</TabsTrigger>
|
|
184
|
+
<TabsTrigger
|
|
185
|
+
value="body"
|
|
186
|
+
disabled={["POST", "PUT", "PATCH", "DELETE"].includes(
|
|
187
|
+
method.toUpperCase(),
|
|
188
|
+
)}
|
|
189
|
+
>
|
|
190
|
+
Body
|
|
191
|
+
</TabsTrigger>
|
|
192
|
+
</TabsList>
|
|
193
|
+
</CardContent>
|
|
194
|
+
<CardContent className="overflow-auto h-full">
|
|
195
|
+
<TabsContent value="headers">
|
|
196
|
+
<Headers
|
|
197
|
+
control={control}
|
|
198
|
+
register={register}
|
|
199
|
+
headers={formState.headers}
|
|
200
|
+
/>
|
|
201
|
+
</TabsContent>
|
|
202
|
+
<TabsContent value="parameters">
|
|
203
|
+
<UrlParts control={control} register={register} />
|
|
204
|
+
Query Parameters
|
|
205
|
+
<QueryParams
|
|
206
|
+
control={control}
|
|
207
|
+
queryParams={formState.queryParams}
|
|
208
|
+
register={register}
|
|
209
|
+
/>
|
|
210
|
+
</TabsContent>
|
|
211
|
+
<TabsContent value="auth">
|
|
212
|
+
<CardContent>
|
|
213
|
+
{url
|
|
214
|
+
.split("/")
|
|
215
|
+
.map((part, i) =>
|
|
216
|
+
part.startsWith("{") && part.endsWith("}")
|
|
217
|
+
? formState.urlParts[i]
|
|
218
|
+
: part,
|
|
219
|
+
)
|
|
220
|
+
.join("/")}
|
|
221
|
+
</CardContent>
|
|
222
|
+
Change your password here.
|
|
223
|
+
</TabsContent>
|
|
224
|
+
<TabsContent value="body">
|
|
225
|
+
<textarea
|
|
226
|
+
{...register("body")}
|
|
227
|
+
className="border border-border w-full rounded p-2 bg-muted h-40"
|
|
228
|
+
/>
|
|
229
|
+
</TabsContent>
|
|
230
|
+
</CardContent>
|
|
231
|
+
</Tabs>
|
|
232
|
+
</Card>
|
|
233
|
+
<Card>
|
|
234
|
+
<CardContent>
|
|
235
|
+
<div className="mt-2 font-mono gap-2 flex">
|
|
236
|
+
{method.toUpperCase()} {x.data?.status}{" "}
|
|
237
|
+
{url
|
|
238
|
+
.split("/")
|
|
239
|
+
.map((v) =>
|
|
240
|
+
v.startsWith("{") && v.endsWith("}")
|
|
241
|
+
? formState.urlParts.find((part) => part.name === v)
|
|
242
|
+
?.value ?? v
|
|
243
|
+
: v,
|
|
244
|
+
)
|
|
245
|
+
.join("/")}
|
|
246
|
+
</div>
|
|
247
|
+
|
|
248
|
+
<div className="w-full overflow-auto max-h-80 rounded-xl border border-border p-4 dark:!bg-foreground/10 dark:border-transparent">
|
|
249
|
+
{x.isPending && (
|
|
250
|
+
<>
|
|
251
|
+
<LoaderCircle size={18} className="animate-spins" /> a
|
|
252
|
+
request to see the response."
|
|
253
|
+
</>
|
|
254
|
+
)}
|
|
255
|
+
<SyntaxHighlight
|
|
256
|
+
language={lang ?? "json"}
|
|
257
|
+
noBackground
|
|
258
|
+
copyable={false}
|
|
259
|
+
className="overflow-x-auto "
|
|
260
|
+
code={x.data?.body ?? JSON.stringify("")}
|
|
261
|
+
/>
|
|
262
|
+
</div>
|
|
263
|
+
</CardContent>
|
|
264
|
+
</Card>
|
|
265
|
+
</div>
|
|
266
|
+
</DialogDescription>
|
|
267
|
+
</DialogHeader>
|
|
268
|
+
</form>
|
|
269
|
+
</DialogContent>
|
|
270
|
+
</Dialog>
|
|
271
|
+
);
|
|
272
|
+
};
|
|
273
|
+
|
|
274
|
+
export { Playground };
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Control,
|
|
3
|
+
Controller,
|
|
4
|
+
useFieldArray,
|
|
5
|
+
UseFormRegister,
|
|
6
|
+
} from "react-hook-form";
|
|
7
|
+
import { TrashIcon } from "lucide-react";
|
|
8
|
+
import { InlineInput } from "./InlineInput.js";
|
|
9
|
+
import { PlaygroundForm, QueryParam } from "./Playground.js";
|
|
10
|
+
import { useEffect } from "react";
|
|
11
|
+
|
|
12
|
+
export const QueryParams = ({
|
|
13
|
+
control,
|
|
14
|
+
register,
|
|
15
|
+
queryParams,
|
|
16
|
+
}: {
|
|
17
|
+
register: UseFormRegister<PlaygroundForm>;
|
|
18
|
+
control: Control<PlaygroundForm>;
|
|
19
|
+
queryParams: QueryParam[];
|
|
20
|
+
}) => {
|
|
21
|
+
const { fields, append, remove } = useFieldArray<PlaygroundForm>({
|
|
22
|
+
control,
|
|
23
|
+
name: "queryParams",
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
const queryCount = queryParams?.length;
|
|
27
|
+
const queryLastName = queryParams.at(-1)?.name;
|
|
28
|
+
const queryLastValue = queryParams.at(-1)?.value;
|
|
29
|
+
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
// if (queryCount === 0) {
|
|
32
|
+
// append({ name: "", value: "" });
|
|
33
|
+
// }
|
|
34
|
+
console.log(queryLastName, queryLastValue, queryCount);
|
|
35
|
+
if (queryLastName !== "" || queryLastValue !== "") {
|
|
36
|
+
console.log("appending");
|
|
37
|
+
append({ name: "", value: "" });
|
|
38
|
+
}
|
|
39
|
+
}, [append, queryLastValue, queryLastName, queryCount]);
|
|
40
|
+
|
|
41
|
+
return (
|
|
42
|
+
<div className="grid grid-cols-[1fr_1fr_auto]">
|
|
43
|
+
{fields.map((field, i) => (
|
|
44
|
+
<div
|
|
45
|
+
key={field.id}
|
|
46
|
+
className="grid-cols-subgrid col-span-full grid items-center gap-x-2 has-[:focus]:bg-muted hover:bg-muted rounded overflow-hidden group"
|
|
47
|
+
>
|
|
48
|
+
{field.id}
|
|
49
|
+
<Controller
|
|
50
|
+
control={control}
|
|
51
|
+
render={({ field }) => {
|
|
52
|
+
return (
|
|
53
|
+
<InlineInput {...field} placeholder="Name" className="peer" />
|
|
54
|
+
);
|
|
55
|
+
}}
|
|
56
|
+
name={`queryParams.${i}.name`}
|
|
57
|
+
/>
|
|
58
|
+
<Controller
|
|
59
|
+
control={control}
|
|
60
|
+
render={({ field }) => {
|
|
61
|
+
return (
|
|
62
|
+
<InlineInput {...field} placeholder="Value" className="peer" />
|
|
63
|
+
);
|
|
64
|
+
}}
|
|
65
|
+
name={`queryParams.${i}.value`}
|
|
66
|
+
/>
|
|
67
|
+
|
|
68
|
+
<button
|
|
69
|
+
className="hover:bg-black/5 p-1 rounded mr-2 text-muted-foreground invisible group-hover:visible peer-focus:visible"
|
|
70
|
+
onClick={() => remove(i)}
|
|
71
|
+
>
|
|
72
|
+
<TrashIcon size={16} />
|
|
73
|
+
</button>
|
|
74
|
+
<div className="col-span-full border-b border-border"></div>
|
|
75
|
+
</div>
|
|
76
|
+
))}
|
|
77
|
+
</div>
|
|
78
|
+
);
|
|
79
|
+
};
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { Control, useFieldArray, UseFormRegister } from "react-hook-form";
|
|
2
|
+
import { InlineInput } from "./InlineInput.js";
|
|
3
|
+
import { PlaygroundForm } from "./Playground.js";
|
|
4
|
+
import { DATA_ATTR, usePastellizedColor } from "../ColorizedParam.js";
|
|
5
|
+
import { forwardRef, InputHTMLAttributes } from "react";
|
|
6
|
+
import { cn } from "../../../util/cn.js";
|
|
7
|
+
|
|
8
|
+
type ParameterValueProps = {
|
|
9
|
+
part: string;
|
|
10
|
+
} & InputHTMLAttributes<HTMLInputElement>;
|
|
11
|
+
|
|
12
|
+
const ParameterValue = forwardRef<HTMLInputElement, ParameterValueProps>(
|
|
13
|
+
({ part, className, ...props }, ref) => {
|
|
14
|
+
const color = usePastellizedColor(part);
|
|
15
|
+
return (
|
|
16
|
+
<InlineInput
|
|
17
|
+
{...props}
|
|
18
|
+
ref={ref}
|
|
19
|
+
className={cn(className, "opacity-80 data-[active=true]:opacity-100")}
|
|
20
|
+
style={{
|
|
21
|
+
// color: `hsl(${color})`,
|
|
22
|
+
outlineColor: `hsl(${color})`,
|
|
23
|
+
}}
|
|
24
|
+
/>
|
|
25
|
+
);
|
|
26
|
+
},
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
export const UrlParts = ({
|
|
30
|
+
control,
|
|
31
|
+
register,
|
|
32
|
+
}: {
|
|
33
|
+
register: UseFormRegister<PlaygroundForm>;
|
|
34
|
+
control: Control<PlaygroundForm>;
|
|
35
|
+
}) => {
|
|
36
|
+
const { fields } = useFieldArray<PlaygroundForm>({
|
|
37
|
+
control,
|
|
38
|
+
name: "urlParts",
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
return (
|
|
42
|
+
<div className="grid grid-cols-[1fr_1fr_auto]">
|
|
43
|
+
{fields.map((part, i) => (
|
|
44
|
+
<div
|
|
45
|
+
key={part.id}
|
|
46
|
+
className="grid-cols-subgrid col-span-full grid items-center gap-x-2 has-[:focus]:bg-muted hover:bg-muted rounded overflow-hidden group"
|
|
47
|
+
>
|
|
48
|
+
<InlineInput
|
|
49
|
+
{...register(`urlParts.${i}.name`)}
|
|
50
|
+
disabled
|
|
51
|
+
placeholder="Name"
|
|
52
|
+
className="peer"
|
|
53
|
+
/>
|
|
54
|
+
<ParameterValue
|
|
55
|
+
{...register(`urlParts.${i}.value`)}
|
|
56
|
+
part={part.name}
|
|
57
|
+
{...{ [DATA_ATTR]: part.name }}
|
|
58
|
+
placeholder="Value"
|
|
59
|
+
className="peer"
|
|
60
|
+
/>
|
|
61
|
+
|
|
62
|
+
<div className="col-span-full border-b border-border"></div>
|
|
63
|
+
</div>
|
|
64
|
+
))}
|
|
65
|
+
</div>
|
|
66
|
+
);
|
|
67
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { createSharedWorkerClient } from "./openapi/worker/createSharedWorkerClient.js";
|
|
@@ -2,7 +2,7 @@ import { MDXProvider } from "@mdx-js/react";
|
|
|
2
2
|
import type { ComponentProps } from "react";
|
|
3
3
|
|
|
4
4
|
import { Link } from "react-router-dom";
|
|
5
|
-
import { Heading } from "../Heading.js";
|
|
5
|
+
import { Heading } from "../components/Heading.js";
|
|
6
6
|
import { SyntaxHighlight } from "../components/SyntaxHighlight.js";
|
|
7
7
|
import { Callout } from "../ui/Callout.js";
|
|
8
8
|
import { cn } from "./cn.js";
|