@brainfish-ai/devdoc 0.1.41 → 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.
Files changed (400) hide show
  1. package/ai-agents/.claude/skills/bootstrap-docs/SKILL.md +710 -79
  2. package/ai-agents/.claude/skills/check-docs/SKILL.md +83 -8
  3. package/ai-agents/.claude/skills/create-doc/SKILL.md +267 -55
  4. package/ai-agents/.claude/skills/update-doc/SKILL.md +162 -63
  5. package/ai-agents/.cursor/rules/devdoc-bootstrap.mdc +145 -15
  6. package/ai-agents/.cursor/rules/devdoc-create.mdc +108 -57
  7. package/ai-agents/.cursor/rules/devdoc-update.mdc +93 -70
  8. package/ai-agents/.cursor/rules/devdoc.mdc +21 -0
  9. package/ai-agents/schemas/docs.schema.json +332 -0
  10. package/ai-agents/schemas/theme.schema.json +243 -0
  11. package/dist/cli/commands/create.js +4 -9
  12. package/dist/cli/commands/deploy.js +50 -25
  13. package/dist/cli/commands/dev.js +19 -10
  14. package/package.json +3 -2
  15. package/renderer/app/api/assets/[...path]/route.js +108 -0
  16. package/renderer/app/api/assets/route.js +114 -0
  17. package/renderer/app/api/assets/upload/route.js +163 -0
  18. package/renderer/app/api/auth-schemes/route.js +58 -0
  19. package/renderer/app/api/chat/route.js +759 -0
  20. package/renderer/app/api/codegen/route.js +52 -0
  21. package/renderer/app/api/collections/route.js +675 -0
  22. package/renderer/app/api/debug/route.js +47 -0
  23. package/renderer/app/api/deploy/route.js +199 -0
  24. package/renderer/app/api/device/route.js +36 -0
  25. package/renderer/app/api/docs/route.js +205 -0
  26. package/renderer/app/api/domains/add/route.js +121 -0
  27. package/renderer/app/api/domains/lookup/route.js +43 -0
  28. package/renderer/app/api/domains/remove/route.js +89 -0
  29. package/renderer/app/api/domains/status/route.js +140 -0
  30. package/renderer/app/api/domains/verify/route.js +168 -0
  31. package/renderer/app/api/keys/regenerate/route.js +71 -0
  32. package/renderer/app/api/local-assets/[...path]/route.js +108 -0
  33. package/renderer/app/api/openapi-spec/route.js +73 -0
  34. package/renderer/app/api/projects/[slug]/route.js +129 -0
  35. package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
  36. package/renderer/app/api/projects/register/route.js +176 -0
  37. package/renderer/app/api/proxy/route.js +139 -0
  38. package/renderer/app/api/proxy-stream/route.js +156 -0
  39. package/renderer/app/api/redirects/route.js +35 -0
  40. package/renderer/app/api/schema/route.js +85 -0
  41. package/renderer/app/api/subdomains/check/route.js +158 -0
  42. package/renderer/app/api/suggestions/route.js +175 -0
  43. package/renderer/app/layout.js +47 -0
  44. package/renderer/app/llms-full.txt/route.js +257 -0
  45. package/renderer/app/llms.txt/route.js +219 -0
  46. package/renderer/app/page.js +12 -0
  47. package/renderer/app/robots.txt/route.js +66 -0
  48. package/renderer/app/sitemap.xml/route.js +145 -0
  49. package/renderer/components/docs/index.js +8 -0
  50. package/renderer/components/docs/mdx/accordion.js +113 -0
  51. package/renderer/components/docs/mdx/badge.js +72 -0
  52. package/renderer/components/docs/mdx/callouts.js +137 -0
  53. package/renderer/components/docs/mdx/cards.js +175 -0
  54. package/renderer/components/docs/mdx/changelog.js +100 -0
  55. package/renderer/components/docs/mdx/code-block.js +147 -0
  56. package/renderer/components/docs/mdx/code-group.js +287 -0
  57. package/renderer/components/docs/mdx/file-embeds.js +82 -0
  58. package/renderer/components/docs/mdx/frame.js +59 -0
  59. package/renderer/components/docs/mdx/highlight.js +90 -0
  60. package/renderer/components/docs/mdx/iframe.js +69 -0
  61. package/renderer/components/docs/mdx/image.js +135 -0
  62. package/renderer/components/docs/mdx/index.js +134 -0
  63. package/renderer/components/docs/mdx/landing.js +315 -0
  64. package/renderer/components/docs/mdx/mermaid.js +212 -0
  65. package/renderer/components/docs/mdx/param-field.js +112 -0
  66. package/renderer/components/docs/mdx/steps.js +74 -0
  67. package/renderer/components/docs/mdx/tabs.js +50 -0
  68. package/renderer/components/docs/mdx-renderer.js +77 -0
  69. package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
  70. package/renderer/components/docs/navigation/index.js +6 -0
  71. package/renderer/components/docs/navigation/page-nav.js +57 -0
  72. package/renderer/components/docs/navigation/sidebar.js +375 -0
  73. package/renderer/components/docs/navigation/toc.js +89 -0
  74. package/renderer/components/docs/notice.js +77 -0
  75. package/renderer/components/docs-header.js +202 -0
  76. package/renderer/components/docs-viewer/agent/agent-chat.js +1930 -0
  77. package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
  78. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
  79. package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
  80. package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
  81. package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
  82. package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
  83. package/renderer/components/docs-viewer/agent/index.js +4 -0
  84. package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
  85. package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
  86. package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
  87. package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
  88. package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
  89. package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
  90. package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
  91. package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
  92. package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
  93. package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
  94. package/renderer/components/docs-viewer/content/doc-page.js +264 -0
  95. package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
  96. package/renderer/components/docs-viewer/content/index.js +29 -0
  97. package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
  98. package/renderer/components/docs-viewer/content/request-details.js +528 -0
  99. package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
  100. package/renderer/components/docs-viewer/content/sections/body.js +80 -0
  101. package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
  102. package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
  103. package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
  104. package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
  105. package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
  106. package/renderer/components/docs-viewer/index.js +1552 -0
  107. package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
  108. package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
  109. package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
  110. package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
  111. package/renderer/components/docs-viewer/playground/graphql-playground.js +734 -0
  112. package/renderer/components/docs-viewer/playground/index.js +682 -0
  113. package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
  114. package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
  115. package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
  116. package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
  117. package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
  118. package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
  119. package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
  120. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
  121. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
  122. package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
  123. package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
  124. package/renderer/components/docs-viewer/search/index.js +2 -0
  125. package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
  126. package/renderer/components/docs-viewer/search/use-search.js +89 -0
  127. package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
  128. package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
  129. package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
  130. package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
  131. package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
  132. package/renderer/components/docs-viewer/sidebar/index.js +196 -0
  133. package/renderer/components/docs-viewer/sidebar/right-sidebar.js +163 -0
  134. package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
  135. package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
  136. package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
  137. package/renderer/components/theme-provider.js +10 -0
  138. package/renderer/components/theme-toggle.js +106 -0
  139. package/renderer/components/ui/badge.js +29 -0
  140. package/renderer/components/ui/button.js +40 -0
  141. package/renderer/components/ui/dialog.js +50 -0
  142. package/renderer/components/ui/dropdown-menu.js +143 -0
  143. package/renderer/components/ui/input.js +12 -0
  144. package/renderer/components/ui/label.js +13 -0
  145. package/renderer/components/ui/navigation-menu.js +83 -0
  146. package/renderer/components/ui/select.js +116 -0
  147. package/renderer/components/ui/spinner.js +92 -0
  148. package/renderer/components/ui/tabs.js +34 -0
  149. package/renderer/components/ui/tooltip.js +43 -0
  150. package/renderer/hooks/use-code-copy.js +76 -0
  151. package/renderer/hooks/use-openapi-title.js +33 -0
  152. package/renderer/lib/api-docs/agent/index.js +4 -0
  153. package/renderer/lib/api-docs/agent/indexer.js +254 -0
  154. package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
  155. package/renderer/lib/api-docs/agent/types.js +5 -0
  156. package/renderer/lib/api-docs/auth/auth-context.js +157 -0
  157. package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
  158. package/renderer/lib/api-docs/auth/crypto.js +64 -0
  159. package/renderer/lib/api-docs/auth/index.js +3 -0
  160. package/renderer/lib/api-docs/code-editor/db.js +145 -0
  161. package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
  162. package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
  163. package/renderer/lib/api-docs/code-editor/mode-context.js +154 -0
  164. package/renderer/lib/api-docs/code-editor/types.js +53 -0
  165. package/renderer/lib/api-docs/codegen/definitions.js +258 -0
  166. package/renderer/lib/api-docs/codegen/har.js +171 -0
  167. package/renderer/lib/api-docs/codegen/index.js +118 -0
  168. package/renderer/lib/api-docs/factories.js +136 -0
  169. package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
  170. package/renderer/lib/api-docs/mobile-context.js +79 -0
  171. package/renderer/lib/api-docs/navigation-context.js +62 -0
  172. package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
  173. package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
  174. package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
  175. package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
  176. package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
  177. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
  178. package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
  179. package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
  180. package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
  181. package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
  182. package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
  183. package/renderer/lib/api-docs/playground/context.js +65 -0
  184. package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
  185. package/renderer/lib/api-docs/playground/request-builder.js +163 -0
  186. package/renderer/lib/api-docs/playground/request-runner.js +224 -0
  187. package/renderer/lib/api-docs/playground/types.js +5 -0
  188. package/renderer/lib/api-docs/types.js +23 -0
  189. package/renderer/lib/api-docs/utils.js +212 -0
  190. package/renderer/lib/cache.js +157 -0
  191. package/renderer/lib/docs/config/domain-schema.js +161 -0
  192. package/renderer/lib/docs/config/index.js +5 -0
  193. package/renderer/lib/docs/config/loader.js +113 -0
  194. package/renderer/lib/docs/config/schema.js +269 -0
  195. package/renderer/lib/docs/index.js +8 -0
  196. package/renderer/lib/docs/mdx/compiler.js +128 -0
  197. package/renderer/lib/docs/mdx/frontmatter.js +73 -0
  198. package/renderer/lib/docs/mdx/index.js +8 -0
  199. package/renderer/lib/docs/navigation/generator.js +269 -0
  200. package/renderer/lib/docs/navigation/index.js +4 -0
  201. package/renderer/lib/docs/navigation/types.js +9 -0
  202. package/renderer/lib/docs-navigation-context.js +40 -0
  203. package/renderer/lib/multi-tenant/context.js +80 -0
  204. package/renderer/lib/storage/blob.js +767 -0
  205. package/renderer/lib/utils/icons.js +30 -0
  206. package/renderer/lib/utils.js +5 -0
  207. package/renderer/next.config.js +62 -0
  208. package/renderer/tsconfig.json +23 -5
  209. package/renderer/app/api/assets/[...path]/route.ts +0 -123
  210. package/renderer/app/api/assets/route.ts +0 -124
  211. package/renderer/app/api/assets/upload/route.ts +0 -177
  212. package/renderer/app/api/auth-schemes/route.ts +0 -77
  213. package/renderer/app/api/chat/route.ts +0 -858
  214. package/renderer/app/api/codegen/route.ts +0 -72
  215. package/renderer/app/api/collections/route.ts +0 -1002
  216. package/renderer/app/api/debug/route.ts +0 -53
  217. package/renderer/app/api/deploy/route.ts +0 -234
  218. package/renderer/app/api/device/route.ts +0 -42
  219. package/renderer/app/api/docs/route.ts +0 -201
  220. package/renderer/app/api/domains/add/route.ts +0 -132
  221. package/renderer/app/api/domains/lookup/route.ts +0 -43
  222. package/renderer/app/api/domains/remove/route.ts +0 -100
  223. package/renderer/app/api/domains/status/route.ts +0 -158
  224. package/renderer/app/api/domains/verify/route.ts +0 -181
  225. package/renderer/app/api/keys/regenerate/route.ts +0 -80
  226. package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
  227. package/renderer/app/api/openapi-spec/route.ts +0 -151
  228. package/renderer/app/api/projects/[slug]/route.ts +0 -153
  229. package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
  230. package/renderer/app/api/projects/register/route.ts +0 -152
  231. package/renderer/app/api/proxy/route.ts +0 -149
  232. package/renderer/app/api/proxy-stream/route.ts +0 -168
  233. package/renderer/app/api/redirects/route.ts +0 -47
  234. package/renderer/app/api/schema/route.ts +0 -73
  235. package/renderer/app/api/subdomains/check/route.ts +0 -172
  236. package/renderer/app/api/suggestions/route.ts +0 -144
  237. package/renderer/app/layout.tsx +0 -54
  238. package/renderer/app/llms-full.txt/route.ts +0 -346
  239. package/renderer/app/llms.txt/route.ts +0 -279
  240. package/renderer/app/page.tsx +0 -14
  241. package/renderer/app/robots.txt/route.ts +0 -84
  242. package/renderer/app/sitemap.xml/route.ts +0 -199
  243. package/renderer/components/docs/index.ts +0 -12
  244. package/renderer/components/docs/mdx/accordion.tsx +0 -169
  245. package/renderer/components/docs/mdx/badge.tsx +0 -132
  246. package/renderer/components/docs/mdx/callouts.tsx +0 -154
  247. package/renderer/components/docs/mdx/cards.tsx +0 -241
  248. package/renderer/components/docs/mdx/changelog.tsx +0 -120
  249. package/renderer/components/docs/mdx/code-block.tsx +0 -186
  250. package/renderer/components/docs/mdx/code-group.tsx +0 -421
  251. package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
  252. package/renderer/components/docs/mdx/frame.tsx +0 -112
  253. package/renderer/components/docs/mdx/highlight.tsx +0 -151
  254. package/renderer/components/docs/mdx/iframe.tsx +0 -134
  255. package/renderer/components/docs/mdx/image.tsx +0 -235
  256. package/renderer/components/docs/mdx/index.ts +0 -237
  257. package/renderer/components/docs/mdx/landing.tsx +0 -684
  258. package/renderer/components/docs/mdx/mermaid.tsx +0 -240
  259. package/renderer/components/docs/mdx/param-field.tsx +0 -200
  260. package/renderer/components/docs/mdx/steps.tsx +0 -113
  261. package/renderer/components/docs/mdx/tabs.tsx +0 -86
  262. package/renderer/components/docs/mdx-renderer.tsx +0 -100
  263. package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
  264. package/renderer/components/docs/navigation/index.ts +0 -8
  265. package/renderer/components/docs/navigation/page-nav.tsx +0 -64
  266. package/renderer/components/docs/navigation/sidebar.tsx +0 -515
  267. package/renderer/components/docs/navigation/toc.tsx +0 -113
  268. package/renderer/components/docs/notice.tsx +0 -105
  269. package/renderer/components/docs-header.tsx +0 -278
  270. package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
  271. package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
  272. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
  273. package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
  274. package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
  275. package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
  276. package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
  277. package/renderer/components/docs-viewer/agent/index.tsx +0 -6
  278. package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
  279. package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
  280. package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
  281. package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
  282. package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
  283. package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
  284. package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
  285. package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
  286. package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
  287. package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
  288. package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
  289. package/renderer/components/docs-viewer/content/index.tsx +0 -29
  290. package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
  291. package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
  292. package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
  293. package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
  294. package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
  295. package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
  296. package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
  297. package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
  298. package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
  299. package/renderer/components/docs-viewer/index.tsx +0 -1662
  300. package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
  301. package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
  302. package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
  303. package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
  304. package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
  305. package/renderer/components/docs-viewer/playground/index.tsx +0 -671
  306. package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
  307. package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
  308. package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
  309. package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
  310. package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
  311. package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
  312. package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
  313. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
  314. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
  315. package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
  316. package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
  317. package/renderer/components/docs-viewer/search/index.ts +0 -2
  318. package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
  319. package/renderer/components/docs-viewer/search/use-search.ts +0 -117
  320. package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
  321. package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
  322. package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
  323. package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
  324. package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
  325. package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
  326. package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
  327. package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
  328. package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
  329. package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
  330. package/renderer/components/theme-provider.tsx +0 -11
  331. package/renderer/components/theme-toggle.tsx +0 -76
  332. package/renderer/components/ui/badge.tsx +0 -46
  333. package/renderer/components/ui/button.tsx +0 -59
  334. package/renderer/components/ui/dialog.tsx +0 -118
  335. package/renderer/components/ui/dropdown-menu.tsx +0 -257
  336. package/renderer/components/ui/input.tsx +0 -21
  337. package/renderer/components/ui/label.tsx +0 -24
  338. package/renderer/components/ui/navigation-menu.tsx +0 -168
  339. package/renderer/components/ui/select.tsx +0 -190
  340. package/renderer/components/ui/spinner.tsx +0 -114
  341. package/renderer/components/ui/tabs.tsx +0 -66
  342. package/renderer/components/ui/tooltip.tsx +0 -61
  343. package/renderer/hooks/use-code-copy.ts +0 -88
  344. package/renderer/hooks/use-openapi-title.ts +0 -44
  345. package/renderer/lib/api-docs/agent/index.ts +0 -6
  346. package/renderer/lib/api-docs/agent/indexer.ts +0 -323
  347. package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
  348. package/renderer/lib/api-docs/agent/types.ts +0 -116
  349. package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
  350. package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
  351. package/renderer/lib/api-docs/auth/crypto.ts +0 -89
  352. package/renderer/lib/api-docs/auth/index.ts +0 -4
  353. package/renderer/lib/api-docs/code-editor/db.ts +0 -164
  354. package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
  355. package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
  356. package/renderer/lib/api-docs/code-editor/types.ts +0 -105
  357. package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
  358. package/renderer/lib/api-docs/codegen/har.ts +0 -251
  359. package/renderer/lib/api-docs/codegen/index.ts +0 -159
  360. package/renderer/lib/api-docs/factories.ts +0 -170
  361. package/renderer/lib/api-docs/mobile-context.tsx +0 -112
  362. package/renderer/lib/api-docs/navigation-context.tsx +0 -88
  363. package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
  364. package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
  365. package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
  366. package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
  367. package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
  368. package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
  369. package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
  370. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
  371. package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
  372. package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
  373. package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
  374. package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
  375. package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
  376. package/renderer/lib/api-docs/playground/context.tsx +0 -107
  377. package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
  378. package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
  379. package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
  380. package/renderer/lib/api-docs/playground/types.ts +0 -35
  381. package/renderer/lib/api-docs/types.ts +0 -269
  382. package/renderer/lib/api-docs/utils.ts +0 -311
  383. package/renderer/lib/cache.ts +0 -193
  384. package/renderer/lib/docs/config/domain-schema.ts +0 -260
  385. package/renderer/lib/docs/config/index.ts +0 -43
  386. package/renderer/lib/docs/config/loader.ts +0 -142
  387. package/renderer/lib/docs/config/schema.ts +0 -308
  388. package/renderer/lib/docs/index.ts +0 -12
  389. package/renderer/lib/docs/mdx/compiler.ts +0 -176
  390. package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
  391. package/renderer/lib/docs/mdx/index.ts +0 -26
  392. package/renderer/lib/docs/navigation/generator.ts +0 -348
  393. package/renderer/lib/docs/navigation/index.ts +0 -12
  394. package/renderer/lib/docs/navigation/types.ts +0 -123
  395. package/renderer/lib/docs-navigation-context.tsx +0 -80
  396. package/renderer/lib/multi-tenant/context.ts +0 -105
  397. package/renderer/lib/storage/blob.ts +0 -1083
  398. package/renderer/lib/utils/icons.ts +0 -48
  399. package/renderer/lib/utils.ts +0 -6
  400. package/renderer/next.config.ts +0 -76
