@brainfish-ai/devdoc 0.1.42 → 0.1.43
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/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 +675 -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 +175 -0
- package/renderer/app/layout.js +47 -0
- package/renderer/app/llms-full.txt/route.js +257 -0
- package/renderer/app/llms.txt/route.js +219 -0
- package/renderer/app/page.js +12 -0
- package/renderer/app/robots.txt/route.js +66 -0
- package/renderer/app/sitemap.xml/route.js +145 -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 +315 -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 +1930 -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 +4 -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/doc-page.js +264 -0
- package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
- package/renderer/components/docs-viewer/content/index.js +29 -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 +1552 -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 +734 -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 +163 -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 +106 -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/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/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 +154 -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 +79 -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/index.js +5 -0
- package/renderer/lib/docs/config/loader.js +113 -0
- package/renderer/lib/docs/config/schema.js +269 -0
- package/renderer/lib/docs/index.js +8 -0
- package/renderer/lib/docs/mdx/compiler.js +128 -0
- package/renderer/lib/docs/mdx/frontmatter.js +73 -0
- package/renderer/lib/docs/mdx/index.js +8 -0
- package/renderer/lib/docs/navigation/generator.js +269 -0
- package/renderer/lib/docs/navigation/index.js +4 -0
- package/renderer/lib/docs/navigation/types.js +9 -0
- package/renderer/lib/docs-navigation-context.js +40 -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/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,5 @@
|
|
|
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';
|
|
@@ -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,269 @@
|
|
|
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
|
+
// Page can be a string or a nested group
|
|
19
|
+
const pageRefSchema = z.lazy(()=>z.union([
|
|
20
|
+
z.string(),
|
|
21
|
+
z.object({
|
|
22
|
+
group: z.string(),
|
|
23
|
+
pages: z.array(z.union([
|
|
24
|
+
z.string(),
|
|
25
|
+
z.lazy(()=>pageRefSchema)
|
|
26
|
+
]))
|
|
27
|
+
})
|
|
28
|
+
]));
|
|
29
|
+
const groupSchema = z.object({
|
|
30
|
+
group: z.string(),
|
|
31
|
+
pages: z.array(pageRefSchema),
|
|
32
|
+
icon: z.string().optional()
|
|
33
|
+
});
|
|
34
|
+
// OpenAPI version schema
|
|
35
|
+
const openapiVersionSchema = z.object({
|
|
36
|
+
version: z.string(),
|
|
37
|
+
spec: z.string(),
|
|
38
|
+
default: z.boolean().optional()
|
|
39
|
+
});
|
|
40
|
+
// Different tab types
|
|
41
|
+
const docsTabSchema = z.object({
|
|
42
|
+
tab: z.string(),
|
|
43
|
+
type: z.literal('docs').optional(),
|
|
44
|
+
groups: z.array(groupSchema)
|
|
45
|
+
});
|
|
46
|
+
const openapiTabSchema = z.object({
|
|
47
|
+
tab: z.string(),
|
|
48
|
+
type: z.literal('openapi'),
|
|
49
|
+
path: z.string().optional(),
|
|
50
|
+
versions: z.array(openapiVersionSchema).optional(),
|
|
51
|
+
spec: z.string().optional(),
|
|
52
|
+
groups: z.array(groupSchema).optional()
|
|
53
|
+
});
|
|
54
|
+
const graphqlTabSchema = z.object({
|
|
55
|
+
tab: z.string(),
|
|
56
|
+
type: z.literal('graphql'),
|
|
57
|
+
path: z.string().optional(),
|
|
58
|
+
schema: z.string(),
|
|
59
|
+
endpoint: z.string().optional(),
|
|
60
|
+
groups: z.array(groupSchema).optional()
|
|
61
|
+
});
|
|
62
|
+
const changelogTabSchema = z.object({
|
|
63
|
+
tab: z.string(),
|
|
64
|
+
type: z.literal('changelog'),
|
|
65
|
+
path: z.string().optional()
|
|
66
|
+
});
|
|
67
|
+
const tabSchema = z.union([
|
|
68
|
+
docsTabSchema,
|
|
69
|
+
openapiTabSchema,
|
|
70
|
+
graphqlTabSchema,
|
|
71
|
+
changelogTabSchema
|
|
72
|
+
]);
|
|
73
|
+
const navigationSchema = z.object({
|
|
74
|
+
tabs: z.array(tabSchema).optional(),
|
|
75
|
+
groups: z.array(groupSchema).optional(),
|
|
76
|
+
global: z.object({
|
|
77
|
+
anchors: z.array(anchorSchema).optional()
|
|
78
|
+
}).optional()
|
|
79
|
+
});
|
|
80
|
+
// ============================================================================
|
|
81
|
+
// Theme & Branding Schemas
|
|
82
|
+
// ============================================================================
|
|
83
|
+
const colorSchema = z.object({
|
|
84
|
+
primary: z.string(),
|
|
85
|
+
light: z.string().optional(),
|
|
86
|
+
dark: z.string().optional(),
|
|
87
|
+
background: z.object({
|
|
88
|
+
light: z.string().optional(),
|
|
89
|
+
dark: z.string().optional()
|
|
90
|
+
}).optional()
|
|
91
|
+
});
|
|
92
|
+
const logoSchema = z.object({
|
|
93
|
+
light: z.string(),
|
|
94
|
+
dark: z.string(),
|
|
95
|
+
href: z.string().optional()
|
|
96
|
+
});
|
|
97
|
+
const faviconSchema = z.string();
|
|
98
|
+
// ============================================================================
|
|
99
|
+
// Navbar Schema
|
|
100
|
+
// ============================================================================
|
|
101
|
+
const navbarPrimarySchema = z.object({
|
|
102
|
+
type: z.enum([
|
|
103
|
+
'button',
|
|
104
|
+
'github',
|
|
105
|
+
'link'
|
|
106
|
+
]),
|
|
107
|
+
label: z.string().optional(),
|
|
108
|
+
href: z.string()
|
|
109
|
+
});
|
|
110
|
+
const navbarSchema = z.object({
|
|
111
|
+
links: z.array(navLinkSchema).optional(),
|
|
112
|
+
primary: navbarPrimarySchema.optional()
|
|
113
|
+
});
|
|
114
|
+
// ============================================================================
|
|
115
|
+
// Footer Schema
|
|
116
|
+
// ============================================================================
|
|
117
|
+
const footerLinkSchema = z.object({
|
|
118
|
+
label: z.string(),
|
|
119
|
+
href: z.string()
|
|
120
|
+
});
|
|
121
|
+
const footerGroupSchema = z.object({
|
|
122
|
+
title: z.string(),
|
|
123
|
+
links: z.array(footerLinkSchema)
|
|
124
|
+
});
|
|
125
|
+
const footerSchema = z.object({
|
|
126
|
+
socials: z.record(z.string(), z.string()).optional(),
|
|
127
|
+
links: z.array(footerGroupSchema).optional()
|
|
128
|
+
});
|
|
129
|
+
// ============================================================================
|
|
130
|
+
// API Configuration Schema
|
|
131
|
+
// ============================================================================
|
|
132
|
+
const apiAuthSchema = z.object({
|
|
133
|
+
method: z.enum([
|
|
134
|
+
'bearer',
|
|
135
|
+
'basic',
|
|
136
|
+
'api-key',
|
|
137
|
+
'none'
|
|
138
|
+
]),
|
|
139
|
+
name: z.string().optional()
|
|
140
|
+
});
|
|
141
|
+
const apiPlaygroundSchema = z.object({
|
|
142
|
+
mode: z.enum([
|
|
143
|
+
'show',
|
|
144
|
+
'simple',
|
|
145
|
+
'hide'
|
|
146
|
+
]).optional()
|
|
147
|
+
});
|
|
148
|
+
const apiConfigSchema = z.object({
|
|
149
|
+
baseUrl: z.string().optional(),
|
|
150
|
+
auth: apiAuthSchema.optional(),
|
|
151
|
+
playground: apiPlaygroundSchema.optional()
|
|
152
|
+
});
|
|
153
|
+
// ============================================================================
|
|
154
|
+
// SEO Schema
|
|
155
|
+
// ============================================================================
|
|
156
|
+
const seoSchema = z.object({
|
|
157
|
+
indexHiddenPages: z.boolean().optional(),
|
|
158
|
+
titleTemplate: z.string().optional()
|
|
159
|
+
});
|
|
160
|
+
// ============================================================================
|
|
161
|
+
// Integrations Schema
|
|
162
|
+
// ============================================================================
|
|
163
|
+
const analyticsSchema = z.object({
|
|
164
|
+
posthog: z.object({
|
|
165
|
+
apiKey: z.string()
|
|
166
|
+
}).optional(),
|
|
167
|
+
googleAnalytics: z.object({
|
|
168
|
+
measurementId: z.string()
|
|
169
|
+
}).optional(),
|
|
170
|
+
plausible: z.object({
|
|
171
|
+
domain: z.string()
|
|
172
|
+
}).optional()
|
|
173
|
+
});
|
|
174
|
+
const integrationsSchema = z.object({
|
|
175
|
+
analytics: analyticsSchema.optional()
|
|
176
|
+
});
|
|
177
|
+
// ============================================================================
|
|
178
|
+
// Contextual Menu Schema
|
|
179
|
+
// ============================================================================
|
|
180
|
+
const contextualOptionsEnum = z.enum([
|
|
181
|
+
'copy',
|
|
182
|
+
'view',
|
|
183
|
+
'chatgpt',
|
|
184
|
+
'claude',
|
|
185
|
+
'perplexity',
|
|
186
|
+
'mcp',
|
|
187
|
+
'cursor',
|
|
188
|
+
'vscode'
|
|
189
|
+
]);
|
|
190
|
+
const contextualSchema = z.object({
|
|
191
|
+
options: z.array(contextualOptionsEnum).optional()
|
|
192
|
+
});
|
|
193
|
+
// ============================================================================
|
|
194
|
+
// Main Configuration Schema
|
|
195
|
+
// ============================================================================
|
|
196
|
+
export const docsConfigSchema = z.object({
|
|
197
|
+
// Schema reference (optional)
|
|
198
|
+
$schema: z.string().optional(),
|
|
199
|
+
// Core identity
|
|
200
|
+
name: z.string(),
|
|
201
|
+
// Theme
|
|
202
|
+
theme: z.enum([
|
|
203
|
+
'default',
|
|
204
|
+
'mint',
|
|
205
|
+
'quill',
|
|
206
|
+
'venus'
|
|
207
|
+
]).optional(),
|
|
208
|
+
colors: colorSchema.optional(),
|
|
209
|
+
// Branding
|
|
210
|
+
favicon: faviconSchema.optional(),
|
|
211
|
+
logo: logoSchema.optional(),
|
|
212
|
+
// Navigation
|
|
213
|
+
navigation: navigationSchema,
|
|
214
|
+
// Navbar
|
|
215
|
+
navbar: navbarSchema.optional(),
|
|
216
|
+
// Footer
|
|
217
|
+
footer: footerSchema.optional(),
|
|
218
|
+
// API Configuration
|
|
219
|
+
api: apiConfigSchema.optional(),
|
|
220
|
+
openapi: z.union([
|
|
221
|
+
z.string(),
|
|
222
|
+
z.array(z.string())
|
|
223
|
+
]).optional(),
|
|
224
|
+
// SEO
|
|
225
|
+
seo: seoSchema.optional(),
|
|
226
|
+
// Integrations
|
|
227
|
+
integrations: integrationsSchema.optional(),
|
|
228
|
+
// Contextual menu
|
|
229
|
+
contextual: contextualSchema.optional(),
|
|
230
|
+
// Topbar style
|
|
231
|
+
topbar: z.object({
|
|
232
|
+
style: z.enum([
|
|
233
|
+
'default',
|
|
234
|
+
'gradient'
|
|
235
|
+
]).optional()
|
|
236
|
+
}).optional(),
|
|
237
|
+
// Versioning
|
|
238
|
+
versions: z.array(z.string()).optional()
|
|
239
|
+
});
|
|
240
|
+
// ============================================================================
|
|
241
|
+
// Validation Functions
|
|
242
|
+
// ============================================================================
|
|
243
|
+
/**
|
|
244
|
+
* Parse and validate docs configuration
|
|
245
|
+
*/ export function parseDocsConfig(data) {
|
|
246
|
+
const result = docsConfigSchema.safeParse(data);
|
|
247
|
+
if (!result.success) {
|
|
248
|
+
const issues = result.error.issues || [];
|
|
249
|
+
const errors = issues.map((e)=>`${e.path.map(String).join('.')}: ${e.message}`).join('\n');
|
|
250
|
+
throw new Error(`Invalid docs.json configuration:\n${errors}`);
|
|
251
|
+
}
|
|
252
|
+
return result.data;
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Safe parse that returns null on failure
|
|
256
|
+
*/ export function safeParseDocsConfig(data) {
|
|
257
|
+
const result = docsConfigSchema.safeParse(data);
|
|
258
|
+
return result.success ? result.data : null;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Get default configuration
|
|
262
|
+
*/ export function getDefaultDocsConfig() {
|
|
263
|
+
return {
|
|
264
|
+
theme: 'default',
|
|
265
|
+
navigation: {
|
|
266
|
+
groups: []
|
|
267
|
+
}
|
|
268
|
+
};
|
|
269
|
+
}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { compileMDX } from 'next-mdx-remote/rsc';
|
|
2
|
+
import matter from 'gray-matter';
|
|
3
|
+
import rehypeSlug from 'rehype-slug';
|
|
4
|
+
import rehypeAutolinkHeadings from 'rehype-autolink-headings';
|
|
5
|
+
import remarkGfm from 'remark-gfm';
|
|
6
|
+
import { parseFrontmatter, safeParseFrontmatter } from './frontmatter';
|
|
7
|
+
/**
|
|
8
|
+
* Extract frontmatter from raw MDX content
|
|
9
|
+
*/ export function extractFrontmatter(source) {
|
|
10
|
+
const { content, data } = matter(source);
|
|
11
|
+
return {
|
|
12
|
+
content,
|
|
13
|
+
data
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Extract headings from MDX content for table of contents
|
|
18
|
+
*/ export function extractHeadings(content) {
|
|
19
|
+
const headingRegex = /^(#{1,6})\s+(.+)$/gm;
|
|
20
|
+
const headings = [];
|
|
21
|
+
let match;
|
|
22
|
+
while((match = headingRegex.exec(content)) !== null){
|
|
23
|
+
const level = match[1].length;
|
|
24
|
+
const title = match[2].trim();
|
|
25
|
+
// Generate slug from title (same logic as rehype-slug)
|
|
26
|
+
const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-').replace(/^-+|-+$/g, '');
|
|
27
|
+
headings.push({
|
|
28
|
+
id,
|
|
29
|
+
title,
|
|
30
|
+
level
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
return headings;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Compile MDX content with components and plugins
|
|
37
|
+
*/ export async function compileMDXContent(source, options = {}) {
|
|
38
|
+
const { components = {}, scope = {}, validateFrontmatter = true } = options;
|
|
39
|
+
// Extract frontmatter first
|
|
40
|
+
const { content: mdxContent, data: rawFrontmatter } = extractFrontmatter(source);
|
|
41
|
+
// Validate frontmatter if requested
|
|
42
|
+
const frontmatter = validateFrontmatter ? parseFrontmatter(rawFrontmatter) : rawFrontmatter;
|
|
43
|
+
// Extract headings for ToC
|
|
44
|
+
const headings = extractHeadings(mdxContent);
|
|
45
|
+
// Compile MDX
|
|
46
|
+
const { content } = await compileMDX({
|
|
47
|
+
source: mdxContent,
|
|
48
|
+
components,
|
|
49
|
+
options: {
|
|
50
|
+
parseFrontmatter: false,
|
|
51
|
+
mdxOptions: {
|
|
52
|
+
remarkPlugins: [
|
|
53
|
+
remarkGfm
|
|
54
|
+
],
|
|
55
|
+
rehypePlugins: [
|
|
56
|
+
rehypeSlug,
|
|
57
|
+
[
|
|
58
|
+
rehypeAutolinkHeadings,
|
|
59
|
+
{
|
|
60
|
+
behavior: 'wrap'
|
|
61
|
+
}
|
|
62
|
+
]
|
|
63
|
+
]
|
|
64
|
+
},
|
|
65
|
+
scope: {
|
|
66
|
+
...scope,
|
|
67
|
+
frontmatter
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
return {
|
|
72
|
+
content,
|
|
73
|
+
frontmatter,
|
|
74
|
+
headings
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Quick compile for previews (less validation)
|
|
79
|
+
*/ export async function quickCompileMDX(source, components = {}) {
|
|
80
|
+
const { content: mdxContent, data: frontmatter } = extractFrontmatter(source);
|
|
81
|
+
const { content } = await compileMDX({
|
|
82
|
+
source: mdxContent,
|
|
83
|
+
components,
|
|
84
|
+
options: {
|
|
85
|
+
parseFrontmatter: false,
|
|
86
|
+
mdxOptions: {
|
|
87
|
+
remarkPlugins: [
|
|
88
|
+
remarkGfm
|
|
89
|
+
],
|
|
90
|
+
rehypePlugins: [
|
|
91
|
+
rehypeSlug
|
|
92
|
+
]
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
return {
|
|
97
|
+
content,
|
|
98
|
+
frontmatter
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Validate MDX content without compiling (for linting)
|
|
103
|
+
*/ export function validateMDXContent(source) {
|
|
104
|
+
const errors = [];
|
|
105
|
+
const warnings = [];
|
|
106
|
+
try {
|
|
107
|
+
const { data } = extractFrontmatter(source);
|
|
108
|
+
// Check frontmatter
|
|
109
|
+
const frontmatterResult = safeParseFrontmatter(data);
|
|
110
|
+
if (!frontmatterResult) {
|
|
111
|
+
errors.push('Invalid frontmatter format');
|
|
112
|
+
}
|
|
113
|
+
// Check for common issues
|
|
114
|
+
if (!data.title) {
|
|
115
|
+
warnings.push('Missing title in frontmatter');
|
|
116
|
+
}
|
|
117
|
+
if (!data.description) {
|
|
118
|
+
warnings.push('Missing description in frontmatter (recommended for SEO)');
|
|
119
|
+
}
|
|
120
|
+
} catch (error) {
|
|
121
|
+
errors.push(`Parse error: ${error instanceof Error ? error.message : 'Unknown error'}`);
|
|
122
|
+
}
|
|
123
|
+
return {
|
|
124
|
+
valid: errors.length === 0,
|
|
125
|
+
errors,
|
|
126
|
+
warnings
|
|
127
|
+
};
|
|
128
|
+
}
|