@brainfish-ai/devdoc 0.1.42 → 0.1.44

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 (398) hide show
  1. package/dist/cli/commands/create.js +2 -2
  2. package/dist/cli/commands/dev.js +19 -10
  3. package/package.json +3 -2
  4. package/renderer/app/api/assets/[...path]/route.js +108 -0
  5. package/renderer/app/api/assets/route.js +114 -0
  6. package/renderer/app/api/assets/upload/route.js +163 -0
  7. package/renderer/app/api/auth-schemes/route.js +58 -0
  8. package/renderer/app/api/chat/route.js +759 -0
  9. package/renderer/app/api/codegen/route.js +52 -0
  10. package/renderer/app/api/collections/route.js +706 -0
  11. package/renderer/app/api/debug/route.js +47 -0
  12. package/renderer/app/api/deploy/route.js +199 -0
  13. package/renderer/app/api/device/route.js +36 -0
  14. package/renderer/app/api/docs/route.js +205 -0
  15. package/renderer/app/api/domains/add/route.js +121 -0
  16. package/renderer/app/api/domains/lookup/route.js +43 -0
  17. package/renderer/app/api/domains/remove/route.js +89 -0
  18. package/renderer/app/api/domains/status/route.js +140 -0
  19. package/renderer/app/api/domains/verify/route.js +168 -0
  20. package/renderer/app/api/keys/regenerate/route.js +71 -0
  21. package/renderer/app/api/local-assets/[...path]/route.js +108 -0
  22. package/renderer/app/api/openapi-spec/route.js +73 -0
  23. package/renderer/app/api/projects/[slug]/route.js +129 -0
  24. package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
  25. package/renderer/app/api/projects/register/route.js +176 -0
  26. package/renderer/app/api/proxy/route.js +139 -0
  27. package/renderer/app/api/proxy-stream/route.js +156 -0
  28. package/renderer/app/api/redirects/route.js +35 -0
  29. package/renderer/app/api/schema/route.js +85 -0
  30. package/renderer/app/api/subdomains/check/route.js +158 -0
  31. package/renderer/app/api/suggestions/route.js +195 -0
  32. package/renderer/app/globals.css +69 -0
  33. package/renderer/app/layout.js +47 -0
  34. package/renderer/app/llms-full.txt/route.js +266 -0
  35. package/renderer/app/llms.txt/route.js +228 -0
  36. package/renderer/app/page.js +12 -0
  37. package/renderer/app/robots.txt/route.js +66 -0
  38. package/renderer/app/sitemap.xml/route.js +155 -0
  39. package/renderer/components/docs/index.js +8 -0
  40. package/renderer/components/docs/mdx/accordion.js +113 -0
  41. package/renderer/components/docs/mdx/badge.js +72 -0
  42. package/renderer/components/docs/mdx/callouts.js +137 -0
  43. package/renderer/components/docs/mdx/cards.js +175 -0
  44. package/renderer/components/docs/mdx/changelog.js +100 -0
  45. package/renderer/components/docs/mdx/code-block.js +147 -0
  46. package/renderer/components/docs/mdx/code-group.js +287 -0
  47. package/renderer/components/docs/mdx/file-embeds.js +82 -0
  48. package/renderer/components/docs/mdx/frame.js +59 -0
  49. package/renderer/components/docs/mdx/highlight.js +90 -0
  50. package/renderer/components/docs/mdx/iframe.js +69 -0
  51. package/renderer/components/docs/mdx/image.js +135 -0
  52. package/renderer/components/docs/mdx/index.js +134 -0
  53. package/renderer/components/docs/mdx/landing.js +317 -0
  54. package/renderer/components/docs/mdx/mermaid.js +212 -0
  55. package/renderer/components/docs/mdx/param-field.js +112 -0
  56. package/renderer/components/docs/mdx/steps.js +74 -0
  57. package/renderer/components/docs/mdx/tabs.js +50 -0
  58. package/renderer/components/docs/mdx-renderer.js +77 -0
  59. package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
  60. package/renderer/components/docs/navigation/index.js +6 -0
  61. package/renderer/components/docs/navigation/page-nav.js +57 -0
  62. package/renderer/components/docs/navigation/sidebar.js +375 -0
  63. package/renderer/components/docs/navigation/toc.js +89 -0
  64. package/renderer/components/docs/notice.js +77 -0
  65. package/renderer/components/docs-header.js +202 -0
  66. package/renderer/components/docs-viewer/agent/agent-chat.js +1831 -0
  67. package/renderer/components/docs-viewer/agent/agent-popup-button.js +99 -0
  68. package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
  69. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
  70. package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
  71. package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
  72. package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
  73. package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
  74. package/renderer/components/docs-viewer/agent/index.js +7 -0
  75. package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
  76. package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
  77. package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
  78. package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
  79. package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
  80. package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
  81. package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
  82. package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
  83. package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
  84. package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
  85. package/renderer/components/docs-viewer/content/content-router.js +182 -0
  86. package/renderer/components/docs-viewer/content/doc-page.js +290 -0
  87. package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
  88. package/renderer/components/docs-viewer/content/index.js +31 -0
  89. package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
  90. package/renderer/components/docs-viewer/content/request-details.js +528 -0
  91. package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
  92. package/renderer/components/docs-viewer/content/sections/body.js +80 -0
  93. package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
  94. package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
  95. package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
  96. package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
  97. package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
  98. package/renderer/components/docs-viewer/index.js +1448 -0
  99. package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
  100. package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
  101. package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
  102. package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
  103. package/renderer/components/docs-viewer/playground/graphql-playground.js +936 -0
  104. package/renderer/components/docs-viewer/playground/index.js +682 -0
  105. package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
  106. package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
  107. package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
  108. package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
  109. package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
  110. package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
  111. package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
  112. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
  113. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
  114. package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
  115. package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
  116. package/renderer/components/docs-viewer/search/index.js +2 -0
  117. package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
  118. package/renderer/components/docs-viewer/search/use-search.js +89 -0
  119. package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
  120. package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
  121. package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
  122. package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
  123. package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
  124. package/renderer/components/docs-viewer/sidebar/index.js +196 -0
  125. package/renderer/components/docs-viewer/sidebar/right-sidebar.js +159 -0
  126. package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
  127. package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
  128. package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
  129. package/renderer/components/theme-provider.js +10 -0
  130. package/renderer/components/theme-toggle.js +86 -0
  131. package/renderer/components/ui/badge.js +29 -0
  132. package/renderer/components/ui/button.js +40 -0
  133. package/renderer/components/ui/dialog.js +50 -0
  134. package/renderer/components/ui/dropdown-menu.js +143 -0
  135. package/renderer/components/ui/input.js +12 -0
  136. package/renderer/components/ui/label.js +13 -0
  137. package/renderer/components/ui/navigation-menu.js +83 -0
  138. package/renderer/components/ui/select.js +116 -0
  139. package/renderer/components/ui/spinner.js +92 -0
  140. package/renderer/components/ui/tabs.js +34 -0
  141. package/renderer/components/ui/tooltip.js +43 -0
  142. package/renderer/hooks/use-code-copy.js +76 -0
  143. package/renderer/hooks/use-openapi-title.js +33 -0
  144. package/renderer/hooks/use-route-state.js +159 -0
  145. package/renderer/lib/api-docs/agent/index.js +4 -0
  146. package/renderer/lib/api-docs/agent/indexer.js +254 -0
  147. package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
  148. package/renderer/lib/api-docs/agent/types.js +5 -0
  149. package/renderer/lib/api-docs/agent/use-suggestions.js +97 -0
  150. package/renderer/lib/api-docs/auth/auth-context.js +157 -0
  151. package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
  152. package/renderer/lib/api-docs/auth/crypto.js +64 -0
  153. package/renderer/lib/api-docs/auth/index.js +3 -0
  154. package/renderer/lib/api-docs/code-editor/db.js +145 -0
  155. package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
  156. package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
  157. package/renderer/lib/api-docs/code-editor/mode-context.js +126 -0
  158. package/renderer/lib/api-docs/code-editor/types.js +53 -0
  159. package/renderer/lib/api-docs/codegen/definitions.js +258 -0
  160. package/renderer/lib/api-docs/codegen/har.js +171 -0
  161. package/renderer/lib/api-docs/codegen/index.js +118 -0
  162. package/renderer/lib/api-docs/factories.js +136 -0
  163. package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
  164. package/renderer/lib/api-docs/mobile-context.js +116 -0
  165. package/renderer/lib/api-docs/navigation-context.js +62 -0
  166. package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
  167. package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
  168. package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
  169. package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
  170. package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
  171. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
  172. package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
  173. package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
  174. package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
  175. package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
  176. package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
  177. package/renderer/lib/api-docs/playground/context.js +65 -0
  178. package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
  179. package/renderer/lib/api-docs/playground/request-builder.js +163 -0
  180. package/renderer/lib/api-docs/playground/request-runner.js +224 -0
  181. package/renderer/lib/api-docs/playground/types.js +5 -0
  182. package/renderer/lib/api-docs/types.js +23 -0
  183. package/renderer/lib/api-docs/utils.js +212 -0
  184. package/renderer/lib/cache.js +157 -0
  185. package/renderer/lib/docs/config/domain-schema.js +161 -0
  186. package/renderer/lib/docs/config/environment.js +38 -0
  187. package/renderer/lib/docs/config/index.js +6 -0
  188. package/renderer/lib/docs/config/loader.js +113 -0
  189. package/renderer/lib/docs/config/schema.js +281 -0
  190. package/renderer/lib/docs/index.js +8 -0
  191. package/renderer/lib/docs/mdx/compiler.js +131 -0
  192. package/renderer/lib/docs/mdx/frontmatter.js +73 -0
  193. package/renderer/lib/docs/mdx/index.js +10 -0
  194. package/renderer/lib/docs/mdx/remark-mermaid.js +63 -0
  195. package/renderer/lib/docs/navigation/generator.js +269 -0
  196. package/renderer/lib/docs/navigation/index.js +3 -0
  197. package/renderer/lib/docs/navigation/types.js +11 -0
  198. package/renderer/lib/docs-navigation-context.js +40 -0
  199. package/renderer/lib/docs-navigation.js +140 -0
  200. package/renderer/lib/multi-tenant/context.js +80 -0
  201. package/renderer/lib/storage/blob.js +767 -0
  202. package/renderer/lib/utils/icons.js +30 -0
  203. package/renderer/lib/utils.js +5 -0
  204. package/renderer/next.config.js +62 -0
  205. package/renderer/package.json +1 -0
  206. package/renderer/tsconfig.json +23 -5
  207. package/renderer/app/api/assets/[...path]/route.ts +0 -123
  208. package/renderer/app/api/assets/route.ts +0 -124
  209. package/renderer/app/api/assets/upload/route.ts +0 -177
  210. package/renderer/app/api/auth-schemes/route.ts +0 -77
  211. package/renderer/app/api/chat/route.ts +0 -858
  212. package/renderer/app/api/codegen/route.ts +0 -72
  213. package/renderer/app/api/collections/route.ts +0 -1002
  214. package/renderer/app/api/debug/route.ts +0 -53
  215. package/renderer/app/api/deploy/route.ts +0 -234
  216. package/renderer/app/api/device/route.ts +0 -42
  217. package/renderer/app/api/docs/route.ts +0 -201
  218. package/renderer/app/api/domains/add/route.ts +0 -132
  219. package/renderer/app/api/domains/lookup/route.ts +0 -43
  220. package/renderer/app/api/domains/remove/route.ts +0 -100
  221. package/renderer/app/api/domains/status/route.ts +0 -158
  222. package/renderer/app/api/domains/verify/route.ts +0 -181
  223. package/renderer/app/api/keys/regenerate/route.ts +0 -80
  224. package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
  225. package/renderer/app/api/openapi-spec/route.ts +0 -151
  226. package/renderer/app/api/projects/[slug]/route.ts +0 -153
  227. package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
  228. package/renderer/app/api/projects/register/route.ts +0 -152
  229. package/renderer/app/api/proxy/route.ts +0 -149
  230. package/renderer/app/api/proxy-stream/route.ts +0 -168
  231. package/renderer/app/api/redirects/route.ts +0 -47
  232. package/renderer/app/api/schema/route.ts +0 -73
  233. package/renderer/app/api/subdomains/check/route.ts +0 -172
  234. package/renderer/app/api/suggestions/route.ts +0 -144
  235. package/renderer/app/layout.tsx +0 -54
  236. package/renderer/app/llms-full.txt/route.ts +0 -346
  237. package/renderer/app/llms.txt/route.ts +0 -279
  238. package/renderer/app/page.tsx +0 -14
  239. package/renderer/app/robots.txt/route.ts +0 -84
  240. package/renderer/app/sitemap.xml/route.ts +0 -199
  241. package/renderer/components/docs/index.ts +0 -12
  242. package/renderer/components/docs/mdx/accordion.tsx +0 -169
  243. package/renderer/components/docs/mdx/badge.tsx +0 -132
  244. package/renderer/components/docs/mdx/callouts.tsx +0 -154
  245. package/renderer/components/docs/mdx/cards.tsx +0 -241
  246. package/renderer/components/docs/mdx/changelog.tsx +0 -120
  247. package/renderer/components/docs/mdx/code-block.tsx +0 -186
  248. package/renderer/components/docs/mdx/code-group.tsx +0 -421
  249. package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
  250. package/renderer/components/docs/mdx/frame.tsx +0 -112
  251. package/renderer/components/docs/mdx/highlight.tsx +0 -151
  252. package/renderer/components/docs/mdx/iframe.tsx +0 -134
  253. package/renderer/components/docs/mdx/image.tsx +0 -235
  254. package/renderer/components/docs/mdx/index.ts +0 -237
  255. package/renderer/components/docs/mdx/landing.tsx +0 -684
  256. package/renderer/components/docs/mdx/mermaid.tsx +0 -240
  257. package/renderer/components/docs/mdx/param-field.tsx +0 -200
  258. package/renderer/components/docs/mdx/steps.tsx +0 -113
  259. package/renderer/components/docs/mdx/tabs.tsx +0 -86
  260. package/renderer/components/docs/mdx-renderer.tsx +0 -100
  261. package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
  262. package/renderer/components/docs/navigation/index.ts +0 -8
  263. package/renderer/components/docs/navigation/page-nav.tsx +0 -64
  264. package/renderer/components/docs/navigation/sidebar.tsx +0 -515
  265. package/renderer/components/docs/navigation/toc.tsx +0 -113
  266. package/renderer/components/docs/notice.tsx +0 -105
  267. package/renderer/components/docs-header.tsx +0 -278
  268. package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
  269. package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
  270. package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
  271. package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
  272. package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
  273. package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
  274. package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
  275. package/renderer/components/docs-viewer/agent/index.tsx +0 -6
  276. package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
  277. package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
  278. package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
  279. package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
  280. package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
  281. package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
  282. package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
  283. package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
  284. package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
  285. package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
  286. package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
  287. package/renderer/components/docs-viewer/content/index.tsx +0 -29
  288. package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
  289. package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
  290. package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
  291. package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
  292. package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
  293. package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
  294. package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
  295. package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
  296. package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
  297. package/renderer/components/docs-viewer/index.tsx +0 -1670
  298. package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
  299. package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
  300. package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
  301. package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
  302. package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
  303. package/renderer/components/docs-viewer/playground/index.tsx +0 -671
  304. package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
  305. package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
  306. package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
  307. package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
  308. package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
  309. package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
  310. package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
  311. package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
  312. package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
  313. package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
  314. package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
  315. package/renderer/components/docs-viewer/search/index.ts +0 -2
  316. package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
  317. package/renderer/components/docs-viewer/search/use-search.ts +0 -117
  318. package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
  319. package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
  320. package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
  321. package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
  322. package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
  323. package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
  324. package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
  325. package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
  326. package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
  327. package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
  328. package/renderer/components/theme-provider.tsx +0 -11
  329. package/renderer/components/theme-toggle.tsx +0 -76
  330. package/renderer/components/ui/badge.tsx +0 -46
  331. package/renderer/components/ui/button.tsx +0 -59
  332. package/renderer/components/ui/dialog.tsx +0 -118
  333. package/renderer/components/ui/dropdown-menu.tsx +0 -257
  334. package/renderer/components/ui/input.tsx +0 -21
  335. package/renderer/components/ui/label.tsx +0 -24
  336. package/renderer/components/ui/navigation-menu.tsx +0 -168
  337. package/renderer/components/ui/select.tsx +0 -190
  338. package/renderer/components/ui/spinner.tsx +0 -114
  339. package/renderer/components/ui/tabs.tsx +0 -66
  340. package/renderer/components/ui/tooltip.tsx +0 -61
  341. package/renderer/hooks/use-code-copy.ts +0 -88
  342. package/renderer/hooks/use-openapi-title.ts +0 -44
  343. package/renderer/lib/api-docs/agent/index.ts +0 -6
  344. package/renderer/lib/api-docs/agent/indexer.ts +0 -323
  345. package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
  346. package/renderer/lib/api-docs/agent/types.ts +0 -116
  347. package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
  348. package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
  349. package/renderer/lib/api-docs/auth/crypto.ts +0 -89
  350. package/renderer/lib/api-docs/auth/index.ts +0 -4
  351. package/renderer/lib/api-docs/code-editor/db.ts +0 -164
  352. package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
  353. package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
  354. package/renderer/lib/api-docs/code-editor/types.ts +0 -105
  355. package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
  356. package/renderer/lib/api-docs/codegen/har.ts +0 -251
  357. package/renderer/lib/api-docs/codegen/index.ts +0 -159
  358. package/renderer/lib/api-docs/factories.ts +0 -170
  359. package/renderer/lib/api-docs/mobile-context.tsx +0 -112
  360. package/renderer/lib/api-docs/navigation-context.tsx +0 -88
  361. package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
  362. package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
  363. package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
  364. package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
  365. package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
  366. package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
  367. package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
  368. package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
  369. package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
  370. package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
  371. package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
  372. package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
  373. package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
  374. package/renderer/lib/api-docs/playground/context.tsx +0 -107
  375. package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
  376. package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
  377. package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
  378. package/renderer/lib/api-docs/playground/types.ts +0 -35
  379. package/renderer/lib/api-docs/types.ts +0 -269
  380. package/renderer/lib/api-docs/utils.ts +0 -311
  381. package/renderer/lib/cache.ts +0 -193
  382. package/renderer/lib/docs/config/domain-schema.ts +0 -260
  383. package/renderer/lib/docs/config/index.ts +0 -43
  384. package/renderer/lib/docs/config/loader.ts +0 -142
  385. package/renderer/lib/docs/config/schema.ts +0 -308
  386. package/renderer/lib/docs/index.ts +0 -12
  387. package/renderer/lib/docs/mdx/compiler.ts +0 -176
  388. package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
  389. package/renderer/lib/docs/mdx/index.ts +0 -26
  390. package/renderer/lib/docs/navigation/generator.ts +0 -348
  391. package/renderer/lib/docs/navigation/index.ts +0 -12
  392. package/renderer/lib/docs/navigation/types.ts +0 -123
  393. package/renderer/lib/docs-navigation-context.tsx +0 -80
  394. package/renderer/lib/multi-tenant/context.ts +0 -105
  395. package/renderer/lib/storage/blob.ts +0 -1083
  396. package/renderer/lib/utils/icons.ts +0 -48
  397. package/renderer/lib/utils.ts +0 -6
  398. 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
- }