@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
@@ -1,154 +0,0 @@
1
- 'use client'
2
-
3
- import React from 'react'
4
- import { cn } from '@/lib/utils'
5
- import {
6
- Info as InfoIcon,
7
- Warning as WarningIcon,
8
- Lightbulb,
9
- Note as NoteIcon,
10
- CheckCircle,
11
- XCircle,
12
- } from '@phosphor-icons/react'
13
-
14
- /**
15
- * Callout Components for MDX Documentation
16
- *
17
- * Mintlify-compatible callout components for highlighting important information.
18
- * Supports: Note, Warning, Info, Tip, Check, Error
19
- */
20
-
21
- interface CalloutProps {
22
- children: React.ReactNode
23
- title?: string
24
- className?: string
25
- }
26
-
27
- type CalloutVariant = 'note' | 'warning' | 'info' | 'tip' | 'check' | 'error'
28
-
29
- const calloutConfig: Record<
30
- CalloutVariant,
31
- {
32
- icon: React.ComponentType<{ className?: string; weight?: 'fill' | 'regular' }>
33
- defaultTitle: string
34
- containerClass: string
35
- iconClass: string
36
- titleClass: string
37
- }
38
- > = {
39
- note: {
40
- icon: NoteIcon,
41
- defaultTitle: 'Note',
42
- containerClass: 'border-blue-500/30 bg-blue-500/10 dark:border-blue-400/30 dark:bg-blue-400/10',
43
- iconClass: 'text-blue-600 dark:text-blue-400',
44
- titleClass: 'text-blue-700 dark:text-blue-300',
45
- },
46
- warning: {
47
- icon: WarningIcon,
48
- defaultTitle: 'Warning',
49
- containerClass: 'border-amber-500/30 bg-amber-500/10 dark:border-amber-400/30 dark:bg-amber-400/10',
50
- iconClass: 'text-amber-600 dark:text-amber-400',
51
- titleClass: 'text-amber-700 dark:text-amber-300',
52
- },
53
- info: {
54
- icon: InfoIcon,
55
- defaultTitle: 'Info',
56
- containerClass: 'border-sky-500/30 bg-sky-500/10 dark:border-sky-400/30 dark:bg-sky-400/10',
57
- iconClass: 'text-sky-600 dark:text-sky-400',
58
- titleClass: 'text-sky-700 dark:text-sky-300',
59
- },
60
- tip: {
61
- icon: Lightbulb,
62
- defaultTitle: 'Tip',
63
- containerClass: 'border-emerald-500/30 bg-emerald-500/10 dark:border-emerald-400/30 dark:bg-emerald-400/10',
64
- iconClass: 'text-emerald-600 dark:text-emerald-400',
65
- titleClass: 'text-emerald-700 dark:text-emerald-300',
66
- },
67
- check: {
68
- icon: CheckCircle,
69
- defaultTitle: 'Success',
70
- containerClass: 'border-green-500/30 bg-green-500/10 dark:border-green-400/30 dark:bg-green-400/10',
71
- iconClass: 'text-green-600 dark:text-green-400',
72
- titleClass: 'text-green-700 dark:text-green-300',
73
- },
74
- error: {
75
- icon: XCircle,
76
- defaultTitle: 'Error',
77
- containerClass: 'border-red-500/30 bg-red-500/10 dark:border-red-400/30 dark:bg-red-400/10',
78
- iconClass: 'text-red-600 dark:text-red-400',
79
- titleClass: 'text-red-700 dark:text-red-300',
80
- },
81
- }
82
-
83
- function BaseCallout({
84
- variant,
85
- children,
86
- title,
87
- className,
88
- }: CalloutProps & { variant: CalloutVariant }) {
89
- const config = calloutConfig[variant]
90
- const Icon = config.icon
91
- const displayTitle = title ?? config.defaultTitle
92
-
93
- return (
94
- <div
95
- className={cn(
96
- `docs-callout docs-callout-${variant} my-4 rounded-lg border p-4`,
97
- config.containerClass,
98
- className
99
- )}
100
- >
101
- <div className="flex items-start gap-3">
102
- <Icon
103
- className={cn('docs-callout-icon mt-0.5 h-5 w-5 shrink-0', config.iconClass)}
104
- weight="fill"
105
- />
106
- <div className="docs-callout-content flex-1 min-w-0">
107
- {displayTitle && (
108
- <div className={cn('docs-callout-title font-semibold text-sm mb-1', config.titleClass)}>
109
- {displayTitle}
110
- </div>
111
- )}
112
- <div className="docs-callout-body text-sm text-foreground/90 [&>p]:mb-2 [&>p:last-child]:mb-0 [&>ul]:mt-2 [&>ol]:mt-2">
113
- {children}
114
- </div>
115
- </div>
116
- </div>
117
- </div>
118
- )
119
- }
120
-
121
- // Individual callout components for MDX usage
122
- export function Note({ children, title, className }: CalloutProps) {
123
- return <BaseCallout variant="note" title={title} className={className}>{children}</BaseCallout>
124
- }
125
-
126
- export function Warning({ children, title, className }: CalloutProps) {
127
- return <BaseCallout variant="warning" title={title} className={className}>{children}</BaseCallout>
128
- }
129
-
130
- export function Info({ children, title, className }: CalloutProps) {
131
- return <BaseCallout variant="info" title={title} className={className}>{children}</BaseCallout>
132
- }
133
-
134
- export function Tip({ children, title, className }: CalloutProps) {
135
- return <BaseCallout variant="tip" title={title} className={className}>{children}</BaseCallout>
136
- }
137
-
138
- export function Check({ children, title, className }: CalloutProps) {
139
- return <BaseCallout variant="check" title={title} className={className}>{children}</BaseCallout>
140
- }
141
-
142
- export function Error({ children, title, className }: CalloutProps) {
143
- return <BaseCallout variant="error" title={title} className={className}>{children}</BaseCallout>
144
- }
145
-
146
- // Generic Callout component with type prop
147
- export function Callout({
148
- type = 'note',
149
- children,
150
- title,
151
- className
152
- }: CalloutProps & { type?: CalloutVariant }) {
153
- return <BaseCallout variant={type} title={title} className={className}>{children}</BaseCallout>
154
- }
@@ -1,241 +0,0 @@
1
- 'use client'
2
-
3
- import React from 'react'
4
- import Link from 'next/link'
5
- import { cn } from '@/lib/utils'
6
- import { ArrowRight, ArrowSquareOut } from '@phosphor-icons/react'
7
- import * as PhosphorIcons from '@phosphor-icons/react'
8
- import { useDocsNavigation } from '@/lib/docs-navigation-context'
9
-
10
- /**
11
- * Card Components for MDX Documentation
12
- *
13
- * Mintlify-compatible card components for navigation and content organization.
14
- * Supports both ApiDocs hash-based navigation and standalone /docs route navigation.
15
- */
16
-
17
- interface CardProps {
18
- title: string
19
- children?: React.ReactNode
20
- icon?: string | React.ReactNode // Icon name (string) or custom React node
21
- iconSize?: 'sm' | 'md' | 'lg' | 'xl' // Size of icon container: sm=32px, md=40px (default), lg=48px, xl=64px
22
- href?: string
23
- horizontal?: boolean
24
- img?: string // Full-width header image
25
- cta?: string
26
- arrow?: boolean
27
- className?: string
28
- }
29
-
30
- // Dynamic icon resolver for Phosphor icons
31
- function getIcon(iconName: string): React.ComponentType<{ className?: string; weight?: string }> | null {
32
- if (!iconName) return null
33
-
34
- // Convert kebab-case or snake_case to PascalCase
35
- const pascalCase = iconName
36
- .split(/[-_]/)
37
- .map(word => word.charAt(0).toUpperCase() + word.slice(1).toLowerCase())
38
- .join('')
39
-
40
- // Try to get the icon from Phosphor
41
- const Icon = (PhosphorIcons as Record<string, unknown>)[pascalCase] as React.ComponentType<{ className?: string; weight?: string }> | undefined
42
- return Icon || null
43
- }
44
-
45
- // Icon size configurations
46
- const ICON_SIZES = {
47
- sm: { container: 'h-8 w-8', icon: 'h-4 w-4', img: 'h-5 w-5' },
48
- md: { container: 'h-10 w-10', icon: 'h-5 w-5', img: 'h-6 w-6' },
49
- lg: { container: 'h-12 w-12', icon: 'h-6 w-6', img: 'h-8 w-8' },
50
- xl: { container: 'h-16 w-16', icon: 'h-8 w-8', img: 'h-12 w-12' },
51
- }
52
-
53
- export function Card({
54
- title,
55
- children,
56
- icon,
57
- iconSize = 'md',
58
- href,
59
- horizontal = false,
60
- img,
61
- cta,
62
- arrow,
63
- className,
64
- }: CardProps) {
65
- // Check if icon is a string (icon name) or React node
66
- const isIconString = typeof icon === 'string'
67
- const Icon = isIconString ? getIcon(icon) : null
68
- const hasCustomIcon = !isIconString && icon != null
69
- const sizeConfig = ICON_SIZES[iconSize]
70
- const isExternal = href?.startsWith('http') || href?.startsWith('//')
71
- const docsNav = useDocsNavigation()
72
-
73
- // Check if this is a tab switch link (/api-reference, /changelog)
74
- const isTabSwitchLink = (href === '/api-reference' || href === '/changelog') && docsNav?.isApiDocsView
75
-
76
- // Check if this is an internal docs link (starts with / but not external or tab switch)
77
- const isInternalDocsLink = href?.startsWith('/') && !isExternal && !isTabSwitchLink && docsNav?.isApiDocsView
78
-
79
- // Extract slug from href - removes /docs/ prefix if present, or just the leading /
80
- const getSlugFromHref = (path: string): string => {
81
- let slug = path
82
- if (slug.startsWith('/docs/')) {
83
- slug = slug.slice(6) // Remove '/docs/'
84
- } else if (slug.startsWith('/')) {
85
- slug = slug.slice(1) // Remove leading '/'
86
- }
87
- return slug
88
- }
89
-
90
- // Get tab ID from href
91
- const getTabIdFromHref = (path: string): string => {
92
- if (path === '/api-reference') return 'api-reference'
93
- if (path === '/changelog') return 'changelog'
94
- return 'docs'
95
- }
96
-
97
- // Handle click for internal navigation
98
- const handleClick = (e: React.MouseEvent) => {
99
- if (!href || !docsNav) return
100
-
101
- if (isTabSwitchLink) {
102
- e.preventDefault()
103
- const tabId = getTabIdFromHref(href)
104
- docsNav.switchToTab(tabId)
105
- } else if (isInternalDocsLink) {
106
- e.preventDefault()
107
- const slug = getSlugFromHref(href)
108
- docsNav.navigateToPage(slug)
109
- }
110
- }
111
- const showArrow = arrow ?? isExternal
112
-
113
- const cardContent = (
114
- <div
115
- className={cn(
116
- 'docs-card group relative rounded-lg border border-border bg-card p-4 transition-all h-full',
117
- href && 'hover:border-primary/50 hover:shadow-md cursor-pointer',
118
- horizontal ? 'docs-card-horizontal flex items-start gap-4' : 'flex flex-col justify-start',
119
- className
120
- )}
121
- >
122
- {/* Image */}
123
- {img && !horizontal && (
124
- <div className="mb-4 -mx-4 -mt-4 overflow-hidden rounded-t-lg">
125
- <img
126
- src={img}
127
- alt={title}
128
- className="w-full h-auto object-cover"
129
- />
130
- </div>
131
- )}
132
-
133
- {/* Icon (Phosphor icon from string) */}
134
- {Icon && (
135
- <div
136
- className={cn(
137
- 'docs-card-icon flex shrink-0 items-center justify-center rounded-lg',
138
- sizeConfig.container,
139
- 'bg-primary/10 text-primary',
140
- horizontal && 'mt-0.5'
141
- )}
142
- >
143
- <Icon className={sizeConfig.icon} weight="duotone" />
144
- </div>
145
- )}
146
-
147
- {/* Custom Icon (React node - image, svg, etc.) */}
148
- {hasCustomIcon && (
149
- <div
150
- className={cn(
151
- 'docs-card-icon flex shrink-0 items-center justify-center rounded-lg overflow-hidden',
152
- sizeConfig.container,
153
- horizontal && 'mt-0.5'
154
- )}
155
- >
156
- {icon}
157
- </div>
158
- )}
159
-
160
- {/* Content */}
161
- <div className={cn('docs-card-content min-w-0', horizontal && 'flex-1', !horizontal && (Icon || hasCustomIcon) && 'mt-3')}>
162
- <div className="flex items-center gap-2">
163
- <h3 className="docs-card-title font-semibold text-foreground group-hover:text-primary transition-colors">
164
- {title}
165
- </h3>
166
- {showArrow && (
167
- isExternal ? (
168
- <ArrowSquareOut className="h-4 w-4 text-muted-foreground" />
169
- ) : (
170
- <ArrowRight className="h-4 w-4 text-muted-foreground opacity-0 -translate-x-2 group-hover:opacity-100 group-hover:translate-x-0 transition-all" />
171
- )
172
- )}
173
- </div>
174
-
175
- {children && (
176
- <div className="docs-card-description mt-1 text-sm text-muted-foreground">
177
- {children}
178
- </div>
179
- )}
180
-
181
- {cta && (
182
- <div className="docs-card-cta mt-3 text-sm font-medium text-primary">
183
- {cta}
184
- </div>
185
- )}
186
- </div>
187
- </div>
188
- )
189
-
190
- if (href) {
191
- if (isExternal) {
192
- return (
193
- <a href={href} target="_blank" rel="noopener noreferrer" className="docs-card-link block h-full">
194
- {cardContent}
195
- </a>
196
- )
197
- }
198
-
199
- // For internal docs links or tab switch links in ApiDocs view, use click handler
200
- if (isInternalDocsLink || isTabSwitchLink) {
201
- return (
202
- <a href={href} onClick={handleClick} className="docs-card-link block h-full cursor-pointer">
203
- {cardContent}
204
- </a>
205
- )
206
- }
207
-
208
- // Standard Next.js Link for all other internal links
209
- return (
210
- <Link href={href} className="docs-card-link block h-full">
211
- {cardContent}
212
- </Link>
213
- )
214
- }
215
-
216
- return cardContent
217
- }
218
-
219
- interface CardGroupProps {
220
- children: React.ReactNode
221
- cols?: 1 | 2 | 3 | 4
222
- className?: string
223
- }
224
-
225
- export function CardGroup({ children, cols = 2, className }: CardGroupProps) {
226
- const gridCols = {
227
- 1: 'grid-cols-1',
228
- 2: 'grid-cols-1 sm:grid-cols-2',
229
- 3: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-3',
230
- 4: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4',
231
- }
232
-
233
- return (
234
- <div className={cn('docs-card-group grid gap-4 my-4', gridCols[cols], className)}>
235
- {children}
236
- </div>
237
- )
238
- }
239
-
240
- // Alias for Mintlify compatibility
241
- export { CardGroup as Columns }
@@ -1,120 +0,0 @@
1
- 'use client'
2
-
3
- import { ReactNode } from 'react'
4
- import { Warning } from '@phosphor-icons/react'
5
- import { cn } from '@/lib/utils'
6
-
7
- interface ChangelogEntryProps {
8
- version: string
9
- date: string
10
- children: ReactNode
11
- }
12
-
13
- export function ChangelogEntry({ version, date, children }: ChangelogEntryProps) {
14
- return (
15
- <div
16
- data-version={version}
17
- className="flex gap-6 lg:gap-10 py-8 border-b border-border last:border-b-0"
18
- >
19
- {/* Left column - Version and date */}
20
- <div className="w-24 lg:w-32 shrink-0">
21
- <span className="inline-block px-2.5 py-1 text-sm font-medium rounded-md bg-amber-100 text-amber-800 dark:bg-amber-900/30 dark:text-amber-400 border border-amber-200 dark:border-amber-800">
22
- {version}
23
- </span>
24
- <p className="mt-2 text-sm text-muted-foreground">{date}</p>
25
- </div>
26
-
27
- {/* Right column - Content */}
28
- <div className="flex-1 min-w-0">
29
- {children}
30
- </div>
31
- </div>
32
- )
33
- }
34
-
35
- interface ChangelogTitleProps {
36
- children: ReactNode
37
- className?: string
38
- }
39
-
40
- export function ChangelogTitle({ children, className }: ChangelogTitleProps) {
41
- return (
42
- <h2 className={cn("text-xl font-semibold text-foreground mb-3", className)}>
43
- {children}
44
- </h2>
45
- )
46
- }
47
-
48
- interface ChangelogDescriptionProps {
49
- children: ReactNode
50
- }
51
-
52
- export function ChangelogDescription({ children }: ChangelogDescriptionProps) {
53
- return (
54
- <p className="text-muted-foreground mb-4">
55
- {children}
56
- </p>
57
- )
58
- }
59
-
60
- interface ChangelogImageProps {
61
- src: string
62
- alt?: string
63
- }
64
-
65
- export function ChangelogImage({ src, alt = "Screenshot" }: ChangelogImageProps) {
66
- return (
67
- <div className="my-6 rounded-lg border border-border overflow-hidden shadow-sm">
68
- <img src={src} alt={alt} className="w-full" />
69
- </div>
70
- )
71
- }
72
-
73
- interface BreakingChangeProps {
74
- children: ReactNode
75
- }
76
-
77
- export function BreakingChange({ children }: BreakingChangeProps) {
78
- return (
79
- <div className="my-6 flex gap-3 p-4 rounded-lg bg-amber-50 dark:bg-amber-950/30 border border-amber-200 dark:border-amber-800">
80
- <Warning className="h-5 w-5 text-amber-600 dark:text-amber-500 shrink-0 mt-0.5" weight="fill" />
81
- <div className="text-amber-800 dark:text-amber-200 text-sm">
82
- {children}
83
- </div>
84
- </div>
85
- )
86
- }
87
-
88
- interface MoreUpdatesProps {
89
- children: ReactNode
90
- }
91
-
92
- export function MoreUpdates({ children }: MoreUpdatesProps) {
93
- return (
94
- <div className="mt-6">
95
- <h3 className="text-lg font-semibold text-foreground mb-3">More Updates</h3>
96
- <ul className="space-y-2 text-muted-foreground">
97
- {children}
98
- </ul>
99
- </div>
100
- )
101
- }
102
-
103
- interface UpdateItemProps {
104
- children: ReactNode
105
- type?: 'default' | 'behavior'
106
- }
107
-
108
- export function UpdateItem({ children, type = 'default' }: UpdateItemProps) {
109
- return (
110
- <li className="flex items-start gap-2">
111
- <span className="mt-2 h-1.5 w-1.5 rounded-full bg-foreground shrink-0" />
112
- <span>
113
- {type === 'behavior' && (
114
- <strong className="font-semibold text-foreground">Behavior Change </strong>
115
- )}
116
- {children}
117
- </span>
118
- </li>
119
- )
120
- }
@@ -1,186 +0,0 @@
1
- 'use client'
2
-
3
- import React, { useState, isValidElement, ReactNode, createContext, useContext } from 'react'
4
- import { cn } from '@/lib/utils'
5
- import { Copy, Check } from '@phosphor-icons/react'
6
-
7
- /**
8
- * Pre and Code components for code block styling
9
- */
10
-
11
- // Context to detect if we're inside a CodeGroup
12
- export const CodeGroupContext = createContext(false)
13
-
14
- // Extract text content from nested React elements
15
- function extractTextContent(node: ReactNode): string {
16
- if (typeof node === 'string') return node
17
- if (typeof node === 'number') return String(node)
18
- if (Array.isArray(node)) return node.map(extractTextContent).join('')
19
- if (isValidElement(node)) {
20
- const props = node.props as { children?: ReactNode }
21
- if (props.children) {
22
- return extractTextContent(props.children)
23
- }
24
- }
25
- return ''
26
- }
27
-
28
- // Get display name for language
29
- function getDisplayName(language: string): string {
30
- const displayNames: Record<string, string> = {
31
- javascript: 'JavaScript',
32
- typescript: 'TypeScript',
33
- python: 'Python',
34
- java: 'Java',
35
- go: 'Go',
36
- rust: 'Rust',
37
- ruby: 'Ruby',
38
- php: 'PHP',
39
- csharp: 'C#',
40
- cpp: 'C++',
41
- c: 'C',
42
- swift: 'Swift',
43
- kotlin: 'Kotlin',
44
- bash: 'Bash',
45
- shell: 'Shell',
46
- json: 'JSON',
47
- yaml: 'YAML',
48
- html: 'HTML',
49
- css: 'CSS',
50
- sql: 'SQL',
51
- markdown: 'Markdown',
52
- text: 'Text',
53
- plaintext: 'Text',
54
- }
55
- return displayNames[language.toLowerCase()] || language.charAt(0).toUpperCase() + language.slice(1)
56
- }
57
-
58
- /**
59
- * Pre - Code block wrapper component
60
- * Styled to match CodeGroup default variant
61
- */
62
- interface PreProps extends React.HTMLAttributes<HTMLPreElement> {
63
- children?: ReactNode
64
- 'data-language'?: string
65
- }
66
-
67
- export function Pre({ children, className, 'data-language': dataLanguage, ...props }: PreProps) {
68
- const isInCodeGroup = useContext(CodeGroupContext)
69
- const [copied, setCopied] = useState(false)
70
-
71
- // If inside CodeGroup, render plain pre (CodeGroup handles styling)
72
- if (isInCodeGroup) {
73
- return (
74
- <pre className={cn('overflow-x-auto', className)} {...props}>
75
- {children}
76
- </pre>
77
- )
78
- }
79
-
80
- // Extract language from children's className or data attribute
81
- let language = dataLanguage || 'text'
82
- let content = ''
83
-
84
- if (isValidElement(children)) {
85
- const childProps = children.props as { className?: string; children?: ReactNode }
86
- const childClassName = childProps.className || ''
87
- const match = childClassName.match(/language-(\w+)/)
88
- if (match) {
89
- language = match[1]
90
- }
91
- content = extractTextContent(childProps.children)
92
- }
93
-
94
- const handleCopy = async () => {
95
- try {
96
- await navigator.clipboard.writeText(content.trim())
97
- setCopied(true)
98
- setTimeout(() => setCopied(false), 2000)
99
- } catch (err) {
100
- console.error('Failed to copy:', err)
101
- }
102
- }
103
-
104
- const displayName = getDisplayName(language)
105
-
106
- // Standalone code block - styled like CodeGroup
107
- return (
108
- <div className="docs-code-block my-4 rounded-xl border border-zinc-800 overflow-hidden bg-[#1a1a1a]">
109
- {/* Header */}
110
- <div className="docs-code-header flex items-center justify-between bg-[#262626] px-2">
111
- <div className="flex overflow-x-auto">
112
- <div className="docs-code-tab px-4 py-2.5 text-sm font-medium whitespace-nowrap text-white relative">
113
- {displayName}
114
- <span className="absolute bottom-0 left-0 right-0 h-0.5 bg-emerald-500 rounded-full" />
115
- </div>
116
- </div>
117
-
118
- {/* Copy button */}
119
- <div className="docs-code-actions flex items-center gap-1 pr-2">
120
- <button
121
- type="button"
122
- onClick={handleCopy}
123
- className={cn(
124
- 'p-1.5 rounded text-zinc-500 hover:text-zinc-300',
125
- 'hover:bg-zinc-700/50 transition-colors',
126
- 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary/50'
127
- )}
128
- title="Copy code"
129
- >
130
- {copied ? (
131
- <Check className="h-4 w-4 text-emerald-500" weight="bold" />
132
- ) : (
133
- <Copy className="h-4 w-4" />
134
- )}
135
- </button>
136
- </div>
137
- </div>
138
-
139
- {/* Code content */}
140
- <div className="docs-code-content overflow-x-auto">
141
- <pre
142
- className={cn(
143
- 'p-4 m-0 bg-transparent text-sm',
144
- className
145
- )}
146
- {...props}
147
- >
148
- {children}
149
- </pre>
150
- </div>
151
- </div>
152
- )
153
- }
154
-
155
- /**
156
- * Code - Inline code styling
157
- */
158
- interface CodeProps extends React.HTMLAttributes<HTMLElement> {
159
- children?: ReactNode
160
- }
161
-
162
- export function Code({ children, className, ...props }: CodeProps) {
163
- const isCodeBlock = className?.includes('language-')
164
-
165
- if (isCodeBlock) {
166
- return (
167
- <code className={cn(className, 'bg-transparent')} {...props}>
168
- {children}
169
- </code>
170
- )
171
- }
172
-
173
- // Inline code
174
- return (
175
- <code
176
- className={cn(
177
- 'docs-inline-code px-1.5 py-0.5 rounded text-sm font-mono',
178
- 'bg-zinc-800 text-zinc-200',
179
- className
180
- )}
181
- {...props}
182
- >
183
- {children}
184
- </code>
185
- )
186
- }