@brainfish-ai/devdoc 0.1.42 → 0.1.44
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/dist/cli/commands/create.js +2 -2
- package/dist/cli/commands/dev.js +19 -10
- package/package.json +3 -2
- package/renderer/app/api/assets/[...path]/route.js +108 -0
- package/renderer/app/api/assets/route.js +114 -0
- package/renderer/app/api/assets/upload/route.js +163 -0
- package/renderer/app/api/auth-schemes/route.js +58 -0
- package/renderer/app/api/chat/route.js +759 -0
- package/renderer/app/api/codegen/route.js +52 -0
- package/renderer/app/api/collections/route.js +706 -0
- package/renderer/app/api/debug/route.js +47 -0
- package/renderer/app/api/deploy/route.js +199 -0
- package/renderer/app/api/device/route.js +36 -0
- package/renderer/app/api/docs/route.js +205 -0
- package/renderer/app/api/domains/add/route.js +121 -0
- package/renderer/app/api/domains/lookup/route.js +43 -0
- package/renderer/app/api/domains/remove/route.js +89 -0
- package/renderer/app/api/domains/status/route.js +140 -0
- package/renderer/app/api/domains/verify/route.js +168 -0
- package/renderer/app/api/keys/regenerate/route.js +71 -0
- package/renderer/app/api/local-assets/[...path]/route.js +108 -0
- package/renderer/app/api/openapi-spec/route.js +73 -0
- package/renderer/app/api/projects/[slug]/route.js +129 -0
- package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
- package/renderer/app/api/projects/register/route.js +176 -0
- package/renderer/app/api/proxy/route.js +139 -0
- package/renderer/app/api/proxy-stream/route.js +156 -0
- package/renderer/app/api/redirects/route.js +35 -0
- package/renderer/app/api/schema/route.js +85 -0
- package/renderer/app/api/subdomains/check/route.js +158 -0
- package/renderer/app/api/suggestions/route.js +195 -0
- package/renderer/app/globals.css +69 -0
- package/renderer/app/layout.js +47 -0
- package/renderer/app/llms-full.txt/route.js +266 -0
- package/renderer/app/llms.txt/route.js +228 -0
- package/renderer/app/page.js +12 -0
- package/renderer/app/robots.txt/route.js +66 -0
- package/renderer/app/sitemap.xml/route.js +155 -0
- package/renderer/components/docs/index.js +8 -0
- package/renderer/components/docs/mdx/accordion.js +113 -0
- package/renderer/components/docs/mdx/badge.js +72 -0
- package/renderer/components/docs/mdx/callouts.js +137 -0
- package/renderer/components/docs/mdx/cards.js +175 -0
- package/renderer/components/docs/mdx/changelog.js +100 -0
- package/renderer/components/docs/mdx/code-block.js +147 -0
- package/renderer/components/docs/mdx/code-group.js +287 -0
- package/renderer/components/docs/mdx/file-embeds.js +82 -0
- package/renderer/components/docs/mdx/frame.js +59 -0
- package/renderer/components/docs/mdx/highlight.js +90 -0
- package/renderer/components/docs/mdx/iframe.js +69 -0
- package/renderer/components/docs/mdx/image.js +135 -0
- package/renderer/components/docs/mdx/index.js +134 -0
- package/renderer/components/docs/mdx/landing.js +317 -0
- package/renderer/components/docs/mdx/mermaid.js +212 -0
- package/renderer/components/docs/mdx/param-field.js +112 -0
- package/renderer/components/docs/mdx/steps.js +74 -0
- package/renderer/components/docs/mdx/tabs.js +50 -0
- package/renderer/components/docs/mdx-renderer.js +77 -0
- package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
- package/renderer/components/docs/navigation/index.js +6 -0
- package/renderer/components/docs/navigation/page-nav.js +57 -0
- package/renderer/components/docs/navigation/sidebar.js +375 -0
- package/renderer/components/docs/navigation/toc.js +89 -0
- package/renderer/components/docs/notice.js +77 -0
- package/renderer/components/docs-header.js +202 -0
- package/renderer/components/docs-viewer/agent/agent-chat.js +1831 -0
- package/renderer/components/docs-viewer/agent/agent-popup-button.js +99 -0
- package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
- package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
- package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
- package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
- package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
- package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
- package/renderer/components/docs-viewer/agent/index.js +7 -0
- package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
- package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
- package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
- package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
- package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
- package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
- package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
- package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
- package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
- package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
- package/renderer/components/docs-viewer/content/content-router.js +182 -0
- package/renderer/components/docs-viewer/content/doc-page.js +290 -0
- package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
- package/renderer/components/docs-viewer/content/index.js +31 -0
- package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
- package/renderer/components/docs-viewer/content/request-details.js +528 -0
- package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
- package/renderer/components/docs-viewer/content/sections/body.js +80 -0
- package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
- package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
- package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
- package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
- package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
- package/renderer/components/docs-viewer/index.js +1448 -0
- package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
- package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
- package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
- package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
- package/renderer/components/docs-viewer/playground/graphql-playground.js +936 -0
- package/renderer/components/docs-viewer/playground/index.js +682 -0
- package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
- package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
- package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
- package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
- package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
- package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
- package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
- package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
- package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
- package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
- package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
- package/renderer/components/docs-viewer/search/index.js +2 -0
- package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
- package/renderer/components/docs-viewer/search/use-search.js +89 -0
- package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
- package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
- package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
- package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
- package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
- package/renderer/components/docs-viewer/sidebar/index.js +196 -0
- package/renderer/components/docs-viewer/sidebar/right-sidebar.js +159 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
- package/renderer/components/theme-provider.js +10 -0
- package/renderer/components/theme-toggle.js +86 -0
- package/renderer/components/ui/badge.js +29 -0
- package/renderer/components/ui/button.js +40 -0
- package/renderer/components/ui/dialog.js +50 -0
- package/renderer/components/ui/dropdown-menu.js +143 -0
- package/renderer/components/ui/input.js +12 -0
- package/renderer/components/ui/label.js +13 -0
- package/renderer/components/ui/navigation-menu.js +83 -0
- package/renderer/components/ui/select.js +116 -0
- package/renderer/components/ui/spinner.js +92 -0
- package/renderer/components/ui/tabs.js +34 -0
- package/renderer/components/ui/tooltip.js +43 -0
- package/renderer/hooks/use-code-copy.js +76 -0
- package/renderer/hooks/use-openapi-title.js +33 -0
- package/renderer/hooks/use-route-state.js +159 -0
- package/renderer/lib/api-docs/agent/index.js +4 -0
- package/renderer/lib/api-docs/agent/indexer.js +254 -0
- package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
- package/renderer/lib/api-docs/agent/types.js +5 -0
- package/renderer/lib/api-docs/agent/use-suggestions.js +97 -0
- package/renderer/lib/api-docs/auth/auth-context.js +157 -0
- package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
- package/renderer/lib/api-docs/auth/crypto.js +64 -0
- package/renderer/lib/api-docs/auth/index.js +3 -0
- package/renderer/lib/api-docs/code-editor/db.js +145 -0
- package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
- package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
- package/renderer/lib/api-docs/code-editor/mode-context.js +126 -0
- package/renderer/lib/api-docs/code-editor/types.js +53 -0
- package/renderer/lib/api-docs/codegen/definitions.js +258 -0
- package/renderer/lib/api-docs/codegen/har.js +171 -0
- package/renderer/lib/api-docs/codegen/index.js +118 -0
- package/renderer/lib/api-docs/factories.js +136 -0
- package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
- package/renderer/lib/api-docs/mobile-context.js +116 -0
- package/renderer/lib/api-docs/navigation-context.js +62 -0
- package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
- package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
- package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
- package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
- package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
- package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
- package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
- package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
- package/renderer/lib/api-docs/playground/context.js +65 -0
- package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
- package/renderer/lib/api-docs/playground/request-builder.js +163 -0
- package/renderer/lib/api-docs/playground/request-runner.js +224 -0
- package/renderer/lib/api-docs/playground/types.js +5 -0
- package/renderer/lib/api-docs/types.js +23 -0
- package/renderer/lib/api-docs/utils.js +212 -0
- package/renderer/lib/cache.js +157 -0
- package/renderer/lib/docs/config/domain-schema.js +161 -0
- package/renderer/lib/docs/config/environment.js +38 -0
- package/renderer/lib/docs/config/index.js +6 -0
- package/renderer/lib/docs/config/loader.js +113 -0
- package/renderer/lib/docs/config/schema.js +281 -0
- package/renderer/lib/docs/index.js +8 -0
- package/renderer/lib/docs/mdx/compiler.js +131 -0
- package/renderer/lib/docs/mdx/frontmatter.js +73 -0
- package/renderer/lib/docs/mdx/index.js +10 -0
- package/renderer/lib/docs/mdx/remark-mermaid.js +63 -0
- package/renderer/lib/docs/navigation/generator.js +269 -0
- package/renderer/lib/docs/navigation/index.js +3 -0
- package/renderer/lib/docs/navigation/types.js +11 -0
- package/renderer/lib/docs-navigation-context.js +40 -0
- package/renderer/lib/docs-navigation.js +140 -0
- package/renderer/lib/multi-tenant/context.js +80 -0
- package/renderer/lib/storage/blob.js +767 -0
- package/renderer/lib/utils/icons.js +30 -0
- package/renderer/lib/utils.js +5 -0
- package/renderer/next.config.js +62 -0
- package/renderer/package.json +1 -0
- package/renderer/tsconfig.json +23 -5
- package/renderer/app/api/assets/[...path]/route.ts +0 -123
- package/renderer/app/api/assets/route.ts +0 -124
- package/renderer/app/api/assets/upload/route.ts +0 -177
- package/renderer/app/api/auth-schemes/route.ts +0 -77
- package/renderer/app/api/chat/route.ts +0 -858
- package/renderer/app/api/codegen/route.ts +0 -72
- package/renderer/app/api/collections/route.ts +0 -1002
- package/renderer/app/api/debug/route.ts +0 -53
- package/renderer/app/api/deploy/route.ts +0 -234
- package/renderer/app/api/device/route.ts +0 -42
- package/renderer/app/api/docs/route.ts +0 -201
- package/renderer/app/api/domains/add/route.ts +0 -132
- package/renderer/app/api/domains/lookup/route.ts +0 -43
- package/renderer/app/api/domains/remove/route.ts +0 -100
- package/renderer/app/api/domains/status/route.ts +0 -158
- package/renderer/app/api/domains/verify/route.ts +0 -181
- package/renderer/app/api/keys/regenerate/route.ts +0 -80
- package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
- package/renderer/app/api/openapi-spec/route.ts +0 -151
- package/renderer/app/api/projects/[slug]/route.ts +0 -153
- package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
- package/renderer/app/api/projects/register/route.ts +0 -152
- package/renderer/app/api/proxy/route.ts +0 -149
- package/renderer/app/api/proxy-stream/route.ts +0 -168
- package/renderer/app/api/redirects/route.ts +0 -47
- package/renderer/app/api/schema/route.ts +0 -73
- package/renderer/app/api/subdomains/check/route.ts +0 -172
- package/renderer/app/api/suggestions/route.ts +0 -144
- package/renderer/app/layout.tsx +0 -54
- package/renderer/app/llms-full.txt/route.ts +0 -346
- package/renderer/app/llms.txt/route.ts +0 -279
- package/renderer/app/page.tsx +0 -14
- package/renderer/app/robots.txt/route.ts +0 -84
- package/renderer/app/sitemap.xml/route.ts +0 -199
- package/renderer/components/docs/index.ts +0 -12
- package/renderer/components/docs/mdx/accordion.tsx +0 -169
- package/renderer/components/docs/mdx/badge.tsx +0 -132
- package/renderer/components/docs/mdx/callouts.tsx +0 -154
- package/renderer/components/docs/mdx/cards.tsx +0 -241
- package/renderer/components/docs/mdx/changelog.tsx +0 -120
- package/renderer/components/docs/mdx/code-block.tsx +0 -186
- package/renderer/components/docs/mdx/code-group.tsx +0 -421
- package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
- package/renderer/components/docs/mdx/frame.tsx +0 -112
- package/renderer/components/docs/mdx/highlight.tsx +0 -151
- package/renderer/components/docs/mdx/iframe.tsx +0 -134
- package/renderer/components/docs/mdx/image.tsx +0 -235
- package/renderer/components/docs/mdx/index.ts +0 -237
- package/renderer/components/docs/mdx/landing.tsx +0 -684
- package/renderer/components/docs/mdx/mermaid.tsx +0 -240
- package/renderer/components/docs/mdx/param-field.tsx +0 -200
- package/renderer/components/docs/mdx/steps.tsx +0 -113
- package/renderer/components/docs/mdx/tabs.tsx +0 -86
- package/renderer/components/docs/mdx-renderer.tsx +0 -100
- package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
- package/renderer/components/docs/navigation/index.ts +0 -8
- package/renderer/components/docs/navigation/page-nav.tsx +0 -64
- package/renderer/components/docs/navigation/sidebar.tsx +0 -515
- package/renderer/components/docs/navigation/toc.tsx +0 -113
- package/renderer/components/docs/notice.tsx +0 -105
- package/renderer/components/docs-header.tsx +0 -278
- package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
- package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
- package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
- package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
- package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
- package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
- package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
- package/renderer/components/docs-viewer/agent/index.tsx +0 -6
- package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
- package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
- package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
- package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
- package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
- package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
- package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
- package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
- package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
- package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
- package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
- package/renderer/components/docs-viewer/content/index.tsx +0 -29
- package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
- package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
- package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
- package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
- package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
- package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
- package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
- package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
- package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
- package/renderer/components/docs-viewer/index.tsx +0 -1670
- package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
- package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
- package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
- package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
- package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
- package/renderer/components/docs-viewer/playground/index.tsx +0 -671
- package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
- package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
- package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
- package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
- package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
- package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
- package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
- package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
- package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
- package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
- package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
- package/renderer/components/docs-viewer/search/index.ts +0 -2
- package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
- package/renderer/components/docs-viewer/search/use-search.ts +0 -117
- package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
- package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
- package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
- package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
- package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
- package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
- package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
- package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
- package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
- package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
- package/renderer/components/theme-provider.tsx +0 -11
- package/renderer/components/theme-toggle.tsx +0 -76
- package/renderer/components/ui/badge.tsx +0 -46
- package/renderer/components/ui/button.tsx +0 -59
- package/renderer/components/ui/dialog.tsx +0 -118
- package/renderer/components/ui/dropdown-menu.tsx +0 -257
- package/renderer/components/ui/input.tsx +0 -21
- package/renderer/components/ui/label.tsx +0 -24
- package/renderer/components/ui/navigation-menu.tsx +0 -168
- package/renderer/components/ui/select.tsx +0 -190
- package/renderer/components/ui/spinner.tsx +0 -114
- package/renderer/components/ui/tabs.tsx +0 -66
- package/renderer/components/ui/tooltip.tsx +0 -61
- package/renderer/hooks/use-code-copy.ts +0 -88
- package/renderer/hooks/use-openapi-title.ts +0 -44
- package/renderer/lib/api-docs/agent/index.ts +0 -6
- package/renderer/lib/api-docs/agent/indexer.ts +0 -323
- package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
- package/renderer/lib/api-docs/agent/types.ts +0 -116
- package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
- package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
- package/renderer/lib/api-docs/auth/crypto.ts +0 -89
- package/renderer/lib/api-docs/auth/index.ts +0 -4
- package/renderer/lib/api-docs/code-editor/db.ts +0 -164
- package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
- package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
- package/renderer/lib/api-docs/code-editor/types.ts +0 -105
- package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
- package/renderer/lib/api-docs/codegen/har.ts +0 -251
- package/renderer/lib/api-docs/codegen/index.ts +0 -159
- package/renderer/lib/api-docs/factories.ts +0 -170
- package/renderer/lib/api-docs/mobile-context.tsx +0 -112
- package/renderer/lib/api-docs/navigation-context.tsx +0 -88
- package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
- package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
- package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
- package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
- package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
- package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
- package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
- package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
- package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
- package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
- package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
- package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
- package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
- package/renderer/lib/api-docs/playground/context.tsx +0 -107
- package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
- package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
- package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
- package/renderer/lib/api-docs/playground/types.ts +0 -35
- package/renderer/lib/api-docs/types.ts +0 -269
- package/renderer/lib/api-docs/utils.ts +0 -311
- package/renderer/lib/cache.ts +0 -193
- package/renderer/lib/docs/config/domain-schema.ts +0 -260
- package/renderer/lib/docs/config/index.ts +0 -43
- package/renderer/lib/docs/config/loader.ts +0 -142
- package/renderer/lib/docs/config/schema.ts +0 -308
- package/renderer/lib/docs/index.ts +0 -12
- package/renderer/lib/docs/mdx/compiler.ts +0 -176
- package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
- package/renderer/lib/docs/mdx/index.ts +0 -26
- package/renderer/lib/docs/navigation/generator.ts +0 -348
- package/renderer/lib/docs/navigation/index.ts +0 -12
- package/renderer/lib/docs/navigation/types.ts +0 -123
- package/renderer/lib/docs-navigation-context.tsx +0 -80
- package/renderer/lib/multi-tenant/context.ts +0 -105
- package/renderer/lib/storage/blob.ts +0 -1083
- package/renderer/lib/utils/icons.ts +0 -48
- package/renderer/lib/utils.ts +0 -6
- package/renderer/next.config.ts +0 -76
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
/**
|
|
3
|
+
* Domain Configuration Schema (domain.json)
|
|
4
|
+
*
|
|
5
|
+
* Configuration for custom domains on DevDoc projects.
|
|
6
|
+
* Each project can have ONE custom domain for free.
|
|
7
|
+
*/ // ============================================================================
|
|
8
|
+
// Domain Validation Helpers
|
|
9
|
+
// ============================================================================
|
|
10
|
+
/**
|
|
11
|
+
* Valid domain pattern - allows subdomains like docs.example.com
|
|
12
|
+
* Does NOT allow:
|
|
13
|
+
* - IP addresses
|
|
14
|
+
* - Ports
|
|
15
|
+
* - Paths
|
|
16
|
+
* - Protocol prefixes
|
|
17
|
+
*/ const domainRegex = /^(?!-)[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*\.[a-zA-Z]{2,}$/;
|
|
18
|
+
/**
|
|
19
|
+
* Reserved domains that cannot be used as custom domains
|
|
20
|
+
*/ const RESERVED_DOMAINS = [
|
|
21
|
+
'devdoc.sh',
|
|
22
|
+
'devdoc.io',
|
|
23
|
+
'devdoc.com',
|
|
24
|
+
'localhost'
|
|
25
|
+
];
|
|
26
|
+
// ============================================================================
|
|
27
|
+
// SEO Schema
|
|
28
|
+
// ============================================================================
|
|
29
|
+
const domainSeoSchema = z.object({
|
|
30
|
+
/**
|
|
31
|
+
* Canonical URL for SEO - tells search engines this is the primary URL
|
|
32
|
+
* Should match your custom domain with https://
|
|
33
|
+
*/ canonical: z.string().url().optional()
|
|
34
|
+
});
|
|
35
|
+
// ============================================================================
|
|
36
|
+
// Settings Schema
|
|
37
|
+
// ============================================================================
|
|
38
|
+
const domainSettingsSchema = z.object({
|
|
39
|
+
/**
|
|
40
|
+
* Force HTTPS redirects (recommended, default: true)
|
|
41
|
+
*/ forceHttps: z.boolean().default(true),
|
|
42
|
+
/**
|
|
43
|
+
* WWW redirect preference
|
|
44
|
+
* - "www": Redirect non-www to www (example.com → www.example.com)
|
|
45
|
+
* - "non-www": Redirect www to non-www (www.example.com → example.com)
|
|
46
|
+
* - "none": No redirect, accept both
|
|
47
|
+
*/ wwwRedirect: z.enum([
|
|
48
|
+
'www',
|
|
49
|
+
'non-www',
|
|
50
|
+
'none'
|
|
51
|
+
]).default('none')
|
|
52
|
+
});
|
|
53
|
+
// ============================================================================
|
|
54
|
+
// Main Domain Configuration Schema
|
|
55
|
+
// ============================================================================
|
|
56
|
+
export const domainConfigSchema = z.object({
|
|
57
|
+
/**
|
|
58
|
+
* JSON Schema reference (optional)
|
|
59
|
+
*/ $schema: z.string().optional(),
|
|
60
|
+
/**
|
|
61
|
+
* The custom domain for this project
|
|
62
|
+
* Example: "docs.example.com" or "developer.mycompany.io"
|
|
63
|
+
*
|
|
64
|
+
* Rules:
|
|
65
|
+
* - Must be a valid domain name
|
|
66
|
+
* - Cannot be a DevDoc domain (*.devdoc.sh)
|
|
67
|
+
* - One custom domain per project (free)
|
|
68
|
+
*/ customDomain: z.string().min(4, 'Domain must be at least 4 characters').max(253, 'Domain must be 253 characters or less').regex(domainRegex, 'Invalid domain format. Example: docs.example.com').refine((domain)=>!RESERVED_DOMAINS.some((reserved)=>domain === reserved || domain.endsWith(`.${reserved}`)), 'Cannot use a reserved DevDoc domain'),
|
|
69
|
+
/**
|
|
70
|
+
* SEO configuration for the custom domain
|
|
71
|
+
*/ seo: domainSeoSchema.optional(),
|
|
72
|
+
/**
|
|
73
|
+
* Domain behavior settings
|
|
74
|
+
*/ settings: domainSettingsSchema.optional()
|
|
75
|
+
});
|
|
76
|
+
// ============================================================================
|
|
77
|
+
// Validation Functions
|
|
78
|
+
// ============================================================================
|
|
79
|
+
/**
|
|
80
|
+
* Parse and validate domain configuration
|
|
81
|
+
*/ export function parseDomainConfig(data) {
|
|
82
|
+
const result = domainConfigSchema.safeParse(data);
|
|
83
|
+
if (!result.success) {
|
|
84
|
+
const issues = result.error.issues || [];
|
|
85
|
+
const errors = issues.map((e)=>`${e.path.map(String).join('.')}: ${e.message}`).join('\n');
|
|
86
|
+
throw new Error(`Invalid domain.json configuration:\n${errors}`);
|
|
87
|
+
}
|
|
88
|
+
return result.data;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Safe parse that returns null on failure
|
|
92
|
+
*/ export function safeParseDomainConfig(data) {
|
|
93
|
+
const result = domainConfigSchema.safeParse(data);
|
|
94
|
+
return result.success ? result.data : null;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Validate a domain string format
|
|
98
|
+
*/ export function isValidDomain(domain) {
|
|
99
|
+
if (!domain) {
|
|
100
|
+
return {
|
|
101
|
+
valid: false,
|
|
102
|
+
error: 'Domain is required'
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
if (domain.length < 4) {
|
|
106
|
+
return {
|
|
107
|
+
valid: false,
|
|
108
|
+
error: 'Domain must be at least 4 characters'
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
if (domain.length > 253) {
|
|
112
|
+
return {
|
|
113
|
+
valid: false,
|
|
114
|
+
error: 'Domain must be 253 characters or less'
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
if (!domainRegex.test(domain)) {
|
|
118
|
+
return {
|
|
119
|
+
valid: false,
|
|
120
|
+
error: 'Invalid domain format. Example: docs.example.com'
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
// Check reserved domains
|
|
124
|
+
if (RESERVED_DOMAINS.some((reserved)=>domain === reserved || domain.endsWith(`.${reserved}`))) {
|
|
125
|
+
return {
|
|
126
|
+
valid: false,
|
|
127
|
+
error: 'Cannot use a reserved DevDoc domain'
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
return {
|
|
131
|
+
valid: true
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Normalize a domain (lowercase, trim, remove protocol/path)
|
|
136
|
+
*/ export function normalizeDomain(domain) {
|
|
137
|
+
let normalized = domain.toLowerCase().trim();
|
|
138
|
+
// Remove protocol if present
|
|
139
|
+
normalized = normalized.replace(/^https?:\/\//, '');
|
|
140
|
+
// Remove path if present
|
|
141
|
+
normalized = normalized.split('/')[0];
|
|
142
|
+
// Remove port if present
|
|
143
|
+
normalized = normalized.split(':')[0];
|
|
144
|
+
return normalized;
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Get DNS instructions for a custom domain
|
|
148
|
+
*/ export function getDnsInstructions(customDomain) {
|
|
149
|
+
const parts = customDomain.split('.');
|
|
150
|
+
const subdomain = parts.length > 2 ? parts[0] : '@';
|
|
151
|
+
return {
|
|
152
|
+
cname: {
|
|
153
|
+
name: subdomain === '@' ? customDomain : subdomain,
|
|
154
|
+
value: 'cname.devdoc-dns.com'
|
|
155
|
+
},
|
|
156
|
+
txt: {
|
|
157
|
+
name: `_devdoc-verify.${customDomain}`,
|
|
158
|
+
value: ''
|
|
159
|
+
}
|
|
160
|
+
};
|
|
161
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Environment Detection Utilities
|
|
3
|
+
*
|
|
4
|
+
* Utilities for detecting development vs production environment
|
|
5
|
+
* Used for visibility filtering of private documentation content
|
|
6
|
+
*/ /**
|
|
7
|
+
* Check if the application is running in development mode
|
|
8
|
+
*
|
|
9
|
+
* Development mode is determined by:
|
|
10
|
+
* 1. NODE_ENV !== 'production'
|
|
11
|
+
* 2. DEVDOC_DEV_MODE env var is set to 'true' (set by devdoc dev command)
|
|
12
|
+
*
|
|
13
|
+
* @returns true if in development mode, false if in production
|
|
14
|
+
*/ export function isDevMode() {
|
|
15
|
+
return process.env.NODE_ENV !== 'production' || process.env.DEVDOC_DEV_MODE === 'true';
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Check if the application is running in production mode
|
|
19
|
+
*
|
|
20
|
+
* @returns true if in production mode, false if in development
|
|
21
|
+
*/ export function isProductionMode() {
|
|
22
|
+
return !isDevMode();
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Check if an item should be visible based on its visibility setting
|
|
26
|
+
*
|
|
27
|
+
* @param visibility - The visibility setting ('public', 'private', or undefined)
|
|
28
|
+
* @param devMode - Whether we're in development mode (defaults to isDevMode())
|
|
29
|
+
* @returns true if the item should be shown, false if it should be hidden
|
|
30
|
+
*/ export function shouldShowItem(visibility, devMode) {
|
|
31
|
+
const isDev = devMode ?? isDevMode();
|
|
32
|
+
// Private items are only visible in dev mode
|
|
33
|
+
if (visibility === 'private') {
|
|
34
|
+
return isDev;
|
|
35
|
+
}
|
|
36
|
+
// Public or undefined visibility = always show
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Configuration Module Exports
|
|
3
|
+
*/ export { docsConfigSchema, parseDocsConfig, safeParseDocsConfig, getDefaultDocsConfig } from './schema';
|
|
4
|
+
export { domainConfigSchema, parseDomainConfig, safeParseDomainConfig, isValidDomain, normalizeDomain, getDnsInstructions } from './domain-schema';
|
|
5
|
+
export { loadDocsConfig, safeLoadDocsConfig, clearConfigCache, hasDocsConfig, getContentDir, resolvePagePath, loadPageContent, listMdxFiles } from './loader';
|
|
6
|
+
export { isDevMode, isProductionMode, shouldShowItem } from './environment';
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { readFileSync, existsSync, readdirSync } from 'fs';
|
|
2
|
+
import { join } from 'path';
|
|
3
|
+
import { parseDocsConfig } from './schema';
|
|
4
|
+
/**
|
|
5
|
+
* Configuration Loader
|
|
6
|
+
*
|
|
7
|
+
* Utilities for loading and caching docs.json configuration
|
|
8
|
+
* Uses synchronous fs operations for compatibility with Next.js Turbopack
|
|
9
|
+
*/ // Cache for loaded configuration
|
|
10
|
+
let configCache = null;
|
|
11
|
+
let configCachePath = null;
|
|
12
|
+
/**
|
|
13
|
+
* Load docs.json configuration from a directory
|
|
14
|
+
*/ export function loadDocsConfig(docsDir) {
|
|
15
|
+
const configFilePath = join(docsDir, 'docs.json');
|
|
16
|
+
// Return cached config if path matches
|
|
17
|
+
if (configCache && configCachePath === configFilePath) {
|
|
18
|
+
return configCache;
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
if (!existsSync(configFilePath)) {
|
|
22
|
+
throw new Error(`docs.json not found at ${configFilePath}`);
|
|
23
|
+
}
|
|
24
|
+
const configContent = readFileSync(configFilePath, 'utf-8');
|
|
25
|
+
const rawConfig = JSON.parse(configContent);
|
|
26
|
+
const config = parseDocsConfig(rawConfig);
|
|
27
|
+
// Cache the result
|
|
28
|
+
configCache = config;
|
|
29
|
+
configCachePath = configFilePath;
|
|
30
|
+
return config;
|
|
31
|
+
} catch (error) {
|
|
32
|
+
if (error instanceof Error) {
|
|
33
|
+
throw new Error(`Failed to load docs.json: ${error.message}`);
|
|
34
|
+
}
|
|
35
|
+
throw error;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Load configuration without throwing (returns null on failure)
|
|
40
|
+
*/ export function safeLoadDocsConfig(docsDir) {
|
|
41
|
+
try {
|
|
42
|
+
return loadDocsConfig(docsDir);
|
|
43
|
+
} catch {
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Clear the configuration cache
|
|
49
|
+
*/ export function clearConfigCache() {
|
|
50
|
+
configCache = null;
|
|
51
|
+
configCachePath = null;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Check if a docs.json file exists in a directory
|
|
55
|
+
*/ export function hasDocsConfig(docsDir) {
|
|
56
|
+
return existsSync(join(docsDir, 'docs.json'));
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Get the content directory path from configuration
|
|
60
|
+
*/ export function getContentDir(docsDir) {
|
|
61
|
+
return docsDir;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Resolve a page path to a file path
|
|
65
|
+
*/ export function resolvePagePath(docsDir, pagePath) {
|
|
66
|
+
const contentDir = getContentDir(docsDir);
|
|
67
|
+
const extensions = [
|
|
68
|
+
'.mdx',
|
|
69
|
+
'.md'
|
|
70
|
+
];
|
|
71
|
+
// Try different extensions
|
|
72
|
+
for (const ext of extensions){
|
|
73
|
+
const filePath = join(contentDir, `${pagePath}${ext}`);
|
|
74
|
+
if (existsSync(filePath)) {
|
|
75
|
+
return filePath;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// Try as directory with index file
|
|
79
|
+
for (const ext of extensions){
|
|
80
|
+
const indexPath = join(contentDir, pagePath, `index${ext}`);
|
|
81
|
+
if (existsSync(indexPath)) {
|
|
82
|
+
return indexPath;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Load page content from a resolved path
|
|
89
|
+
*/ export function loadPageContent(filePath) {
|
|
90
|
+
return readFileSync(filePath, 'utf-8');
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* List all MDX files in a directory recursively
|
|
94
|
+
*/ export function listMdxFiles(dir) {
|
|
95
|
+
const files = [];
|
|
96
|
+
function walk(currentDir) {
|
|
97
|
+
const entries = readdirSync(currentDir, {
|
|
98
|
+
withFileTypes: true
|
|
99
|
+
});
|
|
100
|
+
for (const entry of entries){
|
|
101
|
+
const fullPath = join(currentDir, entry.name);
|
|
102
|
+
if (entry.isDirectory()) {
|
|
103
|
+
if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {
|
|
104
|
+
walk(fullPath);
|
|
105
|
+
}
|
|
106
|
+
} else if (entry.isFile() && (entry.name.endsWith('.mdx') || entry.name.endsWith('.md'))) {
|
|
107
|
+
files.push(fullPath);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
walk(dir);
|
|
112
|
+
return files;
|
|
113
|
+
}
|
|
@@ -0,0 +1,281 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
/**
|
|
3
|
+
* Documentation Configuration Schema (docs.json)
|
|
4
|
+
*
|
|
5
|
+
* Mintlify-compatible configuration schema for documentation sites.
|
|
6
|
+
*/ // ============================================================================
|
|
7
|
+
// Navigation Schemas
|
|
8
|
+
// ============================================================================
|
|
9
|
+
const anchorSchema = z.object({
|
|
10
|
+
anchor: z.string(),
|
|
11
|
+
href: z.string(),
|
|
12
|
+
icon: z.string().optional()
|
|
13
|
+
});
|
|
14
|
+
const navLinkSchema = z.object({
|
|
15
|
+
label: z.string(),
|
|
16
|
+
href: z.string()
|
|
17
|
+
});
|
|
18
|
+
// Visibility schema for tabs, groups, and pages
|
|
19
|
+
// - 'public': Always visible (default)
|
|
20
|
+
// - 'private': Only visible in development mode, hidden in production
|
|
21
|
+
const visibilitySchema = z.enum([
|
|
22
|
+
'public',
|
|
23
|
+
'private'
|
|
24
|
+
]).optional();
|
|
25
|
+
// Page can be a string or a nested group
|
|
26
|
+
const pageRefSchema = z.lazy(()=>z.union([
|
|
27
|
+
z.string(),
|
|
28
|
+
z.object({
|
|
29
|
+
group: z.string(),
|
|
30
|
+
pages: z.array(z.union([
|
|
31
|
+
z.string(),
|
|
32
|
+
z.lazy(()=>pageRefSchema)
|
|
33
|
+
]))
|
|
34
|
+
})
|
|
35
|
+
]));
|
|
36
|
+
const groupSchema = z.object({
|
|
37
|
+
group: z.string(),
|
|
38
|
+
pages: z.array(pageRefSchema),
|
|
39
|
+
icon: z.string().optional(),
|
|
40
|
+
visibility: visibilitySchema
|
|
41
|
+
});
|
|
42
|
+
// OpenAPI version schema
|
|
43
|
+
const openapiVersionSchema = z.object({
|
|
44
|
+
version: z.string(),
|
|
45
|
+
spec: z.string(),
|
|
46
|
+
default: z.boolean().optional()
|
|
47
|
+
});
|
|
48
|
+
// Different tab types
|
|
49
|
+
const docsTabSchema = z.object({
|
|
50
|
+
tab: z.string(),
|
|
51
|
+
type: z.literal('docs').optional(),
|
|
52
|
+
groups: z.array(groupSchema),
|
|
53
|
+
visibility: visibilitySchema
|
|
54
|
+
});
|
|
55
|
+
const openapiTabSchema = z.object({
|
|
56
|
+
tab: z.string(),
|
|
57
|
+
type: z.literal('openapi'),
|
|
58
|
+
path: z.string().optional(),
|
|
59
|
+
versions: z.array(openapiVersionSchema).optional(),
|
|
60
|
+
spec: z.string().optional(),
|
|
61
|
+
groups: z.array(groupSchema).optional(),
|
|
62
|
+
visibility: visibilitySchema
|
|
63
|
+
});
|
|
64
|
+
const graphqlTabSchema = z.object({
|
|
65
|
+
tab: z.string(),
|
|
66
|
+
type: z.literal('graphql'),
|
|
67
|
+
path: z.string().optional(),
|
|
68
|
+
schema: z.string(),
|
|
69
|
+
endpoint: z.string().optional(),
|
|
70
|
+
groups: z.array(groupSchema).optional(),
|
|
71
|
+
visibility: visibilitySchema
|
|
72
|
+
});
|
|
73
|
+
const changelogTabSchema = z.object({
|
|
74
|
+
tab: z.string(),
|
|
75
|
+
type: z.literal('changelog'),
|
|
76
|
+
path: z.string().optional(),
|
|
77
|
+
visibility: visibilitySchema
|
|
78
|
+
});
|
|
79
|
+
const tabSchema = z.union([
|
|
80
|
+
docsTabSchema,
|
|
81
|
+
openapiTabSchema,
|
|
82
|
+
graphqlTabSchema,
|
|
83
|
+
changelogTabSchema
|
|
84
|
+
]);
|
|
85
|
+
const navigationSchema = z.object({
|
|
86
|
+
tabs: z.array(tabSchema).optional(),
|
|
87
|
+
groups: z.array(groupSchema).optional(),
|
|
88
|
+
global: z.object({
|
|
89
|
+
anchors: z.array(anchorSchema).optional()
|
|
90
|
+
}).optional()
|
|
91
|
+
});
|
|
92
|
+
// ============================================================================
|
|
93
|
+
// Theme & Branding Schemas
|
|
94
|
+
// ============================================================================
|
|
95
|
+
const colorSchema = z.object({
|
|
96
|
+
primary: z.string(),
|
|
97
|
+
light: z.string().optional(),
|
|
98
|
+
dark: z.string().optional(),
|
|
99
|
+
background: z.object({
|
|
100
|
+
light: z.string().optional(),
|
|
101
|
+
dark: z.string().optional()
|
|
102
|
+
}).optional()
|
|
103
|
+
});
|
|
104
|
+
const logoSchema = z.object({
|
|
105
|
+
light: z.string(),
|
|
106
|
+
dark: z.string(),
|
|
107
|
+
href: z.string().optional()
|
|
108
|
+
});
|
|
109
|
+
const faviconSchema = z.string();
|
|
110
|
+
// ============================================================================
|
|
111
|
+
// Navbar Schema
|
|
112
|
+
// ============================================================================
|
|
113
|
+
const navbarPrimarySchema = z.object({
|
|
114
|
+
type: z.enum([
|
|
115
|
+
'button',
|
|
116
|
+
'github',
|
|
117
|
+
'link'
|
|
118
|
+
]),
|
|
119
|
+
label: z.string().optional(),
|
|
120
|
+
href: z.string()
|
|
121
|
+
});
|
|
122
|
+
const navbarSchema = z.object({
|
|
123
|
+
links: z.array(navLinkSchema).optional(),
|
|
124
|
+
primary: navbarPrimarySchema.optional()
|
|
125
|
+
});
|
|
126
|
+
// ============================================================================
|
|
127
|
+
// Footer Schema
|
|
128
|
+
// ============================================================================
|
|
129
|
+
const footerLinkSchema = z.object({
|
|
130
|
+
label: z.string(),
|
|
131
|
+
href: z.string()
|
|
132
|
+
});
|
|
133
|
+
const footerGroupSchema = z.object({
|
|
134
|
+
title: z.string(),
|
|
135
|
+
links: z.array(footerLinkSchema)
|
|
136
|
+
});
|
|
137
|
+
const footerSchema = z.object({
|
|
138
|
+
socials: z.record(z.string(), z.string()).optional(),
|
|
139
|
+
links: z.array(footerGroupSchema).optional()
|
|
140
|
+
});
|
|
141
|
+
// ============================================================================
|
|
142
|
+
// API Configuration Schema
|
|
143
|
+
// ============================================================================
|
|
144
|
+
const apiAuthSchema = z.object({
|
|
145
|
+
method: z.enum([
|
|
146
|
+
'bearer',
|
|
147
|
+
'basic',
|
|
148
|
+
'api-key',
|
|
149
|
+
'none'
|
|
150
|
+
]),
|
|
151
|
+
name: z.string().optional()
|
|
152
|
+
});
|
|
153
|
+
const apiPlaygroundSchema = z.object({
|
|
154
|
+
mode: z.enum([
|
|
155
|
+
'show',
|
|
156
|
+
'simple',
|
|
157
|
+
'hide'
|
|
158
|
+
]).optional()
|
|
159
|
+
});
|
|
160
|
+
const apiConfigSchema = z.object({
|
|
161
|
+
baseUrl: z.string().optional(),
|
|
162
|
+
auth: apiAuthSchema.optional(),
|
|
163
|
+
playground: apiPlaygroundSchema.optional()
|
|
164
|
+
});
|
|
165
|
+
// ============================================================================
|
|
166
|
+
// SEO Schema
|
|
167
|
+
// ============================================================================
|
|
168
|
+
const seoSchema = z.object({
|
|
169
|
+
indexHiddenPages: z.boolean().optional(),
|
|
170
|
+
titleTemplate: z.string().optional()
|
|
171
|
+
});
|
|
172
|
+
// ============================================================================
|
|
173
|
+
// Integrations Schema
|
|
174
|
+
// ============================================================================
|
|
175
|
+
const analyticsSchema = z.object({
|
|
176
|
+
posthog: z.object({
|
|
177
|
+
apiKey: z.string()
|
|
178
|
+
}).optional(),
|
|
179
|
+
googleAnalytics: z.object({
|
|
180
|
+
measurementId: z.string()
|
|
181
|
+
}).optional(),
|
|
182
|
+
plausible: z.object({
|
|
183
|
+
domain: z.string()
|
|
184
|
+
}).optional()
|
|
185
|
+
});
|
|
186
|
+
const integrationsSchema = z.object({
|
|
187
|
+
analytics: analyticsSchema.optional()
|
|
188
|
+
});
|
|
189
|
+
// ============================================================================
|
|
190
|
+
// Contextual Menu Schema
|
|
191
|
+
// ============================================================================
|
|
192
|
+
const contextualOptionsEnum = z.enum([
|
|
193
|
+
'copy',
|
|
194
|
+
'view',
|
|
195
|
+
'chatgpt',
|
|
196
|
+
'claude',
|
|
197
|
+
'perplexity',
|
|
198
|
+
'mcp',
|
|
199
|
+
'cursor',
|
|
200
|
+
'vscode'
|
|
201
|
+
]);
|
|
202
|
+
const contextualSchema = z.object({
|
|
203
|
+
options: z.array(contextualOptionsEnum).optional()
|
|
204
|
+
});
|
|
205
|
+
// ============================================================================
|
|
206
|
+
// Main Configuration Schema
|
|
207
|
+
// ============================================================================
|
|
208
|
+
export const docsConfigSchema = z.object({
|
|
209
|
+
// Schema reference (optional)
|
|
210
|
+
$schema: z.string().optional(),
|
|
211
|
+
// Core identity
|
|
212
|
+
name: z.string(),
|
|
213
|
+
// Theme
|
|
214
|
+
theme: z.enum([
|
|
215
|
+
'default',
|
|
216
|
+
'mint',
|
|
217
|
+
'quill',
|
|
218
|
+
'venus'
|
|
219
|
+
]).optional(),
|
|
220
|
+
colors: colorSchema.optional(),
|
|
221
|
+
// Branding
|
|
222
|
+
favicon: faviconSchema.optional(),
|
|
223
|
+
logo: logoSchema.optional(),
|
|
224
|
+
// Navigation
|
|
225
|
+
navigation: navigationSchema,
|
|
226
|
+
// Navbar
|
|
227
|
+
navbar: navbarSchema.optional(),
|
|
228
|
+
// Footer
|
|
229
|
+
footer: footerSchema.optional(),
|
|
230
|
+
// API Configuration
|
|
231
|
+
api: apiConfigSchema.optional(),
|
|
232
|
+
openapi: z.union([
|
|
233
|
+
z.string(),
|
|
234
|
+
z.array(z.string())
|
|
235
|
+
]).optional(),
|
|
236
|
+
// SEO
|
|
237
|
+
seo: seoSchema.optional(),
|
|
238
|
+
// Integrations
|
|
239
|
+
integrations: integrationsSchema.optional(),
|
|
240
|
+
// Contextual menu
|
|
241
|
+
contextual: contextualSchema.optional(),
|
|
242
|
+
// Topbar style
|
|
243
|
+
topbar: z.object({
|
|
244
|
+
style: z.enum([
|
|
245
|
+
'default',
|
|
246
|
+
'gradient'
|
|
247
|
+
]).optional()
|
|
248
|
+
}).optional(),
|
|
249
|
+
// Versioning
|
|
250
|
+
versions: z.array(z.string()).optional()
|
|
251
|
+
});
|
|
252
|
+
// ============================================================================
|
|
253
|
+
// Validation Functions
|
|
254
|
+
// ============================================================================
|
|
255
|
+
/**
|
|
256
|
+
* Parse and validate docs configuration
|
|
257
|
+
*/ export function parseDocsConfig(data) {
|
|
258
|
+
const result = docsConfigSchema.safeParse(data);
|
|
259
|
+
if (!result.success) {
|
|
260
|
+
const issues = result.error.issues || [];
|
|
261
|
+
const errors = issues.map((e)=>`${e.path.map(String).join('.')}: ${e.message}`).join('\n');
|
|
262
|
+
throw new Error(`Invalid docs.json configuration:\n${errors}`);
|
|
263
|
+
}
|
|
264
|
+
return result.data;
|
|
265
|
+
}
|
|
266
|
+
/**
|
|
267
|
+
* Safe parse that returns null on failure
|
|
268
|
+
*/ export function safeParseDocsConfig(data) {
|
|
269
|
+
const result = docsConfigSchema.safeParse(data);
|
|
270
|
+
return result.success ? result.data : null;
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Get default configuration
|
|
274
|
+
*/ export function getDefaultDocsConfig() {
|
|
275
|
+
return {
|
|
276
|
+
theme: 'default',
|
|
277
|
+
navigation: {
|
|
278
|
+
groups: []
|
|
279
|
+
}
|
|
280
|
+
};
|
|
281
|
+
}
|