zudoku 0.0.0-f3f6db5 → 0.0.0-f471fb8
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 +1 -1
- package/cli.js +3 -0
- package/dist/app/entry.client.d.ts +5 -0
- package/dist/app/entry.client.js +1 -0
- package/dist/app/entry.client.js.map +1 -1
- package/dist/app/entry.server.d.ts +5 -4
- package/dist/app/entry.server.js +11 -7
- package/dist/app/entry.server.js.map +1 -1
- package/dist/app/main.js +4 -3
- package/dist/app/main.js.map +1 -1
- package/dist/app/tailwind.js +20 -0
- package/dist/app/tailwind.js.map +1 -1
- package/dist/cli/build/handler.d.ts +1 -3
- package/dist/cli/build/handler.js +7 -0
- package/dist/cli/build/handler.js.map +1 -1
- package/dist/cli/cli.js +5 -0
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/cmds/build.d.ts +11 -3
- package/dist/cli/cmds/build.js +20 -13
- package/dist/cli/cmds/build.js.map +1 -1
- package/dist/cli/cmds/dev.d.ts +1 -1
- package/dist/cli/cmds/dev.js +7 -1
- package/dist/cli/cmds/dev.js.map +1 -1
- package/dist/cli/cmds/preview.d.ts +16 -0
- package/dist/cli/cmds/preview.js +25 -0
- package/dist/cli/cmds/preview.js.map +1 -0
- package/dist/cli/common/output.js.map +1 -1
- package/dist/cli/common/utils/ports.d.ts +1 -1
- package/dist/cli/common/utils/ports.js +16 -15
- package/dist/cli/common/utils/ports.js.map +1 -1
- package/dist/cli/dev/handler.js +14 -12
- package/dist/cli/dev/handler.js.map +1 -1
- package/dist/cli/dev/pagefind-command.d.ts +3 -0
- package/dist/cli/dev/pagefind-command.js +59 -0
- package/dist/cli/dev/pagefind-command.js.map +1 -0
- package/dist/cli/preview/handler.d.ts +3 -0
- package/dist/cli/preview/handler.js +35 -0
- package/dist/cli/preview/handler.js.map +1 -0
- package/dist/config/common.d.ts +5 -3
- package/dist/config/config.d.ts +15 -15
- package/dist/config/loader.d.ts +6 -6
- package/dist/config/loader.js +20 -25
- package/dist/config/loader.js.map +1 -1
- package/dist/config/validators/InputSidebarSchema.d.ts +15 -15
- package/dist/config/validators/InputSidebarSchema.js +10 -1
- package/dist/config/validators/InputSidebarSchema.js.map +1 -1
- package/dist/config/validators/common.d.ts +2318 -503
- package/dist/config/validators/common.js +94 -17
- package/dist/config/validators/common.js.map +1 -1
- package/dist/config/validators/icon-types.d.ts +1 -1
- package/dist/config/validators/validate.d.ts +891 -219
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/MissingIcon.d.ts +2 -0
- package/dist/lib/MissingIcon.js +7 -0
- package/dist/lib/MissingIcon.js.map +1 -0
- package/dist/lib/authentication/authentication.d.ts +1 -0
- package/dist/lib/authentication/hook.d.ts +1 -0
- package/dist/lib/authentication/hook.js +11 -1
- package/dist/lib/authentication/hook.js.map +1 -1
- package/dist/lib/authentication/providers/auth0.d.ts +2 -2
- package/dist/lib/authentication/providers/auth0.js +1 -0
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/clerk.d.ts +2 -2
- package/dist/lib/authentication/providers/clerk.js +25 -6
- package/dist/lib/authentication/providers/clerk.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +5 -3
- package/dist/lib/authentication/providers/openid.js +24 -10
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/providers/supabase.d.ts +4 -0
- package/dist/lib/authentication/providers/supabase.js +117 -0
- package/dist/lib/authentication/providers/supabase.js.map +1 -0
- package/dist/lib/authentication/state.d.ts +0 -17
- package/dist/lib/authentication/state.js +9 -7
- package/dist/lib/authentication/state.js.map +1 -1
- package/dist/lib/components/AnchorLink.d.ts +2 -2
- package/dist/lib/components/AnchorLink.js +5 -4
- package/dist/lib/components/AnchorLink.js.map +1 -1
- package/dist/lib/components/Autocomplete.d.ts +4 -3
- package/dist/lib/components/Autocomplete.js +2 -2
- package/dist/lib/components/Autocomplete.js.map +1 -1
- package/dist/lib/components/Banner.js +1 -1
- package/dist/lib/components/Banner.js.map +1 -1
- package/dist/lib/components/Header.js +4 -4
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Heading.d.ts +2 -2
- package/dist/lib/components/InlineCode.d.ts +2 -1
- package/dist/lib/components/InlineCode.js +2 -9
- package/dist/lib/components/InlineCode.js.map +1 -1
- package/dist/lib/components/Layout.js +7 -29
- package/dist/lib/components/Layout.js.map +1 -1
- package/dist/lib/components/Main.d.ts +2 -0
- package/dist/lib/components/Main.js +17 -0
- package/dist/lib/components/Main.js.map +1 -0
- package/dist/lib/components/MobileTopNavigation.js +1 -1
- package/dist/lib/components/MobileTopNavigation.js.map +1 -1
- package/dist/lib/components/Pagination.d.ts +10 -0
- package/dist/lib/components/Pagination.js +10 -0
- package/dist/lib/components/Pagination.js.map +1 -0
- package/dist/lib/components/PathRenderer.js +23 -20
- package/dist/lib/components/PathRenderer.js.map +1 -1
- package/dist/lib/components/ThemeSwitch.js +8 -5
- package/dist/lib/components/ThemeSwitch.js.map +1 -1
- package/dist/lib/components/TopNavigation.d.ts +2 -2
- package/dist/lib/components/TopNavigation.js +28 -14
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/Zudoku.d.ts +1 -1
- package/dist/lib/components/Zudoku.js +12 -8
- package/dist/lib/components/Zudoku.js.map +1 -1
- package/dist/lib/components/cache.d.ts +7 -0
- package/dist/lib/components/cache.js +7 -0
- package/dist/lib/components/cache.js.map +1 -1
- package/dist/lib/components/context/RouterEventsEmitter.d.ts +1 -0
- package/dist/lib/components/context/RouterEventsEmitter.js +17 -0
- package/dist/lib/components/context/RouterEventsEmitter.js.map +1 -0
- package/dist/lib/components/context/ViewportAnchorContext.d.ts +2 -4
- package/dist/lib/components/context/ViewportAnchorContext.js +5 -10
- package/dist/lib/components/context/ViewportAnchorContext.js.map +1 -1
- package/dist/lib/components/context/ZudokuContext.d.ts +2 -2
- package/dist/lib/components/context/ZudokuContext.js +21 -9
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/index.d.ts +9 -2
- package/dist/lib/components/index.js +4 -0
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/Sidebar.d.ts +3 -1
- package/dist/lib/components/navigation/Sidebar.js +8 -5
- package/dist/lib/components/navigation/Sidebar.js.map +1 -1
- package/dist/lib/components/navigation/SidebarBadge.d.ts +2 -0
- package/dist/lib/components/navigation/SidebarBadge.js +3 -1
- package/dist/lib/components/navigation/SidebarBadge.js.map +1 -1
- package/dist/lib/components/navigation/SidebarCategory.d.ts +2 -2
- package/dist/lib/components/navigation/SidebarCategory.js +10 -6
- package/dist/lib/components/navigation/SidebarCategory.js.map +1 -1
- package/dist/lib/components/navigation/SidebarItem.d.ts +1 -0
- package/dist/lib/components/navigation/SidebarItem.js +17 -10
- package/dist/lib/components/navigation/SidebarItem.js.map +1 -1
- package/dist/lib/components/navigation/SidebarWrapper.d.ts +8 -6
- package/dist/lib/components/navigation/SidebarWrapper.js +1 -2
- package/dist/lib/components/navigation/SidebarWrapper.js.map +1 -1
- package/dist/lib/{plugins/markdown → components/navigation}/Toc.js +5 -7
- package/dist/lib/components/navigation/Toc.js.map +1 -0
- package/dist/lib/core/RouteGuard.d.ts +1 -1
- package/dist/lib/core/RouteGuard.js +28 -10
- package/dist/lib/core/RouteGuard.js.map +1 -1
- package/dist/lib/core/ZudokuContext.d.ts +29 -6
- package/dist/lib/core/ZudokuContext.js +29 -6
- package/dist/lib/core/ZudokuContext.js.map +1 -1
- package/dist/lib/core/plugins.d.ts +17 -7
- package/dist/lib/core/plugins.js +3 -0
- package/dist/lib/core/plugins.js.map +1 -1
- package/dist/lib/errors/ErrorAlert.js +6 -1
- package/dist/lib/errors/ErrorAlert.js.map +1 -1
- package/dist/lib/hooks/index.d.ts +3 -0
- package/dist/lib/hooks/index.js +5 -0
- package/dist/lib/hooks/index.js.map +1 -0
- package/dist/lib/hooks/useEvent.d.ts +11 -0
- package/dist/lib/hooks/useEvent.js +19 -0
- package/dist/lib/hooks/useEvent.js.map +1 -0
- package/dist/lib/hooks/useEvent.test.d.ts +1 -0
- package/dist/lib/hooks/useEvent.test.js +100 -0
- package/dist/lib/hooks/useEvent.test.js.map +1 -0
- package/dist/lib/icons.d.ts +1 -0
- package/dist/lib/icons.js +1 -0
- package/dist/lib/icons.js.map +1 -1
- package/dist/lib/oas/graphql/index.d.ts +24 -4
- package/dist/lib/oas/graphql/index.js +163 -48
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/oas/parser/dereference/index.js +2 -0
- package/dist/lib/oas/parser/dereference/index.js.map +1 -1
- package/dist/lib/oas/parser/index.d.ts +5 -3
- package/dist/lib/oas/parser/index.js +0 -22
- package/dist/lib/oas/parser/index.js.map +1 -1
- package/dist/lib/oas/parser/upgrade/index.js +2 -1
- package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
- package/dist/lib/plugins/api-catalog/Catalog.d.ts +4 -2
- package/dist/lib/plugins/api-catalog/Catalog.js +16 -26
- package/dist/lib/plugins/api-catalog/Catalog.js.map +1 -1
- package/dist/lib/plugins/api-catalog/index.d.ts +1 -0
- package/dist/lib/plugins/api-catalog/index.js +39 -8
- package/dist/lib/plugins/api-catalog/index.js.map +1 -1
- package/dist/lib/plugins/api-keys/CreateApiKey.js +7 -3
- package/dist/lib/plugins/api-keys/CreateApiKey.js.map +1 -1
- package/dist/lib/plugins/api-keys/index.d.ts +1 -0
- package/dist/lib/plugins/api-keys/index.js +1 -0
- package/dist/lib/plugins/api-keys/index.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.d.ts +1 -1
- package/dist/lib/plugins/markdown/MdxPage.js +3 -9
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/resolver.d.ts +0 -6
- package/dist/lib/plugins/markdown/resolver.js +0 -29
- package/dist/lib/plugins/markdown/resolver.js.map +1 -1
- package/dist/lib/plugins/openapi/Endpoint.js +6 -7
- package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
- package/dist/lib/plugins/openapi/{OpenApiRoute.d.ts → OasProvider.d.ts} +1 -2
- package/dist/lib/plugins/openapi/OasProvider.js +29 -0
- package/dist/lib/plugins/openapi/OasProvider.js.map +1 -0
- package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
- package/dist/lib/plugins/openapi/OperationList.js +71 -22
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationListItem.d.ts +3 -2
- package/dist/lib/plugins/openapi/OperationListItem.js +8 -13
- package/dist/lib/plugins/openapi/OperationListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/ParamInfos.d.ts +6 -0
- package/dist/lib/plugins/openapi/ParamInfos.js +42 -0
- package/dist/lib/plugins/openapi/ParamInfos.js.map +1 -0
- package/dist/lib/plugins/openapi/ParameterList.d.ts +2 -1
- package/dist/lib/plugins/openapi/ParameterList.js +3 -2
- package/dist/lib/plugins/openapi/ParameterList.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js +8 -4
- 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/PlaygroundDialogWrapper.js +9 -3
- package/dist/lib/plugins/openapi/PlaygroundDialogWrapper.js.map +1 -1
- package/dist/lib/plugins/openapi/SchemaList.d.ts +1 -0
- package/dist/lib/plugins/openapi/SchemaList.js +52 -0
- package/dist/lib/plugins/openapi/SchemaList.js.map +1 -0
- package/dist/lib/plugins/openapi/Sidecar.js +41 -12
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/SidecarExamples.js +2 -2
- package/dist/lib/plugins/openapi/SidecarExamples.js.map +1 -1
- package/dist/lib/plugins/openapi/SimpleSelect.js +1 -1
- package/dist/lib/plugins/openapi/SimpleSelect.js.map +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.js +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -1
- package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +6 -2
- package/dist/lib/plugins/openapi/client/useCreateQuery.js +6 -5
- package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -1
- package/dist/lib/plugins/openapi/components/EnumValues.d.ts +5 -0
- package/dist/lib/plugins/openapi/components/EnumValues.js +15 -0
- package/dist/lib/plugins/openapi/components/EnumValues.js.map +1 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.d.ts +5 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.js +16 -0
- package/dist/lib/plugins/openapi/components/SelectOnClick.js.map +1 -0
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +9 -5
- package/dist/lib/plugins/openapi/graphql/gql.js +5 -15
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +110 -41
- package/dist/lib/plugins/openapi/graphql/graphql.js +63 -24
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.d.ts +10 -7
- package/dist/lib/plugins/openapi/index.js +62 -119
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +39 -11
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.d.ts +2 -2
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js +1 -5
- package/dist/lib/plugins/openapi/playground/ExamplesDropdown.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Headers.d.ts +4 -4
- package/dist/lib/plugins/openapi/playground/Headers.js +42 -26
- package/dist/lib/plugins/openapi/playground/Headers.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/IdentityDialog.d.ts +11 -0
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js +14 -0
- package/dist/lib/plugins/openapi/playground/IdentityDialog.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js +10 -0
- package/dist/lib/plugins/openapi/playground/IdentitySelector.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/ParamsGrid.d.ts +4 -0
- package/dist/lib/plugins/openapi/playground/ParamsGrid.js +2 -1
- package/dist/lib/plugins/openapi/playground/ParamsGrid.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/PathParams.d.ts +3 -2
- package/dist/lib/plugins/openapi/playground/PathParams.js +5 -4
- package/dist/lib/plugins/openapi/playground/PathParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/Playground.d.ts +18 -3
- package/dist/lib/plugins/openapi/playground/Playground.js +84 -30
- 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.js +21 -21
- package/dist/lib/plugins/openapi/playground/QueryParams.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.d.ts +7 -0
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js +8 -0
- package/dist/lib/plugins/openapi/playground/RequestLoginDialog.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.d.ts +17 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.js +11 -0
- package/dist/lib/plugins/openapi/playground/rememberedIdentity.js.map +1 -0
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/RequestTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js +20 -14
- package/dist/lib/plugins/openapi/playground/result-panel/ResponseTab.js.map +1 -1
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.d.ts +6 -4
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js +4 -3
- package/dist/lib/plugins/openapi/playground/result-panel/ResultPanel.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js +10 -8
- package/dist/lib/plugins/openapi/schema/SchemaPropertyItem.js.map +1 -1
- package/dist/lib/plugins/openapi/schema/SchemaView.js +13 -6
- package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
- package/dist/lib/plugins/openapi/state.d.ts +25 -0
- package/dist/lib/plugins/openapi/state.js +18 -0
- package/dist/lib/plugins/openapi/state.js.map +1 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.d.ts +9 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.js +23 -0
- package/dist/lib/plugins/openapi/util/createSidebarCategory.js.map +1 -0
- package/dist/lib/plugins/openapi/util/getRoutes.d.ts +10 -0
- package/dist/lib/plugins/openapi/util/getRoutes.js +80 -0
- package/dist/lib/plugins/openapi/util/getRoutes.js.map +1 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.d.ts +2 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.js +10 -0
- package/dist/lib/plugins/openapi/util/methodColorMap.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.d.ts +6 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js +75 -0
- package/dist/lib/plugins/search-pagefind/PagefindSearch.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/ResultList.d.ts +8 -0
- package/dist/lib/plugins/search-pagefind/ResultList.js +38 -0
- package/dist/lib/plugins/search-pagefind/ResultList.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/get-results.d.ts +10 -0
- package/dist/lib/plugins/search-pagefind/get-results.js +42 -0
- package/dist/lib/plugins/search-pagefind/get-results.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/index.d.ts +8 -0
- package/dist/lib/plugins/search-pagefind/index.js +9 -0
- package/dist/lib/plugins/search-pagefind/index.js.map +1 -0
- package/dist/lib/plugins/search-pagefind/types.d.ts +85 -0
- package/dist/lib/plugins/search-pagefind/types.js +2 -0
- package/dist/lib/plugins/search-pagefind/types.js.map +1 -0
- package/dist/lib/ui/Badge.d.ts +1 -1
- package/dist/lib/ui/Button.d.ts +2 -2
- package/dist/lib/ui/Button.js +2 -1
- package/dist/lib/ui/Button.js.map +1 -1
- package/dist/lib/ui/Callout.d.ts +2 -1
- package/dist/lib/ui/Callout.js +3 -2
- package/dist/lib/ui/Callout.js.map +1 -1
- package/dist/lib/ui/Checkbox.d.ts +2 -8
- package/dist/lib/ui/Checkbox.js +1 -13
- package/dist/lib/ui/Checkbox.js.map +1 -1
- package/dist/lib/ui/Command.d.ts +7 -1
- package/dist/lib/ui/Command.js +2 -2
- package/dist/lib/ui/Command.js.map +1 -1
- package/dist/lib/ui/Input.d.ts +1 -2
- package/dist/lib/ui/Input.js.map +1 -1
- package/dist/lib/ui/Select.js +1 -1
- package/dist/lib/ui/Select.js.map +1 -1
- package/dist/lib/ui/Stepper.d.ts +3 -0
- package/dist/lib/ui/Stepper.js +7 -0
- package/dist/lib/ui/Stepper.js.map +1 -0
- package/dist/lib/ui/SyntaxHighlight.d.ts +15 -0
- package/dist/lib/ui/SyntaxHighlight.js +62 -0
- package/dist/lib/ui/SyntaxHighlight.js.map +1 -0
- package/dist/lib/ui/util.d.ts +2 -0
- package/dist/lib/ui/util.js +3 -0
- package/dist/lib/ui/util.js.map +1 -0
- package/dist/lib/util/MdxComponents.d.ts +5 -2
- package/dist/lib/util/MdxComponents.js +6 -3
- package/dist/lib/util/MdxComponents.js.map +1 -1
- package/dist/lib/util/joinPath.d.ts +3 -0
- package/dist/lib/util/joinPath.js +3 -0
- package/dist/lib/util/joinPath.js.map +1 -1
- package/dist/lib/util/scrollIntoViewIfNeeded.d.ts +1 -0
- package/dist/lib/util/scrollIntoViewIfNeeded.js +14 -0
- package/dist/lib/util/scrollIntoViewIfNeeded.js.map +1 -0
- package/dist/lib/util/traverse.d.ts +2 -8
- package/dist/lib/util/traverse.js +2 -2
- package/dist/lib/util/traverse.js.map +1 -1
- package/dist/lib/util/types.d.ts +7 -0
- package/dist/lib/util/types.js +2 -0
- package/dist/lib/util/types.js.map +1 -0
- package/dist/lib/util/useLatest.d.ts +1 -0
- package/dist/lib/util/useLatest.js +15 -0
- package/dist/lib/util/useLatest.js.map +1 -0
- package/dist/lib/util/useOnScreen.d.ts +3 -2
- package/dist/lib/util/useOnScreen.js +3 -3
- package/dist/lib/util/useOnScreen.js.map +1 -1
- package/dist/lib/util/useScrollToAnchor.js +27 -33
- package/dist/lib/util/useScrollToAnchor.js.map +1 -1
- package/dist/lib/util/useScrollToTop.js +6 -4
- package/dist/lib/util/useScrollToTop.js.map +1 -1
- package/dist/vite/api/schema-codegen.d.ts +1 -1
- package/dist/vite/api/schema-codegen.js +27 -8
- package/dist/vite/api/schema-codegen.js.map +1 -1
- package/dist/vite/api/schema-codegen.test.js +66 -0
- package/dist/vite/api/schema-codegen.test.js.map +1 -1
- package/dist/vite/build.js +35 -16
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.d.ts +2 -5
- package/dist/vite/config.js +63 -71
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/config.test.js +1 -1
- package/dist/vite/config.test.js.map +1 -1
- package/dist/vite/create-pagefind-index.d.ts +4 -0
- package/dist/vite/create-pagefind-index.js +12 -0
- package/dist/vite/create-pagefind-index.js.map +1 -0
- package/dist/vite/css/plugin.d.ts +2 -2
- package/dist/vite/css/plugin.js.map +1 -1
- package/dist/vite/dev-server.d.ts +4 -2
- package/dist/vite/dev-server.js +42 -12
- package/dist/vite/dev-server.js.map +1 -1
- package/dist/vite/error-handler.d.ts +1 -1
- package/dist/vite/error-handler.js +1 -1
- package/dist/vite/error-handler.js.map +1 -1
- package/dist/vite/output.d.ts +14 -2
- package/dist/vite/output.js +12 -14
- package/dist/vite/output.js.map +1 -1
- package/dist/vite/plugin-api-keys.d.ts +2 -2
- package/dist/vite/plugin-api-keys.js +5 -5
- package/dist/vite/plugin-api-keys.js.map +1 -1
- package/dist/vite/plugin-api.d.ts +2 -2
- package/dist/vite/plugin-api.js +143 -116
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-auth.d.ts +2 -2
- package/dist/vite/plugin-auth.js +3 -3
- package/dist/vite/plugin-auth.js.map +1 -1
- package/dist/vite/plugin-component.d.ts +2 -2
- package/dist/vite/plugin-component.js +7 -2
- package/dist/vite/plugin-component.js.map +1 -1
- package/dist/vite/plugin-config-reload.d.ts +4 -3
- package/dist/vite/plugin-config-reload.js +11 -5
- package/dist/vite/plugin-config-reload.js.map +1 -1
- package/dist/vite/plugin-config.d.ts +2 -2
- package/dist/vite/plugin-config.js +9 -5
- package/dist/vite/plugin-config.js.map +1 -1
- package/dist/vite/plugin-custom-pages.d.ts +2 -2
- package/dist/vite/plugin-custom-pages.js +3 -3
- package/dist/vite/plugin-custom-pages.js.map +1 -1
- package/dist/vite/plugin-docs.d.ts +3 -3
- package/dist/vite/plugin-docs.js +23 -6
- package/dist/vite/plugin-docs.js.map +1 -1
- package/dist/vite/plugin-frontmatter.d.ts +2 -2
- package/dist/vite/plugin-frontmatter.js +5 -4
- package/dist/vite/plugin-frontmatter.js.map +1 -1
- package/dist/vite/plugin-mdx.d.ts +2 -2
- package/dist/vite/plugin-mdx.js +34 -23
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/plugin-redirect.d.ts +2 -2
- package/dist/vite/plugin-redirect.js +3 -3
- package/dist/vite/plugin-redirect.js.map +1 -1
- package/dist/vite/plugin-search.d.ts +2 -2
- package/dist/vite/plugin-search.js +5 -1
- package/dist/vite/plugin-search.js.map +1 -1
- package/dist/vite/plugin-sidebar.d.ts +2 -2
- package/dist/vite/plugin-sidebar.js +13 -4
- package/dist/vite/plugin-sidebar.js.map +1 -1
- package/dist/vite/plugin-theme-css.d.ts +2 -2
- package/dist/vite/plugin-theme-css.js +7 -4
- package/dist/vite/plugin-theme-css.js.map +1 -1
- package/dist/vite/plugin.d.ts +2 -2
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/{prerender.d.ts → prerender/FileWritingResponse.d.ts} +8 -9
- package/dist/vite/prerender/FileWritingResponse.js +51 -0
- package/dist/vite/prerender/FileWritingResponse.js.map +1 -0
- package/dist/vite/prerender/prerender.d.ts +14 -0
- package/dist/vite/prerender/prerender.js +90 -0
- package/dist/vite/prerender/prerender.js.map +1 -0
- package/dist/vite/prerender/worker.d.ts +13 -0
- package/dist/vite/prerender/worker.js +31 -0
- package/dist/vite/prerender/worker.js.map +1 -0
- package/dist/vite/reporter.d.ts +3 -0
- package/dist/vite/reporter.js +33 -0
- package/dist/vite/reporter.js.map +1 -0
- package/dist/vite/sitemap.js +2 -1
- package/dist/vite/sitemap.js.map +1 -1
- package/lib/{AuthenticationPlugin-Du8cLBSr.js → AuthenticationPlugin-foqdvvkf.js} +4 -4
- package/lib/{AuthenticationPlugin-Du8cLBSr.js.map → AuthenticationPlugin-foqdvvkf.js.map} +1 -1
- package/lib/Button-Fp19CMUr.js +49 -0
- package/lib/Button-Fp19CMUr.js.map +1 -0
- package/lib/Callout-D5frCCJ0.js +229 -0
- package/lib/Callout-D5frCCJ0.js.map +1 -0
- package/lib/{CategoryHeading-MYL1u_6K.js → CategoryHeading-DpB47wvk.js} +3 -3
- package/lib/{CategoryHeading-MYL1u_6K.js.map → CategoryHeading-DpB47wvk.js.map} +1 -1
- package/lib/Dialog-Dv6WG8RN.js +98 -0
- package/lib/Dialog-Dv6WG8RN.js.map +1 -0
- package/lib/Drawer-kDAfOq_2.js +1133 -0
- package/lib/Drawer-kDAfOq_2.js.map +1 -0
- package/lib/{Markdown-Cyrx_JrO.js → Markdown-aF5FdsNi.js} +8223 -6475
- package/lib/Markdown-aF5FdsNi.js.map +1 -0
- package/lib/MdxPage-ZW1StNhp.js +83 -0
- package/lib/MdxPage-ZW1StNhp.js.map +1 -0
- package/lib/OasProvider-OlYb8W57.js +34 -0
- package/lib/OasProvider-OlYb8W57.js.map +1 -0
- package/lib/OperationList-BvfIzVRx.js +5065 -0
- package/lib/OperationList-BvfIzVRx.js.map +1 -0
- package/lib/Pagination-CYB3nVYx.js +46 -0
- package/lib/Pagination-CYB3nVYx.js.map +1 -0
- package/lib/SchemaList-Bi35O4XD.js +148 -0
- package/lib/SchemaList-Bi35O4XD.js.map +1 -0
- package/lib/SchemaView-D7MC5cjz.js +356 -0
- package/lib/SchemaView-D7MC5cjz.js.map +1 -0
- package/lib/{Select-CnCZ4WhS.js → Select-DVFRKf1R.js} +71 -71
- package/lib/{Select-CnCZ4WhS.js.map → Select-DVFRKf1R.js.map} +1 -1
- package/lib/SlotletProvider-DXvc0aY6.js +338 -0
- package/lib/SlotletProvider-DXvc0aY6.js.map +1 -0
- package/lib/Spinner-CE68iCm0.js +7 -0
- package/lib/Spinner-CE68iCm0.js.map +1 -0
- package/lib/{SyntaxHighlight-B0L4SC_N.js → SyntaxHighlight-BEoSoPEo.js} +496 -592
- package/lib/SyntaxHighlight-BEoSoPEo.js.map +1 -0
- package/lib/Toc-YBsgI72s.js +92 -0
- package/lib/Toc-YBsgI72s.js.map +1 -0
- package/lib/{chunk-SYFQ2XB5-BPvC-soB.js → chunk-HA7DTUK3-C4gP41vD.js} +561 -561
- package/lib/chunk-HA7DTUK3-C4gP41vD.js.map +1 -0
- package/lib/{circular-DxaIIlWD.js → circular-ByJI6Mci.js} +5461 -4993
- package/lib/circular-ByJI6Mci.js.map +1 -0
- package/lib/context-DLCwaMXN.js +22 -0
- package/lib/{context-rwLGh-6_.js.map → context-DLCwaMXN.js.map} +1 -1
- package/lib/{createServer-CjNktZzL.js → createServer-mMau3eV_.js} +4801 -4976
- package/lib/createServer-mMau3eV_.js.map +1 -0
- package/lib/hook-CqpVYDqN.js +1483 -0
- package/lib/hook-CqpVYDqN.js.map +1 -0
- package/lib/index-Bn6Lc9tq.js +9 -0
- package/lib/index-Bn6Lc9tq.js.map +1 -0
- package/lib/index-Bt7MKhZq.js +2514 -0
- package/lib/index-Bt7MKhZq.js.map +1 -0
- package/lib/index-CPNSgwSb.js +36 -0
- package/lib/{index-Djenk2Hj.js.map → index-CPNSgwSb.js.map} +1 -1
- package/lib/index-CXfEwK_7.js +2226 -0
- package/lib/index-CXfEwK_7.js.map +1 -0
- package/lib/index-DwT-v3zK.js +86 -0
- package/lib/index-DwT-v3zK.js.map +1 -0
- package/lib/{index-CjJS0l4l.js → index-LNp6rxyU.js} +2 -2
- package/lib/{index-CjJS0l4l.js.map → index-LNp6rxyU.js.map} +1 -1
- package/lib/index-gQD2h1wX.js +447 -0
- package/lib/index-gQD2h1wX.js.map +1 -0
- package/lib/{index.esm-CrSoEshU.js → index.esm--gIChbWs.js} +3 -3
- package/lib/{index.esm-CrSoEshU.js.map → index.esm--gIChbWs.js.map} +1 -1
- package/lib/{jsx-runtime-Bdg6XQ1m.js → jsx-runtime-CYK1ROHF.js} +99 -99
- package/lib/{jsx-runtime-Bdg6XQ1m.js.map → jsx-runtime-CYK1ROHF.js.map} +1 -1
- package/lib/{hook-FT3SJLe_.js → mutation-8LjrN7uz.js} +43 -62
- package/lib/mutation-8LjrN7uz.js.map +1 -0
- package/lib/objectEntries-BS7aAgOm.js +12 -0
- package/lib/objectEntries-BS7aAgOm.js.map +1 -0
- package/lib/post-processors/removeExtensions.js +4 -4
- package/lib/post-processors/traverse.js +2 -2
- package/lib/post-processors/traverse.js.map +1 -1
- package/lib/prism-bash.min-HHIMdNJ_.js.map +1 -1
- package/lib/prism-csharp.min-bQAo2pmx.js.map +1 -1
- package/lib/prism-java.min-BpvsOuIa.js.map +1 -1
- package/lib/prism-javascript.min-CEqHqgbm.js.map +1 -1
- package/lib/prism-json.min-B1GJqK1k.js.map +1 -1
- package/lib/prism-jsstacktrace.min-BfobCF2F.js +2 -0
- package/lib/prism-jsstacktrace.min-BfobCF2F.js.map +1 -0
- package/lib/prism-markdown.min-C0Qn0m-5.js.map +1 -1
- package/lib/prism-markup-BNGj0Tvm.js.map +1 -1
- package/lib/prism-objectivec.min-BXSWqpJJ.js.map +1 -1
- package/lib/prism-ruby.min-Dx9KO9ds.js.map +1 -1
- package/lib/prism-typescript.min-CD7H2IYQ.js.map +1 -1
- package/lib/ui/Accordion.js +1 -1
- package/lib/ui/ActionButton.js +11 -10
- package/lib/ui/ActionButton.js.map +1 -1
- package/lib/ui/Alert.js +2 -2
- package/lib/ui/AlertDialog.js +1 -1
- package/lib/ui/Badge.js +2 -2
- package/lib/ui/Breadcrumb.js +4 -4
- package/lib/ui/Button.js +13 -12
- package/lib/ui/Button.js.map +1 -1
- package/lib/ui/Callout.js +39 -21
- 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 +16 -26
- package/lib/ui/Checkbox.js.map +1 -1
- package/lib/ui/Command.js +105 -78
- package/lib/ui/Command.js.map +1 -1
- package/lib/ui/Dialog.js +1 -1
- package/lib/ui/Drawer.js +14 -1151
- package/lib/ui/Drawer.js.map +1 -1
- package/lib/ui/DropdownMenu.js +1 -1
- package/lib/ui/Form.js +5 -5
- package/lib/ui/HoverCard.js +1 -1
- package/lib/ui/Input.js +1 -1
- package/lib/ui/Input.js.map +1 -1
- package/lib/ui/Label.js +2 -2
- package/lib/ui/Pagination.js +10 -10
- 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/Stepper.js +6 -0
- package/lib/ui/Stepper.js.map +1 -0
- package/lib/ui/Switch.js +1 -1
- package/lib/ui/SyntaxHighlight.js +11 -0
- package/lib/ui/SyntaxHighlight.js.map +1 -0
- 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 +1 -1
- package/lib/ui/util.js +6 -0
- package/lib/ui/util.js.map +1 -0
- package/lib/{useExposedProps-BLKFBylA.js → useExposedProps-B9qXJedG.js} +2 -2
- package/lib/{useExposedProps-BLKFBylA.js.map → useExposedProps-B9qXJedG.js.map} +1 -1
- package/lib/zudoku.auth-auth0.js +15 -14
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +67 -49
- package/lib/zudoku.auth-clerk.js.map +1 -1
- package/lib/zudoku.auth-openid.js +370 -405
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +31 -1215
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.hooks.js +19 -0
- package/lib/zudoku.hooks.js.map +1 -0
- package/lib/zudoku.icons.js +10 -0
- package/lib/zudoku.icons.js.map +1 -1
- package/lib/zudoku.plugin-api-catalog.js +109 -109
- package/lib/zudoku.plugin-api-catalog.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +108 -106
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +3 -3
- package/lib/zudoku.plugin-markdown.js +23 -44
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +6 -7
- package/lib/zudoku.plugin-openapi.js.map +1 -1
- package/lib/zudoku.plugin-redirect.js +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +9 -9
- package/lib/zudoku.plugin-search-pagefind.js +238 -0
- package/lib/zudoku.plugin-search-pagefind.js.map +1 -0
- package/lib/zudoku.plugins.js +14 -0
- package/lib/zudoku.plugins.js.map +1 -0
- package/package.json +83 -55
- package/src/app/demo-cdn.html +31 -31
- package/src/app/entry.client.tsx +8 -0
- package/src/app/entry.server.tsx +18 -11
- package/src/app/main.css +100 -58
- package/src/app/main.tsx +10 -3
- package/src/app/tailwind.ts +20 -0
- package/src/lib/MissingIcon.tsx +22 -0
- package/src/lib/authentication/authentication.ts +2 -0
- package/src/lib/authentication/hook.ts +12 -1
- package/src/lib/authentication/providers/auth0.tsx +3 -2
- package/src/lib/authentication/providers/clerk.tsx +32 -8
- package/src/lib/authentication/providers/openid.tsx +31 -15
- package/src/lib/authentication/providers/supabase.tsx +157 -0
- package/src/lib/authentication/state.ts +9 -19
- package/src/lib/components/AnchorLink.tsx +9 -7
- package/src/lib/components/Autocomplete.tsx +6 -4
- package/src/lib/components/Banner.tsx +1 -0
- package/src/lib/components/Header.tsx +12 -8
- package/src/lib/components/Heading.tsx +1 -1
- package/src/lib/components/InlineCode.tsx +13 -16
- package/src/lib/components/Layout.tsx +20 -67
- package/src/lib/components/Main.tsx +49 -0
- package/src/lib/components/MobileTopNavigation.tsx +1 -1
- package/src/lib/components/Pagination.tsx +47 -0
- package/src/lib/components/PathRenderer.tsx +6 -4
- package/src/lib/components/ThemeSwitch.tsx +28 -8
- package/src/lib/components/TopNavigation.tsx +51 -24
- package/src/lib/components/Zudoku.tsx +18 -7
- package/src/lib/components/cache.ts +8 -0
- package/src/lib/components/context/RouterEventsEmitter.tsx +19 -0
- package/src/lib/components/context/ViewportAnchorContext.tsx +6 -15
- package/src/lib/components/context/ZudokuContext.ts +30 -10
- package/src/lib/components/index.ts +4 -0
- package/src/lib/components/navigation/Sidebar.tsx +14 -10
- package/src/lib/components/navigation/SidebarBadge.tsx +4 -1
- package/src/lib/components/navigation/SidebarCategory.tsx +15 -12
- package/src/lib/components/navigation/SidebarItem.tsx +22 -28
- package/src/lib/components/navigation/SidebarWrapper.tsx +13 -15
- package/src/lib/{plugins/markdown → components/navigation}/Toc.tsx +5 -14
- package/src/lib/core/RouteGuard.tsx +48 -9
- package/src/lib/core/ZudokuContext.ts +57 -12
- package/src/lib/core/plugins.ts +29 -7
- package/src/lib/errors/ErrorAlert.tsx +24 -17
- package/src/lib/hooks/index.ts +5 -0
- package/src/lib/hooks/useEvent.test.tsx +149 -0
- package/src/lib/hooks/useEvent.ts +41 -0
- package/src/lib/icons.ts +1 -0
- package/src/lib/oas/graphql/index.ts +223 -73
- package/src/lib/oas/parser/dereference/index.ts +2 -0
- package/src/lib/oas/parser/index.ts +7 -29
- package/src/lib/oas/parser/upgrade/index.ts +2 -1
- package/src/lib/plugins/api-catalog/Catalog.tsx +53 -100
- package/src/lib/plugins/api-catalog/index.tsx +66 -15
- package/src/lib/plugins/api-keys/CreateApiKey.tsx +7 -3
- package/src/lib/plugins/api-keys/index.tsx +3 -0
- package/src/lib/plugins/markdown/MdxPage.tsx +13 -46
- package/src/lib/plugins/markdown/resolver.ts +0 -33
- package/src/lib/plugins/openapi/Endpoint.tsx +11 -9
- package/src/lib/plugins/openapi/OasProvider.tsx +51 -0
- package/src/lib/plugins/openapi/OperationList.tsx +180 -83
- package/src/lib/plugins/openapi/OperationListItem.tsx +118 -104
- package/src/lib/plugins/openapi/ParamInfos.tsx +87 -0
- package/src/lib/plugins/openapi/ParameterList.tsx +4 -0
- package/src/lib/plugins/openapi/ParameterListItem.tsx +33 -23
- package/src/lib/plugins/openapi/PlaygroundDialogWrapper.tsx +15 -3
- package/src/lib/plugins/openapi/SchemaList.tsx +151 -0
- package/src/lib/plugins/openapi/Sidecar.tsx +52 -16
- package/src/lib/plugins/openapi/SidecarExamples.tsx +1 -2
- package/src/lib/plugins/openapi/SimpleSelect.tsx +1 -1
- package/src/lib/plugins/openapi/client/GraphQLClient.tsx +1 -1
- package/src/lib/plugins/openapi/client/useCreateQuery.ts +13 -5
- package/src/lib/plugins/openapi/components/EnumValues.tsx +58 -0
- package/src/lib/plugins/openapi/components/SelectOnClick.tsx +29 -0
- package/src/lib/plugins/openapi/graphql/gql.ts +34 -17
- package/src/lib/plugins/openapi/graphql/graphql.ts +175 -65
- package/src/lib/plugins/openapi/index.tsx +90 -152
- package/src/lib/plugins/openapi/interfaces.ts +48 -24
- package/src/lib/plugins/openapi/playground/ExamplesDropdown.tsx +30 -32
- package/src/lib/plugins/openapi/playground/Headers.tsx +119 -88
- package/src/lib/plugins/openapi/playground/IdentityDialog.tsx +74 -0
- package/src/lib/plugins/openapi/playground/IdentitySelector.tsx +54 -0
- package/src/lib/plugins/openapi/playground/ParamsGrid.tsx +6 -1
- package/src/lib/plugins/openapi/playground/PathParams.tsx +16 -10
- package/src/lib/plugins/openapi/playground/Playground.tsx +207 -112
- package/src/lib/plugins/openapi/playground/PlaygroundDialog.tsx +5 -2
- package/src/lib/plugins/openapi/playground/QueryParams.tsx +87 -86
- package/src/lib/plugins/openapi/playground/RequestLoginDialog.tsx +51 -0
- package/src/lib/plugins/openapi/playground/rememberedIdentity.ts +26 -0
- package/src/lib/plugins/openapi/playground/result-panel/RequestTab.tsx +1 -1
- package/src/lib/plugins/openapi/playground/result-panel/ResponseTab.tsx +25 -5
- package/src/lib/plugins/openapi/playground/result-panel/ResultPanel.tsx +67 -45
- package/src/lib/plugins/openapi/schema/SchemaPropertyItem.tsx +29 -31
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +48 -35
- package/src/lib/plugins/openapi/state.ts +36 -0
- package/src/lib/plugins/openapi/util/createSidebarCategory.tsx +37 -0
- package/src/lib/plugins/openapi/util/getRoutes.tsx +126 -0
- package/src/lib/plugins/openapi/util/methodColorMap.tsx +11 -0
- package/src/lib/plugins/search-pagefind/PagefindSearch.tsx +157 -0
- package/src/lib/plugins/search-pagefind/ResultList.tsx +116 -0
- package/src/lib/plugins/search-pagefind/get-results.tsx +75 -0
- package/src/lib/plugins/search-pagefind/index.tsx +21 -0
- package/src/lib/plugins/search-pagefind/types.ts +118 -0
- package/src/lib/ui/Button.tsx +4 -2
- package/src/lib/ui/Callout.tsx +28 -10
- package/src/lib/ui/Checkbox.tsx +8 -24
- package/src/lib/ui/Command.tsx +25 -3
- package/src/lib/ui/Input.tsx +1 -2
- package/src/lib/ui/Select.tsx +1 -1
- package/src/lib/ui/Stepper.tsx +8 -0
- package/src/lib/ui/SyntaxHighlight.tsx +186 -0
- package/src/lib/ui/util.tsx +3 -0
- package/src/lib/util/MdxComponents.tsx +7 -4
- package/src/lib/util/joinPath.tsx +3 -0
- package/src/lib/util/scrollIntoViewIfNeeded.ts +18 -0
- package/src/lib/util/traverse.ts +4 -8
- package/src/lib/util/types.ts +7 -0
- package/src/lib/util/useLatest.ts +18 -0
- package/src/lib/util/useOnScreen.ts +6 -4
- package/src/lib/util/useScrollToAnchor.ts +31 -39
- package/src/lib/util/useScrollToTop.ts +8 -3
- package/dist/lib/components/SyntaxHighlight.d.ts +0 -12
- package/dist/lib/components/SyntaxHighlight.js +0 -53
- package/dist/lib/components/SyntaxHighlight.js.map +0 -1
- package/dist/lib/plugins/markdown/Toc.js.map +0 -1
- package/dist/lib/plugins/openapi/OpenApiRoute.js +0 -25
- package/dist/lib/plugins/openapi/OpenApiRoute.js.map +0 -1
- package/dist/vite/prerender.js +0 -89
- package/dist/vite/prerender.js.map +0 -1
- package/lib/Markdown-Cyrx_JrO.js.map +0 -1
- package/lib/MdxPage-BuG8Tuwc.js +0 -193
- package/lib/MdxPage-BuG8Tuwc.js.map +0 -1
- package/lib/OpenApiRoute-UrC_t0e5.js +0 -36
- package/lib/OpenApiRoute-UrC_t0e5.js.map +0 -1
- package/lib/OperationList-CDt1xdc4.js +0 -5169
- package/lib/OperationList-CDt1xdc4.js.map +0 -1
- package/lib/SlotletProvider-mQiPDQIH.js +0 -221
- package/lib/SlotletProvider-mQiPDQIH.js.map +0 -1
- package/lib/Spinner-BlzrEEk1.js +0 -51
- package/lib/Spinner-BlzrEEk1.js.map +0 -1
- package/lib/SyntaxHighlight-B0L4SC_N.js.map +0 -1
- package/lib/ZudokuContext-BTUJPpQl.js +0 -1229
- package/lib/ZudokuContext-BTUJPpQl.js.map +0 -1
- package/lib/__vite-browser-external-BYRIRx8p.js +0 -9
- package/lib/__vite-browser-external-BYRIRx8p.js.map +0 -1
- package/lib/chunk-SYFQ2XB5-BPvC-soB.js.map +0 -1
- package/lib/circular-DxaIIlWD.js.map +0 -1
- package/lib/context-rwLGh-6_.js +0 -22
- package/lib/createServer-CjNktZzL.js.map +0 -1
- package/lib/hook-FT3SJLe_.js.map +0 -1
- package/lib/index-B7mqiOei.js +0 -509
- package/lib/index-B7mqiOei.js.map +0 -1
- package/lib/index-Djenk2Hj.js +0 -36
- package/lib/index-Eb1oiHbM.js +0 -1997
- package/lib/index-Eb1oiHbM.js.map +0 -1
- package/lib/index.esm-9-TF9KQB.js +0 -692
- package/lib/index.esm-9-TF9KQB.js.map +0 -1
- package/lib/joinUrl-nLx9pD-Z.js +0 -20
- package/lib/joinUrl-nLx9pD-Z.js.map +0 -1
- package/lib/state-mM7uaXTW.js +0 -202
- package/lib/state-mM7uaXTW.js.map +0 -1
- package/lib/useScrollToAnchor-BZsGmBng.js +0 -284
- package/lib/useScrollToAnchor-BZsGmBng.js.map +0 -1
- package/src/lib/components/SyntaxHighlight.tsx +0 -171
- package/src/lib/plugins/openapi/OpenApiRoute.tsx +0 -51
- /package/dist/lib/{plugins/markdown → components/navigation}/Toc.d.ts +0 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { ZudokuConfig } from "../../../config/validators/validate.js";
|
|
2
|
+
import { ClientOnly } from "../../components/ClientOnly.js";
|
|
3
|
+
import type { ZudokuPlugin } from "../../core/plugins.js";
|
|
4
|
+
import { PagefindSearch } from "./PagefindSearch.js";
|
|
5
|
+
|
|
6
|
+
export type PagefindOptions = Extract<
|
|
7
|
+
ZudokuConfig["search"],
|
|
8
|
+
{ type: "pagefind" }
|
|
9
|
+
> & { basePath?: string };
|
|
10
|
+
|
|
11
|
+
export const pagefindSearchPlugin = (
|
|
12
|
+
options: PagefindOptions,
|
|
13
|
+
): ZudokuPlugin => {
|
|
14
|
+
return {
|
|
15
|
+
renderSearch: ({ isOpen, onClose }) => (
|
|
16
|
+
<ClientOnly>
|
|
17
|
+
<PagefindSearch isOpen={isOpen} onClose={onClose} options={options} />
|
|
18
|
+
</ClientOnly>
|
|
19
|
+
),
|
|
20
|
+
};
|
|
21
|
+
};
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
interface PagefindIndexOptions {
|
|
2
|
+
basePath?: string;
|
|
3
|
+
baseUrl?: string;
|
|
4
|
+
excerptLength?: number;
|
|
5
|
+
indexWeight?: number;
|
|
6
|
+
mergeFilter?: Record<string, unknown>;
|
|
7
|
+
highlightParam?: string;
|
|
8
|
+
language?: string;
|
|
9
|
+
primary?: boolean;
|
|
10
|
+
ranking?: PagefindRankingWeights;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
interface PagefindRankingWeights {
|
|
14
|
+
termSimilarity?: number;
|
|
15
|
+
pageLength?: number;
|
|
16
|
+
termSaturation?: number;
|
|
17
|
+
termFrequency?: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
interface PagefindSearchOptions {
|
|
21
|
+
preload?: boolean;
|
|
22
|
+
verbose?: boolean;
|
|
23
|
+
filters?: Record<string, unknown>;
|
|
24
|
+
sort?: Record<string, unknown>;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
type PagefindFilterCounts = Record<string, Record<string, number>> & {};
|
|
28
|
+
|
|
29
|
+
interface PagefindSearchResults {
|
|
30
|
+
results: PagefindSearchResult[];
|
|
31
|
+
unfilteredResultCount: number;
|
|
32
|
+
filters: PagefindFilterCounts;
|
|
33
|
+
totalFilters: PagefindFilterCounts;
|
|
34
|
+
timings: {
|
|
35
|
+
preload: number;
|
|
36
|
+
search: number;
|
|
37
|
+
total: number;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
interface PagefindSearchResult {
|
|
42
|
+
id: string;
|
|
43
|
+
score: number;
|
|
44
|
+
words: number[];
|
|
45
|
+
data: () => Promise<PagefindSearchFragment>;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
interface PagefindSearchFragment {
|
|
49
|
+
url: string;
|
|
50
|
+
raw_url?: string;
|
|
51
|
+
content: string;
|
|
52
|
+
raw_content?: string;
|
|
53
|
+
excerpt: string;
|
|
54
|
+
sub_results: PagefindSubResult[];
|
|
55
|
+
word_count: number;
|
|
56
|
+
locations: number[];
|
|
57
|
+
weighted_locations: PagefindWordLocation[];
|
|
58
|
+
filters: Record<string, string[]>;
|
|
59
|
+
meta: Record<string, string>;
|
|
60
|
+
anchors: PagefindSearchAnchor[];
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
interface PagefindSubResult {
|
|
64
|
+
title: string;
|
|
65
|
+
url: string;
|
|
66
|
+
locations: number[];
|
|
67
|
+
weighted_locations: PagefindWordLocation[];
|
|
68
|
+
excerpt: string;
|
|
69
|
+
anchor?: PagefindSearchAnchor;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
interface PagefindWordLocation {
|
|
73
|
+
weight: number;
|
|
74
|
+
balanced_score: number;
|
|
75
|
+
location: number;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
interface PagefindSearchAnchor {
|
|
79
|
+
element: string;
|
|
80
|
+
id: string;
|
|
81
|
+
text?: string;
|
|
82
|
+
location: number;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
interface Pagefind {
|
|
86
|
+
debouncedSearch: (
|
|
87
|
+
query: string,
|
|
88
|
+
options?: PagefindSearchOptions,
|
|
89
|
+
duration?: number,
|
|
90
|
+
) => Promise<PagefindSearchResults>;
|
|
91
|
+
destroy: () => Promise<void>;
|
|
92
|
+
filters: () => Promise<PagefindFilterCounts>;
|
|
93
|
+
init: () => Promise<void>;
|
|
94
|
+
mergeIndex: (
|
|
95
|
+
indexPath: string,
|
|
96
|
+
options?: Record<string, unknown>,
|
|
97
|
+
) => Promise<void>;
|
|
98
|
+
options: (options: PagefindIndexOptions) => Promise<void>;
|
|
99
|
+
preload: (term: string, options?: PagefindIndexOptions) => Promise<void>;
|
|
100
|
+
search: (
|
|
101
|
+
term: string,
|
|
102
|
+
options?: PagefindSearchOptions,
|
|
103
|
+
) => Promise<PagefindSearchResults>;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export type {
|
|
107
|
+
Pagefind,
|
|
108
|
+
PagefindFilterCounts,
|
|
109
|
+
PagefindIndexOptions,
|
|
110
|
+
PagefindRankingWeights,
|
|
111
|
+
PagefindSearchAnchor,
|
|
112
|
+
PagefindSearchFragment,
|
|
113
|
+
PagefindSearchOptions,
|
|
114
|
+
PagefindSearchResult,
|
|
115
|
+
PagefindSearchResults,
|
|
116
|
+
PagefindSubResult,
|
|
117
|
+
PagefindWordLocation,
|
|
118
|
+
};
|
package/src/lib/ui/Button.tsx
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Slot } from "@radix-ui/react-slot";
|
|
2
|
-
import { cva, VariantProps } from "class-variance-authority";
|
|
2
|
+
import { cva, type VariantProps } from "class-variance-authority";
|
|
3
3
|
import * as React from "react";
|
|
4
4
|
import { cn } from "../util/cn.js";
|
|
5
5
|
|
|
6
6
|
export const buttonVariants = cva(
|
|
7
|
-
"not-prose inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50",
|
|
7
|
+
"not-prose inline-flex shrink-0 items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50",
|
|
8
8
|
{
|
|
9
9
|
variants: {
|
|
10
10
|
variant: {
|
|
@@ -18,6 +18,8 @@ export const buttonVariants = cva(
|
|
|
18
18
|
"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80",
|
|
19
19
|
ghost: "hover:bg-accent hover:text-accent-foreground",
|
|
20
20
|
link: "text-primary underline-offset-4 hover:underline",
|
|
21
|
+
expand:
|
|
22
|
+
"flex gap-1.5 border bg-transparent rounded-xl text-muted-foreground hover:text-foreground",
|
|
21
23
|
},
|
|
22
24
|
size: {
|
|
23
25
|
default: "h-9 px-4 py-2",
|
package/src/lib/ui/Callout.tsx
CHANGED
|
@@ -56,31 +56,49 @@ type CalloutProps = {
|
|
|
56
56
|
title?: string;
|
|
57
57
|
children: ReactNode;
|
|
58
58
|
className?: string;
|
|
59
|
+
icon?: boolean;
|
|
59
60
|
};
|
|
60
61
|
|
|
61
|
-
export const Callout = ({
|
|
62
|
+
export const Callout = ({
|
|
63
|
+
type,
|
|
64
|
+
children,
|
|
65
|
+
title,
|
|
66
|
+
className,
|
|
67
|
+
icon = true,
|
|
68
|
+
}: CalloutProps) => {
|
|
62
69
|
const { border, bg, iconColor, titleColor, textColor, Icon } =
|
|
63
70
|
stylesMap[type];
|
|
64
71
|
|
|
65
72
|
return (
|
|
66
73
|
<div
|
|
67
74
|
className={cn(
|
|
68
|
-
"not-prose
|
|
75
|
+
"not-prose rounded-md border p-4 text-md my-2",
|
|
76
|
+
icon &&
|
|
77
|
+
"grid grid-cols-[min-content_1fr] items-baseline grid-rows-[fit-content_1fr] gap-x-4 gap-y-2",
|
|
78
|
+
!icon && title && "flex flex-col gap-2",
|
|
69
79
|
"[&_a]:underline [&_a]:decoration-current [&_a]:decoration-from-font [&_a]:underline-offset-4 hover:[&_a]:decoration-1",
|
|
70
|
-
"[&_code]:!bg-gray-50 [&_code]:dark:!bg-gray-800 [&_code]:!border-none
|
|
71
|
-
title && "items-center",
|
|
80
|
+
"[&_code]:!bg-gray-50 [&_code]:dark:!bg-gray-800 [&_code]:!border-none",
|
|
81
|
+
icon && title && "items-center",
|
|
72
82
|
border,
|
|
73
83
|
bg,
|
|
74
84
|
className,
|
|
75
85
|
)}
|
|
76
86
|
>
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
87
|
+
{icon && (
|
|
88
|
+
<Icon
|
|
89
|
+
className={cn(!title ? "translate-y-1" : "align-middle", iconColor)}
|
|
90
|
+
size={20}
|
|
91
|
+
aria-hidden="true"
|
|
92
|
+
/>
|
|
93
|
+
)}
|
|
82
94
|
{title && <h3 className={cn("font-medium", titleColor)}>{title}</h3>}
|
|
83
|
-
<div
|
|
95
|
+
<div
|
|
96
|
+
className={cn(
|
|
97
|
+
icon && "col-start-2",
|
|
98
|
+
!title && icon && "row-start-1",
|
|
99
|
+
textColor,
|
|
100
|
+
)}
|
|
101
|
+
>
|
|
84
102
|
{children}
|
|
85
103
|
</div>
|
|
86
104
|
</div>
|
package/src/lib/ui/Checkbox.tsx
CHANGED
|
@@ -1,36 +1,20 @@
|
|
|
1
1
|
import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
|
|
2
|
-
import { cva, type VariantProps } from "class-variance-authority";
|
|
3
2
|
import { Check } from "lucide-react";
|
|
4
3
|
import * as React from "react";
|
|
5
4
|
|
|
6
5
|
import { cn } from "../util/cn.js";
|
|
7
6
|
|
|
8
|
-
const checkboxVariants = cva(
|
|
9
|
-
"peer h-4 w-4 shrink-0 rounded-sm ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:text-primary",
|
|
10
|
-
{
|
|
11
|
-
variants: {
|
|
12
|
-
variant: {
|
|
13
|
-
default: "border border-primary data-[state=checked]:bg-primary",
|
|
14
|
-
outline: "border border-input data-[state=checked]:bg-accent",
|
|
15
|
-
},
|
|
16
|
-
},
|
|
17
|
-
defaultVariants: {
|
|
18
|
-
variant: "default",
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
interface CheckboxProps
|
|
24
|
-
extends React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>,
|
|
25
|
-
VariantProps<typeof checkboxVariants> {}
|
|
26
|
-
|
|
27
7
|
const Checkbox = React.forwardRef<
|
|
28
8
|
React.ElementRef<typeof CheckboxPrimitive.Root>,
|
|
29
|
-
|
|
30
|
-
>(({ className,
|
|
9
|
+
React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root>
|
|
10
|
+
>(({ className, ...props }, ref) => (
|
|
31
11
|
<CheckboxPrimitive.Root
|
|
32
12
|
ref={ref}
|
|
33
|
-
className={cn(
|
|
13
|
+
className={cn(
|
|
14
|
+
"peer h-4 w-4 shrink-0 rounded-[min(6px,var(--radius)-4px)] ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:text-primary",
|
|
15
|
+
"border border-primary data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground data-[state=checked]:border-primary",
|
|
16
|
+
className,
|
|
17
|
+
)}
|
|
34
18
|
{...props}
|
|
35
19
|
>
|
|
36
20
|
<CheckboxPrimitive.Indicator
|
|
@@ -42,4 +26,4 @@ const Checkbox = React.forwardRef<
|
|
|
42
26
|
));
|
|
43
27
|
Checkbox.displayName = CheckboxPrimitive.Root.displayName;
|
|
44
28
|
|
|
45
|
-
export { Checkbox
|
|
29
|
+
export { Checkbox };
|
package/src/lib/ui/Command.tsx
CHANGED
|
@@ -2,6 +2,7 @@ import { type DialogProps } from "@radix-ui/react-dialog";
|
|
|
2
2
|
import { Command as CommandPrimitive } from "cmdk";
|
|
3
3
|
import { Search } from "lucide-react";
|
|
4
4
|
import * as React from "react";
|
|
5
|
+
import { ComponentPropsWithoutRef } from "react";
|
|
5
6
|
import { Dialog, DialogContent } from "zudoku/ui/Dialog.js";
|
|
6
7
|
import { cn } from "../util/cn.js";
|
|
7
8
|
|
|
@@ -20,11 +21,32 @@ const Command = React.forwardRef<
|
|
|
20
21
|
));
|
|
21
22
|
Command.displayName = CommandPrimitive.displayName;
|
|
22
23
|
|
|
23
|
-
const CommandDialog = ({
|
|
24
|
+
const CommandDialog = ({
|
|
25
|
+
children,
|
|
26
|
+
command,
|
|
27
|
+
content,
|
|
28
|
+
...props
|
|
29
|
+
}: DialogProps & {
|
|
30
|
+
command?: ComponentPropsWithoutRef<typeof CommandPrimitive>;
|
|
31
|
+
content?: ComponentPropsWithoutRef<typeof DialogContent>;
|
|
32
|
+
}) => {
|
|
24
33
|
return (
|
|
25
34
|
<Dialog {...props}>
|
|
26
|
-
<DialogContent
|
|
27
|
-
|
|
35
|
+
<DialogContent
|
|
36
|
+
{...content}
|
|
37
|
+
className={cn(
|
|
38
|
+
"overflow-hidden p-0 shadow-lg top-[15vh] translate-y-[0%]",
|
|
39
|
+
content?.className,
|
|
40
|
+
)}
|
|
41
|
+
aria-describedby={undefined}
|
|
42
|
+
>
|
|
43
|
+
<Command
|
|
44
|
+
{...command}
|
|
45
|
+
className={cn(
|
|
46
|
+
"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5",
|
|
47
|
+
command?.className,
|
|
48
|
+
)}
|
|
49
|
+
>
|
|
28
50
|
{children}
|
|
29
51
|
</Command>
|
|
30
52
|
</DialogContent>
|
package/src/lib/ui/Input.tsx
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import * as React from "react";
|
|
2
2
|
import { cn } from "../util/cn.js";
|
|
3
3
|
|
|
4
|
-
|
|
5
|
-
extends React.InputHTMLAttributes<HTMLInputElement> {}
|
|
4
|
+
type InputProps = React.InputHTMLAttributes<HTMLInputElement>;
|
|
6
5
|
|
|
7
6
|
const Input = React.forwardRef<HTMLInputElement, InputProps>(
|
|
8
7
|
({ className, type, ...props }, ref) => {
|
package/src/lib/ui/Select.tsx
CHANGED
|
@@ -115,7 +115,7 @@ const SelectItem = React.forwardRef<
|
|
|
115
115
|
<SelectPrimitive.Item
|
|
116
116
|
ref={ref}
|
|
117
117
|
className={cn(
|
|
118
|
-
"relative flex w-full cursor-default select-none items-center
|
|
118
|
+
"relative flex w-full cursor-default select-none items-center py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",
|
|
119
119
|
className,
|
|
120
120
|
)}
|
|
121
121
|
{...props}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Highlight,
|
|
3
|
+
Prism,
|
|
4
|
+
themes,
|
|
5
|
+
type HighlightProps,
|
|
6
|
+
} from "prism-react-renderer";
|
|
7
|
+
|
|
8
|
+
import { CheckIcon, CopyIcon } from "lucide-react";
|
|
9
|
+
|
|
10
|
+
globalThis.Prism = Prism;
|
|
11
|
+
// @ts-expect-error This is untyped
|
|
12
|
+
void import("prismjs/components/prism-bash.min.js");
|
|
13
|
+
// @ts-expect-error This is untyped
|
|
14
|
+
void import("prismjs/components/prism-ruby.min.js");
|
|
15
|
+
// @ts-expect-error This is untyped
|
|
16
|
+
void import("prismjs/components/prism-markup.js");
|
|
17
|
+
// @ts-expect-error This is untyped
|
|
18
|
+
void import("prismjs/components/prism-json.min.js");
|
|
19
|
+
// @ts-expect-error This is untyped
|
|
20
|
+
void import("prismjs/components/prism-java.min.js");
|
|
21
|
+
// @ts-expect-error This is untyped
|
|
22
|
+
void import("prismjs/components/prism-csharp.min.js");
|
|
23
|
+
// @ts-expect-error This is untyped
|
|
24
|
+
void import("prismjs/components/prism-objectivec.min.js");
|
|
25
|
+
// @ts-expect-error This is untyped
|
|
26
|
+
void import("prismjs/components/prism-markdown.min.js");
|
|
27
|
+
// @ts-expect-error This is untyped
|
|
28
|
+
void import("prismjs/components/prism-javascript.min.js");
|
|
29
|
+
// @ts-expect-error This is untyped
|
|
30
|
+
void import("prismjs/components/prism-typescript.min.js");
|
|
31
|
+
// @ts-expect-error This is untyped
|
|
32
|
+
void import("prismjs/components/prism-jsstacktrace.min.js");
|
|
33
|
+
|
|
34
|
+
import { useTheme } from "next-themes";
|
|
35
|
+
import { memo, useState } from "react";
|
|
36
|
+
import { ClientOnly } from "../components/ClientOnly.js";
|
|
37
|
+
import { cn } from "../util/cn.js";
|
|
38
|
+
|
|
39
|
+
export type SyntaxHighlightProps = {
|
|
40
|
+
className?: string;
|
|
41
|
+
noBackground?: boolean;
|
|
42
|
+
wrapLines?: boolean;
|
|
43
|
+
showLanguageIndicator?: boolean;
|
|
44
|
+
language?: string;
|
|
45
|
+
title?: string;
|
|
46
|
+
children?: string;
|
|
47
|
+
code?: string;
|
|
48
|
+
showCopy?: "hover" | "always" | "never";
|
|
49
|
+
showCopyText?: boolean;
|
|
50
|
+
disabled?: boolean;
|
|
51
|
+
} & Omit<HighlightProps, "children" | "language">;
|
|
52
|
+
|
|
53
|
+
const remapLang = {
|
|
54
|
+
mdx: "md",
|
|
55
|
+
} as Record<string, string>;
|
|
56
|
+
|
|
57
|
+
const SyntaxHighlightInner = ({
|
|
58
|
+
language = "plain",
|
|
59
|
+
showCopy = "hover",
|
|
60
|
+
showCopyText,
|
|
61
|
+
title,
|
|
62
|
+
children,
|
|
63
|
+
disabled,
|
|
64
|
+
...props
|
|
65
|
+
}: SyntaxHighlightProps) => {
|
|
66
|
+
const { resolvedTheme } = useTheme();
|
|
67
|
+
const [isCopied, setIsCopied] = useState(false);
|
|
68
|
+
|
|
69
|
+
const code = children ?? props.code;
|
|
70
|
+
|
|
71
|
+
if (!code) {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const highlightTheme =
|
|
76
|
+
resolvedTheme === "dark" ? themes.vsDark : themes.github;
|
|
77
|
+
|
|
78
|
+
// hardcoded values from the themes to avoid color flash in SSR
|
|
79
|
+
const themeColorClasses =
|
|
80
|
+
"bg-[#f6f8fa] text-[#393a34] dark:bg-[#1e1e1e] dark:text-[#9cdcfe]";
|
|
81
|
+
|
|
82
|
+
const Wrapper = ({
|
|
83
|
+
children,
|
|
84
|
+
className,
|
|
85
|
+
style,
|
|
86
|
+
}: {
|
|
87
|
+
children: React.ReactNode;
|
|
88
|
+
className?: string;
|
|
89
|
+
style?: React.CSSProperties;
|
|
90
|
+
}) => (
|
|
91
|
+
<div className="relative group">
|
|
92
|
+
{title && (
|
|
93
|
+
<div className="text-xs text-muted-foreground absolute top-2 font-mono border-b w-full pb-2 px-4 ">
|
|
94
|
+
{title}
|
|
95
|
+
</div>
|
|
96
|
+
)}
|
|
97
|
+
<pre
|
|
98
|
+
className={cn(
|
|
99
|
+
"relative scrollbar overflow-x-auto",
|
|
100
|
+
props.className,
|
|
101
|
+
props.noBackground ? "!bg-transparent" : themeColorClasses,
|
|
102
|
+
props.wrapLines && "whitespace-pre-wrap break-words",
|
|
103
|
+
title && "pt-10",
|
|
104
|
+
className,
|
|
105
|
+
)}
|
|
106
|
+
style={style}
|
|
107
|
+
>
|
|
108
|
+
{children}
|
|
109
|
+
</pre>
|
|
110
|
+
{props.showLanguageIndicator && (
|
|
111
|
+
<span className="absolute top-1.5 right-3 text-[11px] font-mono text-muted-foreground transition group-hover:opacity-0">
|
|
112
|
+
{language}
|
|
113
|
+
</span>
|
|
114
|
+
)}
|
|
115
|
+
{showCopy !== "never" && (
|
|
116
|
+
<button
|
|
117
|
+
type="button"
|
|
118
|
+
aria-label="Copy code"
|
|
119
|
+
title="Copy code"
|
|
120
|
+
className={cn(
|
|
121
|
+
"absolute top-2 right-2 p-2 hover:outline hover:outline-border/75 dark:hover:outline-border rounded-md text-sm text-muted-foreground transition",
|
|
122
|
+
showCopy === "hover"
|
|
123
|
+
? "opacity-0 group-hover:opacity-100 group-hover:bg-zinc-100 group-hover:dark:bg-zinc-700"
|
|
124
|
+
: "bg-zinc-100 dark:bg-zinc-700",
|
|
125
|
+
showCopyText && "flex gap-2 items-center font-medium",
|
|
126
|
+
)}
|
|
127
|
+
disabled={isCopied}
|
|
128
|
+
onClick={() => {
|
|
129
|
+
setIsCopied(true);
|
|
130
|
+
void navigator.clipboard.writeText(code);
|
|
131
|
+
setTimeout(() => setIsCopied(false), 2000);
|
|
132
|
+
}}
|
|
133
|
+
>
|
|
134
|
+
{isCopied ? (
|
|
135
|
+
<CheckIcon
|
|
136
|
+
className="text-emerald-600"
|
|
137
|
+
size={16}
|
|
138
|
+
strokeWidth={2.5}
|
|
139
|
+
absoluteStrokeWidth
|
|
140
|
+
/>
|
|
141
|
+
) : (
|
|
142
|
+
<CopyIcon size={16} />
|
|
143
|
+
)}
|
|
144
|
+
{showCopyText && "Copy"}
|
|
145
|
+
</button>
|
|
146
|
+
)}
|
|
147
|
+
</div>
|
|
148
|
+
);
|
|
149
|
+
|
|
150
|
+
if (disabled) {
|
|
151
|
+
return (
|
|
152
|
+
<ClientOnly fallback={<Wrapper>{code}</Wrapper>}>
|
|
153
|
+
<Wrapper>{code}</Wrapper>
|
|
154
|
+
</ClientOnly>
|
|
155
|
+
);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
return (
|
|
159
|
+
<ClientOnly fallback={<Wrapper>{code}</Wrapper>}>
|
|
160
|
+
<Highlight
|
|
161
|
+
theme={highlightTheme}
|
|
162
|
+
language={remapLang[language] ?? language}
|
|
163
|
+
{...props}
|
|
164
|
+
code={code}
|
|
165
|
+
>
|
|
166
|
+
{({ className, style, tokens, getLineProps, getTokenProps }) => (
|
|
167
|
+
<Wrapper className={className} style={style}>
|
|
168
|
+
{tokens.map((line, i) => (
|
|
169
|
+
// eslint-disable-next-line react/no-array-index-key
|
|
170
|
+
<div key={i} {...getLineProps({ line })}>
|
|
171
|
+
{line.map((token, key) => (
|
|
172
|
+
// eslint-disable-next-line react/no-array-index-key
|
|
173
|
+
<span key={key} {...getTokenProps({ token })} />
|
|
174
|
+
))}
|
|
175
|
+
</div>
|
|
176
|
+
))}
|
|
177
|
+
</Wrapper>
|
|
178
|
+
)}
|
|
179
|
+
</Highlight>
|
|
180
|
+
</ClientOnly>
|
|
181
|
+
);
|
|
182
|
+
};
|
|
183
|
+
|
|
184
|
+
export const SyntaxHighlight = memo(SyntaxHighlightInner);
|
|
185
|
+
|
|
186
|
+
SyntaxHighlight.displayName = "SyntaxHighlight";
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { MDXComponents } from "mdx/types.js";
|
|
2
|
-
import {
|
|
1
|
+
import { type MDXComponents } from "mdx/types.js";
|
|
2
|
+
import { AnchorLink } from "../components/AnchorLink.js";
|
|
3
3
|
import { Heading } from "../components/Heading.js";
|
|
4
4
|
import { InlineCode } from "../components/InlineCode.js";
|
|
5
|
-
import { SyntaxHighlight } from "../components/SyntaxHighlight.js";
|
|
6
5
|
import { Callout } from "../ui/Callout.js";
|
|
6
|
+
import { Stepper } from "../ui/Stepper.js";
|
|
7
|
+
import { SyntaxHighlight } from "../ui/SyntaxHighlight.js";
|
|
7
8
|
|
|
8
9
|
export type MdxComponentsType = Readonly<MDXComponents> | null | undefined;
|
|
9
10
|
|
|
@@ -46,11 +47,13 @@ export const MdxComponents = {
|
|
|
46
47
|
),
|
|
47
48
|
a: ({ href, node, ...props }) =>
|
|
48
49
|
href && !href.startsWith("http") ? (
|
|
49
|
-
<
|
|
50
|
+
<AnchorLink to={href} relative="path" {...props} />
|
|
50
51
|
) : (
|
|
51
52
|
<a href={href} target="_blank" {...props} rel="noreferrer" />
|
|
52
53
|
),
|
|
53
54
|
Callout,
|
|
55
|
+
Stepper,
|
|
56
|
+
SyntaxHighlight,
|
|
54
57
|
tip: (props) => <Callout type="tip" {...props} />,
|
|
55
58
|
info: (props) => <Callout type="info" {...props} />,
|
|
56
59
|
note: (props) => <Callout type="note" {...props} />,
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export const scrollIntoViewIfNeeded = (
|
|
2
|
+
element: Element | null,
|
|
3
|
+
options: ScrollIntoViewOptions = { block: "center" },
|
|
4
|
+
) => {
|
|
5
|
+
if (!element) return;
|
|
6
|
+
|
|
7
|
+
const rect = element.getBoundingClientRect();
|
|
8
|
+
const isInView =
|
|
9
|
+
rect.top >= 0 &&
|
|
10
|
+
rect.left >= 0 &&
|
|
11
|
+
rect.bottom <=
|
|
12
|
+
(window.innerHeight || document.documentElement.clientHeight) &&
|
|
13
|
+
rect.right <= (window.innerWidth || document.documentElement.clientWidth);
|
|
14
|
+
|
|
15
|
+
if (isInView) return;
|
|
16
|
+
|
|
17
|
+
element.scrollIntoView(options);
|
|
18
|
+
};
|
package/src/lib/util/traverse.ts
CHANGED
|
@@ -1,10 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
export type RecordAny = Record<string, any>;
|
|
1
|
+
import type { JsonValue, RecordAny } from "./types.js";
|
|
3
2
|
|
|
4
|
-
type
|
|
5
|
-
type JsonArray = JsonValue[];
|
|
6
|
-
type JsonObject = { [key: string]: JsonValue };
|
|
7
|
-
type JsonValue = JsonPrimitive | JsonArray | JsonObject;
|
|
3
|
+
export type { RecordAny };
|
|
8
4
|
|
|
9
5
|
export const traverse = <T extends JsonValue = RecordAny>(
|
|
10
6
|
specification: RecordAny,
|
|
@@ -20,11 +16,11 @@ export const traverse = <T extends JsonValue = RecordAny>(
|
|
|
20
16
|
for (const [key, value] of Object.entries(transformed)) {
|
|
21
17
|
if (Array.isArray(value)) {
|
|
22
18
|
result[key] = value.map((item) =>
|
|
23
|
-
typeof item === "object" && item
|
|
19
|
+
typeof item === "object" && item != null
|
|
24
20
|
? traverse(item, transform)
|
|
25
21
|
: item,
|
|
26
22
|
);
|
|
27
|
-
} else if (typeof value === "object" && value
|
|
23
|
+
} else if (typeof value === "object" && value != null) {
|
|
28
24
|
result[key] = traverse(value, transform);
|
|
29
25
|
} else {
|
|
30
26
|
result[key] = value;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
2
|
+
export type RecordAny = Record<string, any>;
|
|
3
|
+
|
|
4
|
+
export type JsonPrimitive = string | number | boolean | null;
|
|
5
|
+
export type JsonArray = JsonValue[];
|
|
6
|
+
export type JsonObject = { [key: string]: JsonValue };
|
|
7
|
+
export type JsonValue = JsonPrimitive | JsonArray | JsonObject;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
|
|
3
|
+
// This hook is useful when you need to store a reference to a variable that changes over time,
|
|
4
|
+
// but you don't want to re-run any callbacks that depend on that variable every time it changes.
|
|
5
|
+
// By using a reference to the latest value, you can ensure that any callbacks only run when necessary,
|
|
6
|
+
// without any unnecessary re-renders.
|
|
7
|
+
|
|
8
|
+
// Note: It's safe to put the return value of this hook in a dependency array, because it won't change!
|
|
9
|
+
export const useLatest = <T>(current: T) => {
|
|
10
|
+
const valueRef = useRef(current);
|
|
11
|
+
valueRef.current = current;
|
|
12
|
+
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
valueRef.current = current;
|
|
15
|
+
}, [current]);
|
|
16
|
+
|
|
17
|
+
return valueRef;
|
|
18
|
+
};
|