@brainfish-ai/devdoc 0.1.41 → 0.1.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (400) hide show
  1. package/ai-agents/.claude/skills/bootstrap-docs/SKILL.md +710 -79
  2. package/ai-agents/.claude/skills/check-docs/SKILL.md +83 -8
  3. package/ai-agents/.claude/skills/create-doc/SKILL.md +267 -55
  4. package/ai-agents/.claude/skills/update-doc/SKILL.md +162 -63
  5. package/ai-agents/.cursor/rules/devdoc-bootstrap.mdc +145 -15
  6. package/ai-agents/.cursor/rules/devdoc-create.mdc +108 -57
  7. package/ai-agents/.cursor/rules/devdoc-update.mdc +93 -70
  8. package/ai-agents/.cursor/rules/devdoc.mdc +21 -0
  9. package/ai-agents/schemas/docs.schema.json +332 -0
  10. package/ai-agents/schemas/theme.schema.json +243 -0
  11. package/dist/cli/commands/create.js +4 -9
  12. package/dist/cli/commands/deploy.js +50 -25
  13. package/dist/cli/commands/dev.js +19 -10
  14. package/package.json +3 -2
  15. package/renderer/app/api/assets/[...path]/route.js +108 -0
  16. package/renderer/app/api/assets/route.js +114 -0
  17. package/renderer/app/api/assets/upload/route.js +163 -0
  18. package/renderer/app/api/auth-schemes/route.js +58 -0
  19. package/renderer/app/api/chat/route.js +759 -0
  20. package/renderer/app/api/codegen/route.js +52 -0
  21. package/renderer/app/api/collections/route.js +675 -0
  22. package/renderer/app/api/debug/route.js +47 -0
  23. package/renderer/app/api/deploy/route.js +199 -0
  24. package/renderer/app/api/device/route.js +36 -0
  25. package/renderer/app/api/docs/route.js +205 -0
  26. package/renderer/app/api/domains/add/route.js +121 -0
  27. package/renderer/app/api/domains/lookup/route.js +43 -0
  28. package/renderer/app/api/domains/remove/route.js +89 -0
  29. package/renderer/app/api/domains/status/route.js +140 -0
  30. package/renderer/app/api/domains/verify/route.js +168 -0
  31. package/renderer/app/api/keys/regenerate/route.js +71 -0
  32. package/renderer/app/api/local-assets/[...path]/route.js +108 -0
  33. package/renderer/app/api/openapi-spec/route.js +73 -0
  34. package/renderer/app/api/projects/[slug]/route.js +129 -0
  35. package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
  36. package/renderer/app/api/projects/register/route.js +176 -0
  37. package/renderer/app/api/proxy/route.js +139 -0
  38. package/renderer/app/api/proxy-stream/route.js +156 -0
  39. package/renderer/app/api/redirects/route.js +35 -0
  40. package/renderer/app/api/schema/route.js +85 -0
  41. package/renderer/app/api/subdomains/check/route.js +158 -0
  42. package/renderer/app/api/suggestions/route.js +175 -0
  43. package/renderer/app/layout.js +47 -0
  44. package/renderer/app/llms-full.txt/route.js +257 -0
  45. package/renderer/app/llms.txt/route.js +219 -0
  46. package/renderer/app/page.js +12 -0
  47. package/renderer/app/robots.txt/route.js +66 -0
  48. package/renderer/app/sitemap.xml/route.js +145 -0
  49. package/renderer/components/docs/index.js +8 -0
  50. package/renderer/components/docs/mdx/accordion.js +113 -0
  51. package/renderer/components/docs/mdx/badge.js +72 -0
  52. package/renderer/components/docs/mdx/callouts.js +137 -0
  53. package/renderer/components/docs/mdx/cards.js +175 -0
  54. package/renderer/components/docs/mdx/changelog.js +100 -0
  55. package/renderer/components/docs/mdx/code-block.js +147 -0
  56. package/renderer/components/docs/mdx/code-group.js +287 -0
  57. package/renderer/components/docs/mdx/file-embeds.js +82 -0
  58. package/renderer/components/docs/mdx/frame.js +59 -0
  59. package/renderer/components/docs/mdx/highlight.js +90 -0
  60. package/renderer/components/docs/mdx/iframe.js +69 -0
  61. package/renderer/components/docs/mdx/image.js +135 -0
  62. package/renderer/components/docs/mdx/index.js +134 -0
  63. package/renderer/components/docs/mdx/landing.js +315 -0
  64. package/renderer/components/docs/mdx/mermaid.js +212 -0
  65. package/renderer/components/docs/mdx/param-field.js +112 -0
  66. package/renderer/components/docs/mdx/steps.js +74 -0
  67. package/renderer/components/docs/mdx/tabs.js +50 -0
  68. package/renderer/components/docs/mdx-renderer.js +77 -0
  69. package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
  70. package/renderer/components/docs/navigation/index.js +6 -0
  71. package/renderer/components/docs/navigation/page-nav.js +57 -0
  72. package/renderer/components/docs/navigation/sidebar.js +375 -0
  73. package/renderer/components/docs/navigation/toc.js +89 -0
  74. package/renderer/components/docs/notice.js +77 -0
  75. package/renderer/components/docs-header.js +202 -0
  76. package/renderer/components/docs-viewer/agent/agent-chat.js +1930 -0
  77. package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
  78. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
  79. package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
  80. package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
  81. package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
  82. package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
  83. package/renderer/components/docs-viewer/agent/index.js +4 -0
  84. package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
  85. package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
  86. package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
  87. package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
  88. package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
  89. package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
  90. package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
  91. package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
  92. package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
  93. package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
  94. package/renderer/components/docs-viewer/content/doc-page.js +264 -0
  95. package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
  96. package/renderer/components/docs-viewer/content/index.js +29 -0
  97. package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
  98. package/renderer/components/docs-viewer/content/request-details.js +528 -0
  99. package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
  100. package/renderer/components/docs-viewer/content/sections/body.js +80 -0
  101. package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
  102. package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
  103. package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
  104. package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
  105. package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
  106. package/renderer/components/docs-viewer/index.js +1552 -0
  107. package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
  108. package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
  109. package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
  110. package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
  111. package/renderer/components/docs-viewer/playground/graphql-playground.js +734 -0
  112. package/renderer/components/docs-viewer/playground/index.js +682 -0
  113. package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
  114. package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
  115. package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
  116. package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
  117. package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
  118. package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
  119. package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
  120. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
  121. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
  122. package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
  123. package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
  124. package/renderer/components/docs-viewer/search/index.js +2 -0
  125. package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
  126. package/renderer/components/docs-viewer/search/use-search.js +89 -0
  127. package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
  128. package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
  129. package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
  130. package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
  131. package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
  132. package/renderer/components/docs-viewer/sidebar/index.js +196 -0
  133. package/renderer/components/docs-viewer/sidebar/right-sidebar.js +163 -0
  134. package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
  135. package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
  136. package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
  137. package/renderer/components/theme-provider.js +10 -0
  138. package/renderer/components/theme-toggle.js +106 -0
  139. package/renderer/components/ui/badge.js +29 -0
  140. package/renderer/components/ui/button.js +40 -0
  141. package/renderer/components/ui/dialog.js +50 -0
  142. package/renderer/components/ui/dropdown-menu.js +143 -0
  143. package/renderer/components/ui/input.js +12 -0
  144. package/renderer/components/ui/label.js +13 -0
  145. package/renderer/components/ui/navigation-menu.js +83 -0
  146. package/renderer/components/ui/select.js +116 -0
  147. package/renderer/components/ui/spinner.js +92 -0
  148. package/renderer/components/ui/tabs.js +34 -0
  149. package/renderer/components/ui/tooltip.js +43 -0
  150. package/renderer/hooks/use-code-copy.js +76 -0
  151. package/renderer/hooks/use-openapi-title.js +33 -0
  152. package/renderer/lib/api-docs/agent/index.js +4 -0
  153. package/renderer/lib/api-docs/agent/indexer.js +254 -0
  154. package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
  155. package/renderer/lib/api-docs/agent/types.js +5 -0
  156. package/renderer/lib/api-docs/auth/auth-context.js +157 -0
  157. package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
  158. package/renderer/lib/api-docs/auth/crypto.js +64 -0
  159. package/renderer/lib/api-docs/auth/index.js +3 -0
  160. package/renderer/lib/api-docs/code-editor/db.js +145 -0
  161. package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
  162. package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
  163. package/renderer/lib/api-docs/code-editor/mode-context.js +154 -0
  164. package/renderer/lib/api-docs/code-editor/types.js +53 -0
  165. package/renderer/lib/api-docs/codegen/definitions.js +258 -0
  166. package/renderer/lib/api-docs/codegen/har.js +171 -0
  167. package/renderer/lib/api-docs/codegen/index.js +118 -0
  168. package/renderer/lib/api-docs/factories.js +136 -0
  169. package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
  170. package/renderer/lib/api-docs/mobile-context.js +79 -0
  171. package/renderer/lib/api-docs/navigation-context.js +62 -0
  172. package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
  173. package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
  174. package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
  175. package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
  176. package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
  177. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
  178. package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
  179. package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
  180. package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
  181. package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
  182. package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
  183. package/renderer/lib/api-docs/playground/context.js +65 -0
  184. package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
  185. package/renderer/lib/api-docs/playground/request-builder.js +163 -0
  186. package/renderer/lib/api-docs/playground/request-runner.js +224 -0
  187. package/renderer/lib/api-docs/playground/types.js +5 -0
  188. package/renderer/lib/api-docs/types.js +23 -0
  189. package/renderer/lib/api-docs/utils.js +212 -0
  190. package/renderer/lib/cache.js +157 -0
  191. package/renderer/lib/docs/config/domain-schema.js +161 -0
  192. package/renderer/lib/docs/config/index.js +5 -0
  193. package/renderer/lib/docs/config/loader.js +113 -0
  194. package/renderer/lib/docs/config/schema.js +269 -0
  195. package/renderer/lib/docs/index.js +8 -0
  196. package/renderer/lib/docs/mdx/compiler.js +128 -0
  197. package/renderer/lib/docs/mdx/frontmatter.js +73 -0
  198. package/renderer/lib/docs/mdx/index.js +8 -0
  199. package/renderer/lib/docs/navigation/generator.js +269 -0
  200. package/renderer/lib/docs/navigation/index.js +4 -0
  201. package/renderer/lib/docs/navigation/types.js +9 -0
  202. package/renderer/lib/docs-navigation-context.js +40 -0
  203. package/renderer/lib/multi-tenant/context.js +80 -0
  204. package/renderer/lib/storage/blob.js +767 -0
  205. package/renderer/lib/utils/icons.js +30 -0
  206. package/renderer/lib/utils.js +5 -0
  207. package/renderer/next.config.js +62 -0
  208. package/renderer/tsconfig.json +23 -5
  209. package/renderer/app/api/assets/[...path]/route.ts +0 -123
  210. package/renderer/app/api/assets/route.ts +0 -124
  211. package/renderer/app/api/assets/upload/route.ts +0 -177
  212. package/renderer/app/api/auth-schemes/route.ts +0 -77
  213. package/renderer/app/api/chat/route.ts +0 -858
  214. package/renderer/app/api/codegen/route.ts +0 -72
  215. package/renderer/app/api/collections/route.ts +0 -1002
  216. package/renderer/app/api/debug/route.ts +0 -53
  217. package/renderer/app/api/deploy/route.ts +0 -234
  218. package/renderer/app/api/device/route.ts +0 -42
  219. package/renderer/app/api/docs/route.ts +0 -201
  220. package/renderer/app/api/domains/add/route.ts +0 -132
  221. package/renderer/app/api/domains/lookup/route.ts +0 -43
  222. package/renderer/app/api/domains/remove/route.ts +0 -100
  223. package/renderer/app/api/domains/status/route.ts +0 -158
  224. package/renderer/app/api/domains/verify/route.ts +0 -181
  225. package/renderer/app/api/keys/regenerate/route.ts +0 -80
  226. package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
  227. package/renderer/app/api/openapi-spec/route.ts +0 -151
  228. package/renderer/app/api/projects/[slug]/route.ts +0 -153
  229. package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
  230. package/renderer/app/api/projects/register/route.ts +0 -152
  231. package/renderer/app/api/proxy/route.ts +0 -149
  232. package/renderer/app/api/proxy-stream/route.ts +0 -168
  233. package/renderer/app/api/redirects/route.ts +0 -47
  234. package/renderer/app/api/schema/route.ts +0 -73
  235. package/renderer/app/api/subdomains/check/route.ts +0 -172
  236. package/renderer/app/api/suggestions/route.ts +0 -144
  237. package/renderer/app/layout.tsx +0 -54
  238. package/renderer/app/llms-full.txt/route.ts +0 -346
  239. package/renderer/app/llms.txt/route.ts +0 -279
  240. package/renderer/app/page.tsx +0 -14
  241. package/renderer/app/robots.txt/route.ts +0 -84
  242. package/renderer/app/sitemap.xml/route.ts +0 -199
  243. package/renderer/components/docs/index.ts +0 -12
  244. package/renderer/components/docs/mdx/accordion.tsx +0 -169
  245. package/renderer/components/docs/mdx/badge.tsx +0 -132
  246. package/renderer/components/docs/mdx/callouts.tsx +0 -154
  247. package/renderer/components/docs/mdx/cards.tsx +0 -241
  248. package/renderer/components/docs/mdx/changelog.tsx +0 -120
  249. package/renderer/components/docs/mdx/code-block.tsx +0 -186
  250. package/renderer/components/docs/mdx/code-group.tsx +0 -421
  251. package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
  252. package/renderer/components/docs/mdx/frame.tsx +0 -112
  253. package/renderer/components/docs/mdx/highlight.tsx +0 -151
  254. package/renderer/components/docs/mdx/iframe.tsx +0 -134
  255. package/renderer/components/docs/mdx/image.tsx +0 -235
  256. package/renderer/components/docs/mdx/index.ts +0 -237
  257. package/renderer/components/docs/mdx/landing.tsx +0 -684
  258. package/renderer/components/docs/mdx/mermaid.tsx +0 -240
  259. package/renderer/components/docs/mdx/param-field.tsx +0 -200
  260. package/renderer/components/docs/mdx/steps.tsx +0 -113
  261. package/renderer/components/docs/mdx/tabs.tsx +0 -86
  262. package/renderer/components/docs/mdx-renderer.tsx +0 -100
  263. package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
  264. package/renderer/components/docs/navigation/index.ts +0 -8
  265. package/renderer/components/docs/navigation/page-nav.tsx +0 -64
  266. package/renderer/components/docs/navigation/sidebar.tsx +0 -515
  267. package/renderer/components/docs/navigation/toc.tsx +0 -113
  268. package/renderer/components/docs/notice.tsx +0 -105
  269. package/renderer/components/docs-header.tsx +0 -278
  270. package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
  271. package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
  272. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
  273. package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
  274. package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
  275. package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
  276. package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
  277. package/renderer/components/docs-viewer/agent/index.tsx +0 -6
  278. package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
  279. package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
  280. package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
  281. package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
  282. package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
  283. package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
  284. package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
  285. package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
  286. package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
  287. package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
  288. package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
  289. package/renderer/components/docs-viewer/content/index.tsx +0 -29
  290. package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
  291. package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
  292. package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
  293. package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
  294. package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
  295. package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
  296. package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
  297. package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
  298. package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
  299. package/renderer/components/docs-viewer/index.tsx +0 -1662
  300. package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
  301. package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
  302. package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
  303. package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
  304. package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
  305. package/renderer/components/docs-viewer/playground/index.tsx +0 -671
  306. package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
  307. package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
  308. package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
  309. package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
  310. package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
  311. package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
  312. package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
  313. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
  314. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
  315. package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
  316. package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
  317. package/renderer/components/docs-viewer/search/index.ts +0 -2
  318. package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
  319. package/renderer/components/docs-viewer/search/use-search.ts +0 -117
  320. package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
  321. package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
  322. package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
  323. package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
  324. package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
  325. package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
  326. package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
  327. package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
  328. package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
  329. package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
  330. package/renderer/components/theme-provider.tsx +0 -11
  331. package/renderer/components/theme-toggle.tsx +0 -76
  332. package/renderer/components/ui/badge.tsx +0 -46
  333. package/renderer/components/ui/button.tsx +0 -59
  334. package/renderer/components/ui/dialog.tsx +0 -118
  335. package/renderer/components/ui/dropdown-menu.tsx +0 -257
  336. package/renderer/components/ui/input.tsx +0 -21
  337. package/renderer/components/ui/label.tsx +0 -24
  338. package/renderer/components/ui/navigation-menu.tsx +0 -168
  339. package/renderer/components/ui/select.tsx +0 -190
  340. package/renderer/components/ui/spinner.tsx +0 -114
  341. package/renderer/components/ui/tabs.tsx +0 -66
  342. package/renderer/components/ui/tooltip.tsx +0 -61
  343. package/renderer/hooks/use-code-copy.ts +0 -88
  344. package/renderer/hooks/use-openapi-title.ts +0 -44
  345. package/renderer/lib/api-docs/agent/index.ts +0 -6
  346. package/renderer/lib/api-docs/agent/indexer.ts +0 -323
  347. package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
  348. package/renderer/lib/api-docs/agent/types.ts +0 -116
  349. package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
  350. package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
  351. package/renderer/lib/api-docs/auth/crypto.ts +0 -89
  352. package/renderer/lib/api-docs/auth/index.ts +0 -4
  353. package/renderer/lib/api-docs/code-editor/db.ts +0 -164
  354. package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
  355. package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
  356. package/renderer/lib/api-docs/code-editor/types.ts +0 -105
  357. package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
  358. package/renderer/lib/api-docs/codegen/har.ts +0 -251
  359. package/renderer/lib/api-docs/codegen/index.ts +0 -159
  360. package/renderer/lib/api-docs/factories.ts +0 -170
  361. package/renderer/lib/api-docs/mobile-context.tsx +0 -112
  362. package/renderer/lib/api-docs/navigation-context.tsx +0 -88
  363. package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
  364. package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
  365. package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
  366. package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
  367. package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
  368. package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
  369. package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
  370. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
  371. package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
  372. package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
  373. package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
  374. package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
  375. package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
  376. package/renderer/lib/api-docs/playground/context.tsx +0 -107
  377. package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
  378. package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
  379. package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
  380. package/renderer/lib/api-docs/playground/types.ts +0 -35
  381. package/renderer/lib/api-docs/types.ts +0 -269
  382. package/renderer/lib/api-docs/utils.ts +0 -311
  383. package/renderer/lib/cache.ts +0 -193
  384. package/renderer/lib/docs/config/domain-schema.ts +0 -260
  385. package/renderer/lib/docs/config/index.ts +0 -43
  386. package/renderer/lib/docs/config/loader.ts +0 -142
  387. package/renderer/lib/docs/config/schema.ts +0 -308
  388. package/renderer/lib/docs/index.ts +0 -12
  389. package/renderer/lib/docs/mdx/compiler.ts +0 -176
  390. package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
  391. package/renderer/lib/docs/mdx/index.ts +0 -26
  392. package/renderer/lib/docs/navigation/generator.ts +0 -348
  393. package/renderer/lib/docs/navigation/index.ts +0 -12
  394. package/renderer/lib/docs/navigation/types.ts +0 -123
  395. package/renderer/lib/docs-navigation-context.tsx +0 -80
  396. package/renderer/lib/multi-tenant/context.ts +0 -105
  397. package/renderer/lib/storage/blob.ts +0 -1083
  398. package/renderer/lib/utils/icons.ts +0 -48
  399. package/renderer/lib/utils.ts +0 -6
  400. package/renderer/next.config.ts +0 -76
