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
package/src/lib/ui/CodeBlock.tsx
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { CheckIcon, CopyIcon } from "lucide-react";
|
|
2
2
|
import type { ReactNode } from "react";
|
|
3
|
-
import { useRef
|
|
3
|
+
import { useRef } from "react";
|
|
4
4
|
import { cn } from "../util/cn.js";
|
|
5
|
+
import { useCopyToClipboard } from "../util/useCopyToClipboard.js";
|
|
5
6
|
|
|
6
7
|
export type CodeBlockProps = {
|
|
7
8
|
className?: string;
|
|
@@ -13,22 +14,20 @@ export type CodeBlockProps = {
|
|
|
13
14
|
children?: ReactNode;
|
|
14
15
|
code?: ReactNode;
|
|
15
16
|
showCopy?: "hover" | "always" | "never";
|
|
16
|
-
showCopyText?: boolean;
|
|
17
17
|
disabled?: boolean;
|
|
18
18
|
showLineNumbers?: boolean;
|
|
19
19
|
};
|
|
20
20
|
|
|
21
21
|
export const CodeBlock = ({
|
|
22
22
|
children,
|
|
23
|
-
title,
|
|
23
|
+
title = "Code",
|
|
24
24
|
language,
|
|
25
25
|
showCopy = "hover",
|
|
26
|
-
|
|
27
|
-
showLanguageIndicator = true,
|
|
26
|
+
showLanguageIndicator = false,
|
|
28
27
|
showLineNumbers,
|
|
29
28
|
...props
|
|
30
29
|
}: CodeBlockProps) => {
|
|
31
|
-
const [isCopied,
|
|
30
|
+
const [isCopied, copyToClipboard] = useCopyToClipboard();
|
|
32
31
|
const ref = useRef<HTMLDivElement>(null);
|
|
33
32
|
|
|
34
33
|
if (!children) return null;
|
|
@@ -36,15 +35,45 @@ export const CodeBlock = ({
|
|
|
36
35
|
return (
|
|
37
36
|
<div
|
|
38
37
|
className={cn(
|
|
39
|
-
"code-block-wrapper relative group bg-muted/50 rounded-md",
|
|
38
|
+
"border code-block-wrapper relative group bg-muted/50 rounded-md overflow-hidden",
|
|
40
39
|
showLineNumbers && "line-numbers",
|
|
41
40
|
)}
|
|
42
41
|
>
|
|
43
|
-
|
|
44
|
-
<div className="
|
|
42
|
+
<div className="border-b flex items-center h-10 font-sans bg-black/2">
|
|
43
|
+
<div className="flex-1 text-sm w-full px-4">
|
|
45
44
|
{title}
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
{showLanguageIndicator && language && (
|
|
46
|
+
<span className="text-muted-foreground ml-2">({language})</span>
|
|
47
|
+
)}
|
|
48
|
+
</div>{" "}
|
|
49
|
+
{showCopy !== "never" && (
|
|
50
|
+
<button
|
|
51
|
+
type="button"
|
|
52
|
+
aria-label="Copy code"
|
|
53
|
+
title="Copy code"
|
|
54
|
+
className={cn(
|
|
55
|
+
"cursor:pointer h-full hover:border-l-border active:shadow-none active:inset-shadow-xs hover:inset-shadow-xs flex items-center gap-2 px-4 outline-border text-sm hover:bg-black/5 transition-all",
|
|
56
|
+
)}
|
|
57
|
+
disabled={isCopied}
|
|
58
|
+
onClick={() => {
|
|
59
|
+
if (!ref.current?.textContent) return;
|
|
60
|
+
|
|
61
|
+
copyToClipboard(ref.current.textContent);
|
|
62
|
+
}}
|
|
63
|
+
>
|
|
64
|
+
{isCopied ? (
|
|
65
|
+
<CheckIcon
|
|
66
|
+
className="text-emerald-600"
|
|
67
|
+
size={14}
|
|
68
|
+
strokeWidth={2.5}
|
|
69
|
+
absoluteStrokeWidth
|
|
70
|
+
/>
|
|
71
|
+
) : (
|
|
72
|
+
<CopyIcon size={14} />
|
|
73
|
+
)}
|
|
74
|
+
</button>
|
|
75
|
+
)}
|
|
76
|
+
</div>
|
|
48
77
|
<div
|
|
49
78
|
className={cn(
|
|
50
79
|
"code-block text-sm not-prose scrollbar overflow-x-auto scrollbar p-4",
|
|
@@ -54,49 +83,6 @@ export const CodeBlock = ({
|
|
|
54
83
|
>
|
|
55
84
|
{children}
|
|
56
85
|
</div>
|
|
57
|
-
{showLanguageIndicator && (
|
|
58
|
-
<span
|
|
59
|
-
className={cn(
|
|
60
|
-
"absolute top-1.5 end-3 !text-[11px] font-mono text-muted-foreground transition group-hover:opacity-0",
|
|
61
|
-
title && "top-12",
|
|
62
|
-
)}
|
|
63
|
-
>
|
|
64
|
-
{language}
|
|
65
|
-
</span>
|
|
66
|
-
)}
|
|
67
|
-
{showCopy !== "never" && (
|
|
68
|
-
<button
|
|
69
|
-
type="button"
|
|
70
|
-
aria-label="Copy code"
|
|
71
|
-
title="Copy code"
|
|
72
|
-
className={cn(
|
|
73
|
-
"absolute top-2 end-2 p-2 hover:outline hover:outline-border/75 dark:hover:outline-border rounded-md text-sm text-muted-foreground transition",
|
|
74
|
-
title && "top-10",
|
|
75
|
-
showCopy === "hover" && "opacity-0 group-hover:opacity-100",
|
|
76
|
-
showCopyText && "flex gap-2 items-center font-medium",
|
|
77
|
-
)}
|
|
78
|
-
disabled={isCopied}
|
|
79
|
-
onClick={() => {
|
|
80
|
-
if (!ref.current?.textContent) return;
|
|
81
|
-
|
|
82
|
-
setIsCopied(true);
|
|
83
|
-
void navigator.clipboard.writeText(ref.current.textContent);
|
|
84
|
-
setTimeout(() => setIsCopied(false), 2000);
|
|
85
|
-
}}
|
|
86
|
-
>
|
|
87
|
-
{isCopied ? (
|
|
88
|
-
<CheckIcon
|
|
89
|
-
className="text-emerald-600"
|
|
90
|
-
size={16}
|
|
91
|
-
strokeWidth={2.5}
|
|
92
|
-
absoluteStrokeWidth
|
|
93
|
-
/>
|
|
94
|
-
) : (
|
|
95
|
-
<CopyIcon size={16} />
|
|
96
|
-
)}
|
|
97
|
-
{showCopyText && "Copy"}
|
|
98
|
-
</button>
|
|
99
|
-
)}
|
|
100
86
|
</div>
|
|
101
87
|
);
|
|
102
88
|
};
|
package/src/lib/ui/Dialog.tsx
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as DialogPrimitive from "@radix-ui/react-dialog";
|
|
2
|
-
import { X } from "lucide-react";
|
|
3
2
|
import * as React from "react";
|
|
4
3
|
|
|
4
|
+
import { XIcon } from "lucide-react";
|
|
5
5
|
import { cn } from "../util/cn.js";
|
|
6
6
|
|
|
7
7
|
const Dialog = DialogPrimitive.Root;
|
|
@@ -29,8 +29,10 @@ DialogOverlay.displayName = DialogPrimitive.Overlay.displayName;
|
|
|
29
29
|
|
|
30
30
|
const DialogContent = React.forwardRef<
|
|
31
31
|
React.ElementRef<typeof DialogPrimitive.Content>,
|
|
32
|
-
React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content>
|
|
33
|
-
|
|
32
|
+
React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content> & {
|
|
33
|
+
showCloseButton?: boolean;
|
|
34
|
+
}
|
|
35
|
+
>(({ className, children, showCloseButton = true, ...props }, ref) => (
|
|
34
36
|
<DialogPortal>
|
|
35
37
|
<DialogOverlay />
|
|
36
38
|
<DialogPrimitive.Content
|
|
@@ -42,10 +44,12 @@ const DialogContent = React.forwardRef<
|
|
|
42
44
|
{...props}
|
|
43
45
|
>
|
|
44
46
|
{children}
|
|
45
|
-
|
|
46
|
-
<
|
|
47
|
-
|
|
48
|
-
|
|
47
|
+
{showCloseButton && (
|
|
48
|
+
<DialogPrimitive.Close className="absolute left-1 top-1 rounded-xs opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-hidden focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground">
|
|
49
|
+
<XIcon className="h-3 w-3" strokeWidth={2} />
|
|
50
|
+
<span className="sr-only">Close</span>
|
|
51
|
+
</DialogPrimitive.Close>
|
|
52
|
+
)}
|
|
49
53
|
</DialogPrimitive.Content>
|
|
50
54
|
</DialogPortal>
|
|
51
55
|
));
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { CheckIcon, CopyIcon } from "lucide-react";
|
|
2
|
+
import type { ReactNode } from "react";
|
|
3
|
+
import { useRef, useState } from "react";
|
|
4
|
+
import { cn } from "../util/cn.js";
|
|
5
|
+
|
|
6
|
+
export type CodeBlockProps = {
|
|
7
|
+
className?: string;
|
|
8
|
+
noBackground?: boolean;
|
|
9
|
+
wrapLines?: boolean;
|
|
10
|
+
showLanguageIndicator?: boolean;
|
|
11
|
+
language?: string;
|
|
12
|
+
children?: ReactNode;
|
|
13
|
+
code?: ReactNode;
|
|
14
|
+
showCopy?: "hover" | "always" | "never";
|
|
15
|
+
showCopyText?: boolean;
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
showLineNumbers?: boolean;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export const EmbeddedCodeBlock = ({
|
|
21
|
+
children,
|
|
22
|
+
language,
|
|
23
|
+
showCopy = "hover",
|
|
24
|
+
showCopyText,
|
|
25
|
+
showLanguageIndicator = true,
|
|
26
|
+
showLineNumbers,
|
|
27
|
+
...props
|
|
28
|
+
}: CodeBlockProps) => {
|
|
29
|
+
const [isCopied, setIsCopied] = useState(false);
|
|
30
|
+
const ref = useRef<HTMLDivElement>(null);
|
|
31
|
+
|
|
32
|
+
if (!children) return null;
|
|
33
|
+
|
|
34
|
+
return (
|
|
35
|
+
<div
|
|
36
|
+
className={cn(
|
|
37
|
+
"code-block-wrapper relative group bg-muted/50",
|
|
38
|
+
showLineNumbers && "line-numbers",
|
|
39
|
+
)}
|
|
40
|
+
>
|
|
41
|
+
<div
|
|
42
|
+
className={cn(
|
|
43
|
+
"code-block text-sm not-prose scrollbar overflow-x-auto scrollbar p-4",
|
|
44
|
+
props.className,
|
|
45
|
+
)}
|
|
46
|
+
ref={ref}
|
|
47
|
+
>
|
|
48
|
+
{children}
|
|
49
|
+
</div>
|
|
50
|
+
{showLanguageIndicator && (
|
|
51
|
+
<span
|
|
52
|
+
className={cn(
|
|
53
|
+
"absolute top-1.5 end-3 !text-[11px] font-mono text-muted-foreground transition group-hover:opacity-0",
|
|
54
|
+
showCopy === "always" && "hidden",
|
|
55
|
+
)}
|
|
56
|
+
>
|
|
57
|
+
{language}
|
|
58
|
+
</span>
|
|
59
|
+
)}
|
|
60
|
+
{showCopy !== "never" && (
|
|
61
|
+
<button
|
|
62
|
+
type="button"
|
|
63
|
+
aria-label="Copy code"
|
|
64
|
+
title="Copy code"
|
|
65
|
+
className={cn(
|
|
66
|
+
"absolute top-2 end-2 p-2 transition hover:shadow-xs active:shadow-none active:inset-shadow-xs hover:outline outline-border rounded-md text-sm text-muted-foreground",
|
|
67
|
+
showCopy === "hover" && "opacity-0 group-hover:opacity-100",
|
|
68
|
+
showCopyText && "flex gap-2 items-center font-medium",
|
|
69
|
+
)}
|
|
70
|
+
disabled={isCopied}
|
|
71
|
+
onClick={() => {
|
|
72
|
+
if (!ref.current?.textContent) return;
|
|
73
|
+
|
|
74
|
+
setIsCopied(true);
|
|
75
|
+
void navigator.clipboard.writeText(ref.current.textContent);
|
|
76
|
+
setTimeout(() => setIsCopied(false), 2000);
|
|
77
|
+
}}
|
|
78
|
+
>
|
|
79
|
+
{isCopied ? (
|
|
80
|
+
<CheckIcon
|
|
81
|
+
className="text-emerald-600"
|
|
82
|
+
size={16}
|
|
83
|
+
strokeWidth={2.5}
|
|
84
|
+
absoluteStrokeWidth
|
|
85
|
+
/>
|
|
86
|
+
) : (
|
|
87
|
+
<CopyIcon size={16} />
|
|
88
|
+
)}
|
|
89
|
+
{showCopyText && "Copy"}
|
|
90
|
+
</button>
|
|
91
|
+
)}
|
|
92
|
+
</div>
|
|
93
|
+
);
|
|
94
|
+
};
|
package/src/lib/ui/Select.tsx
CHANGED
|
@@ -16,7 +16,7 @@ const SelectTrigger = React.forwardRef<
|
|
|
16
16
|
<SelectPrimitive.Trigger
|
|
17
17
|
ref={ref}
|
|
18
18
|
className={cn(
|
|
19
|
-
"flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus:outline-hidden focus:ring-
|
|
19
|
+
"flex h-10 w-full items-center justify-between rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus:outline-hidden focus:ring-1 focus:ring-ring focus:ring-offset-1 disabled:cursor-not-allowed disabled:opacity-50",
|
|
20
20
|
className,
|
|
21
21
|
)}
|
|
22
22
|
{...props}
|
|
@@ -3,12 +3,16 @@ import { useZudoku } from "../components/context/ZudokuContext.js";
|
|
|
3
3
|
import { highlight } from "../shiki.js";
|
|
4
4
|
import invariant from "../util/invariant.js";
|
|
5
5
|
import { CodeBlock, type CodeBlockProps } from "./CodeBlock.js";
|
|
6
|
+
import { EmbeddedCodeBlock } from "./EmbeddedCodeBlock.js";
|
|
6
7
|
|
|
7
8
|
type SyntaxHighlightProps = CodeBlockProps &
|
|
8
|
-
(
|
|
9
|
+
(
|
|
10
|
+
| { code: string; embedded?: boolean; children?: never }
|
|
11
|
+
| { code?: never; children: string; embedded?: boolean }
|
|
12
|
+
);
|
|
9
13
|
|
|
10
14
|
export const SyntaxHighlight = memo(
|
|
11
|
-
({ code, children, ...props }: SyntaxHighlightProps) => {
|
|
15
|
+
({ code, children, embedded, ...props }: SyntaxHighlightProps) => {
|
|
12
16
|
const { syntaxHighlighting } = useZudoku().options;
|
|
13
17
|
|
|
14
18
|
invariant(syntaxHighlighting?.highlighter, "Highlighter not found");
|
|
@@ -20,7 +24,11 @@ export const SyntaxHighlight = memo(
|
|
|
20
24
|
syntaxHighlighting.themes,
|
|
21
25
|
);
|
|
22
26
|
|
|
23
|
-
return
|
|
27
|
+
return embedded ? (
|
|
28
|
+
<EmbeddedCodeBlock {...props}>{highlightedCode}</EmbeddedCodeBlock>
|
|
29
|
+
) : (
|
|
30
|
+
<CodeBlock {...props}>{highlightedCode}</CodeBlock>
|
|
31
|
+
);
|
|
24
32
|
},
|
|
25
33
|
);
|
|
26
34
|
|
package/src/lib/ui/Tooltip.tsx
CHANGED
|
@@ -9,6 +9,15 @@ const Tooltip = TooltipPrimitive.Root;
|
|
|
9
9
|
|
|
10
10
|
const TooltipTrigger = TooltipPrimitive.Trigger;
|
|
11
11
|
|
|
12
|
+
const TooltipArrow = (
|
|
13
|
+
props: React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Arrow>,
|
|
14
|
+
) => (
|
|
15
|
+
<TooltipPrimitive.Arrow
|
|
16
|
+
{...props}
|
|
17
|
+
className={cn(props.className, "fill-border")}
|
|
18
|
+
/>
|
|
19
|
+
);
|
|
20
|
+
|
|
12
21
|
const TooltipContent = React.forwardRef<
|
|
13
22
|
React.ElementRef<typeof TooltipPrimitive.Content>,
|
|
14
23
|
React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content>
|
|
@@ -25,4 +34,10 @@ const TooltipContent = React.forwardRef<
|
|
|
25
34
|
));
|
|
26
35
|
TooltipContent.displayName = TooltipPrimitive.Content.displayName;
|
|
27
36
|
|
|
28
|
-
export {
|
|
37
|
+
export {
|
|
38
|
+
Tooltip,
|
|
39
|
+
TooltipArrow,
|
|
40
|
+
TooltipContent,
|
|
41
|
+
TooltipProvider,
|
|
42
|
+
TooltipTrigger,
|
|
43
|
+
};
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { type MDXComponents } from "mdx/types.js";
|
|
2
2
|
import { CodeBlock } from "zudoku/ui/CodeBlock.js";
|
|
3
3
|
import { AnchorLink } from "../components/AnchorLink.js";
|
|
4
|
+
import { Framed } from "../components/Framed.js";
|
|
4
5
|
import { Heading } from "../components/Heading.js";
|
|
5
6
|
import { InlineCode } from "../components/InlineCode.js";
|
|
6
7
|
import { Button } from "../ui/Button.js";
|
|
@@ -14,10 +15,20 @@ export type MdxComponentsType = Readonly<MDXComponents> | null | undefined;
|
|
|
14
15
|
export const MdxComponents = {
|
|
15
16
|
img: ({ node, ...props }) => {
|
|
16
17
|
if (/\.(mp4|webm|mov|avi)$/.test(props.src ?? "")) {
|
|
17
|
-
return
|
|
18
|
+
return (
|
|
19
|
+
<video
|
|
20
|
+
src={props.src}
|
|
21
|
+
controls
|
|
22
|
+
playsInline
|
|
23
|
+
autoPlay
|
|
24
|
+
loop
|
|
25
|
+
className={cn("rounded-lg", props.className)}
|
|
26
|
+
/>
|
|
27
|
+
);
|
|
18
28
|
}
|
|
19
|
-
return <img {...props} className="rounded-
|
|
29
|
+
return <img {...props} className={cn("rounded-lg", props.className)} />;
|
|
20
30
|
},
|
|
31
|
+
Framed,
|
|
21
32
|
h1: ({ children, id }) => (
|
|
22
33
|
<Heading level={1} id={id}>
|
|
23
34
|
{children}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { humanFileSize } from "./humanFileSize.js";
|
|
2
|
+
|
|
3
|
+
describe("humanFileSize", () => {
|
|
4
|
+
it("should handle zero bytes", () => {
|
|
5
|
+
expect(humanFileSize(0)).toBe("0 B");
|
|
6
|
+
expect(humanFileSize()).toBe("0 B");
|
|
7
|
+
});
|
|
8
|
+
|
|
9
|
+
it("should handle undefined bytes", () => {
|
|
10
|
+
expect(humanFileSize(undefined)).toBe("0 B");
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
it("should handle positive bytes", () => {
|
|
14
|
+
expect(humanFileSize(200)).toBe("200 B");
|
|
15
|
+
expect(humanFileSize(1000)).toBe("1.00 kB");
|
|
16
|
+
expect(humanFileSize(1000000)).toBe("1.00 MB");
|
|
17
|
+
expect(humanFileSize(1000000000)).toBe("1.00 GB");
|
|
18
|
+
expect(humanFileSize(1000000000000)).toBe("1.00 TB");
|
|
19
|
+
expect(humanFileSize(1000000000000000)).toBe("1.00 PB");
|
|
20
|
+
expect(humanFileSize(1000000000000000000)).toBe("1.00 EB");
|
|
21
|
+
expect(humanFileSize(1000000000000000000000)).toBe("1.00 ZB");
|
|
22
|
+
expect(humanFileSize(1000000000000000000000000)).toBe("1.00 YB");
|
|
23
|
+
});
|
|
24
|
+
});
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Converts a number of bytes to a human-readable file size string
|
|
3
|
+
* @param bytes - The number of bytes (defaults to 0)
|
|
4
|
+
* @returns A formatted string like "1.23 MB" or "456 B"
|
|
5
|
+
*/
|
|
6
|
+
export const humanFileSize = (bytes = 0) => {
|
|
7
|
+
if (bytes === 0) {
|
|
8
|
+
return "0 B";
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const exponent = Math.floor(Math.log(bytes) / Math.log(1000.0));
|
|
12
|
+
const decimal = (bytes / Math.pow(1000.0, exponent)).toFixed(
|
|
13
|
+
exponent ? 2 : 0,
|
|
14
|
+
);
|
|
15
|
+
return `${decimal} ${exponent ? `${"kMGTPEZY"[exponent - 1]}B` : "B"}`;
|
|
16
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export function getOS(): "apple" | "linux" | "unix" | "windows" | undefined {
|
|
2
|
+
const notFound = -1;
|
|
3
|
+
const userAgent = navigator.userAgent.toLowerCase();
|
|
4
|
+
if (userAgent.indexOf("win") !== notFound) {
|
|
5
|
+
return "windows";
|
|
6
|
+
} else if (userAgent.indexOf("mac") !== notFound) {
|
|
7
|
+
return "apple";
|
|
8
|
+
} else if (userAgent.indexOf("linux") !== notFound) {
|
|
9
|
+
return "linux";
|
|
10
|
+
} else if (userAgent.indexOf("x11") !== notFound) {
|
|
11
|
+
return "unix";
|
|
12
|
+
}
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export function isAppleDevice(): boolean {
|
|
17
|
+
return getOS() === "apple";
|
|
18
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useCallback, useState } from "react";
|
|
2
|
+
|
|
3
|
+
export const useCopyToClipboard = (timeout = 2000) => {
|
|
4
|
+
const [isCopied, setIsCopied] = useState(false);
|
|
5
|
+
|
|
6
|
+
const copyToClipboard = useCallback(
|
|
7
|
+
(text: string) => {
|
|
8
|
+
void navigator.clipboard.writeText(text);
|
|
9
|
+
setIsCopied(true);
|
|
10
|
+
|
|
11
|
+
setTimeout(() => setIsCopied(false), timeout);
|
|
12
|
+
},
|
|
13
|
+
[timeout],
|
|
14
|
+
);
|
|
15
|
+
|
|
16
|
+
return [isCopied, copyToClipboard] as const;
|
|
17
|
+
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { useCallback, useEffect, useRef } from "react";
|
|
2
2
|
import { useLocation } from "react-router";
|
|
3
3
|
import { useViewportAnchor } from "../components/context/ViewportAnchorContext.js";
|
|
4
|
-
import { DATA_ANCHOR_ATTR } from "../components/navigation/
|
|
4
|
+
import { DATA_ANCHOR_ATTR } from "../components/navigation/NavigationItem.js";
|
|
5
5
|
import { scrollIntoViewIfNeeded } from "./scrollIntoViewIfNeeded.js";
|
|
6
6
|
|
|
7
7
|
export const useScrollToHash = () => {
|
|
@@ -11,8 +11,8 @@ export const useScrollToHash = () => {
|
|
|
11
11
|
(hash: string) => {
|
|
12
12
|
const cleanHash = hash.replace(/^#/, "");
|
|
13
13
|
|
|
14
|
-
// Operation list items might have subdivisions that the
|
|
15
|
-
// The subdivisions are separated by a slash so we need to remove everything before the slash to get the
|
|
14
|
+
// Operation list items might have subdivisions that the navigation doesn't show.
|
|
15
|
+
// The subdivisions are separated by a slash so we need to remove everything before the slash to get the navigation correct item.
|
|
16
16
|
const linkHash = cleanHash.split("/").at(0)!;
|
|
17
17
|
const element = document.getElementById(decodeURIComponent(cleanHash));
|
|
18
18
|
|