@brainfish-ai/devdoc 0.1.42 → 0.1.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (388) hide show
  1. package/dist/cli/commands/dev.js +19 -10
  2. package/package.json +3 -2
  3. package/renderer/app/api/assets/[...path]/route.js +108 -0
  4. package/renderer/app/api/assets/route.js +114 -0
  5. package/renderer/app/api/assets/upload/route.js +163 -0
  6. package/renderer/app/api/auth-schemes/route.js +58 -0
  7. package/renderer/app/api/chat/route.js +759 -0
  8. package/renderer/app/api/codegen/route.js +52 -0
  9. package/renderer/app/api/collections/route.js +675 -0
  10. package/renderer/app/api/debug/route.js +47 -0
  11. package/renderer/app/api/deploy/route.js +199 -0
  12. package/renderer/app/api/device/route.js +36 -0
  13. package/renderer/app/api/docs/route.js +205 -0
  14. package/renderer/app/api/domains/add/route.js +121 -0
  15. package/renderer/app/api/domains/lookup/route.js +43 -0
  16. package/renderer/app/api/domains/remove/route.js +89 -0
  17. package/renderer/app/api/domains/status/route.js +140 -0
  18. package/renderer/app/api/domains/verify/route.js +168 -0
  19. package/renderer/app/api/keys/regenerate/route.js +71 -0
  20. package/renderer/app/api/local-assets/[...path]/route.js +108 -0
  21. package/renderer/app/api/openapi-spec/route.js +73 -0
  22. package/renderer/app/api/projects/[slug]/route.js +129 -0
  23. package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
  24. package/renderer/app/api/projects/register/route.js +176 -0
  25. package/renderer/app/api/proxy/route.js +139 -0
  26. package/renderer/app/api/proxy-stream/route.js +156 -0
  27. package/renderer/app/api/redirects/route.js +35 -0
  28. package/renderer/app/api/schema/route.js +85 -0
  29. package/renderer/app/api/subdomains/check/route.js +158 -0
  30. package/renderer/app/api/suggestions/route.js +175 -0
  31. package/renderer/app/layout.js +47 -0
  32. package/renderer/app/llms-full.txt/route.js +257 -0
  33. package/renderer/app/llms.txt/route.js +219 -0
  34. package/renderer/app/page.js +12 -0
  35. package/renderer/app/robots.txt/route.js +66 -0
  36. package/renderer/app/sitemap.xml/route.js +145 -0
  37. package/renderer/components/docs/index.js +8 -0
  38. package/renderer/components/docs/mdx/accordion.js +113 -0
  39. package/renderer/components/docs/mdx/badge.js +72 -0
  40. package/renderer/components/docs/mdx/callouts.js +137 -0
  41. package/renderer/components/docs/mdx/cards.js +175 -0
  42. package/renderer/components/docs/mdx/changelog.js +100 -0
  43. package/renderer/components/docs/mdx/code-block.js +147 -0
  44. package/renderer/components/docs/mdx/code-group.js +287 -0
  45. package/renderer/components/docs/mdx/file-embeds.js +82 -0
  46. package/renderer/components/docs/mdx/frame.js +59 -0
  47. package/renderer/components/docs/mdx/highlight.js +90 -0
  48. package/renderer/components/docs/mdx/iframe.js +69 -0
  49. package/renderer/components/docs/mdx/image.js +135 -0
  50. package/renderer/components/docs/mdx/index.js +134 -0
  51. package/renderer/components/docs/mdx/landing.js +315 -0
  52. package/renderer/components/docs/mdx/mermaid.js +212 -0
  53. package/renderer/components/docs/mdx/param-field.js +112 -0
  54. package/renderer/components/docs/mdx/steps.js +74 -0
  55. package/renderer/components/docs/mdx/tabs.js +50 -0
  56. package/renderer/components/docs/mdx-renderer.js +77 -0
  57. package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
  58. package/renderer/components/docs/navigation/index.js +6 -0
  59. package/renderer/components/docs/navigation/page-nav.js +57 -0
  60. package/renderer/components/docs/navigation/sidebar.js +375 -0
  61. package/renderer/components/docs/navigation/toc.js +89 -0
  62. package/renderer/components/docs/notice.js +77 -0
  63. package/renderer/components/docs-header.js +202 -0
  64. package/renderer/components/docs-viewer/agent/agent-chat.js +1930 -0
  65. package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
  66. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
  67. package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
  68. package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
  69. package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
  70. package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
  71. package/renderer/components/docs-viewer/agent/index.js +4 -0
  72. package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
  73. package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
  74. package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
  75. package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
  76. package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
  77. package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
  78. package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
  79. package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
  80. package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
  81. package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
  82. package/renderer/components/docs-viewer/content/doc-page.js +264 -0
  83. package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
  84. package/renderer/components/docs-viewer/content/index.js +29 -0
  85. package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
  86. package/renderer/components/docs-viewer/content/request-details.js +528 -0
  87. package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
  88. package/renderer/components/docs-viewer/content/sections/body.js +80 -0
  89. package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
  90. package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
  91. package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
  92. package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
  93. package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
  94. package/renderer/components/docs-viewer/index.js +1552 -0
  95. package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
  96. package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
  97. package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
  98. package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
  99. package/renderer/components/docs-viewer/playground/graphql-playground.js +734 -0
  100. package/renderer/components/docs-viewer/playground/index.js +682 -0
  101. package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
  102. package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
  103. package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
  104. package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
  105. package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
  106. package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
  107. package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
  108. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
  109. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
  110. package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
  111. package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
  112. package/renderer/components/docs-viewer/search/index.js +2 -0
  113. package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
  114. package/renderer/components/docs-viewer/search/use-search.js +89 -0
  115. package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
  116. package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
  117. package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
  118. package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
  119. package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
  120. package/renderer/components/docs-viewer/sidebar/index.js +196 -0
  121. package/renderer/components/docs-viewer/sidebar/right-sidebar.js +163 -0
  122. package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
  123. package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
  124. package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
  125. package/renderer/components/theme-provider.js +10 -0
  126. package/renderer/components/theme-toggle.js +106 -0
  127. package/renderer/components/ui/badge.js +29 -0
  128. package/renderer/components/ui/button.js +40 -0
  129. package/renderer/components/ui/dialog.js +50 -0
  130. package/renderer/components/ui/dropdown-menu.js +143 -0
  131. package/renderer/components/ui/input.js +12 -0
  132. package/renderer/components/ui/label.js +13 -0
  133. package/renderer/components/ui/navigation-menu.js +83 -0
  134. package/renderer/components/ui/select.js +116 -0
  135. package/renderer/components/ui/spinner.js +92 -0
  136. package/renderer/components/ui/tabs.js +34 -0
  137. package/renderer/components/ui/tooltip.js +43 -0
  138. package/renderer/hooks/use-code-copy.js +76 -0
  139. package/renderer/hooks/use-openapi-title.js +33 -0
  140. package/renderer/lib/api-docs/agent/index.js +4 -0
  141. package/renderer/lib/api-docs/agent/indexer.js +254 -0
  142. package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
  143. package/renderer/lib/api-docs/agent/types.js +5 -0
  144. package/renderer/lib/api-docs/auth/auth-context.js +157 -0
  145. package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
  146. package/renderer/lib/api-docs/auth/crypto.js +64 -0
  147. package/renderer/lib/api-docs/auth/index.js +3 -0
  148. package/renderer/lib/api-docs/code-editor/db.js +145 -0
  149. package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
  150. package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
  151. package/renderer/lib/api-docs/code-editor/mode-context.js +154 -0
  152. package/renderer/lib/api-docs/code-editor/types.js +53 -0
  153. package/renderer/lib/api-docs/codegen/definitions.js +258 -0
  154. package/renderer/lib/api-docs/codegen/har.js +171 -0
  155. package/renderer/lib/api-docs/codegen/index.js +118 -0
  156. package/renderer/lib/api-docs/factories.js +136 -0
  157. package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
  158. package/renderer/lib/api-docs/mobile-context.js +79 -0
  159. package/renderer/lib/api-docs/navigation-context.js +62 -0
  160. package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
  161. package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
  162. package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
  163. package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
  164. package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
  165. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
  166. package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
  167. package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
  168. package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
  169. package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
  170. package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
  171. package/renderer/lib/api-docs/playground/context.js +65 -0
  172. package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
  173. package/renderer/lib/api-docs/playground/request-builder.js +163 -0
  174. package/renderer/lib/api-docs/playground/request-runner.js +224 -0
  175. package/renderer/lib/api-docs/playground/types.js +5 -0
  176. package/renderer/lib/api-docs/types.js +23 -0
  177. package/renderer/lib/api-docs/utils.js +212 -0
  178. package/renderer/lib/cache.js +157 -0
  179. package/renderer/lib/docs/config/domain-schema.js +161 -0
  180. package/renderer/lib/docs/config/index.js +5 -0
  181. package/renderer/lib/docs/config/loader.js +113 -0
  182. package/renderer/lib/docs/config/schema.js +269 -0
  183. package/renderer/lib/docs/index.js +8 -0
  184. package/renderer/lib/docs/mdx/compiler.js +128 -0
  185. package/renderer/lib/docs/mdx/frontmatter.js +73 -0
  186. package/renderer/lib/docs/mdx/index.js +8 -0
  187. package/renderer/lib/docs/navigation/generator.js +269 -0
  188. package/renderer/lib/docs/navigation/index.js +4 -0
  189. package/renderer/lib/docs/navigation/types.js +9 -0
  190. package/renderer/lib/docs-navigation-context.js +40 -0
  191. package/renderer/lib/multi-tenant/context.js +80 -0
  192. package/renderer/lib/storage/blob.js +767 -0
  193. package/renderer/lib/utils/icons.js +30 -0
  194. package/renderer/lib/utils.js +5 -0
  195. package/renderer/next.config.js +62 -0
  196. package/renderer/tsconfig.json +23 -5
  197. package/renderer/app/api/assets/[...path]/route.ts +0 -123
  198. package/renderer/app/api/assets/route.ts +0 -124
  199. package/renderer/app/api/assets/upload/route.ts +0 -177
  200. package/renderer/app/api/auth-schemes/route.ts +0 -77
  201. package/renderer/app/api/chat/route.ts +0 -858
  202. package/renderer/app/api/codegen/route.ts +0 -72
  203. package/renderer/app/api/collections/route.ts +0 -1002
  204. package/renderer/app/api/debug/route.ts +0 -53
  205. package/renderer/app/api/deploy/route.ts +0 -234
  206. package/renderer/app/api/device/route.ts +0 -42
  207. package/renderer/app/api/docs/route.ts +0 -201
  208. package/renderer/app/api/domains/add/route.ts +0 -132
  209. package/renderer/app/api/domains/lookup/route.ts +0 -43
  210. package/renderer/app/api/domains/remove/route.ts +0 -100
  211. package/renderer/app/api/domains/status/route.ts +0 -158
  212. package/renderer/app/api/domains/verify/route.ts +0 -181
  213. package/renderer/app/api/keys/regenerate/route.ts +0 -80
  214. package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
  215. package/renderer/app/api/openapi-spec/route.ts +0 -151
  216. package/renderer/app/api/projects/[slug]/route.ts +0 -153
  217. package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
  218. package/renderer/app/api/projects/register/route.ts +0 -152
  219. package/renderer/app/api/proxy/route.ts +0 -149
  220. package/renderer/app/api/proxy-stream/route.ts +0 -168
  221. package/renderer/app/api/redirects/route.ts +0 -47
  222. package/renderer/app/api/schema/route.ts +0 -73
  223. package/renderer/app/api/subdomains/check/route.ts +0 -172
  224. package/renderer/app/api/suggestions/route.ts +0 -144
  225. package/renderer/app/layout.tsx +0 -54
  226. package/renderer/app/llms-full.txt/route.ts +0 -346
  227. package/renderer/app/llms.txt/route.ts +0 -279
  228. package/renderer/app/page.tsx +0 -14
  229. package/renderer/app/robots.txt/route.ts +0 -84
  230. package/renderer/app/sitemap.xml/route.ts +0 -199
  231. package/renderer/components/docs/index.ts +0 -12
  232. package/renderer/components/docs/mdx/accordion.tsx +0 -169
  233. package/renderer/components/docs/mdx/badge.tsx +0 -132
  234. package/renderer/components/docs/mdx/callouts.tsx +0 -154
  235. package/renderer/components/docs/mdx/cards.tsx +0 -241
  236. package/renderer/components/docs/mdx/changelog.tsx +0 -120
  237. package/renderer/components/docs/mdx/code-block.tsx +0 -186
  238. package/renderer/components/docs/mdx/code-group.tsx +0 -421
  239. package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
  240. package/renderer/components/docs/mdx/frame.tsx +0 -112
  241. package/renderer/components/docs/mdx/highlight.tsx +0 -151
  242. package/renderer/components/docs/mdx/iframe.tsx +0 -134
  243. package/renderer/components/docs/mdx/image.tsx +0 -235
  244. package/renderer/components/docs/mdx/index.ts +0 -237
  245. package/renderer/components/docs/mdx/landing.tsx +0 -684
  246. package/renderer/components/docs/mdx/mermaid.tsx +0 -240
  247. package/renderer/components/docs/mdx/param-field.tsx +0 -200
  248. package/renderer/components/docs/mdx/steps.tsx +0 -113
  249. package/renderer/components/docs/mdx/tabs.tsx +0 -86
  250. package/renderer/components/docs/mdx-renderer.tsx +0 -100
  251. package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
  252. package/renderer/components/docs/navigation/index.ts +0 -8
  253. package/renderer/components/docs/navigation/page-nav.tsx +0 -64
  254. package/renderer/components/docs/navigation/sidebar.tsx +0 -515
  255. package/renderer/components/docs/navigation/toc.tsx +0 -113
  256. package/renderer/components/docs/notice.tsx +0 -105
  257. package/renderer/components/docs-header.tsx +0 -278
  258. package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
  259. package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
  260. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
  261. package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
  262. package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
  263. package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
  264. package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
  265. package/renderer/components/docs-viewer/agent/index.tsx +0 -6
  266. package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
  267. package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
  268. package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
  269. package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
  270. package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
  271. package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
  272. package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
  273. package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
  274. package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
  275. package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
  276. package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
  277. package/renderer/components/docs-viewer/content/index.tsx +0 -29
  278. package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
  279. package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
  280. package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
  281. package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
  282. package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
  283. package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
  284. package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
  285. package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
  286. package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
  287. package/renderer/components/docs-viewer/index.tsx +0 -1670
  288. package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
  289. package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
  290. package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
  291. package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
  292. package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
  293. package/renderer/components/docs-viewer/playground/index.tsx +0 -671
  294. package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
  295. package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
  296. package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
  297. package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
  298. package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
  299. package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
  300. package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
  301. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
  302. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
  303. package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
  304. package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
  305. package/renderer/components/docs-viewer/search/index.ts +0 -2
  306. package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
  307. package/renderer/components/docs-viewer/search/use-search.ts +0 -117
  308. package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
  309. package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
  310. package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
  311. package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
  312. package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
  313. package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
  314. package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
  315. package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
  316. package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
  317. package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
  318. package/renderer/components/theme-provider.tsx +0 -11
  319. package/renderer/components/theme-toggle.tsx +0 -76
  320. package/renderer/components/ui/badge.tsx +0 -46
  321. package/renderer/components/ui/button.tsx +0 -59
  322. package/renderer/components/ui/dialog.tsx +0 -118
  323. package/renderer/components/ui/dropdown-menu.tsx +0 -257
  324. package/renderer/components/ui/input.tsx +0 -21
  325. package/renderer/components/ui/label.tsx +0 -24
  326. package/renderer/components/ui/navigation-menu.tsx +0 -168
  327. package/renderer/components/ui/select.tsx +0 -190
  328. package/renderer/components/ui/spinner.tsx +0 -114
  329. package/renderer/components/ui/tabs.tsx +0 -66
  330. package/renderer/components/ui/tooltip.tsx +0 -61
  331. package/renderer/hooks/use-code-copy.ts +0 -88
  332. package/renderer/hooks/use-openapi-title.ts +0 -44
  333. package/renderer/lib/api-docs/agent/index.ts +0 -6
  334. package/renderer/lib/api-docs/agent/indexer.ts +0 -323
  335. package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
  336. package/renderer/lib/api-docs/agent/types.ts +0 -116
  337. package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
  338. package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
  339. package/renderer/lib/api-docs/auth/crypto.ts +0 -89
  340. package/renderer/lib/api-docs/auth/index.ts +0 -4
  341. package/renderer/lib/api-docs/code-editor/db.ts +0 -164
  342. package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
  343. package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
  344. package/renderer/lib/api-docs/code-editor/types.ts +0 -105
  345. package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
  346. package/renderer/lib/api-docs/codegen/har.ts +0 -251
  347. package/renderer/lib/api-docs/codegen/index.ts +0 -159
  348. package/renderer/lib/api-docs/factories.ts +0 -170
  349. package/renderer/lib/api-docs/mobile-context.tsx +0 -112
  350. package/renderer/lib/api-docs/navigation-context.tsx +0 -88
  351. package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
  352. package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
  353. package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
  354. package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
  355. package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
  356. package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
  357. package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
  358. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
  359. package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
  360. package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
  361. package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
  362. package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
  363. package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
  364. package/renderer/lib/api-docs/playground/context.tsx +0 -107
  365. package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
  366. package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
  367. package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
  368. package/renderer/lib/api-docs/playground/types.ts +0 -35
  369. package/renderer/lib/api-docs/types.ts +0 -269
  370. package/renderer/lib/api-docs/utils.ts +0 -311
  371. package/renderer/lib/cache.ts +0 -193
  372. package/renderer/lib/docs/config/domain-schema.ts +0 -260
  373. package/renderer/lib/docs/config/index.ts +0 -43
  374. package/renderer/lib/docs/config/loader.ts +0 -142
  375. package/renderer/lib/docs/config/schema.ts +0 -308
  376. package/renderer/lib/docs/index.ts +0 -12
  377. package/renderer/lib/docs/mdx/compiler.ts +0 -176
  378. package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
  379. package/renderer/lib/docs/mdx/index.ts +0 -26
  380. package/renderer/lib/docs/navigation/generator.ts +0 -348
  381. package/renderer/lib/docs/navigation/index.ts +0 -12
  382. package/renderer/lib/docs/navigation/types.ts +0 -123
  383. package/renderer/lib/docs-navigation-context.tsx +0 -80
  384. package/renderer/lib/multi-tenant/context.ts +0 -105
  385. package/renderer/lib/storage/blob.ts +0 -1083
  386. package/renderer/lib/utils/icons.ts +0 -48
  387. package/renderer/lib/utils.ts +0 -6
  388. package/renderer/next.config.ts +0 -76
