@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,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Code Generation Utility
|
|
3
|
+
* Generates code snippets for API requests in various languages
|
|
4
|
+
* Uses server-side API route to run httpsnippet (avoids browser compatibility issues)
|
|
5
|
+
*/ import { buildHarRequest } from './har';
|
|
6
|
+
import { CodegenDefinitions, findCodegenByName } from './definitions';
|
|
7
|
+
export { CodegenDefinitions, findCodegenByName, getCodegenByCategory } from './definitions';
|
|
8
|
+
/**
|
|
9
|
+
* Generate code snippet for a request (async - calls server API)
|
|
10
|
+
* @param codegenName The codegen target name (e.g., 'shell-curl', 'javascript-fetch')
|
|
11
|
+
* @param request The Brainfish REST request to generate code for
|
|
12
|
+
* @returns Promise<CodegenResult> with generated code or error
|
|
13
|
+
*/ export async function generateCodeAsync(codegenName, request) {
|
|
14
|
+
try {
|
|
15
|
+
const codegenInfo = findCodegenByName(codegenName);
|
|
16
|
+
if (!codegenInfo) {
|
|
17
|
+
return {
|
|
18
|
+
success: false,
|
|
19
|
+
error: `Unknown code generator: ${codegenName}`
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
// Build HAR request from Brainfish request
|
|
23
|
+
const harRequest = buildHarRequest(request);
|
|
24
|
+
// Call server-side API to generate code
|
|
25
|
+
const response = await fetch('/api/codegen', {
|
|
26
|
+
method: 'POST',
|
|
27
|
+
headers: {
|
|
28
|
+
'Content-Type': 'application/json'
|
|
29
|
+
},
|
|
30
|
+
body: JSON.stringify({
|
|
31
|
+
harRequest,
|
|
32
|
+
lang: codegenInfo.lang,
|
|
33
|
+
client: codegenInfo.client
|
|
34
|
+
})
|
|
35
|
+
});
|
|
36
|
+
const result = await response.json();
|
|
37
|
+
if (result.success) {
|
|
38
|
+
return {
|
|
39
|
+
success: true,
|
|
40
|
+
code: result.code
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
success: false,
|
|
45
|
+
error: result.error || 'Code generation failed'
|
|
46
|
+
};
|
|
47
|
+
} catch (error) {
|
|
48
|
+
console.error('Code generation error:', error);
|
|
49
|
+
return {
|
|
50
|
+
success: false,
|
|
51
|
+
error: error instanceof Error ? error.message : 'Unknown error during code generation'
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Synchronous version that returns a placeholder - use generateCodeAsync for actual code
|
|
57
|
+
* This exists for backwards compatibility with synchronous code
|
|
58
|
+
*/ export function generateCode(codegenName, request) {
|
|
59
|
+
// For synchronous calls, we can't make API requests
|
|
60
|
+
// Return a placeholder that indicates async is needed
|
|
61
|
+
const codegenInfo = findCodegenByName(codegenName);
|
|
62
|
+
if (!codegenInfo) {
|
|
63
|
+
return {
|
|
64
|
+
success: false,
|
|
65
|
+
error: `Unknown code generator: ${codegenName}`
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
// Generate a simple placeholder based on the request
|
|
69
|
+
// This will be replaced by the async version in the UI
|
|
70
|
+
const url = request.endpoint;
|
|
71
|
+
const method = request.method;
|
|
72
|
+
// Simple cURL as fallback
|
|
73
|
+
let code = `curl --request ${method} \\\n --url '${url}'`;
|
|
74
|
+
request.headers.filter((h)=>h.active).forEach((h)=>{
|
|
75
|
+
code += ` \\\n --header '${h.key}: ${h.value}'`;
|
|
76
|
+
});
|
|
77
|
+
if (request.body.body && method !== 'GET' && method !== 'HEAD') {
|
|
78
|
+
const bodyStr = typeof request.body.body === 'string' ? request.body.body : JSON.stringify(request.body.body);
|
|
79
|
+
code += ` \\\n --data '${bodyStr}'`;
|
|
80
|
+
}
|
|
81
|
+
return {
|
|
82
|
+
success: true,
|
|
83
|
+
code
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Get the Monaco editor language for a codegen target
|
|
88
|
+
*/ export function getMonacoLanguage(codegenName) {
|
|
89
|
+
const def = findCodegenByName(codegenName);
|
|
90
|
+
if (!def) return 'plaintext';
|
|
91
|
+
const languageMap = {
|
|
92
|
+
shell: 'shell',
|
|
93
|
+
javascript: 'javascript',
|
|
94
|
+
node: 'javascript',
|
|
95
|
+
python: 'python',
|
|
96
|
+
go: 'go',
|
|
97
|
+
java: 'java',
|
|
98
|
+
csharp: 'csharp',
|
|
99
|
+
ruby: 'ruby',
|
|
100
|
+
php: 'php',
|
|
101
|
+
swift: 'swift',
|
|
102
|
+
kotlin: 'kotlin',
|
|
103
|
+
rust: 'rust',
|
|
104
|
+
c: 'c',
|
|
105
|
+
powershell: 'powershell',
|
|
106
|
+
clojure: 'clojure',
|
|
107
|
+
objc: 'objective-c',
|
|
108
|
+
ocaml: 'plaintext',
|
|
109
|
+
r: 'r',
|
|
110
|
+
http: 'plaintext'
|
|
111
|
+
};
|
|
112
|
+
return languageMap[def.lang] || 'plaintext';
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Get all available codegen targets
|
|
116
|
+
*/ export function getAvailableCodegens() {
|
|
117
|
+
return CodegenDefinitions;
|
|
118
|
+
}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Factory Functions for Brainfish API Documentation
|
|
3
|
+
*
|
|
4
|
+
* Creates instances of BrainfishCollection and BrainfishRESTRequest
|
|
5
|
+
* with proper defaults and unique IDs.
|
|
6
|
+
*/ /**
|
|
7
|
+
* Generates a URL-friendly slug from a string
|
|
8
|
+
* Converts to lowercase, replaces spaces and special chars with hyphens
|
|
9
|
+
*/ function slugify(str) {
|
|
10
|
+
return str.toLowerCase().replace(/[{}]/g, '') // Remove braces from path params
|
|
11
|
+
.replace(/[^a-z0-9]+/g, '-') // Replace non-alphanumeric with hyphens
|
|
12
|
+
.replace(/^-+|-+$/g, '') // Remove leading/trailing hyphens
|
|
13
|
+
.replace(/-+/g, '-') // Collapse multiple hyphens
|
|
14
|
+
;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Generates a human-readable, deterministic ID for requests
|
|
18
|
+
* Uses operationId if available, otherwise method + path
|
|
19
|
+
*/ function generateRequestId(method, path, operationId) {
|
|
20
|
+
if (operationId) {
|
|
21
|
+
// Use operationId directly (it's already unique per spec)
|
|
22
|
+
return slugify(operationId);
|
|
23
|
+
}
|
|
24
|
+
// Generate from method + path: "get-users-id" for "GET /users/{id}"
|
|
25
|
+
const pathSlug = slugify(path);
|
|
26
|
+
return `${method.toLowerCase()}-${pathSlug}`;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Generates a unique ID for collections
|
|
30
|
+
* If a seed is provided, generates a deterministic slug-based ID
|
|
31
|
+
*/ function generateCollectionId(name) {
|
|
32
|
+
if (name) {
|
|
33
|
+
return `coll-${slugify(name)}`;
|
|
34
|
+
}
|
|
35
|
+
return `coll_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Creates a BrainfishRESTRequest with defaults
|
|
39
|
+
* Generates human-readable, deterministic IDs based on operationId or method+path
|
|
40
|
+
*/ export function makeBrainfishRESTRequest(request) {
|
|
41
|
+
// Extract path from endpoint (remove base URL)
|
|
42
|
+
const path = request.endpoint ? request.endpoint.replace(/^https?:\/\/[^/]+/, '') || '/' : '/';
|
|
43
|
+
// Generate human-readable ID
|
|
44
|
+
const id = generateRequestId(request.method || 'GET', path, request.operationId);
|
|
45
|
+
return {
|
|
46
|
+
id,
|
|
47
|
+
name: request.name || 'Untitled Request',
|
|
48
|
+
description: request.description ?? null,
|
|
49
|
+
method: request.method || 'GET',
|
|
50
|
+
endpoint: request.endpoint || '',
|
|
51
|
+
params: request.params || [],
|
|
52
|
+
headers: request.headers || [],
|
|
53
|
+
auth: request.auth || {
|
|
54
|
+
authType: 'none',
|
|
55
|
+
authActive: true
|
|
56
|
+
},
|
|
57
|
+
body: request.body || {
|
|
58
|
+
contentType: null,
|
|
59
|
+
body: null
|
|
60
|
+
},
|
|
61
|
+
requestVariables: request.requestVariables || [],
|
|
62
|
+
responses: request.responses || {},
|
|
63
|
+
tags: request.tags || []
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Creates a BrainfishCollection with defaults
|
|
68
|
+
* If name is provided, generates a deterministic ID
|
|
69
|
+
*/ export function makeBrainfishCollection(collection) {
|
|
70
|
+
return {
|
|
71
|
+
id: generateCollectionId(collection.name),
|
|
72
|
+
name: collection.name || 'Untitled Collection',
|
|
73
|
+
description: collection.description ?? null,
|
|
74
|
+
folders: collection.folders || [],
|
|
75
|
+
requests: collection.requests || [],
|
|
76
|
+
variables: collection.variables || [],
|
|
77
|
+
auth: collection.auth || {
|
|
78
|
+
authType: 'inherit',
|
|
79
|
+
authActive: true
|
|
80
|
+
},
|
|
81
|
+
headers: collection.headers || []
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Creates a default BrainfishRESTRequest
|
|
86
|
+
*/ export function getDefaultBrainfishRESTRequest() {
|
|
87
|
+
return makeBrainfishRESTRequest({
|
|
88
|
+
name: 'Untitled Request',
|
|
89
|
+
description: null,
|
|
90
|
+
method: 'GET',
|
|
91
|
+
endpoint: '',
|
|
92
|
+
params: [],
|
|
93
|
+
headers: [],
|
|
94
|
+
auth: {
|
|
95
|
+
authType: 'none',
|
|
96
|
+
authActive: true
|
|
97
|
+
},
|
|
98
|
+
body: {
|
|
99
|
+
contentType: null,
|
|
100
|
+
body: null
|
|
101
|
+
},
|
|
102
|
+
requestVariables: [],
|
|
103
|
+
responses: {},
|
|
104
|
+
tags: []
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Creates a default BrainfishCollection
|
|
109
|
+
*/ export function getDefaultBrainfishCollection() {
|
|
110
|
+
return makeBrainfishCollection({
|
|
111
|
+
name: 'Untitled Collection',
|
|
112
|
+
description: null,
|
|
113
|
+
folders: [],
|
|
114
|
+
requests: [],
|
|
115
|
+
variables: [],
|
|
116
|
+
auth: {
|
|
117
|
+
authType: 'inherit',
|
|
118
|
+
authActive: true
|
|
119
|
+
},
|
|
120
|
+
headers: []
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Creates a BrainfishRESTResponseOriginalRequest
|
|
125
|
+
*/ export function makeBrainfishRESTResponseOriginalRequest(request) {
|
|
126
|
+
return {
|
|
127
|
+
name: request.name,
|
|
128
|
+
method: request.method,
|
|
129
|
+
endpoint: request.endpoint,
|
|
130
|
+
params: request.params,
|
|
131
|
+
headers: request.headers,
|
|
132
|
+
body: request.body,
|
|
133
|
+
auth: request.auth,
|
|
134
|
+
requestVariables: request.requestVariables
|
|
135
|
+
};
|
|
136
|
+
}
|
|
@@ -2,16 +2,11 @@
|
|
|
2
2
|
* Brainfish API Documentation - Main Export
|
|
3
3
|
*
|
|
4
4
|
* This module exports all types, factories, and utilities for the API documentation system.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
// Types
|
|
8
|
-
export * from './types'
|
|
9
|
-
|
|
5
|
+
*/ // Types
|
|
6
|
+
export * from './types';
|
|
10
7
|
// Factories
|
|
11
|
-
export * from './factories'
|
|
12
|
-
|
|
8
|
+
export * from './factories';
|
|
13
9
|
// Utils
|
|
14
|
-
export * from './utils'
|
|
15
|
-
|
|
10
|
+
export * from './utils';
|
|
16
11
|
// Parsers
|
|
17
|
-
export * from './parsers/openapi'
|
|
12
|
+
export * from './parsers/openapi';
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { createContext, useContext, useState, useCallback, useEffect } from 'react';
|
|
4
|
+
const AGENT_ASSIST_STORAGE_KEY = 'devdoc-agent-assist-open';
|
|
5
|
+
const MobileContext = /*#__PURE__*/ createContext(null);
|
|
6
|
+
// Helper to get initial state from localStorage (default to true)
|
|
7
|
+
function getInitialAgentAssistState() {
|
|
8
|
+
if (typeof window === 'undefined') return true;
|
|
9
|
+
const stored = localStorage.getItem(AGENT_ASSIST_STORAGE_KEY);
|
|
10
|
+
// Default to true (open) if not set
|
|
11
|
+
return stored === null ? true : stored === 'true';
|
|
12
|
+
}
|
|
13
|
+
export function MobileProvider({ children }) {
|
|
14
|
+
const [isLeftSidebarOpen, setIsLeftSidebarOpen] = useState(false);
|
|
15
|
+
const [isRightSidebarOpen, setIsRightSidebarOpen] = useState(false);
|
|
16
|
+
const [isMobile, setIsMobile] = useState(false);
|
|
17
|
+
const [isHydrated, setIsHydrated] = useState(false);
|
|
18
|
+
// Initialize from localStorage after hydration (only on desktop)
|
|
19
|
+
useEffect(()=>{
|
|
20
|
+
const isMobileView = window.innerWidth < 1024;
|
|
21
|
+
if (!isMobileView) {
|
|
22
|
+
const savedState = getInitialAgentAssistState();
|
|
23
|
+
setIsRightSidebarOpen(savedState);
|
|
24
|
+
}
|
|
25
|
+
setIsHydrated(true);
|
|
26
|
+
}, []);
|
|
27
|
+
// Detect mobile on mount and window resize
|
|
28
|
+
useEffect(()=>{
|
|
29
|
+
const checkMobile = ()=>{
|
|
30
|
+
setIsMobile(window.innerWidth < 1024); // lg breakpoint
|
|
31
|
+
};
|
|
32
|
+
// Initial check
|
|
33
|
+
checkMobile();
|
|
34
|
+
// Listen for resize
|
|
35
|
+
window.addEventListener('resize', checkMobile);
|
|
36
|
+
return ()=>window.removeEventListener('resize', checkMobile);
|
|
37
|
+
}, []);
|
|
38
|
+
// Close left sidebar when switching to desktop (left sidebar is mobile-only)
|
|
39
|
+
// Note: Right sidebar can stay open on desktop as it's now a toggleable panel
|
|
40
|
+
useEffect(()=>{
|
|
41
|
+
if (!isMobile) {
|
|
42
|
+
setIsLeftSidebarOpen(false);
|
|
43
|
+
}
|
|
44
|
+
}, [
|
|
45
|
+
isMobile
|
|
46
|
+
]);
|
|
47
|
+
const toggleLeftSidebar = useCallback(()=>{
|
|
48
|
+
setIsLeftSidebarOpen((prev)=>!prev);
|
|
49
|
+
// Close right sidebar when opening left
|
|
50
|
+
setIsRightSidebarOpen(false);
|
|
51
|
+
}, []);
|
|
52
|
+
const toggleRightSidebar = useCallback(()=>{
|
|
53
|
+
setIsRightSidebarOpen((prev)=>{
|
|
54
|
+
const newState = !prev;
|
|
55
|
+
// Persist to localStorage (only on desktop)
|
|
56
|
+
if (typeof window !== 'undefined' && window.innerWidth >= 1024) {
|
|
57
|
+
localStorage.setItem(AGENT_ASSIST_STORAGE_KEY, String(newState));
|
|
58
|
+
}
|
|
59
|
+
return newState;
|
|
60
|
+
});
|
|
61
|
+
// Close left sidebar when opening right
|
|
62
|
+
setIsLeftSidebarOpen(false);
|
|
63
|
+
}, []);
|
|
64
|
+
const openLeftSidebar = useCallback(()=>{
|
|
65
|
+
setIsLeftSidebarOpen(true);
|
|
66
|
+
setIsRightSidebarOpen(false);
|
|
67
|
+
}, []);
|
|
68
|
+
const closeLeftSidebar = useCallback(()=>{
|
|
69
|
+
setIsLeftSidebarOpen(false);
|
|
70
|
+
}, []);
|
|
71
|
+
const openRightSidebar = useCallback(()=>{
|
|
72
|
+
setIsRightSidebarOpen(true);
|
|
73
|
+
setIsLeftSidebarOpen(false);
|
|
74
|
+
// Persist to localStorage (only on desktop)
|
|
75
|
+
if (typeof window !== 'undefined' && window.innerWidth >= 1024) {
|
|
76
|
+
localStorage.setItem(AGENT_ASSIST_STORAGE_KEY, 'true');
|
|
77
|
+
}
|
|
78
|
+
}, []);
|
|
79
|
+
const closeRightSidebar = useCallback(()=>{
|
|
80
|
+
setIsRightSidebarOpen(false);
|
|
81
|
+
// Persist to localStorage (only on desktop)
|
|
82
|
+
if (typeof window !== 'undefined' && window.innerWidth >= 1024) {
|
|
83
|
+
localStorage.setItem(AGENT_ASSIST_STORAGE_KEY, 'false');
|
|
84
|
+
}
|
|
85
|
+
}, []);
|
|
86
|
+
const closeAllSidebars = useCallback(()=>{
|
|
87
|
+
setIsLeftSidebarOpen(false);
|
|
88
|
+
setIsRightSidebarOpen(false);
|
|
89
|
+
// Persist to localStorage (only on desktop)
|
|
90
|
+
if (typeof window !== 'undefined' && window.innerWidth >= 1024) {
|
|
91
|
+
localStorage.setItem(AGENT_ASSIST_STORAGE_KEY, 'false');
|
|
92
|
+
}
|
|
93
|
+
}, []);
|
|
94
|
+
return /*#__PURE__*/ _jsx(MobileContext.Provider, {
|
|
95
|
+
value: {
|
|
96
|
+
isLeftSidebarOpen,
|
|
97
|
+
isRightSidebarOpen,
|
|
98
|
+
toggleLeftSidebar,
|
|
99
|
+
toggleRightSidebar,
|
|
100
|
+
openLeftSidebar,
|
|
101
|
+
closeLeftSidebar,
|
|
102
|
+
openRightSidebar,
|
|
103
|
+
closeRightSidebar,
|
|
104
|
+
closeAllSidebars,
|
|
105
|
+
isMobile
|
|
106
|
+
},
|
|
107
|
+
children: children
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
export function useMobile() {
|
|
111
|
+
const context = useContext(MobileContext);
|
|
112
|
+
if (!context) {
|
|
113
|
+
throw new Error('useMobile must be used within a MobileProvider');
|
|
114
|
+
}
|
|
115
|
+
return context;
|
|
116
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { createContext, useContext, useCallback } from 'react';
|
|
4
|
+
const NavigationContext = /*#__PURE__*/ createContext(null);
|
|
5
|
+
/**
|
|
6
|
+
* Helper to find request by operationId (name) or ID in collection
|
|
7
|
+
*/ function findRequestByOperationIdOrId(collection, operationIdOrId) {
|
|
8
|
+
// Normalize the search term (handle both snake_case and the formatted name)
|
|
9
|
+
const normalizedSearch = operationIdOrId.toLowerCase().replace(/[\s-]/g, '_');
|
|
10
|
+
// Check direct requests
|
|
11
|
+
for (const request of collection.requests){
|
|
12
|
+
// Check by ID
|
|
13
|
+
if (request.id === operationIdOrId) return request;
|
|
14
|
+
// Check by name (operationId) - exact match
|
|
15
|
+
if (request.name.toLowerCase().replace(/[\s-]/g, '_') === normalizedSearch) return request;
|
|
16
|
+
// Check by name - partial match (for formatted names like "Post Carts" -> "post_carts")
|
|
17
|
+
const requestNameNormalized = request.name.toLowerCase().replace(/[\s-]/g, '_');
|
|
18
|
+
if (requestNameNormalized === normalizedSearch) return request;
|
|
19
|
+
}
|
|
20
|
+
// Check folders recursively
|
|
21
|
+
for (const folder of collection.folders){
|
|
22
|
+
const request = findRequestByOperationIdOrId(folder, operationIdOrId);
|
|
23
|
+
if (request) return request;
|
|
24
|
+
}
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
export function NavigationProvider({ children, collection, onSelectRequest }) {
|
|
28
|
+
const navigateToEndpoint = useCallback((operationIdOrId)=>{
|
|
29
|
+
if (!collection) {
|
|
30
|
+
console.warn('[Navigation] No collection available');
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const request = findRequestByOperationIdOrId(collection, operationIdOrId);
|
|
34
|
+
if (request) {
|
|
35
|
+
console.log('[Navigation] Navigating to endpoint:', request.name);
|
|
36
|
+
onSelectRequest(request);
|
|
37
|
+
} else {
|
|
38
|
+
console.warn('[Navigation] Endpoint not found:', operationIdOrId);
|
|
39
|
+
}
|
|
40
|
+
}, [
|
|
41
|
+
collection,
|
|
42
|
+
onSelectRequest
|
|
43
|
+
]);
|
|
44
|
+
return /*#__PURE__*/ _jsx(NavigationContext.Provider, {
|
|
45
|
+
value: {
|
|
46
|
+
navigateToEndpoint,
|
|
47
|
+
collection
|
|
48
|
+
},
|
|
49
|
+
children: children
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
export function useNavigation() {
|
|
53
|
+
const context = useContext(NavigationContext);
|
|
54
|
+
if (!context) {
|
|
55
|
+
// Return a no-op function if not in provider (for backwards compatibility)
|
|
56
|
+
return {
|
|
57
|
+
navigateToEndpoint: ()=>{},
|
|
58
|
+
collection: null
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
return context;
|
|
62
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GraphQL Parser Module
|
|
3
|
+
*
|
|
4
|
+
* Main entry point for GraphQL schema parsing and transformation.
|
|
5
|
+
*/ export * from './types';
|
|
6
|
+
export * from './parser';
|
|
7
|
+
export * from './transformer';
|
|
8
|
+
import { parseGraphQLSchema, validateGraphQLSchema } from './parser';
|
|
9
|
+
import { convertGraphQLToBrainfishCollection, convertGraphQLToCollection } from './transformer';
|
|
10
|
+
export const GRAPHQL_INVALID_SCHEMA = 'graphql/invalid_schema';
|
|
11
|
+
/**
|
|
12
|
+
* Import a GraphQL schema from SDL string or file content
|
|
13
|
+
* Returns a BrainfishCollection for integration with existing UI
|
|
14
|
+
*/ export async function importGraphQLSchema(input, options = {}) {
|
|
15
|
+
const { name = 'GraphQL API', endpoint = '/graphql', description } = options;
|
|
16
|
+
// Validate the schema
|
|
17
|
+
const validation = validateGraphQLSchema(input);
|
|
18
|
+
if (!validation.valid) {
|
|
19
|
+
throw new Error(`${GRAPHQL_INVALID_SCHEMA}: ${validation.error}`);
|
|
20
|
+
}
|
|
21
|
+
// Parse the schema
|
|
22
|
+
const schema = parseGraphQLSchema(input);
|
|
23
|
+
// Convert to BrainfishCollection
|
|
24
|
+
return convertGraphQLToBrainfishCollection(schema, name, endpoint, description);
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Import a GraphQL schema and return the full GraphQL collection
|
|
28
|
+
* with schema information preserved
|
|
29
|
+
*/ export async function importGraphQLSchemaFull(input, options = {}) {
|
|
30
|
+
const { name = 'GraphQL API', endpoint = '/graphql', description } = options;
|
|
31
|
+
// Validate the schema
|
|
32
|
+
const validation = validateGraphQLSchema(input);
|
|
33
|
+
if (!validation.valid) {
|
|
34
|
+
throw new Error(`${GRAPHQL_INVALID_SCHEMA}: ${validation.error}`);
|
|
35
|
+
}
|
|
36
|
+
// Parse the schema
|
|
37
|
+
const schema = parseGraphQLSchema(input);
|
|
38
|
+
// Convert to full GraphQL collection
|
|
39
|
+
return convertGraphQLToCollection(schema, name, endpoint, description);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Parse GraphQL schema without converting to collection
|
|
43
|
+
* Useful for schema exploration and type information
|
|
44
|
+
*/ export async function parseGraphQL(input) {
|
|
45
|
+
const validation = validateGraphQLSchema(input);
|
|
46
|
+
if (!validation.valid) {
|
|
47
|
+
throw new Error(`${GRAPHQL_INVALID_SCHEMA}: ${validation.error}`);
|
|
48
|
+
}
|
|
49
|
+
return parseGraphQLSchema(input);
|
|
50
|
+
}
|