@@ -0,0 +1,734 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { useState, useCallback, useEffect, useRef } from 'react';
4
+ import { cn } from '@/lib/utils';
5
+ import { Play, ArrowClockwise, Copy, Check, Spinner, X, FileText, BracketsCurly, Key, CaretRight, CaretDown, MagnifyingGlass, Lightning, ArrowsClockwise } from '@phosphor-icons/react';
6
+ import { Button } from '@/components/ui/button';
7
+ import { Tooltip, TooltipContent, TooltipProvider, TooltipTrigger } from '@/components/ui/tooltip';
8
+ import Editor, { loader } from '@monaco-editor/react';
9
+ // Configure Monaco to use CDN
10
+ loader.config({
11
+ paths: {
12
+ vs: 'https://cdn.jsdelivr.net/npm/monaco-editor@0.45.0/min/vs'
13
+ }
14
+ });
15
+ const STORAGE_KEY = 'brainfish-graphql-playground';
16
+ // ============================================================================
17
+ // Helpers
18
+ // ============================================================================
19
+ function loadStoredState() {
20
+ if (typeof window === 'undefined') return null;
21
+ try {
22
+ const stored = localStorage.getItem(STORAGE_KEY);
23
+ if (stored) return JSON.parse(stored);
24
+ } catch {}
25
+ return null;
26
+ }
27
+ function saveStoredState(state) {
28
+ if (typeof window === 'undefined') return;
29
+ try {
30
+ localStorage.setItem(STORAGE_KEY, JSON.stringify(state));
31
+ } catch {}
32
+ }
33
+ function SchemaExplorer({ operations, onSelectOperation, selectedOperationId }) {
34
+ const [searchQuery, setSearchQuery] = useState('');
35
+ const [expandedSections, setExpandedSections] = useState({
36
+ query: true,
37
+ mutation: true,
38
+ subscription: true
39
+ });
40
+ // Group operations by type
41
+ const queries = operations.filter((op)=>op.operationType === 'query');
42
+ const mutations = operations.filter((op)=>op.operationType === 'mutation');
43
+ const subscriptions = operations.filter((op)=>op.operationType === 'subscription');
44
+ // Filter by search
45
+ const filterOps = (ops)=>{
46
+ if (!searchQuery.trim()) return ops;
47
+ const query = searchQuery.toLowerCase();
48
+ return ops.filter((op)=>op.name.toLowerCase().includes(query) || op.description?.toLowerCase().includes(query));
49
+ };
50
+ const filteredQueries = filterOps(queries);
51
+ const filteredMutations = filterOps(mutations);
52
+ const filteredSubscriptions = filterOps(subscriptions);
53
+ const toggleSection = (section)=>{
54
+ setExpandedSections((prev)=>({
55
+ ...prev,
56
+ [section]: !prev[section]
57
+ }));
58
+ };
59
+ const renderSection = (title, icon, ops, sectionKey, iconColor)=>{
60
+ if (ops.length === 0) return null;
61
+ const isExpanded = expandedSections[sectionKey];
62
+ return /*#__PURE__*/ _jsxs("div", {
63
+ className: "mb-2",
64
+ children: [
65
+ /*#__PURE__*/ _jsxs("button", {
66
+ onClick: ()=>toggleSection(sectionKey),
67
+ className: "w-full flex items-center gap-2 px-3 py-2 text-xs font-semibold uppercase tracking-wider text-muted-foreground hover:bg-muted/50 transition-colors",
68
+ children: [
69
+ isExpanded ? /*#__PURE__*/ _jsx(CaretDown, {
70
+ className: "w-3 h-3"
71
+ }) : /*#__PURE__*/ _jsx(CaretRight, {
72
+ className: "w-3 h-3"
73
+ }),
74
+ /*#__PURE__*/ _jsx("span", {
75
+ className: iconColor,
76
+ children: icon
77
+ }),
78
+ /*#__PURE__*/ _jsx("span", {
79
+ children: title
80
+ }),
81
+ /*#__PURE__*/ _jsx("span", {
82
+ className: "ml-auto text-[10px] font-normal opacity-60",
83
+ children: ops.length
84
+ })
85
+ ]
86
+ }),
87
+ isExpanded && /*#__PURE__*/ _jsx("div", {
88
+ className: "ml-2",
89
+ children: ops.map((op)=>/*#__PURE__*/ _jsx("button", {
90
+ onClick: ()=>onSelectOperation(op),
91
+ className: cn('w-full flex items-start gap-2 px-3 py-2 text-left', 'hover:bg-muted/50 transition-colors rounded-sm', 'border-l-2', selectedOperationId === op.id ? 'bg-muted/70 border-primary' : 'border-transparent'),
92
+ children: /*#__PURE__*/ _jsxs("div", {
93
+ className: "flex-1 min-w-0",
94
+ children: [
95
+ /*#__PURE__*/ _jsx("div", {
96
+ className: "text-sm font-medium truncate",
97
+ children: op.name
98
+ }),
99
+ op.description && /*#__PURE__*/ _jsx("div", {
100
+ className: "text-xs text-muted-foreground truncate mt-0.5",
101
+ children: op.description
102
+ })
103
+ ]
104
+ })
105
+ }, op.id))
106
+ })
107
+ ]
108
+ });
109
+ };
110
+ const hasOperations = operations.length > 0;
111
+ const hasFilteredResults = filteredQueries.length > 0 || filteredMutations.length > 0 || filteredSubscriptions.length > 0;
112
+ return /*#__PURE__*/ _jsxs("div", {
113
+ className: "flex flex-col h-full border-r border-border bg-muted/20",
114
+ children: [
115
+ /*#__PURE__*/ _jsx("div", {
116
+ className: "p-2 border-b border-border",
117
+ children: /*#__PURE__*/ _jsxs("div", {
118
+ className: "relative",
119
+ children: [
120
+ /*#__PURE__*/ _jsx(MagnifyingGlass, {
121
+ className: "absolute left-2.5 top-1/2 -translate-y-1/2 w-4 h-4 text-muted-foreground"
122
+ }),
123
+ /*#__PURE__*/ _jsx("input", {
124
+ type: "text",
125
+ value: searchQuery,
126
+ onChange: (e)=>setSearchQuery(e.target.value),
127
+ placeholder: "Search operations...",
128
+ className: cn('w-full pl-8 pr-3 py-1.5 text-sm rounded-md', 'bg-background border border-border', 'focus:outline-none focus:ring-1 focus:ring-primary', 'placeholder:text-muted-foreground')
129
+ })
130
+ ]
131
+ })
132
+ }),
133
+ /*#__PURE__*/ _jsx("div", {
134
+ className: "flex-1 overflow-y-auto py-2",
135
+ children: !hasOperations ? /*#__PURE__*/ _jsxs("div", {
136
+ className: "flex flex-col items-center justify-center h-full px-4 text-center",
137
+ children: [
138
+ /*#__PURE__*/ _jsx(FileText, {
139
+ className: "w-8 h-8 text-muted-foreground/50 mb-2"
140
+ }),
141
+ /*#__PURE__*/ _jsx("p", {
142
+ className: "text-sm text-muted-foreground",
143
+ children: "No schema loaded"
144
+ }),
145
+ /*#__PURE__*/ _jsx("p", {
146
+ className: "text-xs text-muted-foreground/60 mt-1",
147
+ children: "Operations will appear here"
148
+ })
149
+ ]
150
+ }) : !hasFilteredResults ? /*#__PURE__*/ _jsx("div", {
151
+ className: "flex flex-col items-center justify-center h-32 px-4 text-center",
152
+ children: /*#__PURE__*/ _jsx("p", {
153
+ className: "text-sm text-muted-foreground",
154
+ children: "No matching operations"
155
+ })
156
+ }) : /*#__PURE__*/ _jsxs(_Fragment, {
157
+ children: [
158
+ renderSection('Queries', /*#__PURE__*/ _jsx(MagnifyingGlass, {
159
+ className: "w-3.5 h-3.5",
160
+ weight: "bold"
161
+ }), filteredQueries, 'query', 'text-blue-500'),
162
+ renderSection('Mutations', /*#__PURE__*/ _jsx(Lightning, {
163
+ className: "w-3.5 h-3.5",
164
+ weight: "bold"
165
+ }), filteredMutations, 'mutation', 'text-orange-500'),
166
+ renderSection('Subscriptions', /*#__PURE__*/ _jsx(ArrowsClockwise, {
167
+ className: "w-3.5 h-3.5",
168
+ weight: "bold"
169
+ }), filteredSubscriptions, 'subscription', 'text-purple-500')
170
+ ]
171
+ })
172
+ })
173
+ ]
174
+ });
175
+ }
176
+ // ============================================================================
177
+ // Main Component
178
+ // ============================================================================
179
+ export function GraphQLPlayground({ endpoint, defaultQuery = `# Welcome to the GraphQL Playground!
180
+ #
181
+ # Select an operation from the sidebar, or
182
+ # type your query below and press Ctrl+Enter
183
+
184
+ query {
185
+ __typename
186
+ }
187
+ `, headers: defaultHeaders = {}, operations = [], selectedOperationId: externalSelectedId, hideExplorer = false, className, theme = 'dark' }) {
188
+ const [query, setQuery] = useState(defaultQuery);
189
+ const [variables, setVariables] = useState('{}');
190
+ const [customHeaders, setCustomHeaders] = useState(Object.keys(defaultHeaders).length > 0 ? JSON.stringify(defaultHeaders, null, 2) : '{}');
191
+ const [response, setResponse] = useState(null);
192
+ const [isLoading, setIsLoading] = useState(false);
193
+ const [error, setError] = useState(null);
194
+ const [copied, setCopied] = useState(false);
195
+ const [activeTab, setActiveTab] = useState('variables');
196
+ const [responseTime, setResponseTime] = useState(null);
197
+ const [internalSelectedId, setInternalSelectedId] = useState();
198
+ // Use external selection if provided, otherwise use internal
199
+ const selectedOperationId = externalSelectedId ?? internalSelectedId;
200
+ const abortControllerRef = useRef(null);
201
+ const hasLoadedRef = useRef(false);
202
+ // Load from localStorage on mount
203
+ useEffect(()=>{
204
+ const stored = loadStoredState();
205
+ if (stored) {
206
+ if (stored.query) setQuery(stored.query);
207
+ if (stored.variables) setVariables(stored.variables);
208
+ if (stored.headers) setCustomHeaders(stored.headers);
209
+ }
210
+ hasLoadedRef.current = true;
211
+ }, []);
212
+ // Save to localStorage when values change
213
+ useEffect(()=>{
214
+ if (!hasLoadedRef.current) return;
215
+ const timeoutId = setTimeout(()=>{
216
+ saveStoredState({
217
+ query,
218
+ variables,
219
+ headers: customHeaders
220
+ });
221
+ }, 500);
222
+ return ()=>clearTimeout(timeoutId);
223
+ }, [
224
+ query,
225
+ variables,
226
+ customHeaders
227
+ ]);
228
+ // Handle operation selection from sidebar (internal)
229
+ const handleSelectOperation = useCallback((operation)=>{
230
+ setQuery(operation.query);
231
+ setInternalSelectedId(operation.id);
232
+ // Set example variables if available
233
+ if (operation.exampleVariables && Object.keys(operation.exampleVariables).length > 0) {
234
+ setVariables(JSON.stringify(operation.exampleVariables, null, 2));
235
+ } else {
236
+ setVariables('{}');
237
+ }
238
+ // Clear previous response
239
+ setResponse(null);
240
+ setError(null);
241
+ setResponseTime(null);
242
+ }, []);
243
+ // Sync with external selection (from main sidebar)
244
+ useEffect(()=>{
245
+ if (externalSelectedId && operations.length > 0) {
246
+ const op = operations.find((o)=>o.id === externalSelectedId);
247
+ if (op) {
248
+ setQuery(op.query);
249
+ if (op.exampleVariables && Object.keys(op.exampleVariables).length > 0) {
250
+ setVariables(JSON.stringify(op.exampleVariables, null, 2));
251
+ } else {
252
+ setVariables('{}');
253
+ }
254
+ setResponse(null);
255
+ setError(null);
256
+ setResponseTime(null);
257
+ }
258
+ }
259
+ }, [
260
+ externalSelectedId,
261
+ operations
262
+ ]);
263
+ // Execute GraphQL query
264
+ const executeQuery = useCallback(async ()=>{
265
+ setIsLoading(true);
266
+ setError(null);
267
+ setResponse(null);
268
+ setResponseTime(null);
269
+ if (abortControllerRef.current) {
270
+ abortControllerRef.current.abort();
271
+ }
272
+ abortControllerRef.current = new AbortController();
273
+ const startTime = performance.now();
274
+ try {
275
+ let parsedVariables = {};
276
+ try {
277
+ parsedVariables = variables.trim() && variables.trim() !== '{}' ? JSON.parse(variables) : {};
278
+ } catch {
279
+ setError('Invalid JSON in variables');
280
+ setIsLoading(false);
281
+ return;
282
+ }
283
+ let parsedHeaders = {};
284
+ try {
285
+ parsedHeaders = customHeaders.trim() && customHeaders.trim() !== '{}' ? JSON.parse(customHeaders) : {};
286
+ } catch {
287
+ setError('Invalid JSON in headers');
288
+ setIsLoading(false);
289
+ return;
290
+ }
291
+ const res = await fetch(endpoint, {
292
+ method: 'POST',
293
+ headers: {
294
+ 'Content-Type': 'application/json',
295
+ Accept: 'application/json',
296
+ ...defaultHeaders,
297
+ ...parsedHeaders
298
+ },
299
+ body: JSON.stringify({
300
+ query,
301
+ variables: parsedVariables
302
+ }),
303
+ signal: abortControllerRef.current.signal
304
+ });
305
+ const endTime = performance.now();
306
+ setResponseTime(Math.round(endTime - startTime));
307
+ const data = await res.json();
308
+ setResponse(data);
309
+ } catch (err) {
310
+ if (err instanceof Error && err.name === 'AbortError') return;
311
+ setError(err instanceof Error ? err.message : 'Request failed');
312
+ } finally{
313
+ setIsLoading(false);
314
+ }
315
+ }, [
316
+ query,
317
+ variables,
318
+ customHeaders,
319
+ endpoint,
320
+ defaultHeaders
321
+ ]);
322
+ const handleCancel = useCallback(()=>{
323
+ if (abortControllerRef.current) {
324
+ abortControllerRef.current.abort();
325
+ abortControllerRef.current = null;
326
+ }
327
+ setIsLoading(false);
328
+ }, []);
329
+ useEffect(()=>{
330
+ const handleKeyDown = (e)=>{
331
+ if ((e.ctrlKey || e.metaKey) && e.key === 'Enter') {
332
+ e.preventDefault();
333
+ if (!isLoading) executeQuery();
334
+ }
335
+ };
336
+ window.addEventListener('keydown', handleKeyDown);
337
+ return ()=>window.removeEventListener('keydown', handleKeyDown);
338
+ }, [
339
+ executeQuery,
340
+ isLoading
341
+ ]);
342
+ const copyResponse = useCallback(()=>{
343
+ if (response) {
344
+ navigator.clipboard.writeText(JSON.stringify(response, null, 2));
345
+ setCopied(true);
346
+ setTimeout(()=>setCopied(false), 2000);
347
+ }
348
+ }, [
349
+ response
350
+ ]);
351
+ const handleReset = useCallback(()=>{
352
+ setQuery(defaultQuery);
353
+ setVariables('{}');
354
+ setCustomHeaders(Object.keys(defaultHeaders).length > 0 ? JSON.stringify(defaultHeaders, null, 2) : '{}');
355
+ setResponse(null);
356
+ setError(null);
357
+ setResponseTime(null);
358
+ setInternalSelectedId(undefined);
359
+ localStorage.removeItem(STORAGE_KEY);
360
+ }, [
361
+ defaultQuery,
362
+ defaultHeaders
363
+ ]);
364
+ const monacoTheme = theme === 'dark' ? 'vs-dark' : 'vs';
365
+ const hasErrors = response?.errors && response.errors.length > 0;
366
+ const statusColor = hasErrors ? 'text-red-400' : response ? 'text-emerald-400' : 'text-zinc-500';
367
+ return /*#__PURE__*/ _jsx(TooltipProvider, {
368
+ children: /*#__PURE__*/ _jsxs("div", {
369
+ className: cn('flex flex-col h-full bg-background', className),
370
+ children: [
371
+ /*#__PURE__*/ _jsxs("div", {
372
+ className: "flex items-center justify-between gap-2 px-4 py-2 border-b border-border bg-muted/50",
373
+ children: [
374
+ /*#__PURE__*/ _jsx("div", {
375
+ className: "flex items-center gap-2",
376
+ children: /*#__PURE__*/ _jsxs("div", {
377
+ className: "hidden sm:flex items-center gap-2 px-3 py-1.5 rounded-md bg-background border border-border",
378
+ children: [
379
+ /*#__PURE__*/ _jsx("span", {
380
+ className: "text-xs font-medium text-emerald-500",
381
+ children: "POST"
382
+ }),
383
+ /*#__PURE__*/ _jsx("span", {
384
+ className: "text-xs text-muted-foreground font-mono truncate max-w-[200px] md:max-w-[400px]",
385
+ children: endpoint
386
+ })
387
+ ]
388
+ })
389
+ }),
390
+ /*#__PURE__*/ _jsxs("div", {
391
+ className: "flex items-center gap-2",
392
+ children: [
393
+ /*#__PURE__*/ _jsx(Button, {
394
+ onClick: isLoading ? handleCancel : executeQuery,
395
+ variant: isLoading ? 'destructive' : 'default',
396
+ size: "sm",
397
+ className: "px-4",
398
+ children: isLoading ? /*#__PURE__*/ _jsxs(_Fragment, {
399
+ children: [
400
+ /*#__PURE__*/ _jsx(X, {
401
+ className: "h-4 w-4 mr-2",
402
+ weight: "bold"
403
+ }),
404
+ "Cancel"
405
+ ]
406
+ }) : /*#__PURE__*/ _jsxs(_Fragment, {
407
+ children: [
408
+ /*#__PURE__*/ _jsx(Play, {
409
+ className: "h-4 w-4 mr-2",
410
+ weight: "fill"
411
+ }),
412
+ "Run"
413
+ ]
414
+ })
415
+ }),
416
+ /*#__PURE__*/ _jsxs(Tooltip, {
417
+ children: [
418
+ /*#__PURE__*/ _jsx(TooltipTrigger, {
419
+ asChild: true,
420
+ children: /*#__PURE__*/ _jsx(Button, {
421
+ variant: "outline",
422
+ size: "icon",
423
+ onClick: handleReset,
424
+ children: /*#__PURE__*/ _jsx(ArrowClockwise, {
425
+ className: "h-4 w-4",
426
+ weight: "bold"
427
+ })
428
+ })
429
+ }),
430
+ /*#__PURE__*/ _jsx(TooltipContent, {
431
+ children: "Reset to defaults"
432
+ })
433
+ ]
434
+ })
435
+ ]
436
+ })
437
+ ]
438
+ }),
439
+ /*#__PURE__*/ _jsxs("div", {
440
+ className: "flex-1 flex overflow-hidden",
441
+ children: [
442
+ !hideExplorer && operations.length > 0 && /*#__PURE__*/ _jsx("div", {
443
+ className: "w-64 flex-shrink-0 hidden md:block",
444
+ children: /*#__PURE__*/ _jsx(SchemaExplorer, {
445
+ operations: operations,
446
+ onSelectOperation: handleSelectOperation,
447
+ selectedOperationId: selectedOperationId
448
+ })
449
+ }),
450
+ /*#__PURE__*/ _jsxs("div", {
451
+ className: "flex-1 flex flex-col lg:flex-row overflow-hidden",
452
+ children: [
453
+ /*#__PURE__*/ _jsxs("div", {
454
+ className: "flex-1 flex flex-col border-b lg:border-b-0 lg:border-r border-border min-h-[200px] lg:min-h-0",
455
+ children: [
456
+ /*#__PURE__*/ _jsxs("div", {
457
+ className: "flex-1 flex flex-col min-h-0",
458
+ children: [
459
+ /*#__PURE__*/ _jsxs("div", {
460
+ className: "flex items-center px-3 py-2 border-b border-border bg-muted/30",
461
+ children: [
462
+ /*#__PURE__*/ _jsx(FileText, {
463
+ className: "h-4 w-4 mr-2 text-muted-foreground"
464
+ }),
465
+ /*#__PURE__*/ _jsx("span", {
466
+ className: "text-xs font-medium text-muted-foreground uppercase tracking-wider",
467
+ children: "Query"
468
+ }),
469
+ /*#__PURE__*/ _jsx("span", {
470
+ className: "ml-auto text-xs text-muted-foreground",
471
+ children: "Ctrl+Enter to run"
472
+ })
473
+ ]
474
+ }),
475
+ /*#__PURE__*/ _jsx("div", {
476
+ className: "flex-1 min-h-0",
477
+ children: /*#__PURE__*/ _jsx(Editor, {
478
+ height: "100%",
479
+ language: "graphql",
480
+ value: query,
481
+ onChange: (value)=>{
482
+ setQuery(value || '');
483
+ setInternalSelectedId(undefined); // Clear internal selection when manually editing
484
+ },
485
+ theme: monacoTheme,
486
+ options: {
487
+ minimap: {
488
+ enabled: false
489
+ },
490
+ scrollBeyondLastLine: false,
491
+ fontSize: 13,
492
+ fontFamily: "'JetBrains Mono', 'Fira Code', 'SF Mono', Consolas, monospace",
493
+ lineNumbers: 'on',
494
+ renderLineHighlight: 'line',
495
+ scrollbar: {
496
+ vertical: 'auto',
497
+ horizontal: 'auto'
498
+ },
499
+ padding: {
500
+ top: 12,
501
+ bottom: 12
502
+ },
503
+ wordWrap: 'on',
504
+ automaticLayout: true,
505
+ tabSize: 2
506
+ },
507
+ loading: /*#__PURE__*/ _jsxs("div", {
508
+ className: "flex items-center justify-center h-full text-muted-foreground text-sm",
509
+ children: [
510
+ /*#__PURE__*/ _jsx(Spinner, {
511
+ className: "w-5 h-5 animate-spin mr-2"
512
+ }),
513
+ "Loading editor..."
514
+ ]
515
+ })
516
+ })
517
+ })
518
+ ]
519
+ }),
520
+ /*#__PURE__*/ _jsxs("div", {
521
+ className: "border-t border-border h-[180px] flex flex-col",
522
+ children: [
523
+ /*#__PURE__*/ _jsxs("div", {
524
+ className: "flex border-b border-border bg-muted/30",
525
+ children: [
526
+ /*#__PURE__*/ _jsxs("button", {
527
+ onClick: ()=>setActiveTab('variables'),
528
+ className: cn('flex items-center gap-1.5 px-4 py-2 text-xs font-medium uppercase tracking-wider transition-colors', activeTab === 'variables' ? 'text-primary border-b-2 border-primary -mb-px bg-background' : 'text-muted-foreground hover:text-foreground'),
529
+ children: [
530
+ /*#__PURE__*/ _jsx(BracketsCurly, {
531
+ className: "h-3.5 w-3.5"
532
+ }),
533
+ "Variables"
534
+ ]
535
+ }),
536
+ /*#__PURE__*/ _jsxs("button", {
537
+ onClick: ()=>setActiveTab('headers'),
538
+ className: cn('flex items-center gap-1.5 px-4 py-2 text-xs font-medium uppercase tracking-wider transition-colors', activeTab === 'headers' ? 'text-primary border-b-2 border-primary -mb-px bg-background' : 'text-muted-foreground hover:text-foreground'),
539
+ children: [
540
+ /*#__PURE__*/ _jsx(Key, {
541
+ className: "h-3.5 w-3.5"
542
+ }),
543
+ "Headers"
544
+ ]
545
+ })
546
+ ]
547
+ }),
548
+ /*#__PURE__*/ _jsx("div", {
549
+ className: "flex-1 min-h-0",
550
+ children: /*#__PURE__*/ _jsx(Editor, {
551
+ height: "100%",
552
+ language: "json",
553
+ value: activeTab === 'variables' ? variables : customHeaders,
554
+ onChange: (value)=>activeTab === 'variables' ? setVariables(value || '{}') : setCustomHeaders(value || '{}'),
555
+ theme: monacoTheme,
556
+ options: {
557
+ minimap: {
558
+ enabled: false
559
+ },
560
+ scrollBeyondLastLine: false,
561
+ fontSize: 13,
562
+ fontFamily: "'JetBrains Mono', 'Fira Code', 'SF Mono', Consolas, monospace",
563
+ lineNumbers: 'off',
564
+ renderLineHighlight: 'none',
565
+ scrollbar: {
566
+ vertical: 'auto',
567
+ horizontal: 'auto'
568
+ },
569
+ padding: {
570
+ top: 8,
571
+ bottom: 8
572
+ },
573
+ wordWrap: 'on',
574
+ automaticLayout: true,
575
+ tabSize: 2,
576
+ folding: false
577
+ },
578
+ loading: /*#__PURE__*/ _jsx("div", {
579
+ className: "flex items-center justify-center h-full text-muted-foreground text-sm",
580
+ children: "Loading..."
581
+ })
582
+ })
583
+ })
584
+ ]
585
+ })
586
+ ]
587
+ }),
588
+ /*#__PURE__*/ _jsxs("div", {
589
+ className: "flex-1 flex flex-col min-h-[200px] lg:min-h-0",
590
+ children: [
591
+ /*#__PURE__*/ _jsxs("div", {
592
+ className: "flex items-center justify-between px-3 py-2 border-b border-border bg-muted/30",
593
+ children: [
594
+ /*#__PURE__*/ _jsxs("div", {
595
+ className: "flex items-center gap-3",
596
+ children: [
597
+ /*#__PURE__*/ _jsx("span", {
598
+ className: "text-xs font-medium text-muted-foreground uppercase tracking-wider",
599
+ children: "Response"
600
+ }),
601
+ responseTime !== null && /*#__PURE__*/ _jsxs("span", {
602
+ className: "text-xs text-muted-foreground",
603
+ children: [
604
+ responseTime,
605
+ "ms"
606
+ ]
607
+ }),
608
+ response && /*#__PURE__*/ _jsx("span", {
609
+ className: cn('text-xs font-medium', statusColor),
610
+ children: hasErrors ? 'Error' : 'Success'
611
+ })
612
+ ]
613
+ }),
614
+ response && /*#__PURE__*/ _jsxs(Tooltip, {
615
+ children: [
616
+ /*#__PURE__*/ _jsx(TooltipTrigger, {
617
+ asChild: true,
618
+ children: /*#__PURE__*/ _jsx(Button, {
619
+ variant: "ghost",
620
+ size: "sm",
621
+ onClick: copyResponse,
622
+ className: "h-7 px-2",
623
+ children: copied ? /*#__PURE__*/ _jsxs(_Fragment, {
624
+ children: [
625
+ /*#__PURE__*/ _jsx(Check, {
626
+ className: "h-3.5 w-3.5 mr-1 text-emerald-500"
627
+ }),
628
+ /*#__PURE__*/ _jsx("span", {
629
+ className: "text-xs",
630
+ children: "Copied"
631
+ })
632
+ ]
633
+ }) : /*#__PURE__*/ _jsxs(_Fragment, {
634
+ children: [
635
+ /*#__PURE__*/ _jsx(Copy, {
636
+ className: "h-3.5 w-3.5 mr-1"
637
+ }),
638
+ /*#__PURE__*/ _jsx("span", {
639
+ className: "text-xs",
640
+ children: "Copy"
641
+ })
642
+ ]
643
+ })
644
+ })
645
+ }),
646
+ /*#__PURE__*/ _jsx(TooltipContent, {
647
+ children: "Copy response"
648
+ })
649
+ ]
650
+ })
651
+ ]
652
+ }),
653
+ /*#__PURE__*/ _jsx("div", {
654
+ className: "flex-1 min-h-0 overflow-hidden",
655
+ children: isLoading ? /*#__PURE__*/ _jsxs("div", {
656
+ className: "flex items-center justify-center h-full",
657
+ children: [
658
+ /*#__PURE__*/ _jsx(Spinner, {
659
+ className: "w-6 h-6 animate-spin text-primary"
660
+ }),
661
+ /*#__PURE__*/ _jsx("span", {
662
+ className: "ml-2 text-sm text-muted-foreground",
663
+ children: "Executing query..."
664
+ })
665
+ ]
666
+ }) : error ? /*#__PURE__*/ _jsx("div", {
667
+ className: "p-4",
668
+ children: /*#__PURE__*/ _jsx("div", {
669
+ className: "p-4 bg-destructive/10 border border-destructive/20 rounded-lg",
670
+ children: /*#__PURE__*/ _jsx("p", {
671
+ className: "text-destructive text-sm font-mono",
672
+ children: error
673
+ })
674
+ })
675
+ }) : response ? /*#__PURE__*/ _jsx(Editor, {
676
+ height: "100%",
677
+ language: "json",
678
+ value: JSON.stringify(response, null, 2),
679
+ theme: monacoTheme,
680
+ options: {
681
+ readOnly: true,
682
+ minimap: {
683
+ enabled: false
684
+ },
685
+ scrollBeyondLastLine: false,
686
+ fontSize: 13,
687
+ fontFamily: "'JetBrains Mono', 'Fira Code', 'SF Mono', Consolas, monospace",
688
+ lineNumbers: 'on',
689
+ renderLineHighlight: 'none',
690
+ scrollbar: {
691
+ vertical: 'auto',
692
+ horizontal: 'auto'
693
+ },
694
+ padding: {
695
+ top: 12,
696
+ bottom: 12
697
+ },
698
+ wordWrap: 'on',
699
+ automaticLayout: true,
700
+ folding: true
701
+ }
702
+ }) : /*#__PURE__*/ _jsxs("div", {
703
+ className: "flex flex-col items-center justify-center h-full text-muted-foreground",
704
+ children: [
705
+ /*#__PURE__*/ _jsx(Play, {
706
+ className: "h-12 w-12 mb-3 opacity-20"
707
+ }),
708
+ /*#__PURE__*/ _jsx("p", {
709
+ className: "text-sm",
710
+ children: "Run a query to see results"
711
+ }),
712
+ /*#__PURE__*/ _jsx("p", {
713
+ className: "text-xs mt-1 opacity-60",
714
+ children: "Press Ctrl+Enter or click Run"
715
+ })
716
+ ]
717
+ })
718
+ })
719
+ ]
720
+ })
721
+ ]
722
+ })
723
+ ]
724
+ })
725
+ ]
726
+ })
727
+ });
728
+ }
729
+ export function GraphQLPlaygroundWithExplorer(props) {
730
+ return /*#__PURE__*/ _jsx(GraphQLPlayground, {
731
+ ...props
732
+ });
733
+ }
734
+ export default GraphQLPlayground;