@@ -0,0 +1,161 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Domain Configuration Schema (domain.json)
4
+ *
5
+ * Configuration for custom domains on DevDoc projects.
6
+ * Each project can have ONE custom domain for free.
7
+ */ // ============================================================================
8
+ // Domain Validation Helpers
9
+ // ============================================================================
10
+ /**
11
+ * Valid domain pattern - allows subdomains like docs.example.com
12
+ * Does NOT allow:
13
+ * - IP addresses
14
+ * - Ports
15
+ * - Paths
16
+ * - Protocol prefixes
17
+ */ const domainRegex = /^(?!-)[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*\.[a-zA-Z]{2,}$/;
18
+ /**
19
+ * Reserved domains that cannot be used as custom domains
20
+ */ const RESERVED_DOMAINS = [
21
+ 'devdoc.sh',
22
+ 'devdoc.io',
23
+ 'devdoc.com',
24
+ 'localhost'
25
+ ];
26
+ // ============================================================================
27
+ // SEO Schema
28
+ // ============================================================================
29
+ const domainSeoSchema = z.object({
30
+ /**
31
+ * Canonical URL for SEO - tells search engines this is the primary URL
32
+ * Should match your custom domain with https://
33
+ */ canonical: z.string().url().optional()
34
+ });
35
+ // ============================================================================
36
+ // Settings Schema
37
+ // ============================================================================
38
+ const domainSettingsSchema = z.object({
39
+ /**
40
+ * Force HTTPS redirects (recommended, default: true)
41
+ */ forceHttps: z.boolean().default(true),
42
+ /**
43
+ * WWW redirect preference
44
+ * - "www": Redirect non-www to www (example.com → www.example.com)
45
+ * - "non-www": Redirect www to non-www (www.example.com → example.com)
46
+ * - "none": No redirect, accept both
47
+ */ wwwRedirect: z.enum([
48
+ 'www',
49
+ 'non-www',
50
+ 'none'
51
+ ]).default('none')
52
+ });
53
+ // ============================================================================
54
+ // Main Domain Configuration Schema
55
+ // ============================================================================
56
+ export const domainConfigSchema = z.object({
57
+ /**
58
+ * JSON Schema reference (optional)
59
+ */ $schema: z.string().optional(),
60
+ /**
61
+ * The custom domain for this project
62
+ * Example: "docs.example.com" or "developer.mycompany.io"
63
+ *
64
+ * Rules:
65
+ * - Must be a valid domain name
66
+ * - Cannot be a DevDoc domain (*.devdoc.sh)
67
+ * - One custom domain per project (free)
68
+ */ customDomain: z.string().min(4, 'Domain must be at least 4 characters').max(253, 'Domain must be 253 characters or less').regex(domainRegex, 'Invalid domain format. Example: docs.example.com').refine((domain)=>!RESERVED_DOMAINS.some((reserved)=>domain === reserved || domain.endsWith(`.${reserved}`)), 'Cannot use a reserved DevDoc domain'),
69
+ /**
70
+ * SEO configuration for the custom domain
71
+ */ seo: domainSeoSchema.optional(),
72
+ /**
73
+ * Domain behavior settings
74
+ */ settings: domainSettingsSchema.optional()
75
+ });
76
+ // ============================================================================
77
+ // Validation Functions
78
+ // ============================================================================
79
+ /**
80
+ * Parse and validate domain configuration
81
+ */ export function parseDomainConfig(data) {
82
+ const result = domainConfigSchema.safeParse(data);
83
+ if (!result.success) {
84
+ const issues = result.error.issues || [];
85
+ const errors = issues.map((e)=>`${e.path.map(String).join('.')}: ${e.message}`).join('\n');
86
+ throw new Error(`Invalid domain.json configuration:\n${errors}`);
87
+ }
88
+ return result.data;
89
+ }
90
+ /**
91
+ * Safe parse that returns null on failure
92
+ */ export function safeParseDomainConfig(data) {
93
+ const result = domainConfigSchema.safeParse(data);
94
+ return result.success ? result.data : null;
95
+ }
96
+ /**
97
+ * Validate a domain string format
98
+ */ export function isValidDomain(domain) {
99
+ if (!domain) {
100
+ return {
101
+ valid: false,
102
+ error: 'Domain is required'
103
+ };
104
+ }
105
+ if (domain.length < 4) {
106
+ return {
107
+ valid: false,
108
+ error: 'Domain must be at least 4 characters'
109
+ };
110
+ }
111
+ if (domain.length > 253) {
112
+ return {
113
+ valid: false,
114
+ error: 'Domain must be 253 characters or less'
115
+ };
116
+ }
117
+ if (!domainRegex.test(domain)) {
118
+ return {
119
+ valid: false,
120
+ error: 'Invalid domain format. Example: docs.example.com'
121
+ };
122
+ }
123
+ // Check reserved domains
124
+ if (RESERVED_DOMAINS.some((reserved)=>domain === reserved || domain.endsWith(`.${reserved}`))) {
125
+ return {
126
+ valid: false,
127
+ error: 'Cannot use a reserved DevDoc domain'
128
+ };
129
+ }
130
+ return {
131
+ valid: true
132
+ };
133
+ }
134
+ /**
135
+ * Normalize a domain (lowercase, trim, remove protocol/path)
136
+ */ export function normalizeDomain(domain) {
137
+ let normalized = domain.toLowerCase().trim();
138
+ // Remove protocol if present
139
+ normalized = normalized.replace(/^https?:\/\//, '');
140
+ // Remove path if present
141
+ normalized = normalized.split('/')[0];
142
+ // Remove port if present
143
+ normalized = normalized.split(':')[0];
144
+ return normalized;
145
+ }
146
+ /**
147
+ * Get DNS instructions for a custom domain
148
+ */ export function getDnsInstructions(customDomain) {
149
+ const parts = customDomain.split('.');
150
+ const subdomain = parts.length > 2 ? parts[0] : '@';
151
+ return {
152
+ cname: {
153
+ name: subdomain === '@' ? customDomain : subdomain,
154
+ value: 'cname.devdoc-dns.com'
155
+ },
156
+ txt: {
157
+ name: `_devdoc-verify.${customDomain}`,
158
+ value: ''
159
+ }
160
+ };
161
+ }
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Configuration Module Exports
3
+ */ export { docsConfigSchema, parseDocsConfig, safeParseDocsConfig, getDefaultDocsConfig } from './schema';
4
+ export { domainConfigSchema, parseDomainConfig, safeParseDomainConfig, isValidDomain, normalizeDomain, getDnsInstructions } from './domain-schema';
5
+ export { loadDocsConfig, safeLoadDocsConfig, clearConfigCache, hasDocsConfig, getContentDir, resolvePagePath, loadPageContent, listMdxFiles } from './loader';
@@ -0,0 +1,113 @@
1
+ import { readFileSync, existsSync, readdirSync } from 'fs';
2
+ import { join } from 'path';
3
+ import { parseDocsConfig } from './schema';
4
+ /**
5
+ * Configuration Loader
6
+ *
7
+ * Utilities for loading and caching docs.json configuration
8
+ * Uses synchronous fs operations for compatibility with Next.js Turbopack
9
+ */ // Cache for loaded configuration
10
+ let configCache = null;
11
+ let configCachePath = null;
12
+ /**
13
+ * Load docs.json configuration from a directory
14
+ */ export function loadDocsConfig(docsDir) {
15
+ const configFilePath = join(docsDir, 'docs.json');
16
+ // Return cached config if path matches
17
+ if (configCache && configCachePath === configFilePath) {
18
+ return configCache;
19
+ }
20
+ try {
21
+ if (!existsSync(configFilePath)) {
22
+ throw new Error(`docs.json not found at ${configFilePath}`);
23
+ }
24
+ const configContent = readFileSync(configFilePath, 'utf-8');
25
+ const rawConfig = JSON.parse(configContent);
26
+ const config = parseDocsConfig(rawConfig);
27
+ // Cache the result
28
+ configCache = config;
29
+ configCachePath = configFilePath;
30
+ return config;
31
+ } catch (error) {
32
+ if (error instanceof Error) {
33
+ throw new Error(`Failed to load docs.json: ${error.message}`);
34
+ }
35
+ throw error;
36
+ }
37
+ }
38
+ /**
39
+ * Load configuration without throwing (returns null on failure)
40
+ */ export function safeLoadDocsConfig(docsDir) {
41
+ try {
42
+ return loadDocsConfig(docsDir);
43
+ } catch {
44
+ return null;
45
+ }
46
+ }
47
+ /**
48
+ * Clear the configuration cache
49
+ */ export function clearConfigCache() {
50
+ configCache = null;
51
+ configCachePath = null;
52
+ }
53
+ /**
54
+ * Check if a docs.json file exists in a directory
55
+ */ export function hasDocsConfig(docsDir) {
56
+ return existsSync(join(docsDir, 'docs.json'));
57
+ }
58
+ /**
59
+ * Get the content directory path from configuration
60
+ */ export function getContentDir(docsDir) {
61
+ return docsDir;
62
+ }
63
+ /**
64
+ * Resolve a page path to a file path
65
+ */ export function resolvePagePath(docsDir, pagePath) {
66
+ const contentDir = getContentDir(docsDir);
67
+ const extensions = [
68
+ '.mdx',
69
+ '.md'
70
+ ];
71
+ // Try different extensions
72
+ for (const ext of extensions){
73
+ const filePath = join(contentDir, `${pagePath}${ext}`);
74
+ if (existsSync(filePath)) {
75
+ return filePath;
76
+ }
77
+ }
78
+ // Try as directory with index file
79
+ for (const ext of extensions){
80
+ const indexPath = join(contentDir, pagePath, `index${ext}`);
81
+ if (existsSync(indexPath)) {
82
+ return indexPath;
83
+ }
84
+ }
85
+ return null;
86
+ }
87
+ /**
88
+ * Load page content from a resolved path
89
+ */ export function loadPageContent(filePath) {
90
+ return readFileSync(filePath, 'utf-8');
91
+ }
92
+ /**
93
+ * List all MDX files in a directory recursively
94
+ */ export function listMdxFiles(dir) {
95
+ const files = [];
96
+ function walk(currentDir) {
97
+ const entries = readdirSync(currentDir, {
98
+ withFileTypes: true
99
+ });
100
+ for (const entry of entries){
101
+ const fullPath = join(currentDir, entry.name);
102
+ if (entry.isDirectory()) {
103
+ if (!entry.name.startsWith('.') && entry.name !== 'node_modules') {
104
+ walk(fullPath);
105
+ }
106
+ } else if (entry.isFile() && (entry.name.endsWith('.mdx') || entry.name.endsWith('.md'))) {
107
+ files.push(fullPath);
108
+ }
109
+ }
110
+ }
111
+ walk(dir);
112
+ return files;
113
+ }
@@ -0,0 +1,269 @@
1
+ import { z } from 'zod';
2
+ /**
3
+ * Documentation Configuration Schema (docs.json)
4
+ *
5
+ * Mintlify-compatible configuration schema for documentation sites.
6
+ */ // ============================================================================
7
+ // Navigation Schemas
8
+ // ============================================================================
9
+ const anchorSchema = z.object({
10
+ anchor: z.string(),
11
+ href: z.string(),
12
+ icon: z.string().optional()
13
+ });
14
+ const navLinkSchema = z.object({
15
+ label: z.string(),
16
+ href: z.string()
17
+ });
18
+ // Page can be a string or a nested group
19
+ const pageRefSchema = z.lazy(()=>z.union([
20
+ z.string(),
21
+ z.object({
22
+ group: z.string(),
23
+ pages: z.array(z.union([
24
+ z.string(),
25
+ z.lazy(()=>pageRefSchema)
26
+ ]))
27
+ })
28
+ ]));
29
+ const groupSchema = z.object({
30
+ group: z.string(),
31
+ pages: z.array(pageRefSchema),
32
+ icon: z.string().optional()
33
+ });
34
+ // OpenAPI version schema
35
+ const openapiVersionSchema = z.object({
36
+ version: z.string(),
37
+ spec: z.string(),
38
+ default: z.boolean().optional()
39
+ });
40
+ // Different tab types
41
+ const docsTabSchema = z.object({
42
+ tab: z.string(),
43
+ type: z.literal('docs').optional(),
44
+ groups: z.array(groupSchema)
45
+ });
46
+ const openapiTabSchema = z.object({
47
+ tab: z.string(),
48
+ type: z.literal('openapi'),
49
+ path: z.string().optional(),
50
+ versions: z.array(openapiVersionSchema).optional(),
51
+ spec: z.string().optional(),
52
+ groups: z.array(groupSchema).optional()
53
+ });
54
+ const graphqlTabSchema = z.object({
55
+ tab: z.string(),
56
+ type: z.literal('graphql'),
57
+ path: z.string().optional(),
58
+ schema: z.string(),
59
+ endpoint: z.string().optional(),
60
+ groups: z.array(groupSchema).optional()
61
+ });
62
+ const changelogTabSchema = z.object({
63
+ tab: z.string(),
64
+ type: z.literal('changelog'),
65
+ path: z.string().optional()
66
+ });
67
+ const tabSchema = z.union([
68
+ docsTabSchema,
69
+ openapiTabSchema,
70
+ graphqlTabSchema,
71
+ changelogTabSchema
72
+ ]);
73
+ const navigationSchema = z.object({
74
+ tabs: z.array(tabSchema).optional(),
75
+ groups: z.array(groupSchema).optional(),
76
+ global: z.object({
77
+ anchors: z.array(anchorSchema).optional()
78
+ }).optional()
79
+ });
80
+ // ============================================================================
81
+ // Theme & Branding Schemas
82
+ // ============================================================================
83
+ const colorSchema = z.object({
84
+ primary: z.string(),
85
+ light: z.string().optional(),
86
+ dark: z.string().optional(),
87
+ background: z.object({
88
+ light: z.string().optional(),
89
+ dark: z.string().optional()
90
+ }).optional()
91
+ });
92
+ const logoSchema = z.object({
93
+ light: z.string(),
94
+ dark: z.string(),
95
+ href: z.string().optional()
96
+ });
97
+ const faviconSchema = z.string();
98
+ // ============================================================================
99
+ // Navbar Schema
100
+ // ============================================================================
101
+ const navbarPrimarySchema = z.object({
102
+ type: z.enum([
103
+ 'button',
104
+ 'github',
105
+ 'link'
106
+ ]),
107
+ label: z.string().optional(),
108
+ href: z.string()
109
+ });
110
+ const navbarSchema = z.object({
111
+ links: z.array(navLinkSchema).optional(),
112
+ primary: navbarPrimarySchema.optional()
113
+ });
114
+ // ============================================================================
115
+ // Footer Schema
116
+ // ============================================================================
117
+ const footerLinkSchema = z.object({
118
+ label: z.string(),
119
+ href: z.string()
120
+ });
121
+ const footerGroupSchema = z.object({
122
+ title: z.string(),
123
+ links: z.array(footerLinkSchema)
124
+ });
125
+ const footerSchema = z.object({
126
+ socials: z.record(z.string(), z.string()).optional(),
127
+ links: z.array(footerGroupSchema).optional()
128
+ });
129
+ // ============================================================================
130
+ // API Configuration Schema
131
+ // ============================================================================
132
+ const apiAuthSchema = z.object({
133
+ method: z.enum([
134
+ 'bearer',
135
+ 'basic',
136
+ 'api-key',
137
+ 'none'
138
+ ]),
139
+ name: z.string().optional()
140
+ });
141
+ const apiPlaygroundSchema = z.object({
142
+ mode: z.enum([
143
+ 'show',
144
+ 'simple',
145
+ 'hide'
146
+ ]).optional()
147
+ });
148
+ const apiConfigSchema = z.object({
149
+ baseUrl: z.string().optional(),
150
+ auth: apiAuthSchema.optional(),
151
+ playground: apiPlaygroundSchema.optional()
152
+ });
153
+ // ============================================================================
154
+ // SEO Schema
155
+ // ============================================================================
156
+ const seoSchema = z.object({
157
+ indexHiddenPages: z.boolean().optional(),
158
+ titleTemplate: z.string().optional()
159
+ });
160
+ // ============================================================================
161
+ // Integrations Schema
162
+ // ============================================================================
163
+ const analyticsSchema = z.object({
164
+ posthog: z.object({
165
+ apiKey: z.string()
166
+ }).optional(),
167
+ googleAnalytics: z.object({
168
+ measurementId: z.string()
169
+ }).optional(),
170
+ plausible: z.object({
171
+ domain: z.string()
172
+ }).optional()
173
+ });
174
+ const integrationsSchema = z.object({
175
+ analytics: analyticsSchema.optional()
176
+ });
177
+ // ============================================================================
178
+ // Contextual Menu Schema
179
+ // ============================================================================
180
+ const contextualOptionsEnum = z.enum([
181
+ 'copy',
182
+ 'view',
183
+ 'chatgpt',
184
+ 'claude',
185
+ 'perplexity',
186
+ 'mcp',
187
+ 'cursor',
188
+ 'vscode'
189
+ ]);
190
+ const contextualSchema = z.object({
191
+ options: z.array(contextualOptionsEnum).optional()
192
+ });
193
+ // ============================================================================
194
+ // Main Configuration Schema
195
+ // ============================================================================
196
+ export const docsConfigSchema = z.object({
197
+ // Schema reference (optional)
198
+ $schema: z.string().optional(),
199
+ // Core identity
200
+ name: z.string(),
201
+ // Theme
202
+ theme: z.enum([
203
+ 'default',
204
+ 'mint',
205
+ 'quill',
206
+ 'venus'
207
+ ]).optional(),
208
+ colors: colorSchema.optional(),
209
+ // Branding
210
+ favicon: faviconSchema.optional(),
211
+ logo: logoSchema.optional(),
212
+ // Navigation
213
+ navigation: navigationSchema,
214
+ // Navbar
215
+ navbar: navbarSchema.optional(),
216
+ // Footer
217
+ footer: footerSchema.optional(),
218
+ // API Configuration
219
+ api: apiConfigSchema.optional(),
220
+ openapi: z.union([
221
+ z.string(),
222
+ z.array(z.string())
223
+ ]).optional(),
224
+ // SEO
225
+ seo: seoSchema.optional(),
226
+ // Integrations
227
+ integrations: integrationsSchema.optional(),
228
+ // Contextual menu
229
+ contextual: contextualSchema.optional(),
230
+ // Topbar style
231
+ topbar: z.object({
232
+ style: z.enum([
233
+ 'default',
234
+ 'gradient'
235
+ ]).optional()
236
+ }).optional(),
237
+ // Versioning
238
+ versions: z.array(z.string()).optional()
239
+ });
240
+ // ============================================================================
241
+ // Validation Functions
242
+ // ============================================================================
243
+ /**
244
+ * Parse and validate docs configuration
245
+ */ export function parseDocsConfig(data) {
246
+ const result = docsConfigSchema.safeParse(data);
247
+ if (!result.success) {
248
+ const issues = result.error.issues || [];
249
+ const errors = issues.map((e)=>`${e.path.map(String).join('.')}: ${e.message}`).join('\n');
250
+ throw new Error(`Invalid docs.json configuration:\n${errors}`);
251
+ }
252
+ return result.data;
253
+ }
254
+ /**
255
+ * Safe parse that returns null on failure
256
+ */ export function safeParseDocsConfig(data) {
257
+ const result = docsConfigSchema.safeParse(data);
258
+ return result.success ? result.data : null;
259
+ }
260
+ /**
261
+ * Get default configuration
262
+ */ export function getDefaultDocsConfig() {
263
+ return {
264
+ theme: 'default',
265
+ navigation: {
266
+ groups: []
267
+ }
268
+ };
269
+ }
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Documentation Library Exports
3
+ */ // MDX
4
+ export * from './mdx';
5
+ // Configuration
6
+ export * from './config';
7
+ // Navigation
8
+ export * from './navigation';
@@ -0,0 +1,128 @@
1
+ import { compileMDX } from 'next-mdx-remote/rsc';
2
+ import matter from 'gray-matter';
3
+ import rehypeSlug from 'rehype-slug';
4
+ import rehypeAutolinkHeadings from 'rehype-autolink-headings';
5
+ import remarkGfm from 'remark-gfm';
6
+ import { parseFrontmatter, safeParseFrontmatter } from './frontmatter';
7
+ /**
8
+ * Extract frontmatter from raw MDX content
9
+ */ export function extractFrontmatter(source) {
10
+ const { content, data } = matter(source);
11
+ return {
12
+ content,
13
+ data
14
+ };
15
+ }
16
+ /**
17
+ * Extract headings from MDX content for table of contents
18
+ */ export function extractHeadings(content) {
19
+ const headingRegex = /^(#{1,6})\s+(.+)$/gm;
20
+ const headings = [];
21
+ let match;
22
+ while((match = headingRegex.exec(content)) !== null){
23
+ const level = match[1].length;
24
+ const title = match[2].trim();
25
+ // Generate slug from title (same logic as rehype-slug)
26
+ const id = title.toLowerCase().replace(/[^a-z0-9]+/g, '-').replace(/^-+|-+$/g, '');
27
+ headings.push({
28
+ id,
29
+ title,
30
+ level
31
+ });
32
+ }
33
+ return headings;
34
+ }
35
+ /**
36
+ * Compile MDX content with components and plugins
37
+ */ export async function compileMDXContent(source, options = {}) {
38
+ const { components = {}, scope = {}, validateFrontmatter = true } = options;
39
+ // Extract frontmatter first
40
+ const { content: mdxContent, data: rawFrontmatter } = extractFrontmatter(source);
41
+ // Validate frontmatter if requested
42
+ const frontmatter = validateFrontmatter ? parseFrontmatter(rawFrontmatter) : rawFrontmatter;
43
+ // Extract headings for ToC
44
+ const headings = extractHeadings(mdxContent);
45
+ // Compile MDX
46
+ const { content } = await compileMDX({
47
+ source: mdxContent,
48
+ components,
49
+ options: {
50
+ parseFrontmatter: false,
51
+ mdxOptions: {
52
+ remarkPlugins: [
53
+ remarkGfm
54
+ ],
55
+ rehypePlugins: [
56
+ rehypeSlug,
57
+ [
58
+ rehypeAutolinkHeadings,
59
+ {
60
+ behavior: 'wrap'
61
+ }
62
+ ]
63
+ ]
64
+ },
65
+ scope: {
66
+ ...scope,
67
+ frontmatter
68
+ }
69
+ }
70
+ });
71
+ return {
72
+ content,
73
+ frontmatter,
74
+ headings
75
+ };
76
+ }
77
+ /**
78
+ * Quick compile for previews (less validation)
79
+ */ export async function quickCompileMDX(source, components = {}) {
80
+ const { content: mdxContent, data: frontmatter } = extractFrontmatter(source);
81
+ const { content } = await compileMDX({
82
+ source: mdxContent,
83
+ components,
84
+ options: {
85
+ parseFrontmatter: false,
86
+ mdxOptions: {
87
+ remarkPlugins: [
88
+ remarkGfm
89
+ ],
90
+ rehypePlugins: [
91
+ rehypeSlug
92
+ ]
93
+ }
94
+ }
95
+ });
96
+ return {
97
+ content,
98
+ frontmatter
99
+ };
100
+ }
101
+ /**
102
+ * Validate MDX content without compiling (for linting)
103
+ */ export function validateMDXContent(source) {
104
+ const errors = [];
105
+ const warnings = [];
106
+ try {
107
+ const { data } = extractFrontmatter(source);
108
+ // Check frontmatter
109
+ const frontmatterResult = safeParseFrontmatter(data);
110
+ if (!frontmatterResult) {
111
+ errors.push('Invalid frontmatter format');
112
+ }
113
+ // Check for common issues
114
+ if (!data.title) {
115
+ warnings.push('Missing title in frontmatter');
116
+ }
117
+ if (!data.description) {
118
+ warnings.push('Missing description in frontmatter (recommended for SEO)');
119
+ }
120
+ } catch (error) {
121
+ errors.push(`Parse error: ${error instanceof Error ? error.message : 'Unknown error'}`);
122
+ }
123
+ return {
124
+ valid: errors.length === 0,
125
+ errors,
126
+ warnings
127
+ };
128
+ }