@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,684 +0,0 @@
1
- 'use client'
2
-
3
- import React, { useState } from 'react'
4
- import { cn } from '@/lib/utils'
5
- import {
6
- Copy,
7
- Check,
8
- ArrowRight,
9
- GithubLogo,
10
- Terminal,
11
- ArrowUpRight,
12
- RocketLaunch,
13
- } from '@phosphor-icons/react'
14
- import { getPhosphorIcon, type PhosphorIconComponent } from '@/lib/utils/icons'
15
-
16
- // Direct icon map for commonly used icons (fallback if dynamic import fails)
17
- const iconMap: Record<string, PhosphorIconComponent> = {
18
- 'arrow-right': ArrowRight,
19
- 'github-logo': GithubLogo,
20
- 'terminal': Terminal,
21
- 'arrow-up-right': ArrowUpRight,
22
- 'rocket-launch': RocketLaunch,
23
- }
24
-
25
- /**
26
- * Landing Page Components for MDX Documentation
27
- *
28
- * These components enable creating custom landing pages similar to skills.sh
29
- * with hero sections, command boxes, feature grids, and more.
30
- */
31
-
32
- /**
33
- * Hero Section Component
34
- *
35
- * A full-width hero section for landing pages with optional
36
- * logo/ASCII art, tagline, and description.
37
- */
38
- interface HeroProps {
39
- children?: React.ReactNode
40
- className?: string
41
- /** Background variant */
42
- variant?: 'default' | 'gradient' | 'dark' | 'light' | 'pattern'
43
- /** Vertical alignment */
44
- align?: 'top' | 'center' | 'bottom'
45
- /** Minimum height */
46
- minHeight?: 'sm' | 'md' | 'lg' | 'full'
47
- }
48
-
49
- export function Hero({
50
- children,
51
- className,
52
- variant = 'default',
53
- align = 'center',
54
- minHeight = 'md'
55
- }: HeroProps) {
56
- const variantStyles = {
57
- default: 'bg-background text-foreground',
58
- gradient: 'bg-gradient-to-b from-background via-background to-muted/30 text-foreground',
59
- dark: 'bg-zinc-950 text-white [&_.landing-tagline]:text-zinc-400 [&_.landing-headline]:text-white [&_.landing-description]:text-zinc-300 [&_.landing-button]:border-zinc-600',
60
- light: 'bg-white text-zinc-900 [&_.landing-tagline]:text-zinc-500 [&_.landing-headline]:text-zinc-900 [&_.landing-description]:text-zinc-600 [&_.landing-button]:border-zinc-300',
61
- pattern: 'bg-background bg-[radial-gradient(ellipse_at_top,_var(--tw-gradient-stops))] from-primary/10 via-background to-background text-foreground',
62
- }
63
-
64
- const alignStyles = {
65
- top: 'items-start pt-12',
66
- center: 'items-center',
67
- bottom: 'items-end pb-12',
68
- }
69
-
70
- const heightStyles = {
71
- sm: 'min-h-[40vh]',
72
- md: 'min-h-[60vh]',
73
- lg: 'min-h-[80vh]',
74
- full: 'min-h-screen',
75
- }
76
-
77
- return (
78
- <section
79
- className={cn(
80
- 'landing-hero w-full flex flex-col justify-center',
81
- variantStyles[variant],
82
- alignStyles[align],
83
- heightStyles[minHeight],
84
- className
85
- )}
86
- >
87
- <div className="landing-hero-content w-full max-w-5xl mx-auto px-4 sm:px-6 lg:px-8 text-center">
88
- {children}
89
- </div>
90
- </section>
91
- )
92
- }
93
-
94
- /**
95
- * Pre Component
96
- *
97
- * Pre-formatted text component for ASCII art, logos, and other
98
- * monospace content that needs to preserve whitespace.
99
- */
100
- interface PreProps {
101
- children: React.ReactNode
102
- className?: string
103
- /** Font size preset */
104
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl'
105
- /** Text alignment */
106
- align?: 'left' | 'center' | 'right'
107
- /** Text color variant */
108
- color?: 'default' | 'muted' | 'primary' | 'white'
109
- /** Line height */
110
- leading?: 'none' | 'tight' | 'normal' | 'relaxed'
111
- /** Hide from screen readers (decorative content) */
112
- decorative?: boolean
113
- }
114
-
115
- export function Pre({
116
- children,
117
- className,
118
- size = 'md',
119
- align = 'center',
120
- color = 'default',
121
- leading = 'tight',
122
- decorative = false,
123
- }: PreProps) {
124
- const sizeStyles = {
125
- xs: 'text-[0.5rem] sm:text-xs',
126
- sm: 'text-xs sm:text-sm',
127
- md: 'text-sm sm:text-base md:text-lg',
128
- lg: 'text-base sm:text-lg md:text-xl lg:text-2xl',
129
- xl: 'text-lg sm:text-xl md:text-2xl lg:text-3xl xl:text-4xl',
130
- }
131
-
132
- const alignStyles = {
133
- left: 'text-left',
134
- center: 'text-center mx-auto',
135
- right: 'text-right ml-auto',
136
- }
137
-
138
- const colorStyles = {
139
- default: 'text-foreground',
140
- muted: 'text-muted-foreground',
141
- primary: 'text-primary',
142
- white: 'text-white',
143
- }
144
-
145
- const leadingStyles = {
146
- none: 'leading-none',
147
- tight: 'leading-tight',
148
- normal: 'leading-normal',
149
- relaxed: 'leading-relaxed',
150
- }
151
-
152
- return (
153
- <pre
154
- className={cn(
155
- 'landing-pre font-mono whitespace-pre select-none overflow-x-auto',
156
- sizeStyles[size],
157
- alignStyles[align],
158
- colorStyles[color],
159
- leadingStyles[leading],
160
- className
161
- )}
162
- aria-hidden={decorative}
163
- >
164
- {children}
165
- </pre>
166
- )
167
- }
168
-
169
- /**
170
- * Tagline Component
171
- *
172
- * Displays a prominent tagline or subtitle.
173
- */
174
- interface TaglineProps {
175
- children: React.ReactNode
176
- className?: string
177
- /** Visual style */
178
- variant?: 'default' | 'muted' | 'accent'
179
- /** Letter spacing */
180
- tracking?: 'normal' | 'wide' | 'wider' | 'widest'
181
- }
182
-
183
- export function Tagline({
184
- children,
185
- className,
186
- variant = 'default',
187
- tracking = 'wider'
188
- }: TaglineProps) {
189
- const variantStyles = {
190
- default: '', // Inherit from parent
191
- muted: 'opacity-60',
192
- accent: 'text-primary',
193
- }
194
-
195
- const trackingStyles = {
196
- normal: 'tracking-normal',
197
- wide: 'tracking-wide',
198
- wider: 'tracking-wider',
199
- widest: 'tracking-widest',
200
- }
201
-
202
- // Use div instead of p to avoid hydration errors when MDX wraps content in <p>
203
- return (
204
- <div
205
- className={cn(
206
- 'landing-tagline text-sm sm:text-base font-medium uppercase',
207
- variantStyles[variant],
208
- trackingStyles[tracking],
209
- className
210
- )}
211
- >
212
- {children}
213
- </div>
214
- )
215
- }
216
-
217
- /**
218
- * Headline Component
219
- *
220
- * Large display text for hero headlines.
221
- */
222
- interface HeadlineProps {
223
- children: React.ReactNode
224
- className?: string
225
- /** Size preset */
226
- size?: 'md' | 'lg' | 'xl' | '2xl'
227
- /** Font weight */
228
- weight?: 'normal' | 'medium' | 'semibold' | 'bold'
229
- }
230
-
231
- export function Headline({
232
- children,
233
- className,
234
- size = 'xl',
235
- weight = 'normal'
236
- }: HeadlineProps) {
237
- const sizeStyles = {
238
- md: 'text-xl sm:text-2xl md:text-3xl',
239
- lg: 'text-2xl sm:text-3xl md:text-4xl',
240
- xl: 'text-3xl sm:text-4xl md:text-5xl',
241
- '2xl': 'text-4xl sm:text-5xl md:text-6xl',
242
- }
243
-
244
- const weightStyles = {
245
- normal: 'font-normal',
246
- medium: 'font-medium',
247
- semibold: 'font-semibold',
248
- bold: 'font-bold',
249
- }
250
-
251
- return (
252
- <h1
253
- className={cn(
254
- 'landing-headline leading-tight',
255
- sizeStyles[size],
256
- weightStyles[weight],
257
- className
258
- )}
259
- >
260
- {children}
261
- </h1>
262
- )
263
- }
264
-
265
- /**
266
- * Description Component
267
- *
268
- * Body text for hero descriptions.
269
- */
270
- interface DescriptionProps {
271
- children: React.ReactNode
272
- className?: string
273
- /** Size preset */
274
- size?: 'sm' | 'md' | 'lg'
275
- /** Max width */
276
- maxWidth?: 'sm' | 'md' | 'lg' | 'full'
277
- }
278
-
279
- export function Description({
280
- children,
281
- className,
282
- size = 'lg',
283
- maxWidth = 'lg'
284
- }: DescriptionProps) {
285
- const sizeStyles = {
286
- sm: 'text-sm sm:text-base',
287
- md: 'text-base sm:text-lg',
288
- lg: 'text-lg sm:text-xl',
289
- }
290
-
291
- const maxWidthStyles = {
292
- sm: 'max-w-md',
293
- md: 'max-w-xl',
294
- lg: 'max-w-2xl',
295
- full: 'max-w-full',
296
- }
297
-
298
- // Use div instead of p to avoid hydration errors when MDX wraps content in <p>
299
- return (
300
- <div
301
- className={cn(
302
- 'landing-description opacity-80 mx-auto',
303
- sizeStyles[size],
304
- maxWidthStyles[maxWidth],
305
- className
306
- )}
307
- >
308
- {children}
309
- </div>
310
- )
311
- }
312
-
313
- /**
314
- * Command Box Component
315
- *
316
- * A copyable command display with a dark background,
317
- * similar to the skills.sh installation command box.
318
- */
319
- interface CommandBoxProps {
320
- /** The command to display */
321
- command: string
322
- /** Optional prefix like $ or > */
323
- prefix?: string
324
- className?: string
325
- /** Visual variant - 'default' is dark (terminal style), 'light' adapts to theme */
326
- variant?: 'default' | 'minimal' | 'bordered' | 'light'
327
- }
328
-
329
- export function CommandBox({
330
- command,
331
- prefix = '$',
332
- className,
333
- variant = 'default'
334
- }: CommandBoxProps) {
335
- const [copied, setCopied] = useState(false)
336
-
337
- const handleCopy = async () => {
338
- try {
339
- await navigator.clipboard.writeText(command)
340
- setCopied(true)
341
- setTimeout(() => setCopied(false), 2000)
342
- } catch (err) {
343
- console.error('Failed to copy:', err)
344
- }
345
- }
346
-
347
- const variantStyles = {
348
- default: 'bg-zinc-950 border border-zinc-800 shadow-lg',
349
- minimal: 'bg-zinc-900',
350
- bordered: 'bg-zinc-950 border-2 border-zinc-700',
351
- light: 'bg-muted border border-border shadow-sm',
352
- }
353
-
354
- const textStyles = {
355
- default: 'text-white',
356
- minimal: 'text-white',
357
- bordered: 'text-white',
358
- light: 'text-foreground',
359
- }
360
-
361
- const prefixStyles = {
362
- default: 'text-zinc-400',
363
- minimal: 'text-zinc-400',
364
- bordered: 'text-zinc-400',
365
- light: 'text-muted-foreground',
366
- }
367
-
368
- const buttonStyles = {
369
- default: 'text-zinc-300 hover:text-white hover:bg-zinc-700',
370
- minimal: 'text-zinc-300 hover:text-white hover:bg-zinc-700',
371
- bordered: 'text-zinc-300 hover:text-white hover:bg-zinc-700',
372
- light: 'text-muted-foreground hover:text-foreground hover:bg-muted-foreground/10',
373
- }
374
-
375
- return (
376
- <div
377
- className={cn(
378
- 'landing-command-box inline-flex items-center gap-3 rounded-lg px-4 py-3',
379
- variantStyles[variant],
380
- className
381
- )}
382
- >
383
- <code className={cn('flex items-center gap-2 font-mono text-sm sm:text-base', textStyles[variant])}>
384
- {prefix && (
385
- <span className={cn('select-none', prefixStyles[variant])}>{prefix}</span>
386
- )}
387
- <span>{command}</span>
388
- </code>
389
- <button
390
- type="button"
391
- onClick={handleCopy}
392
- className={cn(
393
- 'p-1.5 rounded transition-colors',
394
- 'focus:outline-none focus-visible:ring-2 focus-visible:ring-primary/50',
395
- buttonStyles[variant]
396
- )}
397
- title="Copy command"
398
- >
399
- {copied ? (
400
- <Check className="h-4 w-4 text-emerald-500" weight="bold" />
401
- ) : (
402
- <Copy className="h-4 w-4" />
403
- )}
404
- </button>
405
- </div>
406
- )
407
- }
408
-
409
- /**
410
- * Section Component
411
- *
412
- * A full-width section wrapper for landing page content.
413
- */
414
- interface SectionProps {
415
- children: React.ReactNode
416
- className?: string
417
- /** Section ID for anchor links */
418
- id?: string
419
- /** Background variant */
420
- variant?: 'default' | 'muted' | 'dark' | 'light' | 'accent'
421
- /** Padding preset */
422
- padding?: 'none' | 'sm' | 'md' | 'lg' | 'xl'
423
- }
424
-
425
- export function Section({
426
- children,
427
- className,
428
- id,
429
- variant = 'default',
430
- padding = 'lg'
431
- }: SectionProps) {
432
- const variantStyles = {
433
- default: 'bg-background text-foreground',
434
- muted: 'bg-muted/30 text-foreground',
435
- dark: 'bg-zinc-950 text-white [&_.landing-tagline]:text-zinc-400 [&_.landing-headline]:text-white [&_.landing-description]:text-zinc-300 [&_.landing-feature-title]:text-white [&_.landing-feature-description]:text-zinc-400 [&_.landing-button]:border-zinc-600',
436
- light: 'bg-white text-zinc-900 [&_.landing-tagline]:text-zinc-500 [&_.landing-headline]:text-zinc-900 [&_.landing-description]:text-zinc-600 [&_.landing-feature-title]:text-zinc-900 [&_.landing-feature-description]:text-zinc-600 [&_.landing-button]:border-zinc-300',
437
- accent: 'bg-primary/5 text-foreground',
438
- }
439
-
440
- const paddingStyles = {
441
- none: '',
442
- sm: 'py-8 sm:py-12',
443
- md: 'py-12 sm:py-16',
444
- lg: 'py-16 sm:py-24',
445
- xl: 'py-24 sm:py-32',
446
- }
447
-
448
- return (
449
- <section
450
- id={id}
451
- className={cn(
452
- 'landing-section w-full',
453
- variantStyles[variant],
454
- paddingStyles[padding],
455
- className
456
- )}
457
- >
458
- <div className="landing-section-content max-w-5xl mx-auto px-4 sm:px-6 lg:px-8">
459
- {children}
460
- </div>
461
- </section>
462
- )
463
- }
464
-
465
- /**
466
- * Center Component
467
- *
468
- * Centers content horizontally and optionally vertically.
469
- */
470
- interface CenterProps {
471
- children: React.ReactNode
472
- className?: string
473
- /** Stack children with gap */
474
- gap?: 'none' | 'sm' | 'md' | 'lg'
475
- }
476
-
477
- export function Center({ children, className, gap = 'md' }: CenterProps) {
478
- const gapStyles = {
479
- none: '',
480
- sm: 'space-y-2',
481
- md: 'space-y-4',
482
- lg: 'space-y-8',
483
- }
484
-
485
- return (
486
- <div
487
- className={cn(
488
- 'landing-center flex flex-col items-center text-center',
489
- gapStyles[gap],
490
- className
491
- )}
492
- >
493
- {children}
494
- </div>
495
- )
496
- }
497
-
498
- /**
499
- * Feature Grid Component
500
- *
501
- * A responsive grid for displaying feature cards.
502
- */
503
- interface FeatureGridProps {
504
- children: React.ReactNode
505
- className?: string
506
- /** Number of columns */
507
- cols?: 2 | 3 | 4
508
- }
509
-
510
- export function FeatureGrid({ children, className, cols = 3 }: FeatureGridProps) {
511
- const colStyles = {
512
- 2: 'grid-cols-1 md:grid-cols-2',
513
- 3: 'grid-cols-1 md:grid-cols-2 lg:grid-cols-3',
514
- 4: 'grid-cols-1 sm:grid-cols-2 lg:grid-cols-4',
515
- }
516
-
517
- return (
518
- <div
519
- className={cn(
520
- 'landing-feature-grid grid gap-6',
521
- colStyles[cols],
522
- className
523
- )}
524
- >
525
- {children}
526
- </div>
527
- )
528
- }
529
-
530
- /**
531
- * Feature Item Component
532
- *
533
- * Individual feature card with icon, title, and description.
534
- */
535
- interface FeatureItemProps {
536
- children?: React.ReactNode
537
- title?: string
538
- icon?: React.ReactNode
539
- className?: string
540
- }
541
-
542
- export function FeatureItem({ children, title, icon, className }: FeatureItemProps) {
543
- return (
544
- <div
545
- className={cn(
546
- 'landing-feature-item p-6 rounded-xl border border-border/50 bg-card/50',
547
- 'hover:border-primary/30 hover:bg-card/80 transition-colors',
548
- className
549
- )}
550
- >
551
- {icon && (
552
- <div className="landing-feature-icon mb-4 text-primary text-2xl">
553
- {icon}
554
- </div>
555
- )}
556
- {title && (
557
- <h3 className="landing-feature-title text-lg font-semibold mb-2">
558
- {title}
559
- </h3>
560
- )}
561
- {children && (
562
- <div className="landing-feature-description text-sm opacity-80">
563
- {children}
564
- </div>
565
- )}
566
- </div>
567
- )
568
- }
569
-
570
- /**
571
- * Button Link Component
572
- *
573
- * Styled button links for CTAs.
574
- */
575
- interface ButtonLinkProps {
576
- href: string
577
- children: React.ReactNode
578
- className?: string
579
- /** Visual variant */
580
- variant?: 'primary' | 'secondary' | 'outline' | 'ghost'
581
- /** Size preset */
582
- size?: 'sm' | 'md' | 'lg'
583
- /** Phosphor icon name (e.g., "arrow-right", "github-logo") */
584
- icon?: string
585
- /** Icon position */
586
- iconPosition?: 'left' | 'right'
587
- }
588
-
589
-
590
- export function ButtonLink({
591
- href,
592
- children,
593
- className,
594
- variant = 'primary',
595
- size = 'md',
596
- icon,
597
- iconPosition = 'right'
598
- }: ButtonLinkProps) {
599
- const variantStyles = {
600
- primary: 'bg-primary text-primary-foreground hover:bg-primary/90',
601
- secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/80',
602
- outline: 'border border-current/30 bg-transparent text-current hover:bg-current/10',
603
- ghost: 'bg-transparent text-current hover:bg-current/10',
604
- }
605
-
606
- const sizeStyles = {
607
- sm: 'px-3 py-1.5 text-sm',
608
- md: 'px-4 py-2 text-base',
609
- lg: 'px-6 py-3 text-lg',
610
- }
611
-
612
- const iconSizes = {
613
- sm: 'h-4 w-4',
614
- md: 'h-5 w-5',
615
- lg: 'h-5 w-5',
616
- }
617
-
618
- // Try direct map first, then dynamic lookup
619
- const IconComponent = icon ? (iconMap[icon] || getPhosphorIcon(icon)) : null
620
-
621
- return (
622
- <a
623
- href={href}
624
- className={cn(
625
- 'landing-button inline-flex items-center justify-center gap-2 rounded-lg font-medium',
626
- 'transition-colors focus:outline-none focus-visible:ring-2 focus-visible:ring-primary/50',
627
- variantStyles[variant],
628
- sizeStyles[size],
629
- className
630
- )}
631
- >
632
- {IconComponent && iconPosition === 'left' && (
633
- <IconComponent className={iconSizes[size]} weight="bold" />
634
- )}
635
- {children}
636
- {IconComponent && iconPosition === 'right' && (
637
- <IconComponent className={iconSizes[size]} weight="bold" />
638
- )}
639
- </a>
640
- )
641
- }
642
-
643
- /**
644
- * Spacer Component
645
- *
646
- * Adds vertical spacing.
647
- */
648
- interface SpacerProps {
649
- size?: 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl'
650
- className?: string
651
- }
652
-
653
- export function Spacer({ size = 'md', className }: SpacerProps) {
654
- const sizeStyles = {
655
- xs: 'h-2',
656
- sm: 'h-4',
657
- md: 'h-8',
658
- lg: 'h-12',
659
- xl: 'h-16',
660
- '2xl': 'h-24',
661
- }
662
-
663
- return <div className={cn('landing-spacer', sizeStyles[size], className)} />
664
- }
665
-
666
- /**
667
- * Divider Component
668
- *
669
- * Horizontal divider line.
670
- */
671
- interface DividerProps {
672
- className?: string
673
- variant?: 'solid' | 'dashed' | 'gradient'
674
- }
675
-
676
- export function Divider({ className, variant = 'solid' }: DividerProps) {
677
- const variantStyles = {
678
- solid: 'border-t border-border',
679
- dashed: 'border-t border-dashed border-border',
680
- gradient: 'h-px bg-gradient-to-r from-transparent via-border to-transparent border-none',
681
- }
682
-
683
- return <hr className={cn('landing-divider w-full my-8', variantStyles[variant], className)} />
684
- }