@@ -0,0 +1,196 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { useEffect, useState } from 'react';
4
+ import { createPortal } from 'react-dom';
5
+ import { X, Spinner } from '@phosphor-icons/react';
6
+ import { Button } from '@/components/ui/button';
7
+ import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select';
8
+ import { CollectionTree } from './collection-tree';
9
+ import { SidebarSection } from './sidebar-section';
10
+ import { SidebarItem, SlidingIndicatorProvider } from './sidebar-item';
11
+ import { SidebarGroup } from './sidebar-group';
12
+ import { useMobile } from '@/lib/api-docs/mobile-context';
13
+ import { cn } from '@/lib/utils';
14
+ export function DocsSidebar({ collection, selectedRequest, selectedDocSection, selectedDocPage, activeTab, onSelectRequest, onSelectDocumentation, onSelectDocPage, apiVersions, selectedApiVersion, onApiVersionChange, isVersionLoading }) {
15
+ const { isMobile, isLeftSidebarOpen, closeLeftSidebar } = useMobile();
16
+ const [mounted, setMounted] = useState(false);
17
+ // Ensure we're mounted before using portal (for SSR)
18
+ useEffect(()=>{
19
+ setMounted(true);
20
+ }, []);
21
+ // Handle request selection with mobile close
22
+ const handleSelectRequest = (request)=>{
23
+ onSelectRequest(request);
24
+ if (isMobile) {
25
+ closeLeftSidebar();
26
+ }
27
+ };
28
+ // Handle doc click with mobile close
29
+ const handleDocClickWithClose = (headingId)=>{
30
+ if (onSelectDocumentation) {
31
+ onSelectDocumentation(headingId);
32
+ }
33
+ if (isMobile) {
34
+ closeLeftSidebar();
35
+ }
36
+ };
37
+ // Handle doc page click with mobile close
38
+ const handleDocPageClick = (slug)=>{
39
+ if (onSelectDocPage) {
40
+ onSelectDocPage(slug);
41
+ }
42
+ if (isMobile) {
43
+ closeLeftSidebar();
44
+ }
45
+ };
46
+ // Get doc groups from collection
47
+ const docGroups = collection.docGroups || [];
48
+ // Check if any child in a group is selected
49
+ const isChildSelected = (page)=>{
50
+ if (!page.children) return false;
51
+ return page.children.some((child)=>selectedDocPage === child.slug);
52
+ };
53
+ // Get the selected child slug for a group (for triggering auto-expand)
54
+ const getSelectedChildSlug = (page)=>{
55
+ if (!page.children) return null;
56
+ const selected = page.children.find((child)=>selectedDocPage === child.slug);
57
+ return selected?.slug || null;
58
+ };
59
+ // Render a doc page item (may be a collapsible group with children)
60
+ const renderDocPage = (page)=>{
61
+ // Handle collapsible group with children
62
+ if (page.isGroup && page.children && page.children.length > 0) {
63
+ return /*#__PURE__*/ _jsx(SidebarGroup, {
64
+ title: page.title,
65
+ defaultOpen: isChildSelected(page),
66
+ selectedChildSlug: getSelectedChildSlug(page),
67
+ children: page.children.map((child)=>{
68
+ const isSelected = selectedDocPage === child.slug;
69
+ return /*#__PURE__*/ _jsx(SidebarItem, {
70
+ itemId: `doc-${child.slug}`,
71
+ selected: isSelected,
72
+ indent: 1,
73
+ icon: child.icon,
74
+ onClick: ()=>handleDocPageClick(child.slug),
75
+ children: child.title
76
+ }, child.id);
77
+ })
78
+ }, page.id);
79
+ }
80
+ // Regular page item
81
+ const isSelected = selectedDocPage === page.slug;
82
+ return /*#__PURE__*/ _jsx(SidebarItem, {
83
+ itemId: `doc-${page.slug}`,
84
+ selected: isSelected,
85
+ icon: page.icon,
86
+ onClick: ()=>handleDocPageClick(page.slug),
87
+ children: page.title
88
+ }, page.id);
89
+ };
90
+ // Sidebar content component (shared between mobile and desktop)
91
+ const sidebarContent = /*#__PURE__*/ _jsxs(_Fragment, {
92
+ children: [
93
+ isMobile && /*#__PURE__*/ _jsx("div", {
94
+ className: "px-4 h-[41px] flex items-center justify-end border-b border-sidebar-border shrink-0",
95
+ children: /*#__PURE__*/ _jsx(Button, {
96
+ variant: "ghost",
97
+ size: "icon",
98
+ onClick: closeLeftSidebar,
99
+ className: "h-7 w-7 lg:hidden",
100
+ children: /*#__PURE__*/ _jsx(X, {
101
+ className: "h-4 w-4",
102
+ weight: "bold"
103
+ })
104
+ })
105
+ }),
106
+ activeTab === 'api-reference' && apiVersions && apiVersions.length > 1 && /*#__PURE__*/ _jsxs("div", {
107
+ className: "docs-sidebar-version-selector px-4 py-3 border-b border-sidebar-border shrink-0",
108
+ children: [
109
+ /*#__PURE__*/ _jsxs("div", {
110
+ className: "flex items-center justify-between mb-1.5",
111
+ children: [
112
+ /*#__PURE__*/ _jsx("label", {
113
+ className: "docs-sidebar-version-label text-xs font-medium text-muted-foreground",
114
+ children: "API Version"
115
+ }),
116
+ isVersionLoading && /*#__PURE__*/ _jsx(Spinner, {
117
+ className: "h-3 w-3 animate-spin text-muted-foreground"
118
+ })
119
+ ]
120
+ }),
121
+ /*#__PURE__*/ _jsxs(Select, {
122
+ value: selectedApiVersion || apiVersions.find((v)=>v.default)?.version || apiVersions[0]?.version,
123
+ onValueChange: (value)=>onApiVersionChange?.(value),
124
+ disabled: isVersionLoading,
125
+ children: [
126
+ /*#__PURE__*/ _jsx(SelectTrigger, {
127
+ className: cn("docs-sidebar-version-trigger w-full h-9 text-sm", isVersionLoading && "opacity-50"),
128
+ children: /*#__PURE__*/ _jsx(SelectValue, {
129
+ placeholder: "Select version"
130
+ })
131
+ }),
132
+ /*#__PURE__*/ _jsx(SelectContent, {
133
+ children: apiVersions.map((v)=>/*#__PURE__*/ _jsxs(SelectItem, {
134
+ value: v.version,
135
+ children: [
136
+ v.version,
137
+ v.default && /*#__PURE__*/ _jsx("span", {
138
+ className: "ml-2 text-xs text-muted-foreground",
139
+ children: "(latest)"
140
+ })
141
+ ]
142
+ }, v.version))
143
+ })
144
+ ]
145
+ })
146
+ ]
147
+ }),
148
+ /*#__PURE__*/ _jsxs(SlidingIndicatorProvider, {
149
+ className: "docs-sidebar-content flex-1 overflow-y-auto overflow-x-hidden custom-scroll",
150
+ children: [
151
+ docGroups.length > 0 && /*#__PURE__*/ _jsx(_Fragment, {
152
+ children: docGroups.map((group, index)=>/*#__PURE__*/ _jsx(SidebarSection, {
153
+ title: group.title,
154
+ icon: group.icon,
155
+ className: index > 0 ? '' : '',
156
+ children: group.pages.map(renderDocPage)
157
+ }, group.id))
158
+ }),
159
+ (collection.folders.length > 0 || collection.requests.length > 0) && /*#__PURE__*/ _jsx(SidebarSection, {
160
+ title: "Endpoints",
161
+ className: docGroups.length > 0 ? 'border-t border-sidebar-border' : '',
162
+ children: /*#__PURE__*/ _jsx(CollectionTree, {
163
+ collection: collection,
164
+ selectedRequest: selectedRequest,
165
+ onSelectRequest: handleSelectRequest
166
+ })
167
+ })
168
+ ]
169
+ })
170
+ ]
171
+ });
172
+ // Mobile sidebar rendered via portal to escape stacking context
173
+ const mobileSidebar = mounted && isMobile ? /*#__PURE__*/ createPortal(/*#__PURE__*/ _jsxs(_Fragment, {
174
+ children: [
175
+ isLeftSidebarOpen && /*#__PURE__*/ _jsx("div", {
176
+ className: "docs-sidebar-overlay fixed inset-0 bg-black/50 z-[55] lg:hidden",
177
+ onClick: closeLeftSidebar
178
+ }),
179
+ /*#__PURE__*/ _jsx("aside", {
180
+ className: cn("docs-sidebar flex flex-col border-r border-sidebar-border overflow-hidden bg-muted dark:bg-background", "fixed inset-y-0 left-0 z-[60] w-[280px] h-full", "transform transition-transform duration-300 ease-in-out", !isLeftSidebarOpen && "-translate-x-full", isLeftSidebarOpen && "translate-x-0"),
181
+ children: sidebarContent
182
+ })
183
+ ]
184
+ }), document.body) : null;
185
+ // Desktop sidebar rendered in place
186
+ const desktopSidebar = !isMobile ? /*#__PURE__*/ _jsx("aside", {
187
+ className: cn("docs-sidebar flex flex-col border-r border-sidebar-border overflow-hidden bg-muted dark:bg-background", "relative w-72 h-full"),
188
+ children: sidebarContent
189
+ }) : null;
190
+ return /*#__PURE__*/ _jsxs(_Fragment, {
191
+ children: [
192
+ mobileSidebar,
193
+ desktopSidebar
194
+ ]
195
+ });
196
+ }
@@ -0,0 +1,163 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { useEffect, useState, useCallback } from 'react';
4
+ import { createPortal } from 'react-dom';
5
+ import Image from 'next/image';
6
+ import { X, ArrowClockwise } from '@phosphor-icons/react';
7
+ import { AgentChat } from '../agent';
8
+ import { Button } from '@/components/ui/button';
9
+ import { useMobile } from '@/lib/api-docs/mobile-context';
10
+ import { cn } from '@/lib/utils';
11
+ import { Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui/tooltip';
12
+ export function RightSidebar({ request, collection, apiSummary, onNavigateToEndpoint, onPrefillParameters, debugContext, onClearDebugContext, explainContext, onClearExplainContext, onOpenGlobalAuth, onNavigateToAuthTab, onNavigateToParamsTab, onNavigateToBodyTab, onNavigateToHeadersTab, onNavigateToDocSection, onNavigateToDocPage }) {
13
+ // Mobile context
14
+ const { isMobile, isRightSidebarOpen, closeRightSidebar } = useMobile();
15
+ const [mounted, setMounted] = useState(false);
16
+ // Ensure we're mounted before using portal (for SSR)
17
+ useEffect(()=>{
18
+ setMounted(true);
19
+ }, []);
20
+ // Debug context to send to agent (full context for card display)
21
+ const [pendingDebugContext, setPendingDebugContext] = useState(null);
22
+ // Handle debug context
23
+ useEffect(()=>{
24
+ if (debugContext) {
25
+ // Pass full context to agent
26
+ setPendingDebugContext(debugContext);
27
+ // Clear the debug context from parent
28
+ onClearDebugContext?.();
29
+ }
30
+ }, [
31
+ debugContext,
32
+ onClearDebugContext
33
+ ]);
34
+ // Clear debug context after it's been used
35
+ const handleDebugContextConsumed = ()=>{
36
+ setPendingDebugContext(null);
37
+ };
38
+ // Key for resetting chat
39
+ const [chatKey, setChatKey] = useState(0);
40
+ // Track if there are messages
41
+ const [hasMessages, setHasMessages] = useState(false);
42
+ // Handle reset conversation
43
+ const handleResetConversation = useCallback(()=>{
44
+ // Clear chat storage before remounting
45
+ localStorage.removeItem('brainfish-agent-chat');
46
+ setChatKey((prev)=>prev + 1);
47
+ setHasMessages(false);
48
+ }, []);
49
+ // Sidebar content component (shared between mobile and desktop)
50
+ const sidebarContent = /*#__PURE__*/ _jsxs(_Fragment, {
51
+ children: [
52
+ /*#__PURE__*/ _jsx("div", {
53
+ className: "docs-agent-header shrink-0 px-3 sm:px-4 h-[41px] flex items-center border-b border-border bg-muted/30",
54
+ children: /*#__PURE__*/ _jsxs("div", {
55
+ className: "flex items-center justify-between gap-2 w-full",
56
+ children: [
57
+ /*#__PURE__*/ _jsxs("div", {
58
+ className: "docs-agent-title flex items-center gap-2.5",
59
+ children: [
60
+ /*#__PURE__*/ _jsx("div", {
61
+ className: "docs-agent-avatar size-7 rounded-full overflow-hidden bg-muted flex items-center justify-center shrink-0",
62
+ children: /*#__PURE__*/ _jsx(Image, {
63
+ src: "/icon.png",
64
+ alt: "Assistant",
65
+ width: 28,
66
+ height: 28,
67
+ className: "size-7 object-cover"
68
+ })
69
+ }),
70
+ /*#__PURE__*/ _jsx("span", {
71
+ className: "text-sm font-medium",
72
+ children: "Assistant"
73
+ })
74
+ ]
75
+ }),
76
+ /*#__PURE__*/ _jsxs("div", {
77
+ className: "flex items-center gap-1 shrink-0",
78
+ children: [
79
+ hasMessages && /*#__PURE__*/ _jsxs(Tooltip, {
80
+ children: [
81
+ /*#__PURE__*/ _jsx(TooltipTrigger, {
82
+ asChild: true,
83
+ children: /*#__PURE__*/ _jsx(Button, {
84
+ variant: "ghost",
85
+ size: "icon",
86
+ onClick: handleResetConversation,
87
+ className: "h-7 w-7 text-muted-foreground hover:text-foreground",
88
+ children: /*#__PURE__*/ _jsx(ArrowClockwise, {
89
+ className: "h-4 w-4",
90
+ weight: "bold"
91
+ })
92
+ })
93
+ }),
94
+ /*#__PURE__*/ _jsx(TooltipContent, {
95
+ side: "bottom",
96
+ children: "New conversation"
97
+ })
98
+ ]
99
+ }),
100
+ isMobile && /*#__PURE__*/ _jsx(Button, {
101
+ variant: "ghost",
102
+ size: "icon",
103
+ onClick: closeRightSidebar,
104
+ className: "h-7 w-7 lg:hidden",
105
+ children: /*#__PURE__*/ _jsx(X, {
106
+ className: "h-4 w-4",
107
+ weight: "bold"
108
+ })
109
+ })
110
+ ]
111
+ })
112
+ ]
113
+ })
114
+ }),
115
+ /*#__PURE__*/ _jsx("div", {
116
+ className: "docs-agent-content flex-1 overflow-hidden",
117
+ children: /*#__PURE__*/ _jsx(AgentChat, {
118
+ collection: collection,
119
+ currentEndpoint: request,
120
+ apiSummary: apiSummary,
121
+ onNavigate: onNavigateToEndpoint,
122
+ onPrefill: onPrefillParameters,
123
+ debugContext: pendingDebugContext,
124
+ onDebugContextConsumed: handleDebugContextConsumed,
125
+ explainContext: explainContext,
126
+ onExplainContextConsumed: onClearExplainContext,
127
+ onOpenGlobalAuth: onOpenGlobalAuth,
128
+ onNavigateToAuthTab: onNavigateToAuthTab,
129
+ onNavigateToParamsTab: onNavigateToParamsTab,
130
+ onNavigateToBodyTab: onNavigateToBodyTab,
131
+ onNavigateToHeadersTab: onNavigateToHeadersTab,
132
+ onNavigateToDocSection: onNavigateToDocSection,
133
+ onNavigateToDocPage: onNavigateToDocPage,
134
+ onHasMessagesChange: setHasMessages
135
+ }, chatKey)
136
+ })
137
+ ]
138
+ });
139
+ // Mobile sidebar rendered via portal to escape stacking context
140
+ const mobileSidebar = mounted && isMobile ? /*#__PURE__*/ createPortal(/*#__PURE__*/ _jsxs(_Fragment, {
141
+ children: [
142
+ isRightSidebarOpen && /*#__PURE__*/ _jsx("div", {
143
+ className: "docs-agent-overlay fixed inset-0 bg-black/50 z-[55] lg:hidden",
144
+ onClick: closeRightSidebar
145
+ }),
146
+ /*#__PURE__*/ _jsx("div", {
147
+ className: cn("docs-agent-panel border-l border-border bg-background flex flex-col overflow-hidden", "fixed inset-y-0 right-0 z-[60] w-[320px] sm:w-[360px] h-full", "transform transition-transform duration-300 ease-in-out", !isRightSidebarOpen && "translate-x-full", isRightSidebarOpen && "translate-x-0"),
148
+ children: sidebarContent
149
+ })
150
+ ]
151
+ }), document.body) : null;
152
+ // Desktop sidebar rendered in place
153
+ const desktopSidebar = !isMobile ? /*#__PURE__*/ _jsx("div", {
154
+ className: cn("docs-agent-panel border-l border-border bg-background flex flex-col overflow-hidden", "relative w-96 h-full"),
155
+ children: sidebarContent
156
+ }) : null;
157
+ return /*#__PURE__*/ _jsxs(_Fragment, {
158
+ children: [
159
+ mobileSidebar,
160
+ desktopSidebar
161
+ ]
162
+ });
163
+ }
@@ -0,0 +1,87 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useState, useRef, useEffect } from 'react';
4
+ import { CaretRight } from '@phosphor-icons/react';
5
+ import { cn } from '@/lib/utils';
6
+ /**
7
+ * Sidebar Group component - collapsible group with toggle
8
+ * Arrow on right side with smooth rotation and expand animations
9
+ */ export function SidebarGroup({ title, children, defaultOpen = false, selected = false, indent = 0, onClick, asideContent, selectedChildSlug }) {
10
+ const [isOpen, setIsOpen] = useState(defaultOpen);
11
+ const contentRef = useRef(null);
12
+ const [contentHeight, setContentHeight] = useState(defaultOpen ? undefined : 0);
13
+ // Auto-expand when a child is selected (e.g., via agent navigation)
14
+ // Triggers on defaultOpen change OR when selectedChildSlug changes (even if defaultOpen stays true)
15
+ useEffect(()=>{
16
+ if (defaultOpen) {
17
+ setIsOpen(true);
18
+ }
19
+ }, [
20
+ defaultOpen,
21
+ selectedChildSlug
22
+ ]);
23
+ // Update height when open state changes
24
+ useEffect(()=>{
25
+ if (isOpen) {
26
+ const height = contentRef.current?.scrollHeight;
27
+ setContentHeight(height);
28
+ // After animation, set to auto for dynamic content
29
+ const timer = setTimeout(()=>setContentHeight(undefined), 200);
30
+ return ()=>clearTimeout(timer);
31
+ } else {
32
+ // First set the current height, then animate to 0
33
+ const height = contentRef.current?.scrollHeight;
34
+ setContentHeight(height);
35
+ requestAnimationFrame(()=>{
36
+ setContentHeight(0);
37
+ });
38
+ }
39
+ }, [
40
+ isOpen
41
+ ]);
42
+ const handleToggle = ()=>{
43
+ setIsOpen(!isOpen);
44
+ onClick?.();
45
+ };
46
+ return /*#__PURE__*/ _jsxs("li", {
47
+ className: "docs-sidebar-group flex flex-col",
48
+ children: [
49
+ /*#__PURE__*/ _jsxs("button", {
50
+ type: "button",
51
+ "aria-expanded": isOpen,
52
+ onClick: handleToggle,
53
+ className: cn(// Base styles
54
+ 'docs-sidebar-group-toggle group/button flex items-center rounded-lg px-3 py-2 w-full text-left', 'text-sm leading-5 transition-colors duration-150', // State variants
55
+ selected ? 'docs-sidebar-group-active bg-sidebar-primary text-sidebar-primary-foreground font-medium' : 'text-sidebar-foreground/80 hover:bg-sidebar-accent/30 hover:text-sidebar-foreground'),
56
+ style: {
57
+ paddingLeft: indent > 0 ? `${indent * 12 + 12}px` : undefined
58
+ },
59
+ children: [
60
+ /*#__PURE__*/ _jsx("span", {
61
+ className: "flex-1 truncate font-medium",
62
+ children: title
63
+ }),
64
+ asideContent && /*#__PURE__*/ _jsx("span", {
65
+ className: "ml-2 shrink-0",
66
+ children: asideContent
67
+ }),
68
+ /*#__PURE__*/ _jsx("span", {
69
+ className: "docs-sidebar-group-icon ml-2 text-sidebar-foreground/50 group-hover/button:text-sidebar-foreground/70",
70
+ children: /*#__PURE__*/ _jsx(CaretRight, {
71
+ weight: "bold",
72
+ className: cn("h-3.5 w-3.5 transition-transform duration-200 ease-out", isOpen && "rotate-90")
73
+ })
74
+ })
75
+ ]
76
+ }),
77
+ /*#__PURE__*/ _jsx("ul", {
78
+ ref: contentRef,
79
+ className: cn("docs-sidebar-group-items flex flex-col overflow-hidden transition-all duration-200 ease-out", !isOpen && "opacity-0", isOpen && "opacity-100"),
80
+ style: {
81
+ height: contentHeight !== undefined ? `${contentHeight}px` : 'auto'
82
+ },
83
+ children: children
84
+ })
85
+ ]
86
+ });
87
+ }
@@ -0,0 +1,172 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useRef, useEffect, useLayoutEffect, useState, createContext, useContext } from 'react';
4
+ import { cn } from '@/lib/utils';
5
+ import { getPhosphorIcon } from '@/lib/utils/icons';
6
+ const SlidingIndicatorContext = /*#__PURE__*/ createContext(null);
7
+ export function SlidingIndicatorProvider({ children, className }) {
8
+ const containerRef = useRef(null);
9
+ const itemsRef = useRef(new Map());
10
+ const [selectedId, setSelectedId] = useState(null);
11
+ const [indicatorStyle, setIndicatorStyle] = useState({
12
+ opacity: 0,
13
+ top: 0,
14
+ height: 0
15
+ });
16
+ const registerItem = (id, element)=>{
17
+ if (element) {
18
+ itemsRef.current.set(id, element);
19
+ } else {
20
+ itemsRef.current.delete(id);
21
+ }
22
+ };
23
+ // Update indicator position when selection changes
24
+ useLayoutEffect(()=>{
25
+ if (!selectedId || !containerRef.current) {
26
+ setIndicatorStyle((prev)=>({
27
+ ...prev,
28
+ opacity: 0
29
+ }));
30
+ return;
31
+ }
32
+ const selectedElement = itemsRef.current.get(selectedId);
33
+ if (!selectedElement) {
34
+ setIndicatorStyle((prev)=>({
35
+ ...prev,
36
+ opacity: 0
37
+ }));
38
+ return;
39
+ }
40
+ const containerRect = containerRef.current.getBoundingClientRect();
41
+ const itemRect = selectedElement.getBoundingClientRect();
42
+ setIndicatorStyle({
43
+ opacity: 1,
44
+ top: itemRect.top - containerRect.top + containerRef.current.scrollTop,
45
+ height: itemRect.height,
46
+ left: 8,
47
+ right: 8
48
+ });
49
+ }, [
50
+ selectedId
51
+ ]);
52
+ // Also update on scroll to keep indicator in sync
53
+ useEffect(()=>{
54
+ const container = containerRef.current;
55
+ if (!container) return;
56
+ const handleScroll = ()=>{
57
+ if (!selectedId) return;
58
+ const selectedElement = itemsRef.current.get(selectedId);
59
+ if (!selectedElement) return;
60
+ const containerRect = container.getBoundingClientRect();
61
+ const itemRect = selectedElement.getBoundingClientRect();
62
+ setIndicatorStyle((prev)=>({
63
+ ...prev,
64
+ top: itemRect.top - containerRect.top + container.scrollTop
65
+ }));
66
+ };
67
+ container.addEventListener('scroll', handleScroll, {
68
+ passive: true
69
+ });
70
+ return ()=>container.removeEventListener('scroll', handleScroll);
71
+ }, [
72
+ selectedId
73
+ ]);
74
+ return /*#__PURE__*/ _jsx(SlidingIndicatorContext.Provider, {
75
+ value: {
76
+ registerItem,
77
+ selectedId,
78
+ setSelectedId
79
+ },
80
+ children: /*#__PURE__*/ _jsxs("div", {
81
+ ref: containerRef,
82
+ className: cn('relative', className),
83
+ children: [
84
+ /*#__PURE__*/ _jsx("div", {
85
+ className: "docs-sidebar-indicator absolute rounded-lg bg-background dark:bg-stone-800/50 pointer-events-none z-0",
86
+ style: {
87
+ ...indicatorStyle,
88
+ transition: 'top 350ms cubic-bezier(0.4, 0, 0.2, 1), height 250ms cubic-bezier(0.4, 0, 0.2, 1), opacity 200ms ease-out'
89
+ }
90
+ }),
91
+ children
92
+ ]
93
+ })
94
+ });
95
+ }
96
+ /**
97
+ * Sidebar Item component - individual clickable item in the sidebar
98
+ * Uses subtle sage/mint style when selected with smooth sliding animation
99
+ */ export function SidebarItem({ children, selected = false, active = false, disabled = false, indent = 0, onClick, className, asideContent, itemId, icon }) {
100
+ const buttonRef = useRef(null);
101
+ const context = useContext(SlidingIndicatorContext);
102
+ const id = itemId || String(children);
103
+ const IconComponent = getPhosphorIcon(icon);
104
+ // Register this item with the sliding indicator provider
105
+ useEffect(()=>{
106
+ if (context && buttonRef.current) {
107
+ context.registerItem(id, buttonRef.current);
108
+ return ()=>context.registerItem(id, null);
109
+ }
110
+ }, [
111
+ context,
112
+ id
113
+ ]);
114
+ // Update selected state in context
115
+ useEffect(()=>{
116
+ if (context && selected) {
117
+ context.setSelectedId(id);
118
+ }
119
+ }, [
120
+ context,
121
+ selected,
122
+ id
123
+ ]);
124
+ // Auto-scroll into view when selected (e.g., via agent navigation)
125
+ useEffect(()=>{
126
+ if (selected && buttonRef.current) {
127
+ // Small delay to allow folder expansion animation to complete
128
+ setTimeout(()=>{
129
+ buttonRef.current?.scrollIntoView({
130
+ behavior: 'smooth',
131
+ block: 'center'
132
+ });
133
+ }, 100);
134
+ }
135
+ }, [
136
+ selected
137
+ ]);
138
+ // Check if we're inside a sliding indicator provider
139
+ const hasSliding = context !== null;
140
+ return /*#__PURE__*/ _jsx("li", {
141
+ className: "docs-sidebar-item-wrapper flex flex-col",
142
+ children: /*#__PURE__*/ _jsxs("button", {
143
+ ref: buttonRef,
144
+ type: "button",
145
+ disabled: disabled,
146
+ "aria-selected": selected,
147
+ onClick: onClick,
148
+ className: cn(// Base styles
149
+ 'docs-sidebar-item group/button flex items-center rounded-lg px-3 py-2 w-full text-left relative z-10', 'text-sm leading-5 transition-colors duration-150', // Indentation
150
+ indent > 0 && `ml-${indent * 3}`, // State variants
151
+ selected ? hasSliding ? 'docs-sidebar-item-active text-green-700 font-semibold dark:text-green-400' // No bg when sliding
152
+ : 'docs-sidebar-item-active bg-background text-green-700 font-semibold dark:bg-stone-800/50 dark:text-green-400' : active ? 'text-sidebar-foreground font-medium hover:bg-sidebar-accent/50' : disabled ? 'text-sidebar-foreground/50 cursor-default' : 'text-sidebar-foreground/80 hover:bg-sidebar-accent/30 hover:text-sidebar-foreground', className),
153
+ style: {
154
+ paddingLeft: indent > 0 ? `${indent * 12 + 12}px` : undefined
155
+ },
156
+ children: [
157
+ IconComponent && /*#__PURE__*/ _jsx(IconComponent, {
158
+ className: "h-4 w-4 mr-2 shrink-0 opacity-60",
159
+ weight: "regular"
160
+ }),
161
+ /*#__PURE__*/ _jsx("span", {
162
+ className: "flex-1 truncate",
163
+ children: children
164
+ }),
165
+ asideContent && /*#__PURE__*/ _jsx("span", {
166
+ className: "ml-2 shrink-0",
167
+ children: asideContent
168
+ })
169
+ ]
170
+ })
171
+ });
172
+ }
@@ -0,0 +1,31 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { cn } from '@/lib/utils';
4
+ import { getPhosphorIcon } from '@/lib/utils/icons';
5
+ /**
6
+ * Sidebar Section component - groups items under a title with optional icon
7
+ */ export function SidebarSection({ title, children, className = '', icon }) {
8
+ const IconComponent = getPhosphorIcon(icon);
9
+ return /*#__PURE__*/ _jsxs("div", {
10
+ className: cn('docs-sidebar-section flex flex-col', className),
11
+ children: [
12
+ /*#__PURE__*/ _jsxs("div", {
13
+ className: "docs-sidebar-section-header flex items-center gap-2 px-4 py-3",
14
+ children: [
15
+ IconComponent && /*#__PURE__*/ _jsx(IconComponent, {
16
+ className: "docs-sidebar-section-icon h-4 w-4 text-sidebar-foreground/70",
17
+ weight: "regular"
18
+ }),
19
+ /*#__PURE__*/ _jsx("span", {
20
+ className: "docs-sidebar-section-title text-sm font-semibold text-sidebar-foreground",
21
+ children: title
22
+ })
23
+ ]
24
+ }),
25
+ /*#__PURE__*/ _jsx("ul", {
26
+ className: "docs-sidebar-section-items flex flex-col gap-0.5 px-2 pb-4",
27
+ children: children
28
+ })
29
+ ]
30
+ });
31
+ }
@@ -0,0 +1,10 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import * as React from "react";
4
+ import { ThemeProvider as NextThemesProvider } from "next-themes";
5
+ export function ThemeProvider({ children, ...props }) {
6
+ return /*#__PURE__*/ _jsx(NextThemesProvider, {
7
+ ...props,
8
+ children: children
9
+ });
10
+ }