zudoku 0.0.0-f0602bf → 0.0.0-f0b4321
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 +2 -2
- package/dist/app/ZuploBuildConfig.d.ts +11 -121
- package/dist/app/ZuploBuildConfig.js +8 -8
- package/dist/app/ZuploBuildConfig.js.map +1 -1
- package/dist/app/demo.js +21 -5
- package/dist/app/demo.js.map +1 -1
- package/dist/app/entry.client.d.ts +0 -2
- package/dist/app/entry.client.js +0 -2
- package/dist/app/entry.client.js.map +1 -1
- package/dist/app/entry.server.d.ts +0 -2
- package/dist/app/entry.server.js +0 -2
- package/dist/app/entry.server.js.map +1 -1
- package/dist/app/env.d.ts +7 -7
- package/dist/app/env.js +8 -0
- package/dist/app/env.js.map +1 -1
- package/dist/app/main.d.ts +1 -0
- package/dist/app/main.js +15 -20
- package/dist/app/main.js.map +1 -1
- package/dist/app/standalone.js +7 -6
- package/dist/app/standalone.js.map +1 -1
- package/dist/cli/build/handler.js +9 -1
- package/dist/cli/build/handler.js.map +1 -1
- package/dist/config/config.d.ts +11 -0
- package/dist/config/loader.js +4 -8
- package/dist/config/loader.js.map +1 -1
- package/dist/config/validators/BuildSchema.d.ts +20 -44
- package/dist/config/validators/BuildSchema.js +8 -14
- package/dist/config/validators/BuildSchema.js.map +1 -1
- package/dist/config/validators/InputNavigationSchema.d.ts +7364 -0
- package/dist/config/validators/InputNavigationSchema.js +71 -0
- package/dist/config/validators/InputNavigationSchema.js.map +1 -0
- package/dist/config/validators/InputNavigationSchema.test-d.d.ts +1 -0
- package/dist/config/validators/InputNavigationSchema.test-d.js +145 -0
- package/dist/config/validators/InputNavigationSchema.test-d.js.map +1 -0
- package/dist/config/validators/NavigationSchema.d.ts +44 -0
- package/dist/config/validators/NavigationSchema.js +95 -0
- package/dist/config/validators/NavigationSchema.js.map +1 -0
- package/dist/config/validators/icon-types.d.ts +2 -1
- package/dist/config/validators/icon-types.js +1813 -1
- package/dist/config/validators/icon-types.js.map +1 -1
- package/dist/config/validators/validate.d.ts +474 -5556
- package/dist/config/validators/validate.js +106 -73
- package/dist/config/validators/validate.js.map +1 -1
- package/dist/config/validators/validate.test.d.ts +1 -0
- package/dist/config/validators/validate.test.js +141 -0
- package/dist/config/validators/validate.test.js.map +1 -0
- package/dist/index.d.ts +2 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/auth/issuer.d.ts +2 -0
- package/dist/lib/auth/issuer.js +37 -0
- package/dist/lib/auth/issuer.js.map +1 -0
- package/dist/lib/auth/issuer.test.d.ts +1 -0
- package/dist/lib/auth/issuer.test.js +94 -0
- package/dist/lib/auth/issuer.test.js.map +1 -0
- package/dist/lib/authentication/AuthenticationPlugin.d.ts +0 -5
- package/dist/lib/authentication/AuthenticationPlugin.js +0 -12
- package/dist/lib/authentication/AuthenticationPlugin.js.map +1 -1
- package/dist/lib/authentication/authentication.d.ts +2 -0
- package/dist/lib/authentication/components/CallbackHandler.js +1 -1
- package/dist/lib/authentication/components/CallbackHandler.js.map +1 -1
- package/dist/lib/authentication/components/SignIn.js +4 -3
- package/dist/lib/authentication/components/SignIn.js.map +1 -1
- package/dist/lib/authentication/hook.d.ts +6 -0
- package/dist/lib/authentication/providers/auth0.js +1 -1
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/azureb2c.d.ts +28 -0
- package/dist/lib/authentication/providers/azureb2c.js +145 -0
- package/dist/lib/authentication/providers/azureb2c.js.map +1 -0
- package/dist/lib/authentication/providers/clerk.js +3 -12
- package/dist/lib/authentication/providers/clerk.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +5 -2
- package/dist/lib/authentication/providers/openid.js +49 -5
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/providers/supabase.js +2 -9
- package/dist/lib/authentication/providers/supabase.js.map +1 -1
- package/dist/lib/authentication/state.d.ts +6 -5
- package/dist/lib/authentication/state.js +19 -6
- package/dist/lib/authentication/state.js.map +1 -1
- package/dist/lib/components/Autocomplete.js +2 -2
- package/dist/lib/components/Autocomplete.js.map +1 -1
- package/dist/lib/components/Banner.js +2 -2
- package/dist/lib/components/Banner.js.map +1 -1
- package/dist/lib/components/BuildCheck.js +1 -1
- package/dist/lib/components/BuildCheck.js.map +1 -1
- package/dist/lib/components/CategoryHeading.js +1 -1
- package/dist/lib/components/CategoryHeading.js.map +1 -1
- package/dist/lib/components/ErrorPage.js +2 -2
- package/dist/lib/components/ErrorPage.js.map +1 -1
- package/dist/lib/components/Footer.js +1 -1
- package/dist/lib/components/Footer.js.map +1 -1
- package/dist/lib/components/Framed.d.ts +7 -0
- package/dist/lib/components/Framed.js +26 -0
- package/dist/lib/components/Framed.js.map +1 -0
- package/dist/lib/components/Header.js +19 -18
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Heading.d.ts +6 -2
- package/dist/lib/components/Heading.js +7 -2
- package/dist/lib/components/Heading.js.map +1 -1
- package/dist/lib/components/Main.js +4 -4
- package/dist/lib/components/Main.js.map +1 -1
- package/dist/lib/components/Markdown.d.ts +0 -1
- package/dist/lib/components/Markdown.js +9 -5
- package/dist/lib/components/Markdown.js.map +1 -1
- package/dist/lib/components/MobileTopNavigation.js +11 -7
- package/dist/lib/components/MobileTopNavigation.js.map +1 -1
- package/dist/lib/components/NotFoundPage.js +2 -2
- package/dist/lib/components/NotFoundPage.js.map +1 -1
- package/dist/lib/components/PageProgress.d.ts +1 -0
- package/dist/lib/components/PageProgress.js +20 -0
- package/dist/lib/components/PageProgress.js.map +1 -0
- package/dist/lib/components/Pagination.js +1 -1
- package/dist/lib/components/Pagination.js.map +1 -1
- package/dist/lib/components/StatusPage.js +4 -0
- package/dist/lib/components/StatusPage.js.map +1 -1
- package/dist/lib/components/TopNavigation.d.ts +7 -3
- package/dist/lib/components/TopNavigation.js +49 -44
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/Typography.d.ts +5 -0
- package/dist/lib/components/Typography.js +8 -0
- package/dist/lib/components/Typography.js.map +1 -0
- package/dist/lib/components/context/ZudokuContext.d.ts +3 -7
- package/dist/lib/components/context/ZudokuContext.js +44 -26
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/context/ZudokuProvider.d.ts +1 -1
- package/dist/lib/components/index.d.ts +39 -23
- package/dist/lib/components/index.js +15 -7
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/Navigation.d.ts +5 -0
- package/dist/lib/components/navigation/Navigation.js +12 -0
- package/dist/lib/components/navigation/Navigation.js.map +1 -0
- package/dist/lib/components/navigation/{SidebarBadge.d.ts → NavigationBadge.d.ts} +1 -1
- package/dist/lib/components/navigation/{SidebarBadge.js → NavigationBadge.js} +2 -2
- package/dist/lib/components/navigation/NavigationBadge.js.map +1 -0
- package/dist/lib/components/navigation/NavigationCategory.d.ts +5 -0
- package/dist/lib/components/navigation/{SidebarCategory.js → NavigationCategory.js} +15 -13
- package/dist/lib/components/navigation/NavigationCategory.js.map +1 -0
- package/dist/lib/components/navigation/NavigationItem.d.ts +6 -0
- package/dist/lib/components/navigation/NavigationItem.js +47 -0
- package/dist/lib/components/navigation/NavigationItem.js.map +1 -0
- package/dist/lib/components/navigation/{SidebarWrapper.d.ts → NavigationWrapper.d.ts} +1 -1
- package/dist/lib/components/navigation/{SidebarWrapper.js → NavigationWrapper.js} +5 -5
- package/dist/lib/components/navigation/NavigationWrapper.js.map +1 -0
- package/dist/lib/components/navigation/utils.d.ts +12 -9
- package/dist/lib/components/navigation/utils.js +38 -18
- package/dist/lib/components/navigation/utils.js.map +1 -1
- package/dist/lib/core/ZudokuContext.d.ts +13 -13
- package/dist/lib/core/ZudokuContext.js +21 -10
- package/dist/lib/core/ZudokuContext.js.map +1 -1
- package/dist/lib/core/plugins.d.ts +2 -2
- package/dist/lib/errors/ErrorAlert.js +2 -3
- package/dist/lib/errors/ErrorAlert.js.map +1 -1
- package/dist/lib/hooks/index.d.ts +25 -0
- package/dist/lib/hooks/index.js +11 -0
- package/dist/lib/hooks/index.js.map +1 -1
- package/dist/lib/hooks/useEvent.test.js +5 -3
- package/dist/lib/hooks/useEvent.test.js.map +1 -1
- package/dist/lib/hooks/useHotkey.d.ts +4 -0
- package/dist/lib/hooks/useHotkey.js +58 -0
- package/dist/lib/hooks/useHotkey.js.map +1 -0
- package/dist/lib/plugins/api-catalog/Catalog.d.ts +1 -1
- package/dist/lib/plugins/api-catalog/index.d.ts +6 -6
- package/dist/lib/plugins/api-catalog/index.js +10 -10
- package/dist/lib/plugins/api-catalog/index.js.map +1 -1
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js +115 -23
- package/dist/lib/plugins/api-keys/SettingsApiKeys.js.map +1 -1
- package/dist/lib/plugins/api-keys/index.d.ts +3 -3
- package/dist/lib/plugins/api-keys/index.js +37 -18
- package/dist/lib/plugins/api-keys/index.js.map +1 -1
- package/dist/lib/plugins/custom-pages/index.d.ts +4 -6
- package/dist/lib/plugins/custom-pages/index.js +15 -10
- package/dist/lib/plugins/custom-pages/index.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.d.ts +1 -2
- package/dist/lib/plugins/markdown/MdxPage.js +30 -10
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/index.d.ts +10 -2
- package/dist/lib/plugins/markdown/index.js +9 -26
- package/dist/lib/plugins/markdown/index.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationList.js +3 -3
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.js +2 -2
- package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.d.ts +1 -1
- package/dist/lib/plugins/openapi/SchemaList.js +2 -3
- package/dist/lib/plugins/openapi/SchemaList.js.map +1 -1
- package/dist/lib/plugins/openapi/Sidecar.js +11 -91
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.js +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.js +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +3 -3
- package/dist/lib/plugins/openapi/graphql/graphql.js +2 -2
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.d.ts +3 -3
- package/dist/lib/plugins/openapi/index.js +10 -10
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +3 -3
- package/dist/lib/plugins/openapi/playground/BodyPanel.d.ts +5 -0
- package/dist/lib/plugins/openapi/playground/BodyPanel.js +26 -0
- package/dist/lib/plugins/openapi/playground/BodyPanel.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/CollapsibleHeader.d.ts +8 -0
- package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js +11 -0
- package/dist/lib/plugins/openapi/playground/CollapsibleHeader.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +2 -1
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Headers.d.ts +5 -4
- package/dist/lib/plugins/openapi/playground/Headers.js +54 -32
- package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js +2 -1
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js +1 -2
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/InlineInput.js +1 -1
- package/dist/lib/plugins/openapi/playground/InlineInput.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/ParamsGrid.js +2 -2
- package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/PathParams.js +1 -2
- package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Playground.d.ts +3 -8
- package/dist/lib/plugins/openapi/playground/Playground.js +110 -92
- package/dist/lib/plugins/openapi/playground/Playground.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js +1 -1
- package/dist/lib/plugins/openapi/playground/PlaygroundDialog.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/QueryParams.d.ts +2 -2
- package/dist/lib/plugins/openapi/playground/QueryParams.js +38 -23
- package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Spinner.d.ts +2 -0
- package/dist/lib/plugins/openapi/playground/Spinner.js +63 -0
- package/dist/lib/plugins/openapi/playground/Spinner.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/fileUtils.d.ts +2 -0
- package/dist/lib/plugins/openapi/playground/fileUtils.js +22 -0
- package/dist/lib/plugins/openapi/playground/fileUtils.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlPath.d.ts +3 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlPath.js +13 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlPath.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.d.ts +1 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js +12 -0
- package/dist/lib/plugins/openapi/playground/request-panel/UrlQueryParams.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/result-panel/Highlight.d.ts +12 -0
- package/dist/lib/plugins/openapi/playground/result-panel/Highlight.js +11 -0
- package/dist/lib/plugins/openapi/playground/result-panel/Highlight.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.d.ts +8 -0
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js +69 -0
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.d.ts +10 -4
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +33 -31
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +4 -2
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +8 -10
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.d.ts +16 -0
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js +10 -0
- package/dist/lib/plugins/openapi/playground/useRememberSkipLoginDialog.js.map +1 -0
- package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js +3 -3
- package/dist/lib/plugins/openapi/schema/SchemaExampleAndDefault.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +2 -3
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.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/utils.js +3 -2
- package/dist/lib/plugins/openapi/schema/utils.js.map +1 -1
- package/dist/lib/plugins/openapi/util/createHttpSnippet.d.ts +11 -0
- package/dist/lib/plugins/openapi/util/createHttpSnippet.js +89 -0
- package/dist/lib/plugins/openapi/util/createHttpSnippet.js.map +1 -0
- package/dist/lib/plugins/openapi/util/createNavigationCategory.d.ts +9 -0
- package/dist/lib/plugins/openapi/util/{createSidebarCategory.js → createNavigationCategory.js} +5 -4
- package/dist/lib/plugins/openapi/util/createNavigationCategory.js.map +1 -0
- package/dist/lib/plugins/openapi/util/getRoutes.js +2 -2
- package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -1
- package/dist/lib/plugins/openapi/util/methodColorMap.d.ts +1 -1
- package/dist/lib/plugins/search-inkeep/index.d.ts +5 -22
- package/dist/lib/plugins/search-inkeep/index.js +35 -29
- package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
- package/dist/lib/plugins/search-inkeep/inkeep.d.ts +5 -21
- package/dist/lib/plugins/search-inkeep/inkeep.js +10 -19
- package/dist/lib/plugins/search-inkeep/inkeep.js.map +1 -1
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js +1 -1
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -1
- package/dist/lib/plugins/search-pagefind/ResultList.d.ts +1 -1
- package/dist/lib/plugins/search-pagefind/ResultList.js +12 -5
- package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -1
- package/dist/lib/shiki.d.ts +8 -12
- package/dist/lib/shiki.js +11 -13
- package/dist/lib/shiki.js.map +1 -1
- package/dist/lib/ui/Alert.d.ts +6 -5
- package/dist/lib/ui/Alert.js +12 -10
- package/dist/lib/ui/Alert.js.map +1 -1
- package/dist/lib/ui/Callout.js +1 -1
- package/dist/lib/ui/Callout.js.map +1 -1
- package/dist/lib/ui/CodeBlock.d.ts +1 -2
- package/dist/lib/ui/CodeBlock.js +10 -11
- package/dist/lib/ui/CodeBlock.js.map +1 -1
- package/dist/lib/ui/Dialog.d.ts +3 -1
- package/dist/lib/ui/Dialog.js +2 -2
- package/dist/lib/ui/Dialog.js.map +1 -1
- package/dist/lib/ui/EmbeddedCodeBlock.d.ts +15 -0
- package/dist/lib/ui/EmbeddedCodeBlock.js +18 -0
- package/dist/lib/ui/EmbeddedCodeBlock.js.map +1 -0
- package/dist/lib/ui/Select.js +1 -1
- package/dist/lib/ui/SyntaxHighlight.d.ts +3 -1
- package/dist/lib/ui/SyntaxHighlight.js +3 -2
- package/dist/lib/ui/SyntaxHighlight.js.map +1 -1
- package/dist/lib/ui/Tooltip.d.ts +2 -1
- package/dist/lib/ui/Tooltip.js +2 -1
- package/dist/lib/ui/Tooltip.js.map +1 -1
- package/dist/lib/util/MdxComponents.d.ts +9 -1
- package/dist/lib/util/MdxComponents.js +4 -2
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/lib/util/humanFileSize.d.ts +6 -0
- package/dist/lib/util/humanFileSize.js +14 -0
- package/dist/lib/util/humanFileSize.js.map +1 -0
- package/dist/lib/util/humanFileSize.test.d.ts +1 -0
- package/dist/lib/util/humanFileSize.test.js +22 -0
- package/dist/lib/util/humanFileSize.test.js.map +1 -0
- package/dist/lib/util/os.d.ts +2 -0
- package/dist/lib/util/os.js +21 -0
- package/dist/lib/util/os.js.map +1 -0
- package/dist/lib/util/useCopyToClipboard.d.ts +1 -0
- package/dist/lib/util/useCopyToClipboard.js +11 -0
- package/dist/lib/util/useCopyToClipboard.js.map +1 -0
- package/dist/lib/util/useScrollToAnchor.js +3 -3
- package/dist/lib/util/useScrollToAnchor.js.map +1 -1
- package/dist/vite/api/SchemaManager.d.ts +4 -4
- package/dist/vite/api/SchemaManager.js +25 -21
- package/dist/vite/api/SchemaManager.js.map +1 -1
- package/dist/vite/api/SchemaManager.test.js +4 -4
- package/dist/vite/api/SchemaManager.test.js.map +1 -1
- package/dist/vite/api/schema-codegen.js +42 -11
- package/dist/vite/api/schema-codegen.js.map +1 -1
- package/dist/vite/api/schema-codegen.test.js +82 -0
- package/dist/vite/api/schema-codegen.test.js.map +1 -1
- package/dist/vite/build.js +10 -34
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.js +12 -2
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/css/plugin.js +11 -0
- package/dist/vite/css/plugin.js.map +1 -1
- package/dist/vite/dev-server.js +1 -1
- package/dist/vite/mdx/remark-last-modified.d.ts +3 -0
- package/dist/vite/mdx/remark-last-modified.js +29 -0
- package/dist/vite/mdx/remark-last-modified.js.map +1 -0
- package/dist/vite/mdx/utils.d.ts +2 -0
- package/dist/vite/mdx/utils.js +31 -0
- package/dist/vite/mdx/utils.js.map +1 -0
- package/dist/vite/plugin-api.js +8 -8
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-config-reload.js +2 -0
- package/dist/vite/plugin-config-reload.js.map +1 -1
- package/dist/vite/plugin-custom-pages.js +2 -2
- package/dist/vite/plugin-custom-pages.js.map +1 -1
- package/dist/vite/plugin-docs.js +61 -59
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-frontmatter.js +6 -2
- package/dist/vite/plugin-frontmatter.js.map +1 -1
- package/dist/vite/plugin-mdx.js +17 -38
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/{plugin-sidebar.d.ts → plugin-navigation.d.ts} +1 -1
- package/dist/vite/{plugin-sidebar.js → plugin-navigation.js} +20 -19
- package/dist/vite/plugin-navigation.js.map +1 -0
- package/dist/vite/plugin-theme.d.ts +8 -0
- package/dist/vite/plugin-theme.js +234 -0
- package/dist/vite/plugin-theme.js.map +1 -0
- package/dist/vite/plugin-theme.test.d.ts +1 -0
- package/dist/vite/plugin-theme.test.js +312 -0
- package/dist/vite/plugin-theme.test.js.map +1 -0
- package/dist/vite/plugin.js +4 -6
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/shadcn-registry.d.ts +45 -0
- package/dist/vite/shadcn-registry.js +29 -0
- package/dist/vite/shadcn-registry.js.map +1 -0
- package/lib/Alert-Cig_8hW6.js +161 -0
- package/lib/Alert-Cig_8hW6.js.map +1 -0
- package/lib/{Button-u7M2QYds.js → Button-B3o-2Xdf.js} +3 -3
- package/lib/{Button-u7M2QYds.js.map → Button-B3o-2Xdf.js.map} +1 -1
- package/lib/{Card-DkH-AU1V.js → Card-CMDQUPM4.js} +2 -2
- package/lib/{Card-DkH-AU1V.js.map → Card-CMDQUPM4.js.map} +1 -1
- package/lib/CodeBlock-BaBgX9Wy.js +85 -0
- package/lib/CodeBlock-BaBgX9Wy.js.map +1 -0
- package/lib/Command-C9AC5cf-.js +140 -0
- package/lib/Command-C9AC5cf-.js.map +1 -0
- package/lib/{Dialog-irKZWXGg.js → Dialog-DMWw1doX.js} +26 -26
- package/lib/Dialog-DMWw1doX.js.map +1 -0
- package/lib/{Drawer-DZ214i5V.js → Drawer-DXGPOKPx.js} +2 -2
- package/lib/{Drawer-DZ214i5V.js.map → Drawer-DXGPOKPx.js.map} +1 -1
- package/lib/MdxPage-D8Med7IR.js +110 -0
- package/lib/MdxPage-D8Med7IR.js.map +1 -0
- package/lib/OasProvider-YexVRErA.js +35 -0
- package/lib/OasProvider-YexVRErA.js.map +1 -0
- package/lib/{OperationList-CkKcRPvk.js → OperationList-CL_tp7DC.js} +1749 -1728
- package/lib/OperationList-CL_tp7DC.js.map +1 -0
- package/lib/Pagination-Bcjbdo_g.js +37 -0
- package/lib/Pagination-Bcjbdo_g.js.map +1 -0
- package/lib/RouteGuard-Vnlz_t51.js +737 -0
- package/lib/RouteGuard-Vnlz_t51.js.map +1 -0
- package/lib/{SchemaList-BUiEgmw6.js → SchemaList-BNDTWO1B.js} +32 -43
- package/lib/SchemaList-BNDTWO1B.js.map +1 -0
- package/lib/{SchemaView-DSgzGi1L.js → SchemaView-DdKqED8D.js} +95 -104
- package/lib/SchemaView-DdKqED8D.js.map +1 -0
- package/lib/SignUp-BkAQMKsK.js +56 -0
- package/lib/SignUp-BkAQMKsK.js.map +1 -0
- package/lib/Slot-CrCBhP3G.js +15743 -0
- package/lib/Slot-CrCBhP3G.js.map +1 -0
- package/lib/{SyntaxHighlight-DTgNHbGp.js → SyntaxHighlight-CVe58ZSY.js} +4683 -3484
- package/lib/SyntaxHighlight-CVe58ZSY.js.map +1 -0
- package/lib/{Toc-Ccycwd-T.js → Toc-CpsFSXeD.js} +3 -3
- package/lib/{Toc-Ccycwd-T.js.map → Toc-CpsFSXeD.js.map} +1 -1
- package/lib/{chunk-BAXFHI7N-C9WnHsLV.js → chunk-DQRVZFIR-DHK7_Ilc.js} +701 -701
- package/lib/chunk-DQRVZFIR-DHK7_Ilc.js.map +1 -0
- package/lib/{circular-D1Bwr5bf.js → circular-BJUzZQ5q.js} +1812 -1807
- package/lib/circular-BJUzZQ5q.js.map +1 -0
- package/lib/clerk-BDZ31hjU.js +25190 -0
- package/lib/clerk-BDZ31hjU.js.map +1 -0
- package/lib/clsx-OuTLNxxd.js +17 -0
- package/lib/clsx-OuTLNxxd.js.map +1 -0
- package/lib/{cn-BOFVZgHd.js → cn-dYga0KKN.js} +237 -250
- package/lib/cn-dYga0KKN.js.map +1 -0
- package/lib/{createServer-BZp1gEBL.js → createServer-C8-YhyiB.js} +2459 -2448
- package/lib/createServer-C8-YhyiB.js.map +1 -0
- package/lib/errors-CKo4K1aM.js +78 -0
- package/lib/errors-CKo4K1aM.js.map +1 -0
- package/lib/hook-CZjW2buS.js +1510 -0
- package/lib/hook-CZjW2buS.js.map +1 -0
- package/lib/{index-BvvmIczU.js → index-4XtG1tlD.js} +2 -2
- package/lib/{index-BvvmIczU.js.map → index-4XtG1tlD.js.map} +1 -1
- package/lib/index-B3xhxwZH.js +3469 -0
- package/lib/index-B3xhxwZH.js.map +1 -0
- package/lib/index-B4yKFxne.js +3980 -0
- package/lib/index-B4yKFxne.js.map +1 -0
- package/lib/index-Bm35Tkgf.js +107 -0
- package/lib/index-Bm35Tkgf.js.map +1 -0
- package/lib/index-CrcNWbel.js.map +1 -1
- package/lib/{index-C1S4w-gl.js → index-DI5SPFK9.js} +2 -2
- package/lib/{index-C1S4w-gl.js.map → index-DI5SPFK9.js.map} +1 -1
- package/lib/{index-zddirpDj.js → index-DmNq2fbN.js} +226 -221
- package/lib/index-DmNq2fbN.js.map +1 -0
- package/lib/index.esm-Cp4wkyud.js +1236 -0
- package/lib/index.esm-Cp4wkyud.js.map +1 -0
- package/lib/ui/Accordion.js +1 -1
- package/lib/ui/ActionButton.js +2 -2
- package/lib/ui/Alert.js +54 -38
- package/lib/ui/Alert.js.map +1 -1
- package/lib/ui/AlertDialog.js +1 -1
- package/lib/ui/Badge.js +2 -2
- package/lib/ui/Breadcrumb.js +1 -1
- package/lib/ui/Button.js +2 -2
- package/lib/ui/Callout.js +6 -5
- 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/Checkbox.js +1 -1
- package/lib/ui/CodeBlock.js +6 -80
- package/lib/ui/CodeBlock.js.map +1 -1
- package/lib/ui/Command.js +2 -2
- package/lib/ui/Dialog.js +40 -40
- 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 +80 -0
- package/lib/ui/EmbeddedCodeBlock.js.map +1 -0
- 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 +2 -2
- 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/ScrollArea.js +1 -1
- package/lib/ui/Select.js +2 -2
- package/lib/ui/Select.js.map +1 -1
- package/lib/ui/Skeleton.js +1 -1
- package/lib/ui/Slider.js +1 -1
- package/lib/ui/Switch.js +1 -1
- package/lib/ui/SyntaxHighlight.js +5 -4
- package/lib/ui/SyntaxHighlight.js.map +1 -1
- package/lib/ui/Tabs.js +1 -1
- package/lib/ui/Textarea.js +1 -1
- package/lib/ui/Toggle.js +2 -2
- package/lib/ui/ToggleGroup.js +1 -1
- package/lib/ui/Tooltip.js +15 -8
- package/lib/ui/Tooltip.js.map +1 -1
- package/lib/ui/util.js +1 -1
- package/lib/{useExposedProps-DG8J6ewJ.js → useExposedProps-BIYjecPD.js} +2 -2
- package/lib/{useExposedProps-DG8J6ewJ.js.map → useExposedProps-BIYjecPD.js.map} +1 -1
- package/lib/zudoku.auth-auth0.js +2 -2
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-azureb2c.js +9971 -0
- package/lib/zudoku.auth-azureb2c.js.map +1 -0
- package/lib/zudoku.auth-clerk.js +39 -48
- package/lib/zudoku.auth-clerk.js.map +1 -1
- package/lib/zudoku.auth-openid.js +381 -406
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +29 -30
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.hooks.js +21 -13
- package/lib/zudoku.hooks.js.map +1 -1
- package/lib/zudoku.plugin-api-catalog.js +45 -45
- package/lib/zudoku.plugin-api-catalog.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +512 -4971
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +12 -18
- package/lib/zudoku.plugin-custom-pages.js.map +1 -1
- package/lib/zudoku.plugin-markdown.js +19 -69
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +6 -6
- package/lib/zudoku.plugin-redirect.js +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +54 -57
- package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
- package/lib/zudoku.plugin-search-pagefind.js +211 -117
- package/lib/zudoku.plugin-search-pagefind.js.map +1 -1
- package/lib/zudoku.plugins.js.map +1 -1
- package/package.json +91 -70
- package/src/app/ZuploBuildConfig.ts +8 -8
- package/src/app/defaultTheme.css +68 -49
- package/src/app/demo.tsx +24 -6
- package/src/app/entry.client.tsx +0 -2
- package/src/app/entry.server.tsx +0 -2
- package/src/app/env.ts +8 -0
- package/src/app/main.css +15 -57
- package/src/app/main.tsx +18 -24
- package/src/app/standalone.tsx +7 -6
- package/src/lib/auth/issuer.test.ts +120 -0
- package/src/lib/auth/issuer.ts +41 -0
- package/src/lib/authentication/AuthenticationPlugin.tsx +0 -14
- package/src/lib/authentication/authentication.ts +2 -2
- package/src/lib/authentication/components/CallbackHandler.tsx +1 -1
- package/src/lib/authentication/components/SignIn.tsx +5 -12
- package/src/lib/authentication/providers/auth0.tsx +1 -1
- package/src/lib/authentication/providers/azureb2c.tsx +196 -0
- package/src/lib/authentication/providers/clerk.tsx +3 -12
- package/src/lib/authentication/providers/openid.tsx +76 -4
- package/src/lib/authentication/providers/supabase.tsx +2 -9
- package/src/lib/authentication/state.ts +37 -7
- package/src/lib/components/Autocomplete.tsx +2 -1
- package/src/lib/components/Banner.tsx +1 -2
- package/src/lib/components/BuildCheck.tsx +1 -1
- package/src/lib/components/CategoryHeading.tsx +4 -1
- package/src/lib/components/ErrorPage.tsx +3 -3
- package/src/lib/components/Footer.tsx +1 -1
- package/src/lib/components/Framed.tsx +51 -0
- package/src/lib/components/Header.tsx +25 -22
- package/src/lib/components/Heading.tsx +16 -8
- package/src/lib/components/Main.tsx +9 -9
- package/src/lib/components/Markdown.tsx +17 -9
- package/src/lib/components/MobileTopNavigation.tsx +69 -15
- package/src/lib/components/NotFoundPage.tsx +3 -3
- package/src/lib/components/PageProgress.tsx +28 -0
- package/src/lib/components/Pagination.tsx +5 -4
- package/src/lib/components/StatusPage.tsx +5 -0
- package/src/lib/components/TopNavigation.tsx +75 -68
- package/src/lib/components/Typography.tsx +14 -0
- package/src/lib/components/context/ZudokuContext.ts +50 -32
- package/src/lib/components/context/ZudokuProvider.tsx +1 -1
- package/src/lib/components/index.ts +16 -10
- package/src/lib/components/navigation/{Sidebar.tsx → Navigation.tsx} +18 -16
- package/src/lib/components/navigation/{SidebarBadge.tsx → NavigationBadge.tsx} +1 -1
- package/src/lib/components/navigation/{SidebarCategory.tsx → NavigationCategory.tsx} +17 -15
- package/src/lib/components/navigation/NavigationItem.tsx +151 -0
- package/src/lib/components/navigation/{SidebarWrapper.tsx → NavigationWrapper.tsx} +7 -4
- package/src/lib/components/navigation/utils.ts +52 -29
- package/src/lib/core/ZudokuContext.ts +36 -20
- package/src/lib/core/plugins.ts +2 -2
- package/src/lib/errors/ErrorAlert.tsx +3 -9
- package/src/lib/hooks/index.ts +11 -0
- package/src/lib/hooks/useEvent.test.tsx +7 -5
- package/src/lib/hooks/useHotkey.ts +70 -0
- package/src/lib/plugins/api-catalog/Catalog.tsx +1 -1
- package/src/lib/plugins/api-catalog/index.tsx +19 -19
- package/src/lib/plugins/api-keys/SettingsApiKeys.tsx +238 -70
- package/src/lib/plugins/api-keys/index.tsx +50 -23
- package/src/lib/plugins/custom-pages/index.tsx +21 -16
- package/src/lib/plugins/markdown/MdxPage.tsx +76 -21
- package/src/lib/plugins/markdown/index.tsx +28 -41
- package/src/lib/plugins/openapi/OperationList.tsx +12 -20
- package/src/lib/plugins/openapi/OperationListItem.tsx +3 -3
- package/src/lib/plugins/openapi/ParameterListItem.tsx +6 -0
- package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +1 -1
- package/src/lib/plugins/openapi/SchemaList.tsx +5 -11
- package/src/lib/plugins/openapi/Sidecar.tsx +12 -97
- package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -0
- package/src/lib/plugins/openapi/graphql/gql.ts +5 -5
- package/src/lib/plugins/openapi/graphql/graphql.ts +6 -6
- package/src/lib/plugins/openapi/index.tsx +12 -12
- package/src/lib/plugins/openapi/interfaces.ts +3 -3
- package/src/lib/plugins/openapi/playground/BodyPanel.tsx +55 -0
- package/src/lib/plugins/openapi/playground/CollapsibleHeader.tsx +47 -0
- package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +8 -1
- package/src/lib/plugins/openapi/playground/Headers.tsx +217 -115
- package/src/lib/plugins/openapi/playground/IdentityDialog.tsx +3 -2
- package/src/lib/plugins/openapi/playground/IdentitySelector.tsx +13 -16
- package/src/lib/plugins/openapi/playground/InlineInput.tsx +1 -1
- package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +2 -2
- package/src/lib/plugins/openapi/playground/PathParams.tsx +4 -5
- package/src/lib/plugins/openapi/playground/Playground.tsx +253 -288
- package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +2 -1
- package/src/lib/plugins/openapi/playground/QueryParams.tsx +104 -58
- package/src/lib/plugins/openapi/playground/Spinner.tsx +87 -0
- package/src/lib/plugins/openapi/playground/fileUtils.ts +32 -0
- package/src/lib/plugins/openapi/playground/request-panel/UrlPath.tsx +31 -0
- package/src/lib/plugins/openapi/playground/request-panel/UrlQueryParams.tsx +25 -0
- package/src/lib/plugins/openapi/playground/result-panel/Highlight.tsx +26 -0
- package/src/lib/plugins/openapi/playground/result-panel/ResponseStatusBar.tsx +115 -0
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +149 -108
- package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +68 -89
- package/src/lib/plugins/openapi/playground/useRememberSkipLoginDialog.tsx +20 -0
- package/src/lib/plugins/openapi/schema/SchemaExampleAndDefault.tsx +3 -3
- package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +2 -3
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +6 -11
- package/src/lib/plugins/openapi/schema/utils.ts +3 -2
- package/src/lib/plugins/openapi/util/createHttpSnippet.ts +107 -0
- package/src/lib/plugins/openapi/util/{createSidebarCategory.tsx → createNavigationCategory.tsx} +6 -5
- package/src/lib/plugins/openapi/util/getRoutes.tsx +2 -2
- package/src/lib/plugins/openapi/util/methodColorMap.tsx +1 -1
- package/src/lib/plugins/search-inkeep/index.tsx +54 -58
- package/src/lib/plugins/search-inkeep/inkeep.ts +19 -21
- package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +1 -0
- package/src/lib/plugins/search-pagefind/ResultList.tsx +13 -4
- package/src/lib/shiki.ts +21 -22
- package/src/lib/ui/Alert.tsx +45 -39
- package/src/lib/ui/Callout.tsx +1 -0
- package/src/lib/ui/CodeBlock.tsx +40 -54
- package/src/lib/ui/Dialog.tsx +11 -7
- package/src/lib/ui/EmbeddedCodeBlock.tsx +94 -0
- package/src/lib/ui/Select.tsx +1 -1
- package/src/lib/ui/SyntaxHighlight.tsx +11 -3
- package/src/lib/ui/Tooltip.tsx +16 -1
- package/src/lib/util/MdxComponents.tsx +13 -2
- package/src/lib/util/humanFileSize.test.ts +24 -0
- package/src/lib/util/humanFileSize.ts +16 -0
- package/src/lib/util/os.ts +18 -0
- package/src/lib/util/useCopyToClipboard.ts +17 -0
- package/src/lib/util/useScrollToAnchor.ts +3 -3
- package/dist/config/validators/InputSidebarSchema.d.ts +0 -217
- package/dist/config/validators/InputSidebarSchema.js +0 -62
- package/dist/config/validators/InputSidebarSchema.js.map +0 -1
- package/dist/config/validators/SidebarSchema.d.ts +0 -46
- package/dist/config/validators/SidebarSchema.js +0 -118
- package/dist/config/validators/SidebarSchema.js.map +0 -1
- package/dist/lib/components/navigation/Sidebar.d.ts +0 -5
- package/dist/lib/components/navigation/Sidebar.js +0 -10
- package/dist/lib/components/navigation/Sidebar.js.map +0 -1
- package/dist/lib/components/navigation/SidebarBadge.js.map +0 -1
- package/dist/lib/components/navigation/SidebarCategory.d.ts +0 -5
- package/dist/lib/components/navigation/SidebarCategory.js.map +0 -1
- package/dist/lib/components/navigation/SidebarItem.d.ts +0 -11
- package/dist/lib/components/navigation/SidebarItem.js +0 -49
- package/dist/lib/components/navigation/SidebarItem.js.map +0 -1
- package/dist/lib/components/navigation/SidebarWrapper.js.map +0 -1
- package/dist/lib/plugins/custom-pages/CustomPage.d.ts +0 -2
- package/dist/lib/plugins/custom-pages/CustomPage.js +0 -11
- package/dist/lib/plugins/custom-pages/CustomPage.js.map +0 -1
- package/dist/lib/plugins/markdown/resolver.d.ts +0 -32
- package/dist/lib/plugins/markdown/resolver.js +0 -46
- package/dist/lib/plugins/markdown/resolver.js.map +0 -1
- package/dist/lib/plugins/openapi/playground/SubmitButton.d.ts +0 -7
- package/dist/lib/plugins/openapi/playground/SubmitButton.js +0 -19
- package/dist/lib/plugins/openapi/playground/SubmitButton.js.map +0 -1
- package/dist/lib/plugins/openapi/playground/UrlDisplay.d.ts +0 -4
- package/dist/lib/plugins/openapi/playground/UrlDisplay.js +0 -22
- package/dist/lib/plugins/openapi/playground/UrlDisplay.js.map +0 -1
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.d.ts +0 -7
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +0 -11
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +0 -1
- package/dist/lib/plugins/openapi/util/createSidebarCategory.d.ts +0 -9
- package/dist/lib/plugins/openapi/util/createSidebarCategory.js.map +0 -1
- package/dist/vite/plugin-configure-tailwind.d.ts +0 -2
- package/dist/vite/plugin-configure-tailwind.js +0 -38
- package/dist/vite/plugin-configure-tailwind.js.map +0 -1
- package/dist/vite/plugin-sidebar.js.map +0 -1
- package/dist/vite/plugin-theme-css.d.ts +0 -5
- package/dist/vite/plugin-theme-css.js +0 -77
- package/dist/vite/plugin-theme-css.js.map +0 -1
- package/lib/Callout-CtCQJ6Cc.js +0 -230
- package/lib/Callout-CtCQJ6Cc.js.map +0 -1
- package/lib/CategoryHeading-BA7lKNWz.js +0 -10
- package/lib/CategoryHeading-BA7lKNWz.js.map +0 -1
- package/lib/Dialog-irKZWXGg.js.map +0 -1
- package/lib/Markdown-BNG8bTDA.js +0 -7691
- package/lib/Markdown-BNG8bTDA.js.map +0 -1
- package/lib/MdxPage-D74eGiYZ.js +0 -84
- package/lib/MdxPage-D74eGiYZ.js.map +0 -1
- package/lib/OasProvider-D61BSWef.js +0 -33
- package/lib/OasProvider-D61BSWef.js.map +0 -1
- package/lib/OperationList-CkKcRPvk.js.map +0 -1
- package/lib/Pagination-CeFxTDan.js +0 -36
- package/lib/Pagination-CeFxTDan.js.map +0 -1
- package/lib/RouteGuard-CIyGFkFD.js +0 -55
- package/lib/RouteGuard-CIyGFkFD.js.map +0 -1
- package/lib/SchemaList-BUiEgmw6.js.map +0 -1
- package/lib/SchemaView-DSgzGi1L.js.map +0 -1
- package/lib/SignUp-DCgoDR--.js +0 -63
- package/lib/SignUp-DCgoDR--.js.map +0 -1
- package/lib/Slot-Dw-g06lX.js +0 -160
- package/lib/Slot-Dw-g06lX.js.map +0 -1
- package/lib/SyntaxHighlight-DTgNHbGp.js.map +0 -1
- package/lib/chunk-BAXFHI7N-C9WnHsLV.js.map +0 -1
- package/lib/circular-D1Bwr5bf.js.map +0 -1
- package/lib/cn-BOFVZgHd.js.map +0 -1
- package/lib/createServer-BZp1gEBL.js.map +0 -1
- package/lib/hook-BpiAQVtd.js +0 -1446
- package/lib/hook-BpiAQVtd.js.map +0 -1
- package/lib/index--oeBayMa.js +0 -86
- package/lib/index--oeBayMa.js.map +0 -1
- package/lib/index-Bn6Lc9tq.js +0 -9
- package/lib/index-Bn6Lc9tq.js.map +0 -1
- package/lib/index-DEr_Ta6s.js +0 -4977
- package/lib/index-DEr_Ta6s.js.map +0 -1
- package/lib/index-E90CTqBl.js +0 -3268
- package/lib/index-E90CTqBl.js.map +0 -1
- package/lib/index-zddirpDj.js.map +0 -1
- package/lib/index.esm-BFcSKCe-.js +0 -683
- package/lib/index.esm-BFcSKCe-.js.map +0 -1
- package/lib/index.esm-DSfX_eMP.js +0 -1216
- package/lib/index.esm-DSfX_eMP.js.map +0 -1
- package/lib/mutation-CJrIFMgY.js +0 -196
- package/lib/mutation-CJrIFMgY.js.map +0 -1
- package/lib/objectEntries-yMIkr2mI.js +0 -5
- package/lib/objectEntries-yMIkr2mI.js.map +0 -1
- package/lib/useLatest-hmRS46UF.js +0 -11
- package/lib/useLatest-hmRS46UF.js.map +0 -1
- package/lib/useMutation-B2LNwShM.js +0 -97
- package/lib/useMutation-B2LNwShM.js.map +0 -1
- package/src/lib/components/navigation/SidebarItem.tsx +0 -117
- package/src/lib/plugins/custom-pages/CustomPage.tsx +0 -18
- package/src/lib/plugins/markdown/resolver.ts +0 -59
- package/src/lib/plugins/openapi/playground/SubmitButton.tsx +0 -70
- package/src/lib/plugins/openapi/playground/UrlDisplay.tsx +0 -32
- package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +0 -73
|
@@ -113,25 +113,41 @@ export class OpenIDAuthenticationProvider
|
|
|
113
113
|
});
|
|
114
114
|
}
|
|
115
115
|
|
|
116
|
-
async signUp({
|
|
116
|
+
async signUp({
|
|
117
|
+
redirectTo,
|
|
118
|
+
replace = false,
|
|
119
|
+
}: {
|
|
120
|
+
redirectTo?: string;
|
|
121
|
+
replace?: boolean;
|
|
122
|
+
} = {}) {
|
|
117
123
|
return this.authorize({
|
|
118
124
|
redirectTo: this.redirectToAfterSignUp ?? redirectTo ?? "/",
|
|
125
|
+
replace,
|
|
119
126
|
isSignUp: true,
|
|
120
127
|
});
|
|
121
128
|
}
|
|
122
129
|
|
|
123
|
-
async signIn({
|
|
130
|
+
async signIn({
|
|
131
|
+
redirectTo,
|
|
132
|
+
replace = false,
|
|
133
|
+
}: {
|
|
134
|
+
redirectTo?: string;
|
|
135
|
+
replace?: boolean;
|
|
136
|
+
} = {}) {
|
|
124
137
|
return this.authorize({
|
|
125
138
|
redirectTo: this.redirectToAfterSignIn ?? redirectTo ?? "/",
|
|
139
|
+
replace,
|
|
126
140
|
});
|
|
127
141
|
}
|
|
128
142
|
|
|
129
143
|
private async authorize({
|
|
130
144
|
redirectTo,
|
|
131
145
|
isSignUp = false,
|
|
146
|
+
replace = false,
|
|
132
147
|
}: {
|
|
133
148
|
redirectTo: string;
|
|
134
149
|
isSignUp?: boolean;
|
|
150
|
+
replace?: boolean;
|
|
135
151
|
}): Promise<void> {
|
|
136
152
|
const code_challenge_method = "S256";
|
|
137
153
|
const authorizationServer = await this.getAuthServer();
|
|
@@ -187,8 +203,11 @@ export class OpenIDAuthenticationProvider
|
|
|
187
203
|
sessionStorage.setItem(STATE_KEY, state);
|
|
188
204
|
authorizationUrl.searchParams.set("state", state);
|
|
189
205
|
|
|
190
|
-
|
|
191
|
-
|
|
206
|
+
if (replace) {
|
|
207
|
+
location.replace(authorizationUrl.href);
|
|
208
|
+
} else {
|
|
209
|
+
location.href = authorizationUrl.href;
|
|
210
|
+
}
|
|
192
211
|
}
|
|
193
212
|
|
|
194
213
|
async getAccessToken(): Promise<string> {
|
|
@@ -273,6 +292,59 @@ export class OpenIDAuthenticationProvider
|
|
|
273
292
|
}
|
|
274
293
|
};
|
|
275
294
|
|
|
295
|
+
onPageLoad = async () => {
|
|
296
|
+
const { providerData } = useAuthState.getState();
|
|
297
|
+
|
|
298
|
+
if (!providerData) {
|
|
299
|
+
useAuthState.setState({ isPending: false });
|
|
300
|
+
return;
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
const tokenState = providerData as OpenIdProviderData;
|
|
304
|
+
|
|
305
|
+
if (new Date(tokenState.expiresOn) < new Date()) {
|
|
306
|
+
if (!tokenState.refreshToken) {
|
|
307
|
+
useAuthState.setState({
|
|
308
|
+
isAuthenticated: false,
|
|
309
|
+
isPending: false,
|
|
310
|
+
profile: null,
|
|
311
|
+
providerData: null,
|
|
312
|
+
});
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
try {
|
|
317
|
+
const as = await this.getAuthServer();
|
|
318
|
+
const request = await oauth.refreshTokenGrantRequest(
|
|
319
|
+
as,
|
|
320
|
+
this.client,
|
|
321
|
+
tokenState.refreshToken,
|
|
322
|
+
);
|
|
323
|
+
const response = await oauth.processRefreshTokenResponse(
|
|
324
|
+
as,
|
|
325
|
+
this.client,
|
|
326
|
+
request,
|
|
327
|
+
);
|
|
328
|
+
|
|
329
|
+
if (!response.access_token) {
|
|
330
|
+
throw new AuthorizationError("No access token in response");
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
this.setTokensFromResponse(response);
|
|
334
|
+
} catch {
|
|
335
|
+
useAuthState.setState({
|
|
336
|
+
isAuthenticated: false,
|
|
337
|
+
isPending: false,
|
|
338
|
+
profile: null,
|
|
339
|
+
providerData: null,
|
|
340
|
+
});
|
|
341
|
+
return;
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
useAuthState.setState({ isPending: false });
|
|
346
|
+
};
|
|
347
|
+
|
|
276
348
|
handleCallback = async () => {
|
|
277
349
|
const url = new URL(window.location.href);
|
|
278
350
|
const state = url.searchParams.get("state");
|
|
@@ -51,12 +51,7 @@ class SupabaseAuthenticationProvider
|
|
|
51
51
|
if (session && (event === "SIGNED_IN" || event === "TOKEN_REFRESHED")) {
|
|
52
52
|
await this.updateUserState(session);
|
|
53
53
|
} else if (event === "SIGNED_OUT") {
|
|
54
|
-
useAuthState.
|
|
55
|
-
isAuthenticated: false,
|
|
56
|
-
isPending: false,
|
|
57
|
-
profile: undefined,
|
|
58
|
-
providerData: undefined,
|
|
59
|
-
});
|
|
54
|
+
useAuthState.getState().setLoggedOut();
|
|
60
55
|
}
|
|
61
56
|
});
|
|
62
57
|
}
|
|
@@ -72,9 +67,7 @@ class SupabaseAuthenticationProvider
|
|
|
72
67
|
pictureUrl: user.user_metadata.avatar_url,
|
|
73
68
|
};
|
|
74
69
|
|
|
75
|
-
useAuthState.
|
|
76
|
-
isAuthenticated: true,
|
|
77
|
-
isPending: false,
|
|
70
|
+
useAuthState.getState().setLoggedIn({
|
|
78
71
|
profile,
|
|
79
72
|
providerData: { session },
|
|
80
73
|
});
|
|
@@ -6,12 +6,15 @@ export interface AuthState<ProviderData = unknown> {
|
|
|
6
6
|
isPending: boolean;
|
|
7
7
|
profile: UserProfile | null;
|
|
8
8
|
providerData: ProviderData | null;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
9
|
+
setAuthenticationPending: () => void;
|
|
10
|
+
setLoggedOut: () => void;
|
|
11
|
+
setLoggedIn: ({
|
|
12
|
+
profile,
|
|
13
|
+
providerData,
|
|
14
|
+
}: {
|
|
15
|
+
profile: UserProfile;
|
|
16
|
+
providerData: unknown;
|
|
17
|
+
}) => void;
|
|
15
18
|
}
|
|
16
19
|
|
|
17
20
|
export type StoreWithPersist<T> = Mutate<
|
|
@@ -35,11 +38,38 @@ const withStorageDOMEvents = <T>(store: StoreWithPersist<T>) => {
|
|
|
35
38
|
|
|
36
39
|
export const useAuthState = create<AuthState>()(
|
|
37
40
|
persist(
|
|
38
|
-
(
|
|
41
|
+
(set) => ({
|
|
39
42
|
isAuthenticated: false,
|
|
40
43
|
isPending: true,
|
|
41
44
|
profile: null,
|
|
42
45
|
providerData: null,
|
|
46
|
+
setAuthenticationPending: () =>
|
|
47
|
+
set(() => ({
|
|
48
|
+
isAuthenticated: false,
|
|
49
|
+
isPending: false,
|
|
50
|
+
profile: null,
|
|
51
|
+
providerData: null,
|
|
52
|
+
})),
|
|
53
|
+
setLoggedOut: () =>
|
|
54
|
+
set(() => ({
|
|
55
|
+
isAuthenticated: false,
|
|
56
|
+
isPending: false,
|
|
57
|
+
profile: null,
|
|
58
|
+
providerData: null,
|
|
59
|
+
})),
|
|
60
|
+
setLoggedIn: ({
|
|
61
|
+
profile,
|
|
62
|
+
providerData,
|
|
63
|
+
}: {
|
|
64
|
+
profile: UserProfile;
|
|
65
|
+
providerData: unknown;
|
|
66
|
+
}) =>
|
|
67
|
+
set(() => ({
|
|
68
|
+
isAuthenticated: true,
|
|
69
|
+
isPending: false,
|
|
70
|
+
profile,
|
|
71
|
+
providerData,
|
|
72
|
+
})),
|
|
43
73
|
}),
|
|
44
74
|
{
|
|
45
75
|
merge: (persistedState, currentState) => {
|
|
@@ -26,7 +26,7 @@ const AutocompletePopover = ({
|
|
|
26
26
|
options,
|
|
27
27
|
onChange,
|
|
28
28
|
className,
|
|
29
|
-
placeholder = "
|
|
29
|
+
placeholder = "Value",
|
|
30
30
|
onEnterPress,
|
|
31
31
|
ref,
|
|
32
32
|
}: AutocompleteProps) => {
|
|
@@ -39,6 +39,7 @@ const AutocompletePopover = ({
|
|
|
39
39
|
<Popover open={open}>
|
|
40
40
|
<PopoverAnchor>
|
|
41
41
|
<CommandInlineInput
|
|
42
|
+
autoComplete="off"
|
|
42
43
|
ref={(el) => {
|
|
43
44
|
inputRef.current = el;
|
|
44
45
|
if (typeof ref === "function") {
|
|
@@ -12,7 +12,7 @@ const COLOR_MAP = {
|
|
|
12
12
|
} as const;
|
|
13
13
|
|
|
14
14
|
export const Banner = () => {
|
|
15
|
-
const { page } = useZudoku();
|
|
15
|
+
const { site: page } = useZudoku();
|
|
16
16
|
const [isBannerOpen, setIsBannerOpen] = useState(true);
|
|
17
17
|
|
|
18
18
|
if (!page?.banner || !isBannerOpen) {
|
|
@@ -34,7 +34,6 @@ export const Banner = () => {
|
|
|
34
34
|
"relative text-primary-foreground text-sm font-medium px-4 py-2 flex gap-2 items-center lg:h-(--banner-height)",
|
|
35
35
|
mappedColor,
|
|
36
36
|
)}
|
|
37
|
-
data-pagefind-ignore="all"
|
|
38
37
|
style={style}
|
|
39
38
|
>
|
|
40
39
|
<div className="w-full">{page.banner.message}</div>
|
|
@@ -9,7 +9,10 @@ export const CategoryHeading = ({
|
|
|
9
9
|
className?: string;
|
|
10
10
|
}) => {
|
|
11
11
|
return (
|
|
12
|
-
<div
|
|
12
|
+
<div
|
|
13
|
+
className={cx("text-sm font-semibold text-primary mb-2", className)}
|
|
14
|
+
data-pagefind-ignore="all"
|
|
15
|
+
>
|
|
13
16
|
{children}
|
|
14
17
|
</div>
|
|
15
18
|
);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { ReactNode } from "react";
|
|
2
2
|
import { CategoryHeading } from "./CategoryHeading.js";
|
|
3
3
|
import { Heading } from "./Heading.js";
|
|
4
|
-
import {
|
|
4
|
+
import { Typography } from "./Typography.js";
|
|
5
5
|
|
|
6
6
|
export const ErrorPage = ({
|
|
7
7
|
title = "An error occurred",
|
|
@@ -13,7 +13,7 @@ export const ErrorPage = ({
|
|
|
13
13
|
category?: ReactNode;
|
|
14
14
|
}) => {
|
|
15
15
|
return (
|
|
16
|
-
<
|
|
16
|
+
<Typography className={"h-full pt-(--padding-content-top)"}>
|
|
17
17
|
{category && <CategoryHeading>{category}</CategoryHeading>}
|
|
18
18
|
{title && (
|
|
19
19
|
<Heading level={1} className="flex gap-3.5 items-center">
|
|
@@ -21,6 +21,6 @@ export const ErrorPage = ({
|
|
|
21
21
|
</Heading>
|
|
22
22
|
)}
|
|
23
23
|
<p>{message}</p>
|
|
24
|
-
</
|
|
24
|
+
</Typography>
|
|
25
25
|
);
|
|
26
26
|
};
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { cva } from "class-variance-authority";
|
|
2
|
+
import type { PropsWithChildren } from "react";
|
|
3
|
+
import { cn } from "../util/cn.js";
|
|
4
|
+
|
|
5
|
+
const frameVariants = cva("", {
|
|
6
|
+
variants: {
|
|
7
|
+
size: {
|
|
8
|
+
sm: "max-w-sm",
|
|
9
|
+
md: "max-w-md",
|
|
10
|
+
lg: "max-w-lg",
|
|
11
|
+
xl: "max-w-xl",
|
|
12
|
+
"2xl": "max-w-2xl",
|
|
13
|
+
full: "max-w-full",
|
|
14
|
+
},
|
|
15
|
+
align: {
|
|
16
|
+
center: "mx-auto",
|
|
17
|
+
start: "me-auto",
|
|
18
|
+
end: "ms-auto",
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
defaultVariants: {
|
|
22
|
+
size: "xl",
|
|
23
|
+
align: "center",
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
export const Framed = ({
|
|
28
|
+
caption,
|
|
29
|
+
className,
|
|
30
|
+
size = "xl",
|
|
31
|
+
align = "center",
|
|
32
|
+
children,
|
|
33
|
+
}: PropsWithChildren<{
|
|
34
|
+
caption?: string;
|
|
35
|
+
className?: string;
|
|
36
|
+
size?: "sm" | "md" | "lg" | "xl" | "2xl" | "full";
|
|
37
|
+
align?: "center" | "start" | "end";
|
|
38
|
+
}>) => (
|
|
39
|
+
<figure className={cn(frameVariants({ size, align }), className)}>
|
|
40
|
+
<div className="relative overflow-hidden rounded-lg border border-border bg-muted/50 p-1 shadow-sm">
|
|
41
|
+
<div className="not-prose rounded-md [&_img]:rounded-md! relative overflow-hidden bg-background">
|
|
42
|
+
{children}
|
|
43
|
+
</div>
|
|
44
|
+
</div>
|
|
45
|
+
{caption && (
|
|
46
|
+
<figcaption className="mt-3 text-center text-sm text-muted-foreground">
|
|
47
|
+
{caption}
|
|
48
|
+
</figcaption>
|
|
49
|
+
)}
|
|
50
|
+
</figure>
|
|
51
|
+
);
|
|
@@ -25,6 +25,7 @@ import { Banner } from "./Banner.js";
|
|
|
25
25
|
import { ClientOnly } from "./ClientOnly.js";
|
|
26
26
|
import { useZudoku } from "./context/ZudokuContext.js";
|
|
27
27
|
import { MobileTopNavigation } from "./MobileTopNavigation.js";
|
|
28
|
+
import { PageProgress } from "./PageProgress.js";
|
|
28
29
|
import { Search } from "./Search.js";
|
|
29
30
|
import { Slot } from "./Slot.js";
|
|
30
31
|
import { ThemeSwitch } from "./ThemeSwitch.js";
|
|
@@ -59,55 +60,57 @@ export const Header = memo(function HeaderInner() {
|
|
|
59
60
|
const auth = useAuth();
|
|
60
61
|
const { isAuthenticated, profile, isAuthEnabled } = useAuth();
|
|
61
62
|
const context = useZudoku();
|
|
62
|
-
const {
|
|
63
|
+
const { site, plugins, options } = context;
|
|
63
64
|
|
|
64
65
|
const accountItems = plugins
|
|
65
66
|
.filter((p) => isProfileMenuPlugin(p))
|
|
66
67
|
.flatMap((p) => p.getProfileMenuItems(context))
|
|
67
68
|
.sort((i) => i.weight ?? 0);
|
|
68
69
|
|
|
69
|
-
const logoLightSrc =
|
|
70
|
-
? /https?:\/\//.test(
|
|
71
|
-
?
|
|
72
|
-
: joinUrl(options.basePath,
|
|
70
|
+
const logoLightSrc = site?.logo
|
|
71
|
+
? /https?:\/\//.test(site.logo.src.light)
|
|
72
|
+
? site.logo.src.light
|
|
73
|
+
: joinUrl(options.basePath, site.logo.src.light)
|
|
73
74
|
: undefined;
|
|
74
|
-
const logoDarkSrc =
|
|
75
|
-
? /https?:\/\//.test(
|
|
76
|
-
?
|
|
77
|
-
: joinUrl(options.basePath,
|
|
75
|
+
const logoDarkSrc = site?.logo
|
|
76
|
+
? /https?:\/\//.test(site.logo.src.dark)
|
|
77
|
+
? site.logo.src.dark
|
|
78
|
+
: joinUrl(options.basePath, site.logo.src.dark)
|
|
78
79
|
: undefined;
|
|
79
80
|
|
|
80
81
|
const borderBottom = "inset-shadow-[0_-1px_0_0_var(--border)]";
|
|
81
82
|
|
|
82
83
|
return (
|
|
83
|
-
<header
|
|
84
|
+
<header
|
|
85
|
+
className="sticky lg:top-0 z-10 bg-background/80 backdrop-blur w-full"
|
|
86
|
+
data-pagefind-ignore="all"
|
|
87
|
+
>
|
|
84
88
|
<Banner />
|
|
85
|
-
<div className={borderBottom}>
|
|
86
|
-
<
|
|
89
|
+
<div className={cn(borderBottom, "relative")}>
|
|
90
|
+
<PageProgress />
|
|
91
|
+
<div className="max-w-screen-2xl mx-auto flex items-center justify-between h-(--top-header-height) px-4 lg:px-8 border-transparent">
|
|
87
92
|
<div className="flex">
|
|
88
|
-
<Link to="/">
|
|
93
|
+
<Link to={site?.logo?.href ?? "/"}>
|
|
89
94
|
<div className="flex items-center gap-3.5">
|
|
90
|
-
{
|
|
95
|
+
{site?.logo && (
|
|
91
96
|
<>
|
|
92
97
|
<img
|
|
93
98
|
src={logoLightSrc}
|
|
94
|
-
alt={
|
|
95
|
-
style={{ width:
|
|
99
|
+
alt={site.logo.alt ?? site.title}
|
|
100
|
+
style={{ width: site.logo.width }}
|
|
96
101
|
className="max-h-(--top-header-height) dark:hidden"
|
|
97
102
|
loading="lazy"
|
|
98
103
|
/>
|
|
99
104
|
<img
|
|
100
105
|
src={logoDarkSrc}
|
|
101
|
-
alt={
|
|
102
|
-
style={{ width:
|
|
106
|
+
alt={site.logo.alt ?? site.title}
|
|
107
|
+
style={{ width: site.logo.width }}
|
|
103
108
|
className="max-h-(--top-header-height) hidden dark:block"
|
|
104
109
|
loading="lazy"
|
|
105
110
|
/>
|
|
106
111
|
</>
|
|
107
112
|
)}
|
|
108
|
-
<span className="font-semibold text-2xl">
|
|
109
|
-
{page?.pageTitle}
|
|
110
|
-
</span>
|
|
113
|
+
<span className="font-semibold text-2xl">{site?.title}</span>
|
|
111
114
|
</div>
|
|
112
115
|
</Link>
|
|
113
116
|
</div>
|
|
@@ -182,7 +185,7 @@ export const Header = memo(function HeaderInner() {
|
|
|
182
185
|
</div>
|
|
183
186
|
</div>
|
|
184
187
|
<div className={cn("hidden lg:block", borderBottom)}>
|
|
185
|
-
<div className="max-w-screen-2xl mx-auto border-transparent">
|
|
188
|
+
<div className="max-w-screen-2xl mx-auto border-transparent relative">
|
|
186
189
|
<Slot.Target name="top-navigation-before" />
|
|
187
190
|
<TopNavigation />
|
|
188
191
|
<Slot.Target name="top-navigation-after" />
|
|
@@ -2,6 +2,8 @@ import type { HTMLAttributes, ReactNode } from "react";
|
|
|
2
2
|
import { useRegisterAnchorElement } from "./context/ViewportAnchorContext.js";
|
|
3
3
|
|
|
4
4
|
import { cva, type VariantProps } from "class-variance-authority";
|
|
5
|
+
import { LinkIcon } from "lucide-react";
|
|
6
|
+
import { cn } from "../util/cn.js";
|
|
5
7
|
|
|
6
8
|
const heading = cva("group relative", {
|
|
7
9
|
variants: {
|
|
@@ -44,7 +46,11 @@ export type HeadingProps = HTMLAttributes<HTMLHeadingElement> &
|
|
|
44
46
|
className?: string;
|
|
45
47
|
id?: string;
|
|
46
48
|
level?: 1 | 2 | 3 | 4 | 5 | 6;
|
|
47
|
-
|
|
49
|
+
/**
|
|
50
|
+
* This is to set labels as active when the heading is in the viewport.
|
|
51
|
+
* It's used in the navigation/toc to highlight the current section.
|
|
52
|
+
*/
|
|
53
|
+
registerNavigationAnchor?: boolean;
|
|
48
54
|
};
|
|
49
55
|
|
|
50
56
|
export const Heading = ({
|
|
@@ -52,28 +58,30 @@ export const Heading = ({
|
|
|
52
58
|
children,
|
|
53
59
|
id,
|
|
54
60
|
className,
|
|
55
|
-
|
|
61
|
+
registerNavigationAnchor,
|
|
56
62
|
}: HeadingProps) => {
|
|
57
63
|
const Component = getComponent(level ?? 1);
|
|
58
64
|
const { ref } = useRegisterAnchorElement();
|
|
59
65
|
|
|
60
66
|
return (
|
|
61
67
|
<Component
|
|
62
|
-
className={heading({
|
|
63
|
-
|
|
68
|
+
className={heading({
|
|
69
|
+
className: cn(className, "flex items-center gap-[0.33em]"),
|
|
70
|
+
level,
|
|
71
|
+
})}
|
|
72
|
+
ref={registerNavigationAnchor ? ref : undefined}
|
|
64
73
|
id={id}
|
|
65
74
|
>
|
|
75
|
+
{children}
|
|
66
76
|
{id && (
|
|
67
77
|
<a
|
|
68
78
|
href={`#${id}`}
|
|
69
|
-
className="
|
|
79
|
+
className="rounded text-[0.8em] text-muted-foreground p-0.5 -m-0.5 opacity-0 group-hover:opacity-50 hover:text-primary hover:!opacity-100 transition-opacity duration-200"
|
|
70
80
|
aria-label={`Link to ${id}`}
|
|
71
81
|
>
|
|
72
|
-
|
|
73
|
-
​
|
|
82
|
+
<LinkIcon className="size-[0.75em] min-w-4 min-h-4" />
|
|
74
83
|
</a>
|
|
75
84
|
)}
|
|
76
|
-
{children}
|
|
77
85
|
</Component>
|
|
78
86
|
);
|
|
79
87
|
};
|
|
@@ -4,29 +4,29 @@ import { useNavigation } from "react-router";
|
|
|
4
4
|
import { Drawer, DrawerTrigger } from "zudoku/ui/Drawer.js";
|
|
5
5
|
import { cn } from "../util/cn.js";
|
|
6
6
|
import { useCurrentNavigation, useZudoku } from "./context/ZudokuContext.js";
|
|
7
|
-
import {
|
|
7
|
+
import { Navigation } from "./navigation/Navigation.js";
|
|
8
8
|
import { Slot } from "./Slot.js";
|
|
9
9
|
|
|
10
10
|
export const Main = ({ children }: PropsWithChildren) => {
|
|
11
11
|
const [isDrawerOpen, setDrawerOpen] = useState(false);
|
|
12
|
-
const {
|
|
13
|
-
const
|
|
12
|
+
const { navigation } = useCurrentNavigation();
|
|
13
|
+
const hasNavigation = navigation.length > 0;
|
|
14
14
|
const isNavigating = useNavigation().state === "loading";
|
|
15
15
|
const { options } = useZudoku();
|
|
16
16
|
|
|
17
17
|
return (
|
|
18
18
|
<Drawer
|
|
19
|
-
direction={options.
|
|
19
|
+
direction={options.site?.dir === "rtl" ? "right" : "left"}
|
|
20
20
|
open={isDrawerOpen}
|
|
21
21
|
onOpenChange={(open) => setDrawerOpen(open)}
|
|
22
22
|
>
|
|
23
|
-
{
|
|
24
|
-
<
|
|
23
|
+
{hasNavigation && (
|
|
24
|
+
<Navigation
|
|
25
25
|
onRequestClose={() => setDrawerOpen(false)}
|
|
26
|
-
|
|
26
|
+
navigation={navigation}
|
|
27
27
|
/>
|
|
28
28
|
)}
|
|
29
|
-
{
|
|
29
|
+
{hasNavigation && (
|
|
30
30
|
<div className="lg:hidden -mx-4 px-4 py-2 sticky bg-background/80 backdrop-blur-xs z-10 top-0 start-0 end-0 border-b">
|
|
31
31
|
<DrawerTrigger className="flex items-center gap-2 px-4">
|
|
32
32
|
<PanelLeftIcon size={16} strokeWidth={1.5} />
|
|
@@ -38,7 +38,7 @@ export const Main = ({ children }: PropsWithChildren) => {
|
|
|
38
38
|
data-pagefind-body
|
|
39
39
|
className={cn(
|
|
40
40
|
"px-4 lg:pe-8 lg:px-8",
|
|
41
|
-
!
|
|
41
|
+
!hasNavigation && "col-span-full",
|
|
42
42
|
isNavigating && "animate-pulse",
|
|
43
43
|
)}
|
|
44
44
|
>
|
|
@@ -1,15 +1,14 @@
|
|
|
1
|
-
import { memo } from "react";
|
|
1
|
+
import { memo, useMemo } from "react";
|
|
2
2
|
import { MarkdownHooks, type Components } from "react-markdown";
|
|
3
|
+
import rehypeRaw from "rehype-raw";
|
|
3
4
|
import remarkGfm from "remark-gfm";
|
|
4
5
|
import { createConfiguredShikiRehypePlugins } from "../shiki.js";
|
|
5
6
|
import { MdxComponents } from "../util/MdxComponents.js";
|
|
6
7
|
import { useZudoku } from "./context/ZudokuContext.js";
|
|
8
|
+
import { Typography } from "./Typography.js";
|
|
7
9
|
|
|
8
10
|
const remarkPlugins = [remarkGfm];
|
|
9
11
|
|
|
10
|
-
// other styles are defined in main.css .prose
|
|
11
|
-
export const ProseClasses = "prose dark:prose-invert prose-neutral";
|
|
12
|
-
|
|
13
12
|
export const Markdown = memo(
|
|
14
13
|
({
|
|
15
14
|
content,
|
|
@@ -21,20 +20,29 @@ export const Markdown = memo(
|
|
|
21
20
|
components?: Components;
|
|
22
21
|
}) => {
|
|
23
22
|
const { syntaxHighlighting } = useZudoku().options;
|
|
24
|
-
const rehypePlugins =
|
|
25
|
-
|
|
23
|
+
const rehypePlugins = useMemo(
|
|
24
|
+
() => [
|
|
25
|
+
rehypeRaw,
|
|
26
|
+
...createConfiguredShikiRehypePlugins(syntaxHighlighting?.themes),
|
|
27
|
+
],
|
|
28
|
+
[syntaxHighlighting?.themes],
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
const mdComponents = useMemo(
|
|
32
|
+
() => ({ ...MdxComponents, ...components }),
|
|
33
|
+
[components],
|
|
26
34
|
);
|
|
27
35
|
|
|
28
36
|
return (
|
|
29
|
-
<
|
|
37
|
+
<Typography className={className}>
|
|
30
38
|
<MarkdownHooks
|
|
31
39
|
remarkPlugins={remarkPlugins}
|
|
32
40
|
rehypePlugins={rehypePlugins}
|
|
33
|
-
components={
|
|
41
|
+
components={mdComponents}
|
|
34
42
|
>
|
|
35
43
|
{content}
|
|
36
44
|
</MarkdownHooks>
|
|
37
|
-
</
|
|
45
|
+
</Typography>
|
|
38
46
|
);
|
|
39
47
|
},
|
|
40
48
|
);
|