@brainfish-ai/devdoc 0.1.42 → 0.1.43

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