zudoku 0.0.0-fix-create-zudoku-run-build.fefccf58 → 0.0.0-reset-hash-value.ac516c6d
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 +32 -12
- package/dist/cli/cli.d.ts +9 -0
- package/dist/cli/cli.js +4 -10
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/common/version-check.d.ts +2 -0
- package/dist/cli/common/version-check.js +58 -0
- package/dist/cli/common/version-check.js.map +1 -0
- package/dist/config/config.d.ts +3 -0
- package/dist/config/validators/BuildSchema.d.ts +10 -3
- package/dist/config/validators/BuildSchema.js +14 -0
- package/dist/config/validators/BuildSchema.js.map +1 -1
- package/dist/config/validators/InputNavigationSchema.d.ts +192 -32
- package/dist/config/validators/InputNavigationSchema.js +1 -0
- package/dist/config/validators/InputNavigationSchema.js.map +1 -1
- package/dist/config/validators/icon-types.d.ts +1 -1
- package/dist/config/validators/icon-types.js +39 -0
- package/dist/config/validators/icon-types.js.map +1 -1
- package/dist/config/validators/validate.d.ts +39 -9
- package/dist/config/validators/validate.js +23 -0
- package/dist/config/validators/validate.js.map +1 -1
- package/dist/flat-config.d.ts +352 -0
- package/dist/lib/assets/language-icons/c.d.ts +3 -0
- package/dist/lib/assets/language-icons/c.js +4 -0
- package/dist/lib/assets/language-icons/c.js.map +1 -0
- package/dist/lib/assets/language-icons/commonlisp.d.ts +3 -0
- package/dist/lib/assets/language-icons/commonlisp.js +4 -0
- package/dist/lib/assets/language-icons/commonlisp.js.map +1 -0
- package/dist/lib/assets/language-icons/cpp.d.ts +3 -0
- package/dist/lib/assets/language-icons/cpp.js +4 -0
- package/dist/lib/assets/language-icons/cpp.js.map +1 -0
- package/dist/lib/assets/language-icons/csharp.d.ts +3 -0
- package/dist/lib/assets/language-icons/csharp.js +4 -0
- package/dist/lib/assets/language-icons/csharp.js.map +1 -0
- package/dist/lib/assets/language-icons/css.d.ts +3 -0
- package/dist/lib/assets/language-icons/css.js +4 -0
- package/dist/lib/assets/language-icons/css.js.map +1 -0
- package/dist/lib/assets/language-icons/dart.d.ts +3 -0
- package/dist/lib/assets/language-icons/dart.js +4 -0
- package/dist/lib/assets/language-icons/dart.js.map +1 -0
- package/dist/lib/assets/language-icons/elixir.d.ts +3 -0
- package/dist/lib/assets/language-icons/elixir.js +4 -0
- package/dist/lib/assets/language-icons/elixir.js.map +1 -0
- package/dist/lib/assets/language-icons/go.d.ts +3 -0
- package/dist/lib/assets/language-icons/go.js +4 -0
- package/dist/lib/assets/language-icons/go.js.map +1 -0
- package/dist/lib/assets/language-icons/graphql.d.ts +3 -0
- package/dist/lib/assets/language-icons/graphql.js +4 -0
- package/dist/lib/assets/language-icons/graphql.js.map +1 -0
- package/dist/lib/assets/language-icons/html.d.ts +3 -0
- package/dist/lib/assets/language-icons/html.js +4 -0
- package/dist/lib/assets/language-icons/html.js.map +1 -0
- package/dist/lib/assets/language-icons/java.d.ts +3 -0
- package/dist/lib/assets/language-icons/java.js +4 -0
- package/dist/lib/assets/language-icons/java.js.map +1 -0
- package/dist/lib/assets/language-icons/javascript.d.ts +3 -0
- package/dist/lib/assets/language-icons/javascript.js +4 -0
- package/dist/lib/assets/language-icons/javascript.js.map +1 -0
- package/dist/lib/assets/language-icons/json.d.ts +3 -0
- package/dist/lib/assets/language-icons/json.js +4 -0
- package/dist/lib/assets/language-icons/json.js.map +1 -0
- package/dist/lib/assets/language-icons/kotlin.d.ts +3 -0
- package/dist/lib/assets/language-icons/kotlin.js +4 -0
- package/dist/lib/assets/language-icons/kotlin.js.map +1 -0
- package/dist/lib/assets/language-icons/markdown.d.ts +3 -0
- package/dist/lib/assets/language-icons/markdown.js +4 -0
- package/dist/lib/assets/language-icons/markdown.js.map +1 -0
- package/dist/lib/assets/language-icons/mdx.d.ts +3 -0
- package/dist/lib/assets/language-icons/mdx.js +4 -0
- package/dist/lib/assets/language-icons/mdx.js.map +1 -0
- package/dist/lib/assets/language-icons/objectivec.d.ts +3 -0
- package/dist/lib/assets/language-icons/objectivec.js +4 -0
- package/dist/lib/assets/language-icons/objectivec.js.map +1 -0
- package/dist/lib/assets/language-icons/ocaml.d.ts +3 -0
- package/dist/lib/assets/language-icons/ocaml.js +4 -0
- package/dist/lib/assets/language-icons/ocaml.js.map +1 -0
- package/dist/lib/assets/language-icons/php.d.ts +3 -0
- package/dist/lib/assets/language-icons/php.js +4 -0
- package/dist/lib/assets/language-icons/php.js.map +1 -0
- package/dist/lib/assets/language-icons/powershell.d.ts +3 -0
- package/dist/lib/assets/language-icons/powershell.js +4 -0
- package/dist/lib/assets/language-icons/powershell.js.map +1 -0
- package/dist/lib/assets/language-icons/python.d.ts +3 -0
- package/dist/lib/assets/language-icons/python.js +4 -0
- package/dist/lib/assets/language-icons/python.js.map +1 -0
- package/dist/lib/assets/language-icons/react.d.ts +3 -0
- package/dist/lib/assets/language-icons/react.js +4 -0
- package/dist/lib/assets/language-icons/react.js.map +1 -0
- package/dist/lib/assets/language-icons/ruby.d.ts +3 -0
- package/dist/lib/assets/language-icons/ruby.js +4 -0
- package/dist/lib/assets/language-icons/ruby.js.map +1 -0
- package/dist/lib/assets/language-icons/rust.d.ts +3 -0
- package/dist/lib/assets/language-icons/rust.js +4 -0
- package/dist/lib/assets/language-icons/rust.js.map +1 -0
- package/dist/lib/assets/language-icons/scala.d.ts +3 -0
- package/dist/lib/assets/language-icons/scala.js +4 -0
- package/dist/lib/assets/language-icons/scala.js.map +1 -0
- package/dist/lib/assets/language-icons/shell.d.ts +3 -0
- package/dist/lib/assets/language-icons/shell.js +4 -0
- package/dist/lib/assets/language-icons/shell.js.map +1 -0
- package/dist/lib/assets/language-icons/swift.d.ts +3 -0
- package/dist/lib/assets/language-icons/swift.js +4 -0
- package/dist/lib/assets/language-icons/swift.js.map +1 -0
- package/dist/lib/assets/language-icons/toml.d.ts +3 -0
- package/dist/lib/assets/language-icons/toml.js +4 -0
- package/dist/lib/assets/language-icons/toml.js.map +1 -0
- package/dist/lib/assets/language-icons/typescript.d.ts +3 -0
- package/dist/lib/assets/language-icons/typescript.js +4 -0
- package/dist/lib/assets/language-icons/typescript.js.map +1 -0
- package/dist/lib/assets/language-icons/xml.d.ts +3 -0
- package/dist/lib/assets/language-icons/xml.js +4 -0
- package/dist/lib/assets/language-icons/xml.js.map +1 -0
- package/dist/lib/assets/language-icons/yaml.d.ts +3 -0
- package/dist/lib/assets/language-icons/yaml.js +4 -0
- package/dist/lib/assets/language-icons/yaml.js.map +1 -0
- package/dist/lib/assets/language-icons/zig.d.ts +3 -0
- package/dist/lib/assets/language-icons/zig.js +4 -0
- package/dist/lib/assets/language-icons/zig.js.map +1 -0
- package/dist/lib/authentication/providers/auth0.js +7 -3
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/openid.js +2 -0
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/state.d.ts +5 -3
- package/dist/lib/components/BuildCheck.js +2 -2
- package/dist/lib/components/BuildCheck.js.map +1 -1
- package/dist/lib/components/Heading.js +1 -5
- package/dist/lib/components/Heading.js.map +1 -1
- package/dist/lib/components/LanguageIcon.d.ts +3 -0
- package/dist/lib/components/LanguageIcon.js +163 -0
- package/dist/lib/components/LanguageIcon.js.map +1 -0
- package/dist/lib/components/Main.js +1 -1
- package/dist/lib/components/Main.js.map +1 -1
- package/dist/lib/components/Meta.js +1 -1
- package/dist/lib/components/Meta.js.map +1 -1
- package/dist/lib/components/cache.d.ts +3 -1
- package/dist/lib/components/cache.js +3 -5
- package/dist/lib/components/cache.js.map +1 -1
- package/dist/lib/components/context/ZudokuContext.js +10 -2
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/index.d.ts +12 -2
- package/dist/lib/components/index.js +2 -0
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/NavigationItem.js +1 -1
- package/dist/lib/components/navigation/NavigationItem.js.map +1 -1
- package/dist/lib/hooks/index.d.ts +1 -1
- package/dist/lib/oas/graphql/index.js +37 -2
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/plugins/api-catalog/Catalog.js +7 -1
- package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
- package/dist/lib/plugins/api-keys/CreateApiKeyDialog.d.ts +11 -0
- package/dist/lib/plugins/api-keys/CreateApiKeyDialog.js +9 -0
- package/dist/lib/plugins/api-keys/CreateApiKeyDialog.js.map +1 -0
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js +5 -10
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.js +27 -4
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/assets/ChatGPTLogo.d.ts +2 -0
- package/dist/lib/plugins/markdown/assets/ChatGPTLogo.js +3 -0
- package/dist/lib/plugins/markdown/assets/ChatGPTLogo.js.map +1 -0
- package/dist/lib/plugins/markdown/assets/ClaudeLogo.d.ts +2 -0
- package/dist/lib/plugins/markdown/assets/ClaudeLogo.js +3 -0
- package/dist/lib/plugins/markdown/assets/ClaudeLogo.js.map +1 -0
- package/dist/lib/plugins/markdown/index.d.ts +2 -1
- package/dist/lib/plugins/markdown/index.js.map +1 -1
- package/dist/lib/plugins/openapi/MCPEndpoint.d.ts +5 -0
- package/dist/lib/plugins/openapi/MCPEndpoint.js +56 -0
- package/dist/lib/plugins/openapi/MCPEndpoint.js.map +1 -0
- package/dist/lib/plugins/openapi/OperationList.d.ts +0 -2
- package/dist/lib/plugins/openapi/OperationList.js +22 -6
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.d.ts +2 -2
- package/dist/lib/plugins/openapi/OperationListItem.js +8 -3
- package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterList.d.ts +2 -2
- package/dist/lib/plugins/openapi/ParameterList.js +1 -1
- package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.d.ts +2 -3
- package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +3 -4
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js +1 -3
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.d.ts +2 -2
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
- package/dist/lib/plugins/openapi/Sidecar.d.ts +4 -3
- package/dist/lib/plugins/openapi/Sidecar.js +6 -9
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.d.ts +2 -4
- package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/fragment-masking.d.ts +1 -1
- package/dist/lib/plugins/openapi/graphql/fragment-masking.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +2 -2
- package/dist/lib/plugins/openapi/graphql/gql.js +3 -2
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +11 -2
- package/dist/lib/plugins/openapi/graphql/graphql.js +11 -0
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.js +1 -1
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +3 -2
- package/dist/lib/plugins/openapi/playground/BodyPanel.d.ts +2 -2
- package/dist/lib/plugins/openapi/playground/BodyPanel.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +3 -3
- package/dist/lib/plugins/openapi/playground/Playground.d.ts +2 -2
- package/dist/lib/plugins/openapi/playground/Playground.js +1 -1
- package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +3 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.d.ts +5 -3
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +15 -3
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.d.ts +5 -3
- package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.d.ts +2 -1
- package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js +2 -2
- package/dist/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaView.js +5 -5
- package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/UnionView.d.ts +2 -1
- package/dist/lib/plugins/openapi/schema/UnionView.js +13 -7
- package/dist/lib/plugins/openapi/schema/UnionView.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/union-helpers.js +25 -1
- package/dist/lib/plugins/openapi/schema/union-helpers.js.map +1 -1
- package/dist/lib/plugins/openapi/state.d.ts +5 -3
- package/dist/lib/shiki.js +13 -0
- package/dist/lib/shiki.js.map +1 -1
- package/dist/lib/ui/Carousel.js.map +1 -1
- package/dist/lib/ui/CodeBlock.d.ts +1 -1
- package/dist/lib/ui/CodeBlock.js +3 -28
- package/dist/lib/ui/CodeBlock.js.map +1 -1
- package/dist/lib/ui/EmbeddedCodeBlock.js +1 -1
- package/dist/lib/ui/EmbeddedCodeBlock.js.map +1 -1
- package/dist/lib/ui/ReactComponentDoc.d.ts +20 -0
- package/dist/lib/ui/ReactComponentDoc.js +10 -0
- package/dist/lib/ui/ReactComponentDoc.js.map +1 -0
- package/dist/lib/ui/Secret.d.ts +18 -0
- package/dist/lib/ui/Secret.js +26 -0
- package/dist/lib/ui/Secret.js.map +1 -0
- package/dist/lib/ui/Value.d.ts +5 -0
- package/dist/lib/ui/Value.js +13 -0
- package/dist/lib/ui/Value.js.map +1 -0
- package/dist/lib/util/MdxComponents.js +1 -1
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/lib/util/pastellize.js +4 -4
- package/dist/lib/util/pastellize.js.map +1 -1
- package/dist/lib/util/traverse.d.ts +1 -0
- package/dist/lib/util/traverse.js +25 -0
- package/dist/lib/util/traverse.js.map +1 -1
- package/dist/vite/api/SchemaManager.js +10 -6
- package/dist/vite/api/SchemaManager.js.map +1 -1
- package/dist/vite/api/schema-codegen.js +60 -41
- package/dist/vite/api/schema-codegen.js.map +1 -1
- package/dist/vite/api/schema-codegen.test.js +75 -2
- package/dist/vite/api/schema-codegen.test.js.map +1 -1
- package/dist/vite/llms.d.ts +12 -0
- package/dist/vite/llms.js +66 -0
- package/dist/vite/llms.js.map +1 -0
- package/dist/vite/plugin-api.js +4 -12
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-docs.d.ts +9 -0
- package/dist/vite/plugin-docs.js +67 -44
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-markdown-export.d.ts +21 -0
- package/dist/vite/plugin-markdown-export.js +139 -0
- package/dist/vite/plugin-markdown-export.js.map +1 -0
- package/dist/vite/plugin-mdx.d.ts +1 -1
- package/dist/vite/plugin-mdx.js +7 -4
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/plugin-navigation.js +4 -0
- package/dist/vite/plugin-navigation.js.map +1 -1
- package/dist/vite/plugin.js +2 -0
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/prerender/prerender.js +37 -4
- package/dist/vite/prerender/prerender.js.map +1 -1
- package/dist/zuplo/enrich-with-zuplo-mcp.d.ts +4 -0
- package/dist/zuplo/enrich-with-zuplo-mcp.js +117 -0
- package/dist/zuplo/enrich-with-zuplo-mcp.js.map +1 -0
- package/dist/zuplo/enrich-with-zuplo.d.ts +1 -0
- package/dist/zuplo/enrich-with-zuplo.js +1 -1
- package/dist/zuplo/enrich-with-zuplo.js.map +1 -1
- package/dist/zuplo/with-zuplo-processors.js +2 -0
- package/dist/zuplo/with-zuplo-processors.js.map +1 -1
- package/lib/{Button-B3o-2Xdf.js → Button-DmS4u8Lj.js} +2 -2
- package/lib/{Button-B3o-2Xdf.js.map → Button-DmS4u8Lj.js.map} +1 -1
- package/lib/{Card-CMDQUPM4.js → Card-KFniaZn5.js} +2 -2
- package/lib/{Card-CMDQUPM4.js.map → Card-KFniaZn5.js.map} +1 -1
- package/lib/{CategoryHeading-DCpZu3yG.js → CategoryHeading-DhmodDcq.js} +2 -2
- package/lib/{CategoryHeading-DCpZu3yG.js.map → CategoryHeading-DhmodDcq.js.map} +1 -1
- package/lib/CodeBlock-CanTUJLl.js +221 -0
- package/lib/CodeBlock-CanTUJLl.js.map +1 -0
- package/lib/{Command-CUSlH0gJ.js → Command-CJY6q3PF.js} +3 -3
- package/lib/{Command-CUSlH0gJ.js.map → Command-CJY6q3PF.js.map} +1 -1
- package/lib/{Dialog-BmgXWOaz.js → Dialog-BOl0QB3n.js} +2 -2
- package/lib/{Dialog-BmgXWOaz.js.map → Dialog-BOl0QB3n.js.map} +1 -1
- package/lib/{Drawer-DJ05s2pH.js → Drawer-Ci7XwhqT.js} +2 -2
- package/lib/{Drawer-DJ05s2pH.js.map → Drawer-Ci7XwhqT.js.map} +1 -1
- package/lib/DropdownMenu-BZ2NKQ3K.js +126 -0
- package/lib/DropdownMenu-BZ2NKQ3K.js.map +1 -0
- package/lib/{Slot-BbdqiRXo.js → ErrorAlert-VBJ8aHH7.js} +1865 -1879
- package/lib/ErrorAlert-VBJ8aHH7.js.map +1 -0
- package/lib/MdxPage-DFRNwSsc.js +239 -0
- package/lib/MdxPage-DFRNwSsc.js.map +1 -0
- package/lib/{OAuthErrorPage-rAKHHveX.js → OAuthErrorPage-DJUOdr6Q.js} +8 -8
- package/lib/{OAuthErrorPage-rAKHHveX.js.map → OAuthErrorPage-DJUOdr6Q.js.map} +1 -1
- package/lib/{OasProvider-BW4OzAuR.js → OasProvider-BMUgPYQU.js} +4 -4
- package/lib/{OasProvider-BW4OzAuR.js.map → OasProvider-BMUgPYQU.js.map} +1 -1
- package/lib/OperationList-DVig5I94.js +5446 -0
- package/lib/OperationList-DVig5I94.js.map +1 -0
- package/lib/{Pagination-ZI2yyuxj.js → Pagination-CT4VUR6u.js} +4 -4
- package/lib/{Pagination-ZI2yyuxj.js.map → Pagination-CT4VUR6u.js.map} +1 -1
- package/lib/{RouteGuard-BIksrt_C.js → RouteGuard-BPWQlxy5.js} +9 -9
- package/lib/{RouteGuard-BIksrt_C.js.map → RouteGuard-BPWQlxy5.js.map} +1 -1
- package/lib/{RouterError-BYHrbLtD.js → RouterError-fm21cqlj.js} +5 -5
- package/lib/{RouterError-BYHrbLtD.js.map → RouterError-fm21cqlj.js.map} +1 -1
- package/lib/{SchemaList-C4Sk-tLI.js → SchemaList-1eLKXqn8.js} +10 -10
- package/lib/{SchemaList-C4Sk-tLI.js.map → SchemaList-1eLKXqn8.js.map} +1 -1
- package/lib/SchemaView-fq3uKfOA.js +458 -0
- package/lib/SchemaView-fq3uKfOA.js.map +1 -0
- package/lib/Select-CPoGZU_V.js +372 -0
- package/lib/Select-CPoGZU_V.js.map +1 -0
- package/lib/{SignUp-CznaQsRx.js → SignUp-BraHuRN_.js} +12 -12
- package/lib/{SignUp-CznaQsRx.js.map → SignUp-BraHuRN_.js.map} +1 -1
- package/lib/{Spinner-mNLZ6awP.js → Spinner-CI6bRyZw.js} +2 -2
- package/lib/{Spinner-mNLZ6awP.js.map → Spinner-CI6bRyZw.js.map} +1 -1
- package/lib/{SyntaxHighlight-CvzJ7DNa.js → SyntaxHighlight-B0laqAqK.js} +293 -273
- package/lib/SyntaxHighlight-B0laqAqK.js.map +1 -0
- package/lib/{Toc-BAa-kpqN.js → Toc-KzXCRqrX.js} +3 -3
- package/lib/{Toc-BAa-kpqN.js.map → Toc-KzXCRqrX.js.map} +1 -1
- package/lib/ZudokuContext-BXTZApgy.js +1506 -0
- package/lib/ZudokuContext-BXTZApgy.js.map +1 -0
- package/lib/c-B-NUhs61.js +46 -0
- package/lib/c-B-NUhs61.js.map +1 -0
- package/lib/chunk-PVWAREVJ-BO6B-RAk.js +7965 -0
- package/lib/chunk-PVWAREVJ-BO6B-RAk.js.map +1 -0
- package/lib/{circular-BFte5TUt.js → circular-D6wbrxuf.js} +30 -30
- package/lib/{circular-BFte5TUt.js.map → circular-D6wbrxuf.js.map} +1 -1
- package/lib/commonlisp-De080z23.js +28 -0
- package/lib/commonlisp-De080z23.js.map +1 -0
- package/lib/cpp-79Paht7T.js +53 -0
- package/lib/cpp-79Paht7T.js.map +1 -0
- package/lib/{createServer-B4giw6jv.js → createServer-C5aY10Bc.js} +3411 -3342
- package/lib/createServer-C5aY10Bc.js.map +1 -0
- package/lib/csharp-D8MIL50B.js +53 -0
- package/lib/csharp-D8MIL50B.js.map +1 -0
- package/lib/css-Bt6hr1td.js +54 -0
- package/lib/css-Bt6hr1td.js.map +1 -0
- package/lib/dart-B0vy1jWB.js +60 -0
- package/lib/dart-B0vy1jWB.js.map +1 -0
- package/lib/elixir-Ds8r0sF8.js +25 -0
- package/lib/elixir-Ds8r0sF8.js.map +1 -0
- package/lib/{errors-CjmCml50.js → errors-XqO6MsfU.js} +3 -3
- package/lib/{errors-CjmCml50.js.map → errors-XqO6MsfU.js.map} +1 -1
- package/lib/go-D2VsmIOS.js +25 -0
- package/lib/go-D2VsmIOS.js.map +1 -0
- package/lib/graphql-BtA6M4m5.js +25 -0
- package/lib/graphql-BtA6M4m5.js.map +1 -0
- package/lib/hook-CAebs2rv.js +31 -0
- package/lib/hook-CAebs2rv.js.map +1 -0
- package/lib/html-MGnI2uzP.js +33 -0
- package/lib/html-MGnI2uzP.js.map +1 -0
- package/lib/{index-BuKx9nrj.js → index-BPSpOxTK.js} +103 -102
- package/lib/index-BPSpOxTK.js.map +1 -0
- package/lib/{index-Dp3Fmnfq.js → index-Bb9AsFlk.js} +702 -778
- package/lib/index-Bb9AsFlk.js.map +1 -0
- package/lib/{index-CQGi1b3U.js → index-C5L4favO.js} +166 -50
- package/lib/index-C5L4favO.js.map +1 -0
- package/lib/index-CrcNWbel.js.map +1 -1
- package/lib/{index-DmNq2fbN.js → index-nGbmHh_A.js} +2 -2
- package/lib/index-nGbmHh_A.js.map +1 -0
- package/lib/index.esm-BYObtETB.js +1294 -0
- package/lib/index.esm-BYObtETB.js.map +1 -0
- package/lib/index.esm-BnYHxCYC.js.map +1 -1
- package/lib/java-CVLzHfb1.js +53 -0
- package/lib/java-CVLzHfb1.js.map +1 -0
- package/lib/javascript-CcmIpL4G.js +10 -0
- package/lib/javascript-CcmIpL4G.js.map +1 -0
- package/lib/json-4AyP4uiY.js +25 -0
- package/lib/json-4AyP4uiY.js.map +1 -0
- package/lib/{jsx-runtime-C5mzlN2N.js → jsx-runtime-BzflLqGi.js} +110 -112
- package/lib/jsx-runtime-BzflLqGi.js.map +1 -0
- package/lib/kotlin-v2plddBQ.js +37 -0
- package/lib/kotlin-v2plddBQ.js.map +1 -0
- package/lib/markdown-DYGWCmGQ.js +25 -0
- package/lib/markdown-DYGWCmGQ.js.map +1 -0
- package/lib/mdx-CHwYvXd4.js +32 -0
- package/lib/mdx-CHwYvXd4.js.map +1 -0
- package/lib/{mutation-CiMUdKRU.js → mutation-CdGPxHNX.js} +2 -2
- package/lib/{mutation-CiMUdKRU.js.map → mutation-CdGPxHNX.js.map} +1 -1
- package/lib/objectivec-HZY8shkd.js +32 -0
- package/lib/objectivec-HZY8shkd.js.map +1 -0
- package/lib/ocaml-DqsdDdwb.js +52 -0
- package/lib/ocaml-DqsdDdwb.js.map +1 -0
- package/lib/php-rQXzo7K_.js +25 -0
- package/lib/php-rQXzo7K_.js.map +1 -0
- package/lib/powershell-CQje9pm1.js +39 -0
- package/lib/powershell-CQje9pm1.js.map +1 -0
- package/lib/processors/traverse.js.map +1 -1
- package/lib/python-QIQAE5Ei.js +32 -0
- package/lib/python-QIQAE5Ei.js.map +1 -0
- package/lib/react-DHpVpxRv.js +24 -0
- package/lib/react-DHpVpxRv.js.map +1 -0
- package/lib/ruby-B2dU8Ny5.js +25 -0
- package/lib/ruby-B2dU8Ny5.js.map +1 -0
- package/lib/rust-DYnLHAi2.js +25 -0
- package/lib/rust-DYnLHAi2.js.map +1 -0
- package/lib/scala-CeKInBR8.js +25 -0
- package/lib/scala-CeKInBR8.js.map +1 -0
- package/lib/shell-HUv9oVtp.js +25 -0
- package/lib/shell-HUv9oVtp.js.map +1 -0
- package/lib/swift-B4z6ig1Z.js +25 -0
- package/lib/swift-B4z6ig1Z.js.map +1 -0
- package/lib/toml-Co9mpdct.js +32 -0
- package/lib/toml-Co9mpdct.js.map +1 -0
- package/lib/typescript-C26xdBDC.js +32 -0
- package/lib/typescript-C26xdBDC.js.map +1 -0
- package/lib/ui/Accordion.js +1 -1
- package/lib/ui/ActionButton.js +3 -3
- package/lib/ui/Alert.js +1 -1
- package/lib/ui/AlertDialog.js +1 -1
- package/lib/ui/Badge.js +1 -1
- package/lib/ui/Breadcrumb.js +1 -1
- package/lib/ui/Button.js +1 -1
- package/lib/ui/Callout.js +1 -1
- package/lib/ui/Card.js +1 -1
- package/lib/ui/Carousel.js +1 -1
- package/lib/ui/Carousel.js.map +1 -1
- package/lib/ui/Checkbox.js +1 -1
- package/lib/ui/CodeBlock.js +4 -3
- package/lib/ui/CodeBlock.js.map +1 -1
- package/lib/ui/Command.js +2 -2
- package/lib/ui/Dialog.js +1 -1
- package/lib/ui/Drawer.js +2 -2
- package/lib/ui/DropdownMenu.js +1 -1
- package/lib/ui/EmbeddedCodeBlock.js +4 -4
- package/lib/ui/EmbeddedCodeBlock.js.map +1 -1
- package/lib/ui/Form.js +2 -2
- package/lib/ui/HoverCard.js +1 -1
- package/lib/ui/Input.js +1 -1
- package/lib/ui/Label.js +1 -1
- package/lib/ui/Pagination.js +1 -1
- package/lib/ui/Popover.js +1 -1
- package/lib/ui/Progress.js +1 -1
- package/lib/ui/RadioGroup.js +1 -1
- package/lib/ui/ReactComponentDoc.js +28 -0
- package/lib/ui/ReactComponentDoc.js.map +1 -0
- package/lib/ui/ScrollArea.js +1 -1
- package/lib/ui/Secret.js +106 -0
- package/lib/ui/Secret.js.map +1 -0
- package/lib/ui/Select.js +1 -1
- package/lib/ui/Skeleton.js +1 -1
- package/lib/ui/Slider.js +1 -1
- package/lib/ui/Stepper.js +1 -1
- package/lib/ui/Switch.js +1 -1
- package/lib/ui/SyntaxHighlight.js +4 -4
- package/lib/ui/Tabs.js +1 -1
- package/lib/ui/Textarea.js +1 -1
- package/lib/ui/Toggle.js +1 -1
- package/lib/ui/ToggleGroup.js +1 -1
- package/lib/ui/Tooltip.js +1 -1
- package/lib/ui/Value.js +39 -0
- package/lib/ui/Value.js.map +1 -0
- package/lib/useCopyToClipboard-B_085nfO.js +14 -0
- package/lib/useCopyToClipboard-B_085nfO.js.map +1 -0
- package/lib/{useExposedProps-BH9aq4MD.js → useExposedProps-Cd7Yg_uG.js} +34 -34
- package/lib/{useExposedProps-BH9aq4MD.js.map → useExposedProps-Cd7Yg_uG.js.map} +1 -1
- package/lib/xml-BQOOC04j.js +25 -0
- package/lib/xml-BQOOC04j.js.map +1 -0
- package/lib/yaml-BGsJItKv.js +32 -0
- package/lib/yaml-BGsJItKv.js.map +1 -0
- package/lib/zig-CUV2sTct.js +35 -0
- package/lib/zig-CUV2sTct.js.map +1 -0
- package/lib/zudoku.__internal.js +1050 -940
- package/lib/zudoku.__internal.js.map +1 -1
- package/lib/zudoku.auth-auth0.js +22 -21
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-azureb2c.js +14 -15
- package/lib/zudoku.auth-azureb2c.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +3 -3
- package/lib/zudoku.auth-openid.js +59 -60
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.auth-supabase.js +2 -2
- package/lib/zudoku.components.js +21 -20
- package/lib/zudoku.hooks.js +6 -6
- package/lib/zudoku.hooks.js.map +1 -1
- package/lib/zudoku.icons.js +1 -1
- package/lib/zudoku.plugin-api-catalog.js +34 -28
- package/lib/zudoku.plugin-api-catalog.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +255 -280
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +1 -1
- package/lib/zudoku.plugin-markdown.js +2 -2
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +5 -5
- package/lib/zudoku.plugin-redirect.js +3 -3
- package/lib/zudoku.plugin-search-inkeep.js +1 -1
- package/lib/zudoku.plugin-search-pagefind.js +28 -29
- package/lib/zudoku.plugin-search-pagefind.js.map +1 -1
- package/lib/zudoku.router.js +2502 -118
- package/lib/zudoku.router.js.map +1 -1
- package/package.json +67 -64
- package/src/app/main.css +10 -10
- package/src/lib/assets/language-icons/c.tsx +31 -0
- package/src/lib/assets/language-icons/commonlisp.tsx +22 -0
- package/src/lib/assets/language-icons/cpp.tsx +35 -0
- package/src/lib/assets/language-icons/csharp.tsx +35 -0
- package/src/lib/assets/language-icons/css.tsx +36 -0
- package/src/lib/assets/language-icons/dart.tsx +39 -0
- package/src/lib/assets/language-icons/elixir.tsx +19 -0
- package/src/lib/assets/language-icons/go.tsx +19 -0
- package/src/lib/assets/language-icons/graphql.tsx +19 -0
- package/src/lib/assets/language-icons/html.tsx +24 -0
- package/src/lib/assets/language-icons/java.tsx +35 -0
- package/src/lib/assets/language-icons/javascript.tsx +11 -0
- package/src/lib/assets/language-icons/json.tsx +19 -0
- package/src/lib/assets/language-icons/kotlin.tsx +30 -0
- package/src/lib/assets/language-icons/markdown.tsx +19 -0
- package/src/lib/assets/language-icons/mdx.tsx +23 -0
- package/src/lib/assets/language-icons/objectivec.tsx +23 -0
- package/src/lib/assets/language-icons/ocaml.tsx +34 -0
- package/src/lib/assets/language-icons/php.tsx +19 -0
- package/src/lib/assets/language-icons/powershell.tsx +27 -0
- package/src/lib/assets/language-icons/python.tsx +23 -0
- package/src/lib/assets/language-icons/react.tsx +21 -0
- package/src/lib/assets/language-icons/ruby.tsx +19 -0
- package/src/lib/assets/language-icons/rust.tsx +19 -0
- package/src/lib/assets/language-icons/scala.tsx +19 -0
- package/src/lib/assets/language-icons/shell.tsx +19 -0
- package/src/lib/assets/language-icons/swift.tsx +19 -0
- package/src/lib/assets/language-icons/toml.tsx +23 -0
- package/src/lib/assets/language-icons/typescript.tsx +23 -0
- package/src/lib/assets/language-icons/xml.tsx +19 -0
- package/src/lib/assets/language-icons/yaml.tsx +23 -0
- package/src/lib/assets/language-icons/zig.tsx +32 -0
- package/src/lib/authentication/providers/auth0.tsx +7 -3
- package/src/lib/authentication/providers/openid.tsx +2 -0
- package/src/lib/authentication/use-broadcast/LICENSE.md +12 -3
- package/src/lib/components/BuildCheck.tsx +12 -10
- package/src/lib/components/Heading.tsx +2 -6
- package/src/lib/components/LanguageIcon.tsx +181 -0
- package/src/lib/components/Main.tsx +1 -1
- package/src/lib/components/Meta.tsx +13 -0
- package/src/lib/components/cache.ts +9 -5
- package/src/lib/components/context/ZudokuContext.ts +11 -2
- package/src/lib/components/index.ts +2 -0
- package/src/lib/components/navigation/NavigationItem.tsx +1 -1
- package/src/lib/oas/graphql/index.ts +37 -2
- package/src/lib/plugins/api-catalog/Catalog.tsx +7 -0
- package/src/lib/plugins/api-keys/CreateApiKeyDialog.tsx +49 -0
- package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +18 -64
- package/src/lib/plugins/markdown/MdxPage.tsx +123 -9
- package/src/lib/plugins/markdown/assets/ChatGPTLogo.tsx +11 -0
- package/src/lib/plugins/markdown/assets/ClaudeLogo.tsx +19 -0
- package/src/lib/plugins/markdown/index.tsx +3 -7
- package/src/lib/plugins/openapi/MCPEndpoint.tsx +273 -0
- package/src/lib/plugins/openapi/OperationList.tsx +30 -10
- package/src/lib/plugins/openapi/OperationListItem.tsx +107 -81
- package/src/lib/plugins/openapi/ParameterList.tsx +3 -5
- package/src/lib/plugins/openapi/ParameterListItem.tsx +3 -9
- package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +6 -11
- package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +3 -2
- package/src/lib/plugins/openapi/Sidecar.tsx +10 -10
- package/src/lib/plugins/openapi/SidecarExamples.tsx +2 -9
- package/src/lib/plugins/openapi/graphql/fragment-masking.ts +2 -1
- package/src/lib/plugins/openapi/graphql/gql.ts +7 -6
- package/src/lib/plugins/openapi/graphql/graphql.ts +26 -3
- package/src/lib/plugins/openapi/index.tsx +1 -1
- package/src/lib/plugins/openapi/interfaces.ts +3 -2
- package/src/lib/plugins/openapi/playground/BodyPanel.tsx +2 -2
- package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +3 -3
- package/src/lib/plugins/openapi/playground/Playground.tsx +3 -3
- package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +12 -1
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +31 -3
- package/src/lib/plugins/openapi/schema/AllOfGroup/AllOfGroupView.tsx +11 -4
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +18 -12
- package/src/lib/plugins/openapi/schema/UnionView.tsx +56 -36
- package/src/lib/plugins/openapi/schema/union-helpers.ts +30 -2
- package/src/lib/shiki.ts +13 -0
- package/src/lib/ui/Carousel.tsx +0 -1
- package/src/lib/ui/CodeBlock.tsx +7 -42
- package/src/lib/ui/EmbeddedCodeBlock.tsx +1 -1
- package/src/lib/ui/ReactComponentDoc.tsx +68 -0
- package/src/lib/ui/Secret.tsx +123 -0
- package/src/lib/ui/Value.tsx +42 -0
- package/src/lib/util/MdxComponents.tsx +4 -1
- package/src/lib/util/pastellize.ts +4 -4
- package/src/lib/util/traverse.ts +36 -0
- package/src/shiki/langs/hurl.js +1 -0
- package/src/shiki/langs/kdl.js +1 -0
- package/src/shiki/langs/pkl.js +1 -0
- package/src/shiki/langs/rosmsg.js +1 -0
- package/lib/CodeBlock-CX_J17Hf.js +0 -98
- package/lib/CodeBlock-CX_J17Hf.js.map +0 -1
- package/lib/MdxPage-yXbTtcWf.js +0 -111
- package/lib/MdxPage-yXbTtcWf.js.map +0 -1
- package/lib/OperationList-CWxpdIbO.js +0 -5165
- package/lib/OperationList-CWxpdIbO.js.map +0 -1
- package/lib/SchemaView-B2BeAuci.js +0 -429
- package/lib/SchemaView-B2BeAuci.js.map +0 -1
- package/lib/Select-DWh0wSay.js +0 -273
- package/lib/Select-DWh0wSay.js.map +0 -1
- package/lib/Slot-BbdqiRXo.js.map +0 -1
- package/lib/SyntaxHighlight-CvzJ7DNa.js.map +0 -1
- package/lib/ZudokuContext-BR-lnR7O.js +0 -1285
- package/lib/ZudokuContext-BR-lnR7O.js.map +0 -1
- package/lib/chunk-QMGIS6GS-DqecZ6nq.js +0 -9204
- package/lib/chunk-QMGIS6GS-DqecZ6nq.js.map +0 -1
- package/lib/createServer-B4giw6jv.js.map +0 -1
- package/lib/hook-B4Q30zMI.js +0 -247
- package/lib/hook-B4Q30zMI.js.map +0 -1
- package/lib/index-BuKx9nrj.js.map +0 -1
- package/lib/index-CQGi1b3U.js.map +0 -1
- package/lib/index-DmNq2fbN.js.map +0 -1
- package/lib/index-Dp3Fmnfq.js.map +0 -1
- package/lib/index.esm-CdzlRw50.js +0 -1254
- package/lib/index.esm-CdzlRw50.js.map +0 -1
- package/lib/jsx-runtime-C5mzlN2N.js.map +0 -1
|
@@ -3,7 +3,7 @@ import { useFormContext } from "react-hook-form";
|
|
|
3
3
|
import { Collapsible, CollapsibleContent } from "zudoku/ui/Collapsible.js";
|
|
4
4
|
import { Textarea } from "zudoku/ui/Textarea.js";
|
|
5
5
|
import { cn } from "../../../util/cn.js";
|
|
6
|
-
import type {
|
|
6
|
+
import type { MediaTypeObject } from "../graphql/graphql.js";
|
|
7
7
|
import {
|
|
8
8
|
CollapsibleHeader,
|
|
9
9
|
CollapsibleHeaderTrigger,
|
|
@@ -11,7 +11,7 @@ import {
|
|
|
11
11
|
import ExamplesDropdown from "./ExamplesDropdown.js";
|
|
12
12
|
import type { PlaygroundForm } from "./Playground.js";
|
|
13
13
|
|
|
14
|
-
export const BodyPanel = ({ content }: { content?:
|
|
14
|
+
export const BodyPanel = ({ content }: { content?: MediaTypeObject[] }) => {
|
|
15
15
|
const { register, setValue, watch } = useFormContext<PlaygroundForm>();
|
|
16
16
|
const examples = (content ?? []).flatMap((e) => e.examples);
|
|
17
17
|
const headers = watch("headers");
|
|
@@ -9,14 +9,14 @@ import {
|
|
|
9
9
|
DropdownMenuSeparator,
|
|
10
10
|
DropdownMenuTrigger,
|
|
11
11
|
} from "zudoku/ui/DropdownMenu.js";
|
|
12
|
-
import type {
|
|
12
|
+
import type { ExampleItem, MediaTypeObject } from "../graphql/graphql.js";
|
|
13
13
|
|
|
14
14
|
const ExamplesDropdown = ({
|
|
15
15
|
examples,
|
|
16
16
|
onSelect,
|
|
17
17
|
}: {
|
|
18
|
-
examples:
|
|
19
|
-
onSelect: (example:
|
|
18
|
+
examples: MediaTypeObject[];
|
|
19
|
+
onSelect: (example: ExampleItem, mediaType: string) => void;
|
|
20
20
|
}) => {
|
|
21
21
|
return (
|
|
22
22
|
<DropdownMenu>
|
|
@@ -23,7 +23,7 @@ import { useHotkey } from "../../../hooks/useHotkey.js";
|
|
|
23
23
|
import { cn } from "../../../util/cn.js";
|
|
24
24
|
import { useCopyToClipboard } from "../../../util/useCopyToClipboard.js";
|
|
25
25
|
import { useLatest } from "../../../util/useLatest.js";
|
|
26
|
-
import type {
|
|
26
|
+
import type { MediaTypeObject } from "../graphql/graphql.js";
|
|
27
27
|
import { useSelectedServer } from "../state.js";
|
|
28
28
|
import BodyPanel from "./BodyPanel.js";
|
|
29
29
|
import {
|
|
@@ -117,7 +117,7 @@ export type PlaygroundContentProps = {
|
|
|
117
117
|
queryParams?: QueryParam[];
|
|
118
118
|
pathParams?: PathParam[];
|
|
119
119
|
defaultBody?: string;
|
|
120
|
-
examples?:
|
|
120
|
+
examples?: MediaTypeObject[];
|
|
121
121
|
requiresLogin?: boolean;
|
|
122
122
|
onLogin?: () => void;
|
|
123
123
|
onSignUp?: () => void;
|
|
@@ -285,7 +285,7 @@ export const Playground = ({
|
|
|
285
285
|
return {
|
|
286
286
|
status: response.status,
|
|
287
287
|
headers: responseHeaders,
|
|
288
|
-
size: responseSize ?
|
|
288
|
+
size: responseSize ? Number(responseSize) : body.length,
|
|
289
289
|
body,
|
|
290
290
|
time,
|
|
291
291
|
isBinary,
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { VisuallyHidden } from "@radix-ui/react-visually-hidden";
|
|
2
2
|
import { type PropsWithChildren, useState } from "react";
|
|
3
|
+
import { useAuth } from "zudoku/hooks";
|
|
3
4
|
import {
|
|
4
5
|
Dialog,
|
|
5
6
|
DialogContent,
|
|
@@ -35,6 +36,9 @@ const HeroPlayIcon = ({
|
|
|
35
36
|
|
|
36
37
|
const PlaygroundDialog = (props: PlaygroundDialogProps) => {
|
|
37
38
|
const [open, setOpen] = useState(false);
|
|
39
|
+
const { isAuthEnabled, login, signup, isPending, isAuthenticated } =
|
|
40
|
+
useAuth();
|
|
41
|
+
|
|
38
42
|
return (
|
|
39
43
|
<Dialog onOpenChange={(open) => setOpen(open)}>
|
|
40
44
|
<DialogTrigger asChild>
|
|
@@ -57,7 +61,14 @@ const PlaygroundDialog = (props: PlaygroundDialogProps) => {
|
|
|
57
61
|
<VisuallyHidden>
|
|
58
62
|
<DialogTitle>Playground</DialogTitle>
|
|
59
63
|
</VisuallyHidden>
|
|
60
|
-
{open &&
|
|
64
|
+
{open && (
|
|
65
|
+
<Playground
|
|
66
|
+
requiresLogin={isAuthEnabled && !isAuthenticated && !isPending}
|
|
67
|
+
onLogin={() => login()}
|
|
68
|
+
onSignUp={() => signup()}
|
|
69
|
+
{...props}
|
|
70
|
+
/>
|
|
71
|
+
)}
|
|
61
72
|
</DialogContent>
|
|
62
73
|
</Dialog>
|
|
63
74
|
);
|
|
@@ -3,6 +3,8 @@ import {
|
|
|
3
3
|
CornerDownLeftIcon,
|
|
4
4
|
CornerDownRightIcon,
|
|
5
5
|
DownloadIcon,
|
|
6
|
+
EyeIcon,
|
|
7
|
+
EyeOffIcon,
|
|
6
8
|
PlusCircleIcon,
|
|
7
9
|
} from "lucide-react";
|
|
8
10
|
import { useState } from "react";
|
|
@@ -12,6 +14,7 @@ import {
|
|
|
12
14
|
CollapsibleContent,
|
|
13
15
|
CollapsibleTrigger,
|
|
14
16
|
} from "zudoku/ui/Collapsible.js";
|
|
17
|
+
import { SecretText } from "zudoku/ui/Secret.js";
|
|
15
18
|
import {
|
|
16
19
|
Select,
|
|
17
20
|
SelectContent,
|
|
@@ -19,6 +22,7 @@ import {
|
|
|
19
22
|
SelectTrigger,
|
|
20
23
|
SelectValue,
|
|
21
24
|
} from "zudoku/ui/Select.js";
|
|
25
|
+
import { cn } from "../../../../util/cn.js";
|
|
22
26
|
import createVariantComponent from "../../../../util/createVariantComponent.js";
|
|
23
27
|
import { humanFileSize } from "../../../../util/humanFileSize.js";
|
|
24
28
|
import {
|
|
@@ -89,6 +93,30 @@ const Row = createVariantComponent(
|
|
|
89
93
|
);
|
|
90
94
|
|
|
91
95
|
const RowContent = createVariantComponent("div", "py-1 break-all");
|
|
96
|
+
const RowValue = ({ value, header }: { value: string; header: string }) => {
|
|
97
|
+
const secretHeaders = ["authorization", "key", "secret", "token"];
|
|
98
|
+
const isSecret = secretHeaders.includes(header.toLowerCase());
|
|
99
|
+
const [revealed, setRevealed] = useState(!isSecret);
|
|
100
|
+
return (
|
|
101
|
+
<RowContent
|
|
102
|
+
className={cn(isSecret && "cursor-pointer flex group")}
|
|
103
|
+
onClick={() => {
|
|
104
|
+
if (isSecret) {
|
|
105
|
+
setRevealed((prev) => !prev);
|
|
106
|
+
}
|
|
107
|
+
}}
|
|
108
|
+
>
|
|
109
|
+
<SecretText secret={value} previewChars={0} revealed={revealed} />
|
|
110
|
+
{isSecret ? (
|
|
111
|
+
revealed ? (
|
|
112
|
+
<EyeOffIcon size={14} className={cn("hidden group-hover:block")} />
|
|
113
|
+
) : (
|
|
114
|
+
<EyeIcon size={14} className={cn("hidden group-hover:block")} />
|
|
115
|
+
)
|
|
116
|
+
) : null}
|
|
117
|
+
</RowContent>
|
|
118
|
+
);
|
|
119
|
+
};
|
|
92
120
|
|
|
93
121
|
export const ResponseTab = ({
|
|
94
122
|
body = "",
|
|
@@ -158,7 +186,7 @@ export const ResponseTab = ({
|
|
|
158
186
|
.map(([key, value]) => (
|
|
159
187
|
<Row key={key}>
|
|
160
188
|
<RowContent>{key}</RowContent>
|
|
161
|
-
<
|
|
189
|
+
<RowValue value={value} header={key} />
|
|
162
190
|
</Row>
|
|
163
191
|
))}
|
|
164
192
|
</div>
|
|
@@ -177,7 +205,7 @@ export const ResponseTab = ({
|
|
|
177
205
|
{sortedHeaders.slice(0, MAX_HEADERS_TO_SHOW).map(([key, value]) => (
|
|
178
206
|
<Row key={key}>
|
|
179
207
|
<RowContent>{key}</RowContent>
|
|
180
|
-
<
|
|
208
|
+
<RowValue value={value} header={key} />
|
|
181
209
|
</Row>
|
|
182
210
|
))}
|
|
183
211
|
{sortedHeaders.length > MAX_HEADERS_TO_SHOW && (
|
|
@@ -195,7 +223,7 @@ export const ResponseTab = ({
|
|
|
195
223
|
.map(([key, value]) => (
|
|
196
224
|
<Row key={key}>
|
|
197
225
|
<RowContent>{key}</RowContent>
|
|
198
|
-
<
|
|
226
|
+
<RowValue value={value} header={key} />
|
|
199
227
|
</Row>
|
|
200
228
|
))}
|
|
201
229
|
</CollapsibleContent>
|
|
@@ -5,7 +5,13 @@ import type { SchemaObject } from "../../../../oas/parser/index.js";
|
|
|
5
5
|
import { Card } from "../../../../ui/Card.js";
|
|
6
6
|
import { AllOfGroupItem } from "./AllOfGroupItem.js";
|
|
7
7
|
|
|
8
|
-
export const AllOfGroupView = ({
|
|
8
|
+
export const AllOfGroupView = ({
|
|
9
|
+
schema,
|
|
10
|
+
cardHeader,
|
|
11
|
+
}: {
|
|
12
|
+
schema: SchemaObject;
|
|
13
|
+
cardHeader?: React.ReactNode;
|
|
14
|
+
}) => {
|
|
9
15
|
const [isOpen, setIsOpen] = useState(true);
|
|
10
16
|
const toggleOpen = useCallback(() => setIsOpen((prev) => !prev), []);
|
|
11
17
|
|
|
@@ -13,8 +19,9 @@ export const AllOfGroupView = ({ schema }: { schema: SchemaObject }) => {
|
|
|
13
19
|
|
|
14
20
|
return (
|
|
15
21
|
<Collapsible.Root open={isOpen} onOpenChange={toggleOpen} asChild>
|
|
16
|
-
<Card className="
|
|
17
|
-
|
|
22
|
+
<Card className="overflow-hidden">
|
|
23
|
+
{cardHeader}
|
|
24
|
+
<Collapsible.Trigger className="flex gap-2 items-center py-2 px-6 w-full text-sm text-muted-foreground -translate-x-1.5">
|
|
18
25
|
{isOpen ? (
|
|
19
26
|
<SquareMinusIcon size={14} />
|
|
20
27
|
) : (
|
|
@@ -23,7 +30,7 @@ export const AllOfGroupView = ({ schema }: { schema: SchemaObject }) => {
|
|
|
23
30
|
<span>All of</span>
|
|
24
31
|
</Collapsible.Trigger>
|
|
25
32
|
|
|
26
|
-
<Collapsible.Content className="pb-4">
|
|
33
|
+
<Collapsible.Content className="pb-4 px-6">
|
|
27
34
|
{schema.allOf.map((subSchema, index) => (
|
|
28
35
|
// biome-ignore lint/suspicious/noArrayIndexKey: Index needed for key
|
|
29
36
|
<AllOfGroupItem key={index} schema={subSchema} />
|
|
@@ -20,14 +20,20 @@ const renderMarkdown = (content?: string) =>
|
|
|
20
20
|
/>
|
|
21
21
|
);
|
|
22
22
|
|
|
23
|
-
const renderBasicSchema = (
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
{
|
|
29
|
-
|
|
30
|
-
|
|
23
|
+
const renderBasicSchema = (
|
|
24
|
+
schema: SchemaObject,
|
|
25
|
+
cardHeader?: React.ReactNode,
|
|
26
|
+
) => (
|
|
27
|
+
<Card className="overflow-hidden">
|
|
28
|
+
{cardHeader}
|
|
29
|
+
<div className="p-4 space-y-2">
|
|
30
|
+
<span className="text-sm text-muted-foreground">
|
|
31
|
+
<ParamInfos schema={schema} />
|
|
32
|
+
</span>
|
|
33
|
+
{schema.enum && <EnumValues values={schema.enum} />}
|
|
34
|
+
{renderMarkdown(schema.description)}
|
|
35
|
+
<SchemaExampleAndDefault schema={schema} />
|
|
36
|
+
</div>
|
|
31
37
|
</Card>
|
|
32
38
|
);
|
|
33
39
|
|
|
@@ -58,19 +64,19 @@ export const SchemaView = ({
|
|
|
58
64
|
}
|
|
59
65
|
|
|
60
66
|
if (Array.isArray(schema.oneOf) || Array.isArray(schema.anyOf)) {
|
|
61
|
-
return <UnionView schema={schema} />;
|
|
67
|
+
return <UnionView schema={schema} cardHeader={cardHeader} />;
|
|
62
68
|
}
|
|
63
69
|
|
|
64
70
|
if (Array.isArray(schema.allOf)) {
|
|
65
|
-
return <AllOfGroupView schema={schema} />;
|
|
71
|
+
return <AllOfGroupView schema={schema} cardHeader={cardHeader} />;
|
|
66
72
|
}
|
|
67
73
|
|
|
68
74
|
if (isBasicType(schema.type)) {
|
|
69
|
-
return renderBasicSchema(schema);
|
|
75
|
+
return renderBasicSchema(schema, cardHeader);
|
|
70
76
|
}
|
|
71
77
|
|
|
72
78
|
if (schema.type === "array" && typeof schema.items === "object") {
|
|
73
|
-
return <SchemaView schema={schema.items} />;
|
|
79
|
+
return <SchemaView schema={schema.items} cardHeader={cardHeader} />;
|
|
74
80
|
}
|
|
75
81
|
|
|
76
82
|
if (schema.type === "object") {
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { useState } from "react";
|
|
1
2
|
import type { SchemaObject } from "../../../oas/parser/index.js";
|
|
2
3
|
import { Badge } from "../../../ui/Badge.js";
|
|
3
4
|
import { Card } from "../../../ui/Card.js";
|
|
4
|
-
import {
|
|
5
|
+
import { cn } from "../../../util/cn.js";
|
|
5
6
|
import { SchemaView } from "./SchemaView.js";
|
|
6
7
|
import {
|
|
7
8
|
decideExclusivity,
|
|
@@ -13,9 +14,13 @@ import {
|
|
|
13
14
|
const DecisionTable = ({
|
|
14
15
|
variants,
|
|
15
16
|
schema,
|
|
17
|
+
selectedVariant,
|
|
18
|
+
onSelectVariant,
|
|
16
19
|
}: {
|
|
17
20
|
variants: SchemaObject[];
|
|
18
21
|
schema: SchemaObject;
|
|
22
|
+
selectedVariant: string;
|
|
23
|
+
onSelectVariant: (label: string) => void;
|
|
19
24
|
}) => {
|
|
20
25
|
const rows = variants.map((v, i) => ({
|
|
21
26
|
label: labelForVariant(i, v),
|
|
@@ -36,7 +41,18 @@ const DecisionTable = ({
|
|
|
36
41
|
<tbody className="divide-y">
|
|
37
42
|
{rows.map((row) => (
|
|
38
43
|
<tr key={row.label} className="hover:bg-muted/30">
|
|
39
|
-
<td className="p-2 font-medium">
|
|
44
|
+
<td className="p-2 font-medium">
|
|
45
|
+
<button
|
|
46
|
+
type="button"
|
|
47
|
+
className={cn(
|
|
48
|
+
"hover:underline",
|
|
49
|
+
selectedVariant === row.label && "text-primary",
|
|
50
|
+
)}
|
|
51
|
+
onClick={() => onSelectVariant(row.label)}
|
|
52
|
+
>
|
|
53
|
+
{row.label}
|
|
54
|
+
</button>
|
|
55
|
+
</td>
|
|
40
56
|
<td className="p-2 text-muted-foreground text-xs">
|
|
41
57
|
{row.guards.length > 0
|
|
42
58
|
? row.guards.join(" · ")
|
|
@@ -51,26 +67,38 @@ const DecisionTable = ({
|
|
|
51
67
|
);
|
|
52
68
|
};
|
|
53
69
|
|
|
54
|
-
const VariantPanel = ({ variant }: { variant: SchemaObject }) =>
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
70
|
+
const VariantPanel = ({ variant }: { variant: SchemaObject }) => {
|
|
71
|
+
return (
|
|
72
|
+
<div className="space-y-2">
|
|
73
|
+
{variant.description && (
|
|
74
|
+
<p className="text-sm text-muted-foreground">{variant.description}</p>
|
|
75
|
+
)}
|
|
76
|
+
<SchemaView schema={variant} />
|
|
77
|
+
</div>
|
|
78
|
+
);
|
|
79
|
+
};
|
|
62
80
|
|
|
63
|
-
export const UnionView = ({
|
|
81
|
+
export const UnionView = ({
|
|
82
|
+
schema,
|
|
83
|
+
cardHeader,
|
|
84
|
+
}: {
|
|
85
|
+
schema: SchemaObject;
|
|
86
|
+
cardHeader?: React.ReactNode;
|
|
87
|
+
}) => {
|
|
64
88
|
const mode = Array.isArray(schema.oneOf)
|
|
65
89
|
? "oneOf"
|
|
66
90
|
: Array.isArray(schema.anyOf)
|
|
67
91
|
? "anyOf"
|
|
68
92
|
: undefined;
|
|
69
93
|
|
|
94
|
+
const variants = mode ? unionVariants(schema) : [];
|
|
95
|
+
const [selectedVariant, setSelectedVariant] = useState(() =>
|
|
96
|
+
variants[0] ? labelForVariant(0, variants[0]) : "",
|
|
97
|
+
);
|
|
98
|
+
|
|
70
99
|
if (!mode) return null;
|
|
71
100
|
|
|
72
101
|
const exclusivity = decideExclusivity(schema);
|
|
73
|
-
const variants = unionVariants(schema);
|
|
74
102
|
|
|
75
103
|
const semanticsMessage =
|
|
76
104
|
exclusivity === "exactly-one" ? (
|
|
@@ -84,8 +112,15 @@ export const UnionView = ({ schema }: { schema: SchemaObject }) => {
|
|
|
84
112
|
</>
|
|
85
113
|
);
|
|
86
114
|
|
|
115
|
+
const currentVariantIndex = variants.findIndex(
|
|
116
|
+
(v, i) => labelForVariant(i, v) === selectedVariant,
|
|
117
|
+
);
|
|
118
|
+
const currentVariant =
|
|
119
|
+
currentVariantIndex >= 0 ? variants[currentVariantIndex] : null;
|
|
120
|
+
|
|
87
121
|
return (
|
|
88
|
-
<Card className="overflow-hidden">
|
|
122
|
+
<Card className="overflow-hidden text-sm">
|
|
123
|
+
{cardHeader}
|
|
89
124
|
<div className="flex flex-col gap-4 p-4">
|
|
90
125
|
<div className="flex items-center gap-2">
|
|
91
126
|
<Badge variant="outline">{mode}</Badge>
|
|
@@ -94,30 +129,15 @@ export const UnionView = ({ schema }: { schema: SchemaObject }) => {
|
|
|
94
129
|
</div>
|
|
95
130
|
</div>
|
|
96
131
|
|
|
97
|
-
<DecisionTable
|
|
132
|
+
<DecisionTable
|
|
133
|
+
variants={variants}
|
|
134
|
+
schema={schema}
|
|
135
|
+
selectedVariant={selectedVariant}
|
|
136
|
+
onSelectVariant={setSelectedVariant}
|
|
137
|
+
/>
|
|
138
|
+
<strong>Properties for {selectedVariant}:</strong>
|
|
139
|
+
{currentVariant && <VariantPanel variant={currentVariant} />}
|
|
98
140
|
</div>
|
|
99
|
-
<Tabs defaultValue="0" className="w-full px-4">
|
|
100
|
-
<TabsList className="flex w-full">
|
|
101
|
-
{variants.map((v, i) => (
|
|
102
|
-
<TabsTrigger
|
|
103
|
-
key={labelForVariant(i, v)}
|
|
104
|
-
value={String(i)}
|
|
105
|
-
className="flex-1"
|
|
106
|
-
>
|
|
107
|
-
{labelForVariant(i, v)}
|
|
108
|
-
</TabsTrigger>
|
|
109
|
-
))}
|
|
110
|
-
</TabsList>
|
|
111
|
-
{variants.map((v, i) => (
|
|
112
|
-
<TabsContent
|
|
113
|
-
key={labelForVariant(i, v)}
|
|
114
|
-
value={String(i)}
|
|
115
|
-
className="px-2"
|
|
116
|
-
>
|
|
117
|
-
<VariantPanel variant={v} />
|
|
118
|
-
</TabsContent>
|
|
119
|
-
))}
|
|
120
|
-
</Tabs>
|
|
121
141
|
</Card>
|
|
122
142
|
);
|
|
123
143
|
};
|
|
@@ -25,8 +25,36 @@ export type FieldDoc = {
|
|
|
25
25
|
requiredInAll: boolean;
|
|
26
26
|
};
|
|
27
27
|
|
|
28
|
-
export const unionVariants = (schema: SchemaObject) =>
|
|
29
|
-
(schema.oneOf ?? schema.anyOf ?? []) as SchemaObject[];
|
|
28
|
+
export const unionVariants = (schema: SchemaObject): SchemaObject[] => {
|
|
29
|
+
const variants = (schema.oneOf ?? schema.anyOf ?? []) as SchemaObject[];
|
|
30
|
+
|
|
31
|
+
// If parent schema has properties that variants don't, merge them
|
|
32
|
+
// This handles the pattern where anyOf/oneOf is used just for required field combinations
|
|
33
|
+
if (schema.properties && Object.keys(schema.properties).length > 0) {
|
|
34
|
+
return variants.map((variant) => {
|
|
35
|
+
// If variant doesn't define its own properties or type, inherit from parent
|
|
36
|
+
const shouldInherit =
|
|
37
|
+
!variant.properties &&
|
|
38
|
+
!variant.type &&
|
|
39
|
+
!variant.allOf &&
|
|
40
|
+
!variant.oneOf &&
|
|
41
|
+
!variant.anyOf;
|
|
42
|
+
|
|
43
|
+
if (shouldInherit) {
|
|
44
|
+
return {
|
|
45
|
+
...variant,
|
|
46
|
+
type: "object" as const,
|
|
47
|
+
properties: schema.properties,
|
|
48
|
+
required: variant.required ?? schema.required,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return variant;
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return variants;
|
|
57
|
+
};
|
|
30
58
|
|
|
31
59
|
export const decideExclusivity = (
|
|
32
60
|
schema: SchemaObject,
|
package/src/lib/shiki.ts
CHANGED
|
@@ -69,6 +69,8 @@ export const defaultLanguages: BundledLanguage[] = [
|
|
|
69
69
|
"jsx",
|
|
70
70
|
"typescript",
|
|
71
71
|
"tsx",
|
|
72
|
+
"graphql",
|
|
73
|
+
"jsonc",
|
|
72
74
|
"json",
|
|
73
75
|
"python",
|
|
74
76
|
"java",
|
|
@@ -83,8 +85,19 @@ export const defaultLanguages: BundledLanguage[] = [
|
|
|
83
85
|
"html",
|
|
84
86
|
"xml",
|
|
85
87
|
"yaml",
|
|
88
|
+
"toml",
|
|
89
|
+
"rust",
|
|
86
90
|
"markdown",
|
|
87
91
|
"mdx",
|
|
92
|
+
"zig",
|
|
93
|
+
"scala",
|
|
94
|
+
"dart",
|
|
95
|
+
"ocaml",
|
|
96
|
+
"c",
|
|
97
|
+
"cpp",
|
|
98
|
+
"common-lisp",
|
|
99
|
+
"elixir",
|
|
100
|
+
"powershell",
|
|
88
101
|
];
|
|
89
102
|
|
|
90
103
|
const rehypeCodeBlockPlugin = () => (tree: Root) => {
|
package/src/lib/ui/Carousel.tsx
CHANGED
package/src/lib/ui/CodeBlock.tsx
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { CheckIcon, CopyIcon } from "lucide-react";
|
|
2
|
-
import type
|
|
3
|
-
import {
|
|
2
|
+
import { type ReactNode, useRef } from "react";
|
|
3
|
+
import { LanguageIcon } from "../components/LanguageIcon.js";
|
|
4
4
|
import { cn } from "../util/cn.js";
|
|
5
5
|
import { useCopyToClipboard } from "../util/useCopyToClipboard.js";
|
|
6
6
|
|
|
@@ -18,35 +18,6 @@ export type CodeBlockProps = {
|
|
|
18
18
|
showLineNumbers?: boolean;
|
|
19
19
|
};
|
|
20
20
|
|
|
21
|
-
const IconToLanguageMap: Record<string, RegExp> = {
|
|
22
|
-
typescript: /(tsx?|typescript)/,
|
|
23
|
-
javascript: /(jsx?|javascript)/,
|
|
24
|
-
markdown: /(md|markdown)/,
|
|
25
|
-
mdx: /mdx/,
|
|
26
|
-
json: /json/,
|
|
27
|
-
yaml: /yaml/,
|
|
28
|
-
toml: /toml/,
|
|
29
|
-
gnubash: /(shell|bash|sh|zsh)/,
|
|
30
|
-
python: /(py|python)/,
|
|
31
|
-
dotnet: /(^cs$|csharp|vb)/,
|
|
32
|
-
rust: /(rs|rust)/,
|
|
33
|
-
ruby: /(rb|ruby)/,
|
|
34
|
-
php: /php/,
|
|
35
|
-
html5: /html?/,
|
|
36
|
-
css: /css/,
|
|
37
|
-
};
|
|
38
|
-
|
|
39
|
-
const getIconUrl = (language?: string) => {
|
|
40
|
-
if (!language) return undefined;
|
|
41
|
-
|
|
42
|
-
const icon = Object.entries(IconToLanguageMap).find(([_, regex]) =>
|
|
43
|
-
regex.test(language),
|
|
44
|
-
);
|
|
45
|
-
return icon
|
|
46
|
-
? `https://cdn.simpleicons.org/${icon[0]}/000/fff?viewbox=auto`
|
|
47
|
-
: undefined;
|
|
48
|
-
};
|
|
49
|
-
|
|
50
21
|
export const CodeBlock = ({
|
|
51
22
|
children,
|
|
52
23
|
title = "Code",
|
|
@@ -61,20 +32,17 @@ export const CodeBlock = ({
|
|
|
61
32
|
|
|
62
33
|
if (!children) return null;
|
|
63
34
|
|
|
64
|
-
const iconUrl = showLanguageIndicator ? getIconUrl(language) : undefined;
|
|
65
|
-
|
|
66
35
|
return (
|
|
67
36
|
<div
|
|
68
37
|
className={cn(
|
|
69
|
-
"border code-block-wrapper relative group
|
|
38
|
+
"border code-block-wrapper relative group rounded-md overflow-hidden",
|
|
70
39
|
showLineNumbers && "line-numbers",
|
|
40
|
+
props.className,
|
|
71
41
|
)}
|
|
72
42
|
>
|
|
73
43
|
<div className="border-b flex items-center h-10 font-sans bg-black/2">
|
|
74
|
-
<div className="flex items-center gap-
|
|
75
|
-
{
|
|
76
|
-
<img src={iconUrl} className="h-3 max-w-4" alt={language} />
|
|
77
|
-
)}
|
|
44
|
+
<div className="flex items-center gap-1.5 flex-1 text-sm w-full px-3">
|
|
45
|
+
<LanguageIcon language={language} />
|
|
78
46
|
{title}
|
|
79
47
|
</div>{" "}
|
|
80
48
|
{showCopy !== "never" && (
|
|
@@ -102,10 +70,7 @@ export const CodeBlock = ({
|
|
|
102
70
|
)}
|
|
103
71
|
</div>
|
|
104
72
|
<div
|
|
105
|
-
className=
|
|
106
|
-
"code-block text-sm not-prose scrollbar overflow-x-auto scrollbar [&_code]:p-3 [&_code]:py-2",
|
|
107
|
-
props.className,
|
|
108
|
-
)}
|
|
73
|
+
className="code-block text-sm not-prose scrollbar [&_code]:px-3 [&_code]:py-2"
|
|
109
74
|
ref={ref}
|
|
110
75
|
>
|
|
111
76
|
{children}
|
|
@@ -40,7 +40,7 @@ export const EmbeddedCodeBlock = ({
|
|
|
40
40
|
>
|
|
41
41
|
<div
|
|
42
42
|
className={cn(
|
|
43
|
-
"code-block text-sm not-prose scrollbar overflow-x-auto
|
|
43
|
+
"code-block text-sm not-prose scrollbar overflow-x-auto [&>pre]:p-2",
|
|
44
44
|
props.className,
|
|
45
45
|
)}
|
|
46
46
|
ref={ref}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { Badge } from "./Badge.js";
|
|
2
|
+
import { Card } from "./Card.js";
|
|
3
|
+
|
|
4
|
+
type PropType =
|
|
5
|
+
| string
|
|
6
|
+
| {
|
|
7
|
+
name: string;
|
|
8
|
+
description: string;
|
|
9
|
+
required: boolean;
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
type ReactComponentDocProps = {
|
|
13
|
+
component: {
|
|
14
|
+
__docgenInfo: {
|
|
15
|
+
displayName: string;
|
|
16
|
+
description: string;
|
|
17
|
+
props: Record<
|
|
18
|
+
string,
|
|
19
|
+
{
|
|
20
|
+
type: PropType;
|
|
21
|
+
description: string;
|
|
22
|
+
required: boolean;
|
|
23
|
+
}
|
|
24
|
+
>;
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export const ReactComponentDoc = ({ component }: ReactComponentDocProps) => {
|
|
30
|
+
const docgen = component.__docgenInfo;
|
|
31
|
+
|
|
32
|
+
if (!docgen) return null;
|
|
33
|
+
|
|
34
|
+
return (
|
|
35
|
+
<Card className="not-prose">
|
|
36
|
+
<div className="flex flex-col gap-2">
|
|
37
|
+
<div className="flex flex-col gap-2 border-b p-6">
|
|
38
|
+
<h2 className="text-lg font-medium">Component Properties</h2>
|
|
39
|
+
<p className="text-sm text-muted-foreground">
|
|
40
|
+
The properties of the component.
|
|
41
|
+
</p>
|
|
42
|
+
</div>
|
|
43
|
+
<div className="grid grid-cols-[1fr_auto_auto] gap-2 divide-y">
|
|
44
|
+
{Object.entries(docgen.props).map(([key, value]) => (
|
|
45
|
+
<div
|
|
46
|
+
key={key}
|
|
47
|
+
className="px-6 pb-2 col-span-full grid grid-cols-subgrid"
|
|
48
|
+
>
|
|
49
|
+
<span className="font-medium text-primary">{key}</span>
|
|
50
|
+
<div>
|
|
51
|
+
{value.required && (
|
|
52
|
+
<Badge className="ml-2 font-mono">required</Badge>
|
|
53
|
+
)}
|
|
54
|
+
</div>
|
|
55
|
+
<div>
|
|
56
|
+
{typeof value.type === "object" && value.type.name && (
|
|
57
|
+
<Badge className="ml-2 font-mono" variant="muted">
|
|
58
|
+
{value.type.name}
|
|
59
|
+
</Badge>
|
|
60
|
+
)}
|
|
61
|
+
</div>
|
|
62
|
+
</div>
|
|
63
|
+
))}
|
|
64
|
+
</div>
|
|
65
|
+
</div>
|
|
66
|
+
</Card>
|
|
67
|
+
);
|
|
68
|
+
};
|