zudoku 0.0.0-fix-create-zudoku-run-build.fefccf58 → 0.0.0-fix-downgrade-openapi-parser.aac00796
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/client.d.ts +8 -0
- package/dist/app/entry.server.js +14 -1
- package/dist/app/entry.server.js.map +1 -1
- 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 +6 -1
- package/dist/config/validators/BuildSchema.d.ts +15 -7
- package/dist/config/validators/BuildSchema.js +19 -2
- package/dist/config/validators/BuildSchema.js.map +1 -1
- package/dist/config/validators/InputNavigationSchema.d.ts +184 -24
- 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 +45 -17
- package/dist/config/validators/validate.js +31 -8
- package/dist/config/validators/validate.js.map +1 -1
- package/dist/flat-config.d.ts +357 -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/authentication.d.ts +17 -9
- package/dist/lib/authentication/components/OAuthErrorPage.js +1 -1
- package/dist/lib/authentication/components/OAuthErrorPage.js.map +1 -1
- package/dist/lib/authentication/components/SignIn.js +6 -5
- package/dist/lib/authentication/components/SignIn.js.map +1 -1
- package/dist/lib/authentication/components/SignOut.js +6 -6
- package/dist/lib/authentication/components/SignOut.js.map +1 -1
- package/dist/lib/authentication/components/SignUp.js +5 -5
- package/dist/lib/authentication/components/SignUp.js.map +1 -1
- package/dist/lib/authentication/hook.d.ts +3 -2
- package/dist/lib/authentication/hook.js +12 -8
- package/dist/lib/authentication/hook.js.map +1 -1
- package/dist/lib/authentication/providers/auth0.js +8 -4
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/azureb2c.d.ts +4 -4
- package/dist/lib/authentication/providers/azureb2c.js +3 -3
- package/dist/lib/authentication/providers/azureb2c.js.map +1 -1
- package/dist/lib/authentication/providers/clerk.js +2 -2
- package/dist/lib/authentication/providers/clerk.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +7 -7
- package/dist/lib/authentication/providers/openid.js +5 -3
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.d.ts +8 -0
- package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.js +39 -0
- package/dist/lib/authentication/providers/supabase/SupabaseAuthUI.js.map +1 -0
- package/dist/lib/authentication/providers/supabase.js +35 -31
- package/dist/lib/authentication/providers/supabase.js.map +1 -1
- package/dist/lib/authentication/state.d.ts +5 -7
- package/dist/lib/authentication/state.js +2 -14
- package/dist/lib/authentication/state.js.map +1 -1
- 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/Zudoku.js +3 -3
- 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 +14 -4
- 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/components/navigation/Toc.js +1 -1
- package/dist/lib/components/navigation/Toc.js.map +1 -1
- package/dist/lib/core/RouteGuard.d.ts +1 -1
- package/dist/lib/core/RouteGuard.js +6 -14
- package/dist/lib/core/RouteGuard.js.map +1 -1
- package/dist/lib/core/ZudokuContext.d.ts +1 -0
- package/dist/lib/core/ZudokuContext.js +2 -0
- package/dist/lib/core/ZudokuContext.js.map +1 -1
- package/dist/lib/core/__internal.d.ts +1 -1
- package/dist/lib/hooks/index.d.ts +3 -3
- 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.d.ts +2 -1
- package/dist/lib/plugins/markdown/MdxPage.js +29 -5
- 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 +3 -1
- package/dist/lib/plugins/markdown/index.js +1 -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 +5 -10
- 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/CollapsibleHeader.js +1 -1
- package/dist/lib/plugins/openapi/playground/CollapsibleHeader.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 +13 -3
- 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/RequestLoginDialog.d.ts +2 -1
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js +10 -2
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.d.ts +5 -3
- package/dist/lib/plugins/openapi/playground/result-panel/Highlight.d.ts +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +33 -19
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.d.ts +5 -3
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js +2 -0
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js.map +1 -1
- 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.d.ts +1 -1
- package/dist/lib/shiki.js +26 -2
- package/dist/lib/shiki.js.map +1 -1
- package/dist/lib/ui/Callout.d.ts +5 -5
- package/dist/lib/ui/Callout.js +5 -5
- package/dist/lib/ui/Callout.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/Dialog.d.ts +12 -18
- package/dist/lib/ui/Dialog.js +30 -17
- package/dist/lib/ui/Dialog.js.map +1 -1
- package/dist/lib/ui/EmbeddedCodeBlock.d.ts +3 -1
- package/dist/lib/ui/EmbeddedCodeBlock.js +2 -2
- 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/SyntaxHighlight.d.ts +1 -0
- package/dist/lib/ui/SyntaxHighlight.js.map +1 -1
- 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.d.ts +2 -1
- package/dist/lib/util/MdxComponents.js +3 -2
- 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/syncZustandState.d.ts +5 -0
- package/dist/lib/util/syncZustandState.js +14 -0
- package/dist/lib/util/syncZustandState.js.map +1 -0
- 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.d.ts +3 -1
- package/dist/vite/api/SchemaManager.js +32 -9
- package/dist/vite/api/SchemaManager.js.map +1 -1
- package/dist/vite/api/SchemaManager.test.js +2 -2
- package/dist/vite/api/SchemaManager.test.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 +18 -17
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-docs.d.ts +9 -0
- package/dist/vite/plugin-docs.js +68 -45
- 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 +141 -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 +41 -32
- 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/{Command-CUSlH0gJ.js → Command-CUcrW3qs.js} +3 -3
- package/lib/{Command-CUSlH0gJ.js.map → Command-CUcrW3qs.js.map} +1 -1
- package/lib/Dialog-BQciPiHN.js +144 -0
- package/lib/Dialog-BQciPiHN.js.map +1 -0
- 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-DE3Sf66a.js} +2176 -2251
- package/lib/ErrorAlert-DE3Sf66a.js.map +1 -0
- package/lib/MdxPage-DZfeC0QY.js +240 -0
- package/lib/MdxPage-DZfeC0QY.js.map +1 -0
- package/lib/{OAuthErrorPage-rAKHHveX.js → OAuthErrorPage-BycMozgn.js} +9 -9
- package/lib/{OAuthErrorPage-rAKHHveX.js.map → OAuthErrorPage-BycMozgn.js.map} +1 -1
- package/lib/{OasProvider-BW4OzAuR.js → OasProvider-Bf5zBDBY.js} +4 -4
- package/lib/{OasProvider-BW4OzAuR.js.map → OasProvider-Bf5zBDBY.js.map} +1 -1
- package/lib/OperationList-Cmiw1xm2.js +5446 -0
- package/lib/OperationList-Cmiw1xm2.js.map +1 -0
- package/lib/{Pagination-ZI2yyuxj.js → Pagination-CJszmeSA.js} +4 -4
- package/lib/{Pagination-ZI2yyuxj.js.map → Pagination-CJszmeSA.js.map} +1 -1
- package/lib/RouteGuard-DhU3LRr1.js +81 -0
- package/lib/RouteGuard-DhU3LRr1.js.map +1 -0
- package/lib/{RouterError-BYHrbLtD.js → RouterError-VDLnrFqF.js} +7 -7
- package/lib/{RouterError-BYHrbLtD.js.map → RouterError-VDLnrFqF.js.map} +1 -1
- package/lib/{SchemaList-C4Sk-tLI.js → SchemaList-xZSf3IMh.js} +10 -10
- package/lib/{SchemaList-C4Sk-tLI.js.map → SchemaList-xZSf3IMh.js.map} +1 -1
- package/lib/SchemaView-tHXTm5oM.js +458 -0
- package/lib/SchemaView-tHXTm5oM.js.map +1 -0
- package/lib/Select-C1DeCqKv.js +372 -0
- package/lib/Select-C1DeCqKv.js.map +1 -0
- package/lib/SignUp-6SGx9Yyq.js +50 -0
- package/lib/SignUp-6SGx9Yyq.js.map +1 -0
- 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-zvlnSnHB.js} +815 -784
- package/lib/SyntaxHighlight-zvlnSnHB.js.map +1 -0
- package/lib/{Toc-BAa-kpqN.js → Toc-Da9yp7lo.js} +6 -6
- package/lib/Toc-Da9yp7lo.js.map +1 -0
- package/lib/ZudokuContext-BUZ5hkWB.js +1508 -0
- package/lib/ZudokuContext-BUZ5hkWB.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-BMhpCH5D.js +7965 -0
- package/lib/chunk-PVWAREVJ-BMhpCH5D.js.map +1 -0
- package/lib/{circular-BFte5TUt.js → circular-DvuimBGQ.js} +30 -30
- package/lib/{circular-BFte5TUt.js.map → circular-DvuimBGQ.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-D9UvCoDf.js} +3411 -3342
- package/lib/createServer-D9UvCoDf.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-CuGgh3hf.js} +3 -3
- package/lib/{errors-CjmCml50.js.map → errors-CuGgh3hf.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-CMeoxziF.js +40 -0
- package/lib/hook-CMeoxziF.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-B1rmok4X.js} +209 -207
- package/lib/index-B1rmok4X.js.map +1 -0
- package/lib/{index-Dp3Fmnfq.js → index-Cr9_YzOZ.js} +908 -938
- package/lib/index-Cr9_YzOZ.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-CQGi1b3U.js → index-rYHsvtTo.js} +166 -50
- package/lib/index-rYHsvtTo.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-BSU0xu4m.js} +2 -2
- package/lib/{mutation-CiMUdKRU.js.map → mutation-BSU0xu4m.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 +19 -19
- package/lib/ui/Callout.js.map +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 +217 -6
- package/lib/ui/CodeBlock.js.map +1 -1
- package/lib/ui/Command.js +2 -2
- package/lib/ui/Dialog.js +135 -105
- package/lib/ui/Dialog.js.map +1 -1
- package/lib/ui/Drawer.js +2 -2
- package/lib/ui/DropdownMenu.js +1 -1
- package/lib/ui/EmbeddedCodeBlock.js +23 -20
- 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-U3pmsHaG.js} +34 -34
- package/lib/{useExposedProps-BH9aq4MD.js.map → useExposedProps-U3pmsHaG.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 +23 -22
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-azureb2c.js +34 -35
- package/lib/zudoku.auth-azureb2c.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +41 -41
- package/lib/zudoku.auth-clerk.js.map +1 -1
- package/lib/zudoku.auth-openid.js +104 -108
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.auth-supabase.js +111 -52
- package/lib/zudoku.auth-supabase.js.map +1 -1
- 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 +302 -327
- 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 +10 -9
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +7 -8
- package/lib/zudoku.plugin-openapi.js.map +1 -1
- package/lib/zudoku.plugin-redirect.js +3 -3
- package/lib/zudoku.plugin-search-inkeep.js +1 -1
- package/lib/zudoku.plugin-search-pagefind.js +47 -48
- 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 +83 -72
- package/src/app/entry.server.tsx +16 -6
- package/src/app/main.css +71 -19
- 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/authentication.ts +22 -4
- package/src/lib/authentication/components/OAuthErrorPage.tsx +1 -1
- package/src/lib/authentication/components/SignIn.tsx +7 -5
- package/src/lib/authentication/components/SignOut.tsx +7 -6
- package/src/lib/authentication/components/SignUp.tsx +5 -8
- package/src/lib/authentication/hook.ts +21 -10
- package/src/lib/authentication/providers/auth0.tsx +9 -4
- package/src/lib/authentication/providers/azureb2c.tsx +10 -3
- package/src/lib/authentication/providers/clerk.tsx +9 -2
- package/src/lib/authentication/providers/openid.tsx +20 -15
- package/src/lib/authentication/providers/supabase/SupabaseAuthUI.tsx +75 -0
- package/src/lib/authentication/providers/supabase.tsx +59 -43
- package/src/lib/authentication/state.ts +3 -23
- 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/Zudoku.tsx +3 -3
- 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/components/navigation/Toc.tsx +3 -3
- package/src/lib/core/RouteGuard.tsx +33 -13
- package/src/lib/core/ZudokuContext.ts +3 -0
- 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 +126 -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 +5 -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 +10 -30
- 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/CollapsibleHeader.tsx +2 -2
- package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +3 -3
- package/src/lib/plugins/openapi/playground/Playground.tsx +16 -5
- package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +13 -2
- package/src/lib/plugins/openapi/playground/RequestLoginDialog.tsx +20 -1
- package/src/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.tsx +2 -2
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +124 -52
- package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +1 -1
- package/src/lib/plugins/openapi/playground/useRememberSkipLoginDialog.tsx +3 -0
- 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 +29 -2
- package/src/lib/ui/Callout.tsx +10 -5
- package/src/lib/ui/Carousel.tsx +0 -1
- package/src/lib/ui/CodeBlock.tsx +7 -42
- package/src/lib/ui/Dialog.tsx +112 -106
- package/src/lib/ui/EmbeddedCodeBlock.tsx +6 -3
- package/src/lib/ui/ReactComponentDoc.tsx +68 -0
- package/src/lib/ui/Secret.tsx +123 -0
- package/src/lib/ui/SyntaxHighlight.tsx +6 -1
- package/src/lib/ui/Value.tsx +42 -0
- package/src/lib/util/MdxComponents.tsx +3 -2
- package/src/lib/util/pastellize.ts +4 -4
- package/src/lib/util/syncZustandState.ts +22 -0
- 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/Dialog-BmgXWOaz.js +0 -114
- package/lib/Dialog-BmgXWOaz.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/RouteGuard-BIksrt_C.js +0 -56
- package/lib/RouteGuard-BIksrt_C.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/SignUp-CznaQsRx.js +0 -56
- package/lib/SignUp-CznaQsRx.js.map +0 -1
- package/lib/Slot-BbdqiRXo.js.map +0 -1
- package/lib/SyntaxHighlight-CvzJ7DNa.js.map +0 -1
- package/lib/Toc-BAa-kpqN.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
|
@@ -8,17 +8,19 @@ import {
|
|
|
8
8
|
CardHeader,
|
|
9
9
|
CardTitle,
|
|
10
10
|
} from "zudoku/ui/Card.js";
|
|
11
|
-
import {
|
|
11
|
+
import { useAuth } from "../hook.js";
|
|
12
12
|
|
|
13
13
|
export const SignIn = () => {
|
|
14
|
-
const
|
|
14
|
+
const auth = useAuth();
|
|
15
15
|
const [search] = useSearchParams();
|
|
16
|
+
const redirectTo = search.get("redirect") ?? undefined;
|
|
17
|
+
|
|
16
18
|
useEffect(() => {
|
|
17
|
-
void
|
|
18
|
-
redirectTo
|
|
19
|
+
void auth.login({
|
|
20
|
+
redirectTo,
|
|
19
21
|
replace: true,
|
|
20
22
|
});
|
|
21
|
-
}, [
|
|
23
|
+
}, [auth, redirectTo]);
|
|
22
24
|
|
|
23
25
|
return (
|
|
24
26
|
<div className="flex items-center justify-center mt-8">
|
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import { useEffect } from "react";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { useLatest } from "../../util/useLatest.js";
|
|
3
|
+
import { useAuth } from "../hook.js";
|
|
4
4
|
|
|
5
5
|
export const SignOut = () => {
|
|
6
|
-
const
|
|
7
|
-
|
|
6
|
+
const auth = useAuth();
|
|
7
|
+
|
|
8
|
+
const logout = useLatest(auth.logout);
|
|
8
9
|
|
|
9
10
|
useEffect(() => {
|
|
10
|
-
void
|
|
11
|
-
}, [
|
|
11
|
+
void logout.current();
|
|
12
|
+
}, [logout]);
|
|
12
13
|
|
|
13
14
|
return null;
|
|
14
15
|
};
|
|
@@ -7,14 +7,14 @@ import {
|
|
|
7
7
|
CardHeader,
|
|
8
8
|
CardTitle,
|
|
9
9
|
} from "zudoku/ui/Card.js";
|
|
10
|
-
import {
|
|
10
|
+
import { useAuth } from "../hook.js";
|
|
11
11
|
|
|
12
12
|
export const SignUp = () => {
|
|
13
|
-
const
|
|
13
|
+
const auth = useAuth();
|
|
14
14
|
|
|
15
15
|
useEffect(() => {
|
|
16
|
-
void
|
|
17
|
-
}, [
|
|
16
|
+
void auth.signup();
|
|
17
|
+
}, [auth]);
|
|
18
18
|
|
|
19
19
|
return (
|
|
20
20
|
<div className="flex items-center justify-center mt-8">
|
|
@@ -28,10 +28,7 @@ export const SignUp = () => {
|
|
|
28
28
|
</CardHeader>
|
|
29
29
|
<CardContent>
|
|
30
30
|
<div className="flex flex-col gap-2 justify-center">
|
|
31
|
-
<Button
|
|
32
|
-
onClick={() => context.authentication?.signIn()}
|
|
33
|
-
variant="default"
|
|
34
|
-
>
|
|
31
|
+
<Button onClick={() => auth.signup()} variant="default">
|
|
35
32
|
Register
|
|
36
33
|
</Button>
|
|
37
34
|
<Button variant="link" className="text-muted-foreground" asChild>
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
import { useNavigate } from "react-router";
|
|
1
2
|
import { useZudoku } from "../components/context/ZudokuContext.js";
|
|
3
|
+
import type { AuthActionOptions } from "./authentication.js";
|
|
2
4
|
import { useAuthState } from "./state.js";
|
|
3
5
|
|
|
4
6
|
export type UseAuthReturn = ReturnType<typeof useAuth>;
|
|
@@ -7,19 +9,24 @@ export const useAuth = () => {
|
|
|
7
9
|
const { authentication } = useZudoku();
|
|
8
10
|
const authState = useAuthState();
|
|
9
11
|
const isAuthEnabled = typeof authentication !== "undefined";
|
|
12
|
+
const navigate = useNavigate();
|
|
10
13
|
|
|
11
14
|
return {
|
|
12
15
|
isAuthEnabled,
|
|
13
16
|
...authState,
|
|
14
17
|
|
|
15
|
-
login: async () => {
|
|
18
|
+
login: async (options?: AuthActionOptions) => {
|
|
16
19
|
if (!isAuthEnabled) {
|
|
17
20
|
throw new Error("Authentication is not enabled.");
|
|
18
21
|
}
|
|
19
22
|
// TODO: Should handle errors/state
|
|
20
|
-
await authentication.signIn(
|
|
21
|
-
|
|
22
|
-
|
|
23
|
+
await authentication.signIn(
|
|
24
|
+
{ navigate },
|
|
25
|
+
{
|
|
26
|
+
...options,
|
|
27
|
+
redirectTo: options?.redirectTo ?? window.location.href,
|
|
28
|
+
},
|
|
29
|
+
);
|
|
23
30
|
},
|
|
24
31
|
|
|
25
32
|
logout: async () => {
|
|
@@ -27,19 +34,23 @@ export const useAuth = () => {
|
|
|
27
34
|
throw new Error("Authentication is not enabled.");
|
|
28
35
|
}
|
|
29
36
|
// TODO: Should handle errors/state
|
|
30
|
-
await authentication.signOut();
|
|
37
|
+
await authentication.signOut({ navigate });
|
|
31
38
|
|
|
32
39
|
// Redirect to home
|
|
33
|
-
|
|
40
|
+
void navigate("/", { replace: true });
|
|
34
41
|
},
|
|
35
42
|
|
|
36
|
-
signup: async () => {
|
|
43
|
+
signup: async (options?: AuthActionOptions) => {
|
|
37
44
|
if (!isAuthEnabled) {
|
|
38
45
|
throw new Error("Authentication is not enabled.");
|
|
39
46
|
}
|
|
40
|
-
await authentication.signUp(
|
|
41
|
-
|
|
42
|
-
|
|
47
|
+
await authentication.signUp(
|
|
48
|
+
{ navigate },
|
|
49
|
+
{
|
|
50
|
+
...options,
|
|
51
|
+
redirectTo: options?.redirectTo ?? window.location.href,
|
|
52
|
+
},
|
|
53
|
+
);
|
|
43
54
|
},
|
|
44
55
|
};
|
|
45
56
|
};
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { Auth0AuthenticationConfig } from "../../../config/config.js";
|
|
2
2
|
import type {
|
|
3
|
+
AuthActionContext,
|
|
3
4
|
AuthenticationPlugin,
|
|
4
5
|
AuthenticationProviderInitializer,
|
|
5
6
|
} from "../authentication.js";
|
|
@@ -10,6 +11,7 @@ class Auth0AuthenticationProvider
|
|
|
10
11
|
extends OpenIDAuthenticationProvider
|
|
11
12
|
implements AuthenticationPlugin
|
|
12
13
|
{
|
|
14
|
+
private readonly options: Auth0AuthenticationConfig["options"];
|
|
13
15
|
constructor(config: Auth0AuthenticationConfig) {
|
|
14
16
|
super({
|
|
15
17
|
...config,
|
|
@@ -19,27 +21,30 @@ class Auth0AuthenticationProvider
|
|
|
19
21
|
audience: config.audience,
|
|
20
22
|
scopes: config.scopes,
|
|
21
23
|
});
|
|
24
|
+
this.options = config.options;
|
|
22
25
|
}
|
|
23
26
|
|
|
24
27
|
onAuthorizationUrl = async (
|
|
25
28
|
url: URL,
|
|
26
29
|
{ isSignUp }: { isSignUp: boolean },
|
|
27
30
|
) => {
|
|
28
|
-
|
|
31
|
+
if (this.options?.alwaysPromptLogin !== false) {
|
|
32
|
+
url.searchParams.set("prompt", "login");
|
|
33
|
+
}
|
|
29
34
|
if (isSignUp) {
|
|
30
35
|
url.searchParams.set("screen_hint", "signup");
|
|
31
36
|
}
|
|
32
37
|
};
|
|
33
38
|
|
|
34
|
-
signOut = async (): Promise<void> => {
|
|
39
|
+
signOut = async (_: AuthActionContext): Promise<void> => {
|
|
35
40
|
const as = await this.getAuthServer();
|
|
36
41
|
const idToken = await this.getAccessToken();
|
|
37
42
|
|
|
38
43
|
useAuthState.setState({
|
|
39
44
|
isAuthenticated: false,
|
|
40
45
|
isPending: false,
|
|
41
|
-
profile:
|
|
42
|
-
providerData:
|
|
46
|
+
profile: undefined,
|
|
47
|
+
providerData: undefined,
|
|
43
48
|
});
|
|
44
49
|
|
|
45
50
|
const redirectUrl = new URL(window.location.origin);
|
|
@@ -6,6 +6,7 @@ import { ClientOnly } from "../../components/ClientOnly.js";
|
|
|
6
6
|
import { joinUrl } from "../../util/joinUrl.js";
|
|
7
7
|
import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
|
|
8
8
|
import type {
|
|
9
|
+
AuthActionContext,
|
|
9
10
|
AuthenticationPlugin,
|
|
10
11
|
AuthenticationProviderInitializer,
|
|
11
12
|
} from "../authentication.js";
|
|
@@ -106,7 +107,10 @@ export class AzureB2CAuthPlugin
|
|
|
106
107
|
});
|
|
107
108
|
}
|
|
108
109
|
|
|
109
|
-
async signUp(
|
|
110
|
+
async signUp(
|
|
111
|
+
_: AuthActionContext,
|
|
112
|
+
{ redirectTo }: { redirectTo?: string } = {},
|
|
113
|
+
) {
|
|
110
114
|
const redirectUri = this.redirectToAfterSignUp ?? redirectTo ?? "/";
|
|
111
115
|
sessionStorage.setItem("redirect-to", redirectUri);
|
|
112
116
|
|
|
@@ -116,7 +120,10 @@ export class AzureB2CAuthPlugin
|
|
|
116
120
|
});
|
|
117
121
|
}
|
|
118
122
|
|
|
119
|
-
async signIn(
|
|
123
|
+
async signIn(
|
|
124
|
+
_: AuthActionContext,
|
|
125
|
+
{ redirectTo }: { redirectTo?: string } = {},
|
|
126
|
+
) {
|
|
120
127
|
const redirectUri = this.redirectToAfterSignIn ?? redirectTo ?? "/";
|
|
121
128
|
sessionStorage.setItem("redirect-to", redirectUri);
|
|
122
129
|
|
|
@@ -156,7 +163,7 @@ export class AzureB2CAuthPlugin
|
|
|
156
163
|
return request;
|
|
157
164
|
};
|
|
158
165
|
|
|
159
|
-
signOut = async () => {
|
|
166
|
+
signOut = async (_: AuthActionContext) => {
|
|
160
167
|
const account = this.msalInstance.getAllAccounts()[0];
|
|
161
168
|
if (account) {
|
|
162
169
|
await this.msalInstance.logoutRedirect({
|
|
@@ -3,6 +3,7 @@ import { LogOutIcon } from "lucide-react";
|
|
|
3
3
|
import type { ZudokuPlugin } from "zudoku/plugins";
|
|
4
4
|
import type { ClerkAuthenticationConfig } from "../../../config/config.js";
|
|
5
5
|
import type {
|
|
6
|
+
AuthActionContext,
|
|
6
7
|
AuthenticationPlugin,
|
|
7
8
|
AuthenticationProviderInitializer,
|
|
8
9
|
} from "../authentication.js";
|
|
@@ -147,7 +148,10 @@ const clerkAuth: AuthenticationProviderInitializer<
|
|
|
147
148
|
});
|
|
148
149
|
useAuthState.getState().setLoggedOut();
|
|
149
150
|
},
|
|
150
|
-
signIn: async (
|
|
151
|
+
signIn: async (
|
|
152
|
+
_: AuthActionContext,
|
|
153
|
+
{ redirectTo }: { redirectTo?: string } = {},
|
|
154
|
+
) => {
|
|
151
155
|
await ensureLoaded;
|
|
152
156
|
await clerkApi?.redirectToSignIn({
|
|
153
157
|
signInForceRedirectUrl: redirectToAfterSignIn
|
|
@@ -158,7 +162,10 @@ const clerkAuth: AuthenticationProviderInitializer<
|
|
|
158
162
|
: redirectTo,
|
|
159
163
|
});
|
|
160
164
|
},
|
|
161
|
-
signUp: async (
|
|
165
|
+
signUp: async (
|
|
166
|
+
_: AuthActionContext,
|
|
167
|
+
{ redirectTo }: { redirectTo?: string } = {},
|
|
168
|
+
) => {
|
|
162
169
|
await ensureLoaded;
|
|
163
170
|
await clerkApi?.redirectToSignUp({
|
|
164
171
|
signInForceRedirectUrl: redirectToAfterSignIn
|
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
import logger from "loglevel";
|
|
2
2
|
import * as oauth from "oauth4webapi";
|
|
3
3
|
import { ErrorBoundary } from "react-error-boundary";
|
|
4
|
+
import type { NavigateFunction } from "react-router";
|
|
4
5
|
import type { OpenIDAuthenticationConfig } from "../../../config/config.js";
|
|
5
6
|
import { ClientOnly } from "../../components/ClientOnly.js";
|
|
6
7
|
import { joinUrl } from "../../util/joinUrl.js";
|
|
7
8
|
import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
|
|
8
9
|
import type {
|
|
10
|
+
AuthActionContext,
|
|
11
|
+
AuthActionOptions,
|
|
9
12
|
AuthenticationPlugin,
|
|
10
13
|
AuthenticationProviderInitializer,
|
|
11
14
|
} from "../authentication.js";
|
|
@@ -115,13 +118,16 @@ export class OpenIDAuthenticationProvider
|
|
|
115
118
|
});
|
|
116
119
|
}
|
|
117
120
|
|
|
118
|
-
async signUp(
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
121
|
+
async signUp(
|
|
122
|
+
_: { navigate: NavigateFunction },
|
|
123
|
+
{
|
|
124
|
+
redirectTo,
|
|
125
|
+
replace = false,
|
|
126
|
+
}: {
|
|
127
|
+
redirectTo?: string;
|
|
128
|
+
replace?: boolean;
|
|
129
|
+
} = {},
|
|
130
|
+
) {
|
|
125
131
|
return this.authorize({
|
|
126
132
|
redirectTo: this.redirectToAfterSignUp ?? redirectTo ?? "/",
|
|
127
133
|
replace,
|
|
@@ -129,13 +135,10 @@ export class OpenIDAuthenticationProvider
|
|
|
129
135
|
});
|
|
130
136
|
}
|
|
131
137
|
|
|
132
|
-
async signIn(
|
|
133
|
-
|
|
134
|
-
replace = false,
|
|
135
|
-
|
|
136
|
-
redirectTo?: string;
|
|
137
|
-
replace?: boolean;
|
|
138
|
-
} = {}) {
|
|
138
|
+
async signIn(
|
|
139
|
+
_: AuthActionContext,
|
|
140
|
+
{ redirectTo, replace = false }: AuthActionOptions,
|
|
141
|
+
) {
|
|
139
142
|
return this.authorize({
|
|
140
143
|
redirectTo: this.redirectToAfterSignIn ?? redirectTo ?? "/",
|
|
141
144
|
replace,
|
|
@@ -178,6 +181,7 @@ export class OpenIDAuthenticationProvider
|
|
|
178
181
|
const redirectUrl = new URL(window.location.origin);
|
|
179
182
|
redirectUrl.pathname = this.callbackUrlPath;
|
|
180
183
|
redirectUrl.search = "";
|
|
184
|
+
redirectUrl.hash = "";
|
|
181
185
|
|
|
182
186
|
authorizationUrl.searchParams.set("client_id", this.client.client_id);
|
|
183
187
|
authorizationUrl.searchParams.set("redirect_uri", redirectUrl.toString());
|
|
@@ -260,7 +264,7 @@ export class OpenIDAuthenticationProvider
|
|
|
260
264
|
return request;
|
|
261
265
|
};
|
|
262
266
|
|
|
263
|
-
signOut = async () => {
|
|
267
|
+
signOut = async (_: AuthActionContext) => {
|
|
264
268
|
useAuthState.setState({
|
|
265
269
|
isAuthenticated: false,
|
|
266
270
|
isPending: false,
|
|
@@ -384,6 +388,7 @@ export class OpenIDAuthenticationProvider
|
|
|
384
388
|
const redirectUrl = new URL(url);
|
|
385
389
|
redirectUrl.pathname = this.callbackUrlPath;
|
|
386
390
|
redirectUrl.search = "";
|
|
391
|
+
redirectUrl.hash = "";
|
|
387
392
|
|
|
388
393
|
const response = await oauth.authorizationCodeGrantRequest(
|
|
389
394
|
authServer,
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Auth } from "@supabase/auth-ui-react";
|
|
2
|
+
import {
|
|
3
|
+
ThemeSupa,
|
|
4
|
+
type ThemeVariables,
|
|
5
|
+
type ViewType,
|
|
6
|
+
} from "@supabase/auth-ui-shared";
|
|
7
|
+
import type { SupabaseClient } from "@supabase/supabase-js";
|
|
8
|
+
import { useSearchParams } from "react-router";
|
|
9
|
+
import type { SupabaseAuthenticationConfig } from "../../../../config/config.js";
|
|
10
|
+
import { Heading } from "../../../components/Heading.js";
|
|
11
|
+
|
|
12
|
+
export const SupabaseAuthUI = ({
|
|
13
|
+
client,
|
|
14
|
+
config,
|
|
15
|
+
view = "sign_in",
|
|
16
|
+
}: {
|
|
17
|
+
client: SupabaseClient;
|
|
18
|
+
config: SupabaseAuthenticationConfig;
|
|
19
|
+
view: ViewType;
|
|
20
|
+
}) => {
|
|
21
|
+
const [searchParams] = useSearchParams();
|
|
22
|
+
const redirectTo = searchParams.get("redirectTo");
|
|
23
|
+
const providers = config.provider ? [config.provider] : config.providers;
|
|
24
|
+
const root = config.basePath ?? "/";
|
|
25
|
+
const redirectToAfterSignUp =
|
|
26
|
+
redirectTo ?? config.redirectToAfterSignUp ?? root;
|
|
27
|
+
const redirectToAfterSignIn =
|
|
28
|
+
redirectTo ?? config.redirectToAfterSignIn ?? root;
|
|
29
|
+
const redirectToAfterSignOut =
|
|
30
|
+
redirectTo ?? config.redirectToAfterSignOut ?? root;
|
|
31
|
+
|
|
32
|
+
return (
|
|
33
|
+
<div className="flex items-center justify-center">
|
|
34
|
+
<div className="max-w-md w-full mt-10">
|
|
35
|
+
<Heading level={1}>
|
|
36
|
+
{view === "sign_in" ? "Sign in" : "Sign up"}
|
|
37
|
+
</Heading>
|
|
38
|
+
<Auth
|
|
39
|
+
view={view}
|
|
40
|
+
redirectToAfterSignIn={redirectToAfterSignIn}
|
|
41
|
+
redirectToAfterSignUp={redirectToAfterSignUp}
|
|
42
|
+
redirectToAfterSignOut={redirectToAfterSignOut}
|
|
43
|
+
supabaseClient={client}
|
|
44
|
+
onlyThirdPartyProviders={config.onlyThirdPartyProviders}
|
|
45
|
+
appearance={{
|
|
46
|
+
theme: ThemeSupa,
|
|
47
|
+
variables: {
|
|
48
|
+
default: {
|
|
49
|
+
colors: {
|
|
50
|
+
dividerBackground: "var(--border)",
|
|
51
|
+
brand: "var(--primary)",
|
|
52
|
+
brandAccent: "hsla(from var(--primary) h s l / 0.8)",
|
|
53
|
+
brandButtonText: "var(--primary-foreground)",
|
|
54
|
+
defaultButtonBorder: "var(--border)",
|
|
55
|
+
inputBorder: "var(--border)",
|
|
56
|
+
inputText: "var(--foreground)",
|
|
57
|
+
inputBorderHover: "var(--accent)",
|
|
58
|
+
defaultButtonBackground: "var(--secondary)",
|
|
59
|
+
defaultButtonBackgroundHover: "var(--accent)",
|
|
60
|
+
},
|
|
61
|
+
radii: {
|
|
62
|
+
borderRadiusButton: "var(--radius)",
|
|
63
|
+
buttonBorderRadius: "var(--radius)",
|
|
64
|
+
inputBorderRadius: "var(--radius)",
|
|
65
|
+
},
|
|
66
|
+
} satisfies ThemeVariables,
|
|
67
|
+
},
|
|
68
|
+
}}
|
|
69
|
+
providers={providers}
|
|
70
|
+
redirectTo={config.redirectToAfterSignIn ?? "/"}
|
|
71
|
+
/>
|
|
72
|
+
</div>
|
|
73
|
+
</div>
|
|
74
|
+
);
|
|
75
|
+
};
|
|
@@ -7,46 +7,38 @@ import {
|
|
|
7
7
|
import type { SupabaseAuthenticationConfig } from "../../../config/config.js";
|
|
8
8
|
import { CoreAuthenticationPlugin } from "../AuthenticationPlugin.js";
|
|
9
9
|
import type {
|
|
10
|
+
AuthActionContext,
|
|
11
|
+
AuthActionOptions,
|
|
10
12
|
AuthenticationPlugin,
|
|
11
13
|
AuthenticationProviderInitializer,
|
|
12
14
|
} from "../authentication.js";
|
|
15
|
+
import { SignOut } from "../components/SignOut.js";
|
|
13
16
|
import { AuthorizationError } from "../errors.js";
|
|
14
17
|
import { type UserProfile, useAuthState } from "../state.js";
|
|
18
|
+
import { SupabaseAuthUI } from "./supabase/SupabaseAuthUI.js";
|
|
15
19
|
|
|
16
20
|
class SupabaseAuthenticationProvider
|
|
17
21
|
extends CoreAuthenticationPlugin
|
|
18
22
|
implements AuthenticationPlugin
|
|
19
23
|
{
|
|
20
24
|
private readonly client: SupabaseClient;
|
|
21
|
-
private readonly
|
|
22
|
-
private readonly
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
constructor({
|
|
28
|
-
supabaseUrl,
|
|
29
|
-
supabaseKey,
|
|
30
|
-
provider,
|
|
31
|
-
redirectToAfterSignUp,
|
|
32
|
-
redirectToAfterSignIn,
|
|
33
|
-
redirectToAfterSignOut,
|
|
34
|
-
basePath,
|
|
35
|
-
}: SupabaseAuthenticationConfig) {
|
|
25
|
+
private readonly providers: Provider[];
|
|
26
|
+
private readonly config: SupabaseAuthenticationConfig;
|
|
27
|
+
|
|
28
|
+
constructor(config: SupabaseAuthenticationConfig) {
|
|
29
|
+
const { provider, providers, supabaseUrl, supabaseKey } = config;
|
|
36
30
|
super();
|
|
37
|
-
this.
|
|
31
|
+
this.providers = providers ?? (provider ? [provider] : []);
|
|
32
|
+
if (this.providers.length === 0) {
|
|
33
|
+
throw new Error("At least one provider must be provided");
|
|
34
|
+
}
|
|
38
35
|
this.client = createClient(supabaseUrl, supabaseKey, {
|
|
39
36
|
auth: {
|
|
40
37
|
autoRefreshToken: true,
|
|
41
38
|
persistSession: true,
|
|
42
39
|
},
|
|
43
40
|
});
|
|
44
|
-
|
|
45
|
-
const root = basePath ?? "/";
|
|
46
|
-
|
|
47
|
-
this.redirectToAfterSignUp = redirectToAfterSignUp ?? root;
|
|
48
|
-
this.redirectToAfterSignIn = redirectToAfterSignIn ?? root;
|
|
49
|
-
this.redirectToAfterSignOut = redirectToAfterSignOut ?? root;
|
|
41
|
+
this.config = config;
|
|
50
42
|
|
|
51
43
|
this.client.auth.onAuthStateChange(async (event, session) => {
|
|
52
44
|
if (session && (event === "SIGNED_IN" || event === "TOKEN_REFRESHED")) {
|
|
@@ -90,31 +82,55 @@ class SupabaseAuthenticationProvider
|
|
|
90
82
|
return request;
|
|
91
83
|
}
|
|
92
84
|
|
|
93
|
-
signUp = async (
|
|
94
|
-
|
|
85
|
+
signUp = async (
|
|
86
|
+
{ navigate }: AuthActionContext,
|
|
87
|
+
{ redirectTo }: AuthActionOptions,
|
|
88
|
+
) => {
|
|
89
|
+
void navigate(
|
|
90
|
+
redirectTo
|
|
91
|
+
? `/signup?redirectTo=${encodeURIComponent(redirectTo)}`
|
|
92
|
+
: `/signup`,
|
|
93
|
+
);
|
|
94
|
+
};
|
|
95
95
|
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
96
|
+
signIn = async (
|
|
97
|
+
{ navigate }: AuthActionContext,
|
|
98
|
+
{ redirectTo }: AuthActionOptions,
|
|
99
|
+
) => {
|
|
100
|
+
void navigate(
|
|
101
|
+
redirectTo
|
|
102
|
+
? `/signin?redirectTo=${encodeURIComponent(redirectTo)}`
|
|
103
|
+
: `/signin`,
|
|
104
|
+
);
|
|
103
105
|
};
|
|
104
106
|
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
107
|
+
getRoutes = () => {
|
|
108
|
+
return [
|
|
109
|
+
{
|
|
110
|
+
path: "/signin",
|
|
111
|
+
element: (
|
|
112
|
+
<SupabaseAuthUI
|
|
113
|
+
view="sign_in"
|
|
114
|
+
client={this.client}
|
|
115
|
+
config={this.config}
|
|
116
|
+
/>
|
|
117
|
+
),
|
|
116
118
|
},
|
|
117
|
-
|
|
119
|
+
{
|
|
120
|
+
path: "/signup",
|
|
121
|
+
element: (
|
|
122
|
+
<SupabaseAuthUI
|
|
123
|
+
view="sign_up"
|
|
124
|
+
client={this.client}
|
|
125
|
+
config={this.config}
|
|
126
|
+
/>
|
|
127
|
+
),
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
path: "/signout",
|
|
131
|
+
element: <SignOut />,
|
|
132
|
+
},
|
|
133
|
+
];
|
|
118
134
|
};
|
|
119
135
|
|
|
120
136
|
signOut = async () => {
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { create
|
|
1
|
+
import { create } from "zustand";
|
|
2
2
|
import { createJSONStorage, persist } from "zustand/middleware";
|
|
3
|
+
import { syncZustandState } from "../util/syncZustandState.js";
|
|
3
4
|
|
|
4
5
|
export interface AuthState<ProviderData = unknown> {
|
|
5
6
|
isAuthenticated: boolean;
|
|
@@ -17,25 +18,6 @@ export interface AuthState<ProviderData = unknown> {
|
|
|
17
18
|
}) => void;
|
|
18
19
|
}
|
|
19
20
|
|
|
20
|
-
export type StoreWithPersist<T> = Mutate<
|
|
21
|
-
StoreApi<T>,
|
|
22
|
-
[["zustand/persist", unknown]]
|
|
23
|
-
>;
|
|
24
|
-
|
|
25
|
-
const withStorageDOMEvents = <T>(store: StoreWithPersist<T>) => {
|
|
26
|
-
const storageEventCallback = (e: StorageEvent) => {
|
|
27
|
-
if (e.key === store.persist.getOptions().name && e.newValue) {
|
|
28
|
-
void store.persist.rehydrate();
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
window.addEventListener("storage", storageEventCallback);
|
|
33
|
-
|
|
34
|
-
return () => {
|
|
35
|
-
window.removeEventListener("storage", storageEventCallback);
|
|
36
|
-
};
|
|
37
|
-
};
|
|
38
|
-
|
|
39
21
|
export const useAuthState = create<AuthState>()(
|
|
40
22
|
persist(
|
|
41
23
|
(set) => ({
|
|
@@ -85,9 +67,7 @@ export const useAuthState = create<AuthState>()(
|
|
|
85
67
|
),
|
|
86
68
|
);
|
|
87
69
|
|
|
88
|
-
|
|
89
|
-
withStorageDOMEvents(useAuthState);
|
|
90
|
-
}
|
|
70
|
+
syncZustandState(useAuthState);
|
|
91
71
|
|
|
92
72
|
export interface UserProfile {
|
|
93
73
|
sub: string;
|
|
@@ -2,8 +2,17 @@ MIT License
|
|
|
2
2
|
|
|
3
3
|
Copyright (c) 2023 Romain
|
|
4
4
|
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
|
|
6
|
+
associated documentation files (the "Software"), to deal in the Software without restriction,
|
|
7
|
+
including without limitation the rights to use, copy, modify, merge, publish, distribute,
|
|
8
|
+
sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
|
|
9
|
+
furnished to do so, subject to the following conditions:
|
|
6
10
|
|
|
7
|
-
The above copyright notice and this permission notice shall be included in all copies or substantial
|
|
11
|
+
The above copyright notice and this permission notice shall be included in all copies or substantial
|
|
12
|
+
portions of the Software.
|
|
8
13
|
|
|
9
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
|
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
|
|
15
|
+
NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
16
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
|
|
17
|
+
OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
18
|
+
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
@@ -71,16 +71,18 @@ export const BuildCheck = ({
|
|
|
71
71
|
? "A new version of the developer portal will be available soon."
|
|
72
72
|
: "To see the new version, reload the page now."}
|
|
73
73
|
</span>
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
74
|
+
{isCompleted && (
|
|
75
|
+
<Button
|
|
76
|
+
variant="outline"
|
|
77
|
+
size="sm"
|
|
78
|
+
className="w-full"
|
|
79
|
+
onClick={() => {
|
|
80
|
+
window.location.reload();
|
|
81
|
+
}}
|
|
82
|
+
>
|
|
83
|
+
Reload
|
|
84
|
+
</Button>
|
|
85
|
+
)}
|
|
84
86
|
</div>
|
|
85
87
|
);
|
|
86
88
|
};
|