@hanzo/ui 4.9.0 → 5.0.1

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 (685) hide show
  1. package/README.md +192 -185
  2. package/assets/ai-icons.tsx +207 -0
  3. package/assets/crypto.tsx +33 -0
  4. package/assets/file-type-icon.tsx +66 -0
  5. package/assets/file.tsx +45 -0
  6. package/assets/general.tsx +2318 -0
  7. package/assets/hanzo-logo.svg +9 -0
  8. package/assets/hanzo-logo.tsx +17 -0
  9. package/assets/index.ts +122 -0
  10. package/assets/index.tsx +4 -0
  11. package/assets/llm-provider.tsx +1094 -0
  12. package/bin/cli.js +100 -0
  13. package/bin/create-registry.js +108 -0
  14. package/bin/mcp.js +403 -0
  15. package/bin/npx-registry-mcp.js +15 -0
  16. package/bin/registry-mcp-wrapper.sh +19 -0
  17. package/bin/registry-mcp.js +100 -0
  18. package/bin/start-mcp-server.sh +22 -0
  19. package/bin/test-mcp.sh +52 -0
  20. package/bin/update-registry.js +196 -0
  21. package/blocks/auth/index.ts +6 -0
  22. package/blocks/auth/login-2fa.tsx +165 -0
  23. package/blocks/auth/login-basic.tsx +94 -0
  24. package/blocks/auth/login-social.tsx +148 -0
  25. package/blocks/auth/magic-link.tsx +129 -0
  26. package/blocks/auth/password-reset.tsx +97 -0
  27. package/blocks/auth/signup.tsx +157 -0
  28. package/blocks/components/accordian-block.tsx +48 -0
  29. package/blocks/components/block-component-props.ts +11 -0
  30. package/blocks/components/bullet-cards-block.tsx +46 -0
  31. package/blocks/components/card-block/index.tsx +171 -0
  32. package/blocks/components/card-block/link-out-button.tsx +20 -0
  33. package/blocks/components/card-block/util.ts +28 -0
  34. package/blocks/components/carte-blanche-block/index.tsx +127 -0
  35. package/blocks/components/carte-blanche-block/variant-content-left.tsx +49 -0
  36. package/blocks/components/content.tsx +70 -0
  37. package/blocks/components/cta-block.tsx +115 -0
  38. package/blocks/components/enh-heading-block.tsx +204 -0
  39. package/blocks/components/grid-block/grid-block-mutator.ts +12 -0
  40. package/blocks/components/grid-block/index.tsx +83 -0
  41. package/blocks/components/grid-block/mutator-registry.ts +10 -0
  42. package/blocks/components/grid-block/table-borders.mutator.ts +47 -0
  43. package/blocks/components/group-block.tsx +83 -0
  44. package/blocks/components/heading-block.tsx +88 -0
  45. package/blocks/components/image-block.tsx +111 -0
  46. package/blocks/components/index.ts +30 -0
  47. package/blocks/components/screenful-block/content.tsx +123 -0
  48. package/blocks/components/screenful-block/index.tsx +107 -0
  49. package/blocks/components/screenful-block/poster-background.tsx +34 -0
  50. package/blocks/components/screenful-block/video-background.tsx +45 -0
  51. package/blocks/components/space-block.tsx +66 -0
  52. package/blocks/components/video-block.tsx +138 -0
  53. package/blocks/data-display/activity-feed.tsx +242 -0
  54. package/blocks/data-display/data-table.tsx +235 -0
  55. package/blocks/data-display/stats-grid.tsx +194 -0
  56. package/blocks/def/accordian-block.ts +14 -0
  57. package/blocks/def/block.ts +7 -0
  58. package/blocks/def/bullet-cards-block.ts +22 -0
  59. package/blocks/def/card-block.ts +22 -0
  60. package/blocks/def/carte-blanche-block.ts +21 -0
  61. package/blocks/def/cta-block.ts +19 -0
  62. package/blocks/def/element-block.ts +11 -0
  63. package/blocks/def/enh-heading-block.ts +44 -0
  64. package/blocks/def/grid-block.ts +16 -0
  65. package/blocks/def/group-block.ts +11 -0
  66. package/blocks/def/heading-block.ts +15 -0
  67. package/blocks/def/image-block.ts +31 -0
  68. package/blocks/def/index.ts +35 -0
  69. package/blocks/def/screenful-block.ts +54 -0
  70. package/blocks/def/space-block.ts +64 -0
  71. package/blocks/def/video-block.ts +9 -0
  72. package/blocks/ecommerce/checkout.tsx +242 -0
  73. package/blocks/ecommerce/index.ts +7 -0
  74. package/blocks/ecommerce/product-detail.tsx +257 -0
  75. package/blocks/ecommerce/product-grid.tsx +148 -0
  76. package/blocks/ecommerce/shopping-cart.tsx +181 -0
  77. package/blocks/index.ts +2 -0
  78. package/blocks/marketing/cta-section.tsx +207 -0
  79. package/blocks/marketing/faq.tsx +159 -0
  80. package/blocks/marketing/features-grid.tsx +156 -0
  81. package/blocks/marketing/hero-section.tsx +192 -0
  82. package/blocks/marketing/index.ts +6 -0
  83. package/blocks/marketing/pricing-table.tsx +121 -0
  84. package/blocks/marketing/testimonials.tsx +196 -0
  85. package/components/index.ts +9 -0
  86. package/dist/index.js +9070 -1089
  87. package/dist/index.js.map +1 -1
  88. package/dist/index.mjs +8695 -45
  89. package/dist/index.mjs.map +1 -1
  90. package/dist/tailwind.js +2025 -0
  91. package/dist/tailwind.js.map +1 -0
  92. package/dist/tailwind.mjs +2013 -0
  93. package/dist/tailwind.mjs.map +1 -0
  94. package/dist/types.js +59 -0
  95. package/dist/types.js.map +1 -0
  96. package/dist/types.mjs +53 -0
  97. package/dist/types.mjs.map +1 -0
  98. package/dist/utils.js +30 -0
  99. package/dist/utils.js.map +1 -0
  100. package/dist/utils.mjs +26 -0
  101. package/dist/utils.mjs.map +1 -0
  102. package/frameworks/core/index.ts +6 -0
  103. package/frameworks/core/utils/index.ts +64 -0
  104. package/frameworks/react/components/button.tsx +26 -0
  105. package/frameworks/react/components/index.ts +5 -0
  106. package/frameworks/react/hooks/index.ts +5 -0
  107. package/frameworks/react/index.ts +9 -0
  108. package/frameworks/react/package.json +8 -0
  109. package/frameworks/react/utils/index.ts +2 -0
  110. package/frameworks/react-native/index.ts +9 -0
  111. package/frameworks/react-native/package.json +8 -0
  112. package/frameworks/registry.json +371 -0
  113. package/frameworks/setup.sh +69 -0
  114. package/frameworks/svelte/index.ts +9 -0
  115. package/frameworks/svelte/package.json +8 -0
  116. package/frameworks/tracker.json +1854 -0
  117. package/frameworks/vue/index.ts +9 -0
  118. package/frameworks/vue/package.json +8 -0
  119. package/helpers/file.ts +33 -0
  120. package/helpers/memoization.ts +40 -0
  121. package/package.json +272 -153
  122. package/primitives/accordion.tsx +74 -0
  123. package/primitives/action-button.tsx +42 -0
  124. package/primitives/alert-dialog.tsx +185 -0
  125. package/primitives/alert.tsx +74 -0
  126. package/primitives/apply-typography.tsx +55 -0
  127. package/primitives/aspect-ratio.tsx +5 -0
  128. package/primitives/avatar.tsx +57 -0
  129. package/primitives/background-beams.tsx +142 -0
  130. package/primitives/badge.tsx +45 -0
  131. package/primitives/breadcrumb.tsx +130 -0
  132. package/primitives/breakpoint-indicator.tsx +19 -0
  133. package/primitives/button.tsx +72 -0
  134. package/primitives/calendar.tsx +72 -0
  135. package/primitives/card.tsx +97 -0
  136. package/primitives/carousel.tsx +238 -0
  137. package/primitives/chat/chat-input-area.tsx +88 -0
  138. package/primitives/chat/chat-input.tsx +71 -0
  139. package/primitives/chat/files-preview.tsx +331 -0
  140. package/primitives/chat/index.ts +6 -0
  141. package/primitives/chat/json-form.tsx +8 -0
  142. package/primitives/chat/message-list.tsx +308 -0
  143. package/primitives/chat/message.tsx +569 -0
  144. package/primitives/chat/sqlite-preview.tsx +215 -0
  145. package/primitives/checkbox.tsx +32 -0
  146. package/primitives/collapsible.tsx +9 -0
  147. package/primitives/combobox.tsx +239 -0
  148. package/primitives/command.tsx +151 -0
  149. package/primitives/context-menu.tsx +206 -0
  150. package/primitives/copy-to-clipboard-icon.tsx +60 -0
  151. package/primitives/dialog-video-controller.tsx +38 -0
  152. package/primitives/dialog.tsx +128 -0
  153. package/primitives/dot-pattern.tsx +57 -0
  154. package/primitives/dots-loader.tsx +13 -0
  155. package/primitives/drawer.tsx +113 -0
  156. package/primitives/dropdown-menu.tsx +199 -0
  157. package/primitives/error-message.tsx +19 -0
  158. package/primitives/file-uploader.tsx +203 -0
  159. package/primitives/form.tsx +185 -0
  160. package/primitives/hover-card.tsx +28 -0
  161. package/primitives/icons/github.tsx +14 -0
  162. package/primitives/icons/index.ts +18 -0
  163. package/primitives/icons/youtube-logo.tsx +59 -0
  164. package/primitives/index-client.ts +4 -0
  165. package/primitives/index-common.ts +304 -0
  166. package/primitives/index-next.ts +4 -0
  167. package/primitives/input-otp.tsx +65 -0
  168. package/primitives/input.tsx +128 -0
  169. package/primitives/label.tsx +21 -0
  170. package/primitives/list-adaptor.ts +12 -0
  171. package/primitives/list-box.tsx +74 -0
  172. package/primitives/loading-spinner.tsx +33 -0
  173. package/primitives/markdown-preview.tsx +612 -0
  174. package/primitives/mermaid.tsx +191 -0
  175. package/primitives/navigation-menu.tsx +147 -0
  176. package/primitives/next/image.tsx +91 -0
  177. package/primitives/next/index.ts +7 -0
  178. package/primitives/next/inline-icon.tsx +36 -0
  179. package/primitives/next/link-element.tsx +109 -0
  180. package/primitives/next/mdx-link.tsx +22 -0
  181. package/primitives/next/media-stack.tsx +52 -0
  182. package/primitives/next/nav-items.tsx +45 -0
  183. package/primitives/next/youtube-embed.tsx +83 -0
  184. package/primitives/pagination.tsx +117 -0
  185. package/primitives/popover.tsx +34 -0
  186. package/primitives/pretty-json-print.tsx +28 -0
  187. package/primitives/progress.tsx +27 -0
  188. package/primitives/prompt-textarea.tsx +72 -0
  189. package/primitives/qr-code.tsx +112 -0
  190. package/primitives/radio-group.tsx +42 -0
  191. package/primitives/resizable.tsx +47 -0
  192. package/primitives/scroll-area.tsx +57 -0
  193. package/primitives/search-input.tsx +66 -0
  194. package/primitives/select.tsx +122 -0
  195. package/primitives/separator.tsx +26 -0
  196. package/primitives/sheet.tsx +139 -0
  197. package/primitives/skeleton.tsx +18 -0
  198. package/primitives/slider.tsx +63 -0
  199. package/primitives/sonner.tsx +35 -0
  200. package/primitives/step-indicator.tsx +69 -0
  201. package/primitives/stepper.tsx +272 -0
  202. package/primitives/switch.tsx +27 -0
  203. package/primitives/table.tsx +105 -0
  204. package/primitives/tabs.tsx +50 -0
  205. package/primitives/text-area.tsx +26 -0
  206. package/primitives/text-link.tsx +27 -0
  207. package/primitives/textarea.tsx +64 -0
  208. package/primitives/textfield.tsx +78 -0
  209. package/primitives/toast.tsx +30 -0
  210. package/primitives/toggle-group.tsx +63 -0
  211. package/primitives/toggle.tsx +44 -0
  212. package/primitives/tooltip.tsx +47 -0
  213. package/primitives/video-player.tsx +23 -0
  214. package/src/button.ts +1 -0
  215. package/src/hooks/index.ts +7 -0
  216. package/src/hooks/use-click-away.ts +31 -0
  217. package/src/hooks/use-combined-refs.ts +22 -0
  218. package/src/hooks/use-copy-clipboard.ts +30 -0
  219. package/src/hooks/use-debounce.ts +17 -0
  220. package/src/hooks/use-fill-ids.ts +25 -0
  221. package/src/hooks/use-map.ts +26 -0
  222. package/src/hooks/use-measure.ts +42 -0
  223. package/src/hooks/use-reverse-video-playback.ts +43 -0
  224. package/src/hooks/use-scroll-restoration.ts +50 -0
  225. package/src/index-lean.ts +87 -0
  226. package/src/index.ts +54 -0
  227. package/src/mcp/README.md +141 -0
  228. package/src/mcp/enhanced-server.ts +1208 -0
  229. package/src/mcp/index.ts +518 -0
  230. package/src/mcp/package.json +10 -0
  231. package/src/registry/api.ts +164 -0
  232. package/src/registry/index.ts +60 -0
  233. package/src/registry/package.json +10 -0
  234. package/src/utils.ts +19 -0
  235. package/style/drawer.css +163 -0
  236. package/style/globals.css +13 -0
  237. package/style/hanzo-common.css +31 -0
  238. package/style/hanzo-default-colors.css +82 -0
  239. package/style/theme-provider.tsx +20 -0
  240. package/tailwind/colors.tailwind.js +53 -0
  241. package/tailwind/fontFamily.tailwind.ts +7 -0
  242. package/tailwind/fontSize.tailwind.ts +13 -0
  243. package/tailwind/index.ts +7 -0
  244. package/tailwind/safelist.tailwind.js +26 -0
  245. package/tailwind/screens.tailwind.js +8 -0
  246. package/tailwind/spacing.tailwind.js +65 -0
  247. package/tailwind/tailwind.config.hanzo-preset.d.ts +5 -0
  248. package/tailwind/tailwind.config.hanzo-preset.js +915 -0
  249. package/tailwind/tw-font-desc.ts +15 -0
  250. package/tailwind/typo-plugin/get-plugin-styles.js +679 -0
  251. package/tailwind/typo-plugin/index.d.ts +9 -0
  252. package/tailwind/typo-plugin/index.js +141 -0
  253. package/tailwind/typo-plugin/utils.js +60 -0
  254. package/tailwind/typography-test.mdx +35 -0
  255. package/tailwind/z-index.tailwind.js +71 -0
  256. package/types/animation-def.ts +3 -0
  257. package/types/breakpoints.ts +11 -0
  258. package/types/bullet-item.ts +10 -0
  259. package/types/button-def.ts +39 -0
  260. package/types/dimensions.ts +8 -0
  261. package/types/grid-def.ts +56 -0
  262. package/types/image-def.ts +32 -0
  263. package/types/index.ts +30 -0
  264. package/types/link-def.ts +56 -0
  265. package/types/media-stack-def.ts +31 -0
  266. package/types/t-shirt-size.ts +5 -0
  267. package/types/tshirt-dimensions.ts +20 -0
  268. package/types/video-def.ts +25 -0
  269. package/util/blob.ts +33 -0
  270. package/util/copy-to-clipboard.ts +17 -0
  271. package/util/create-shadow-root.ts +22 -0
  272. package/util/date.ts +84 -0
  273. package/util/debounce.ts +11 -0
  274. package/util/file.ts +15 -0
  275. package/util/format-and-abbreviate-as-currency.ts +125 -0
  276. package/util/format-text.ts +34 -0
  277. package/util/format-to-max-char.ts +68 -0
  278. package/util/index-client.ts +3 -0
  279. package/util/index.ts +112 -0
  280. package/util/number-abbreviate.ts +49 -0
  281. package/util/specifier.ts +43 -0
  282. package/util/spread-to-transform.ts +25 -0
  283. package/util/step-animation.ts +90 -0
  284. package/util/timing.ts +3 -0
  285. package/util/toasts.tsx +17 -0
  286. package/util/two-way-map.ts +19 -0
  287. package/CHANGELOG.md +0 -184
  288. package/LICENSE +0 -21
  289. package/dist/ai/index.js +0 -53
  290. package/dist/ai/index.js.map +0 -1
  291. package/dist/ai/index.mjs +0 -4
  292. package/dist/ai/index.mjs.map +0 -1
  293. package/dist/blocks/index.js +0 -983
  294. package/dist/blocks/index.js.map +0 -1
  295. package/dist/blocks/index.mjs +0 -945
  296. package/dist/blocks/index.mjs.map +0 -1
  297. package/dist/calendar/index.js +0 -14
  298. package/dist/calendar/index.js.map +0 -1
  299. package/dist/calendar/index.mjs +0 -5
  300. package/dist/calendar/index.mjs.map +0 -1
  301. package/dist/carousel/index.js +0 -220
  302. package/dist/carousel/index.js.map +0 -1
  303. package/dist/carousel/index.mjs +0 -191
  304. package/dist/carousel/index.mjs.map +0 -1
  305. package/dist/charts/index.js +0 -945
  306. package/dist/charts/index.js.map +0 -1
  307. package/dist/charts/index.mjs +0 -901
  308. package/dist/charts/index.mjs.map +0 -1
  309. package/dist/chunk-26T4V5QU.mjs +0 -111
  310. package/dist/chunk-26T4V5QU.mjs.map +0 -1
  311. package/dist/chunk-2A5KXDLJ.js +0 -22
  312. package/dist/chunk-2A5KXDLJ.js.map +0 -1
  313. package/dist/chunk-2CJ4HMF4.js +0 -79
  314. package/dist/chunk-2CJ4HMF4.js.map +0 -1
  315. package/dist/chunk-2OIQKC5E.js +0 -236
  316. package/dist/chunk-2OIQKC5E.js.map +0 -1
  317. package/dist/chunk-2X3KSYBN.js +0 -44
  318. package/dist/chunk-2X3KSYBN.js.map +0 -1
  319. package/dist/chunk-3PBQGYR7.mjs +0 -100
  320. package/dist/chunk-3PBQGYR7.mjs.map +0 -1
  321. package/dist/chunk-3POQQ6L7.js +0 -62
  322. package/dist/chunk-3POQQ6L7.js.map +0 -1
  323. package/dist/chunk-4B47GITH.mjs +0 -28
  324. package/dist/chunk-4B47GITH.mjs.map +0 -1
  325. package/dist/chunk-4BC2OH6B.js +0 -129
  326. package/dist/chunk-4BC2OH6B.js.map +0 -1
  327. package/dist/chunk-5AQSGH4R.js +0 -130
  328. package/dist/chunk-5AQSGH4R.js.map +0 -1
  329. package/dist/chunk-5IHRJFOO.mjs +0 -102
  330. package/dist/chunk-5IHRJFOO.mjs.map +0 -1
  331. package/dist/chunk-5LDGR7YN.mjs +0 -28
  332. package/dist/chunk-5LDGR7YN.mjs.map +0 -1
  333. package/dist/chunk-5MCN3VYM.mjs +0 -23
  334. package/dist/chunk-5MCN3VYM.mjs.map +0 -1
  335. package/dist/chunk-6AVAMRMB.mjs +0 -47
  336. package/dist/chunk-6AVAMRMB.mjs.map +0 -1
  337. package/dist/chunk-6H62JRNM.mjs +0 -120
  338. package/dist/chunk-6H62JRNM.mjs.map +0 -1
  339. package/dist/chunk-6KCII3F6.mjs +0 -126
  340. package/dist/chunk-6KCII3F6.mjs.map +0 -1
  341. package/dist/chunk-7EHB43BJ.js +0 -155
  342. package/dist/chunk-7EHB43BJ.js.map +0 -1
  343. package/dist/chunk-7LRD23Q5.js +0 -191
  344. package/dist/chunk-7LRD23Q5.js.map +0 -1
  345. package/dist/chunk-7SAHKOJG.mjs +0 -45
  346. package/dist/chunk-7SAHKOJG.mjs.map +0 -1
  347. package/dist/chunk-A3D2YZK3.js +0 -50
  348. package/dist/chunk-A3D2YZK3.js.map +0 -1
  349. package/dist/chunk-AL4QFH7V.js +0 -63
  350. package/dist/chunk-AL4QFH7V.js.map +0 -1
  351. package/dist/chunk-B3WFEG6U.js +0 -69
  352. package/dist/chunk-B3WFEG6U.js.map +0 -1
  353. package/dist/chunk-BDZQJ6GK.js +0 -242
  354. package/dist/chunk-BDZQJ6GK.js.map +0 -1
  355. package/dist/chunk-BRWFYRGX.js +0 -61
  356. package/dist/chunk-BRWFYRGX.js.map +0 -1
  357. package/dist/chunk-C5DNTLBO.js +0 -53
  358. package/dist/chunk-C5DNTLBO.js.map +0 -1
  359. package/dist/chunk-CRALRACO.js +0 -54
  360. package/dist/chunk-CRALRACO.js.map +0 -1
  361. package/dist/chunk-CVACQJRM.js +0 -149
  362. package/dist/chunk-CVACQJRM.js.map +0 -1
  363. package/dist/chunk-DEIUKFPZ.mjs +0 -63
  364. package/dist/chunk-DEIUKFPZ.mjs.map +0 -1
  365. package/dist/chunk-DN2AEEA2.js +0 -13
  366. package/dist/chunk-DN2AEEA2.js.map +0 -1
  367. package/dist/chunk-DTNRWU4B.mjs +0 -35
  368. package/dist/chunk-DTNRWU4B.mjs.map +0 -1
  369. package/dist/chunk-DXIUEWRJ.mjs +0 -31
  370. package/dist/chunk-DXIUEWRJ.mjs.map +0 -1
  371. package/dist/chunk-DYFV66JX.mjs +0 -54
  372. package/dist/chunk-DYFV66JX.mjs.map +0 -1
  373. package/dist/chunk-F3WMAHXV.mjs +0 -86
  374. package/dist/chunk-F3WMAHXV.mjs.map +0 -1
  375. package/dist/chunk-F4RWPBBB.js +0 -79
  376. package/dist/chunk-F4RWPBBB.js.map +0 -1
  377. package/dist/chunk-FEGAPM6U.js +0 -194
  378. package/dist/chunk-FEGAPM6U.js.map +0 -1
  379. package/dist/chunk-G5TS56PW.mjs +0 -160
  380. package/dist/chunk-G5TS56PW.mjs.map +0 -1
  381. package/dist/chunk-GG6VGOEN.mjs +0 -590
  382. package/dist/chunk-GG6VGOEN.mjs.map +0 -1
  383. package/dist/chunk-GLAMGK32.mjs +0 -54
  384. package/dist/chunk-GLAMGK32.mjs.map +0 -1
  385. package/dist/chunk-GNMMUJXD.mjs +0 -200
  386. package/dist/chunk-GNMMUJXD.mjs.map +0 -1
  387. package/dist/chunk-GNPBULLS.mjs +0 -600
  388. package/dist/chunk-GNPBULLS.mjs.map +0 -1
  389. package/dist/chunk-GTE2DELE.js +0 -65
  390. package/dist/chunk-GTE2DELE.js.map +0 -1
  391. package/dist/chunk-GUQAFFTH.js +0 -94
  392. package/dist/chunk-GUQAFFTH.js.map +0 -1
  393. package/dist/chunk-H5VOYZHT.mjs +0 -34
  394. package/dist/chunk-H5VOYZHT.mjs.map +0 -1
  395. package/dist/chunk-HR6PBOGG.mjs +0 -59
  396. package/dist/chunk-HR6PBOGG.mjs.map +0 -1
  397. package/dist/chunk-HROONQS3.js +0 -55
  398. package/dist/chunk-HROONQS3.js.map +0 -1
  399. package/dist/chunk-IAO7SOQ3.mjs +0 -56
  400. package/dist/chunk-IAO7SOQ3.mjs.map +0 -1
  401. package/dist/chunk-K2QKU3K6.mjs +0 -40
  402. package/dist/chunk-K2QKU3K6.mjs.map +0 -1
  403. package/dist/chunk-KEUZZCCP.js +0 -53
  404. package/dist/chunk-KEUZZCCP.js.map +0 -1
  405. package/dist/chunk-KJXSLTG7.mjs +0 -73
  406. package/dist/chunk-KJXSLTG7.mjs.map +0 -1
  407. package/dist/chunk-L5AFUCVH.mjs +0 -26
  408. package/dist/chunk-L5AFUCVH.mjs.map +0 -1
  409. package/dist/chunk-LB3I52KZ.mjs +0 -42
  410. package/dist/chunk-LB3I52KZ.mjs.map +0 -1
  411. package/dist/chunk-LN75MJQ2.js +0 -71
  412. package/dist/chunk-LN75MJQ2.js.map +0 -1
  413. package/dist/chunk-LRBOFJUV.js +0 -60
  414. package/dist/chunk-LRBOFJUV.js.map +0 -1
  415. package/dist/chunk-MMNYRBOU.js +0 -157
  416. package/dist/chunk-MMNYRBOU.js.map +0 -1
  417. package/dist/chunk-MO65YF6P.js +0 -236
  418. package/dist/chunk-MO65YF6P.js.map +0 -1
  419. package/dist/chunk-N4KHP5FC.mjs +0 -33
  420. package/dist/chunk-N4KHP5FC.mjs.map +0 -1
  421. package/dist/chunk-NP2J7AB7.mjs +0 -121
  422. package/dist/chunk-NP2J7AB7.mjs.map +0 -1
  423. package/dist/chunk-OLR6SGYO.js +0 -57
  424. package/dist/chunk-OLR6SGYO.js.map +0 -1
  425. package/dist/chunk-ON7NQ4DY.js +0 -21
  426. package/dist/chunk-ON7NQ4DY.js.map +0 -1
  427. package/dist/chunk-PE3VFRLV.mjs +0 -198
  428. package/dist/chunk-PE3VFRLV.mjs.map +0 -1
  429. package/dist/chunk-Q7LOOIE5.mjs +0 -8
  430. package/dist/chunk-Q7LOOIE5.mjs.map +0 -1
  431. package/dist/chunk-QFA6U75G.mjs +0 -51
  432. package/dist/chunk-QFA6U75G.mjs.map +0 -1
  433. package/dist/chunk-QJQPT4WX.js +0 -638
  434. package/dist/chunk-QJQPT4WX.js.map +0 -1
  435. package/dist/chunk-QKHQPBSR.mjs +0 -20
  436. package/dist/chunk-QKHQPBSR.mjs.map +0 -1
  437. package/dist/chunk-SJD4XRFJ.mjs +0 -141
  438. package/dist/chunk-SJD4XRFJ.mjs.map +0 -1
  439. package/dist/chunk-SOOJLU4C.mjs +0 -19
  440. package/dist/chunk-SOOJLU4C.mjs.map +0 -1
  441. package/dist/chunk-T66B5IM5.js +0 -51
  442. package/dist/chunk-T66B5IM5.js.map +0 -1
  443. package/dist/chunk-T7RPZDO4.js +0 -645
  444. package/dist/chunk-T7RPZDO4.js.map +0 -1
  445. package/dist/chunk-TGRMDGTV.mjs +0 -38
  446. package/dist/chunk-TGRMDGTV.mjs.map +0 -1
  447. package/dist/chunk-TH2UKMCO.mjs +0 -11
  448. package/dist/chunk-TH2UKMCO.mjs.map +0 -1
  449. package/dist/chunk-TMV45OKE.mjs +0 -113
  450. package/dist/chunk-TMV45OKE.mjs.map +0 -1
  451. package/dist/chunk-TUJ7EVEK.js +0 -171
  452. package/dist/chunk-TUJ7EVEK.js.map +0 -1
  453. package/dist/chunk-ULNWDOI7.js +0 -122
  454. package/dist/chunk-ULNWDOI7.js.map +0 -1
  455. package/dist/chunk-UNUTTHCH.mjs +0 -210
  456. package/dist/chunk-UNUTTHCH.mjs.map +0 -1
  457. package/dist/chunk-VJMI6BG4.mjs +0 -10
  458. package/dist/chunk-VJMI6BG4.mjs.map +0 -1
  459. package/dist/chunk-VZVOB5MG.mjs +0 -26
  460. package/dist/chunk-VZVOB5MG.mjs.map +0 -1
  461. package/dist/chunk-WD67O22C.js +0 -50
  462. package/dist/chunk-WD67O22C.js.map +0 -1
  463. package/dist/chunk-WYPMLIJN.js +0 -53
  464. package/dist/chunk-WYPMLIJN.js.map +0 -1
  465. package/dist/chunk-X32I34NH.js +0 -109
  466. package/dist/chunk-X32I34NH.js.map +0 -1
  467. package/dist/chunk-X5MOZ3YL.js +0 -65
  468. package/dist/chunk-X5MOZ3YL.js.map +0 -1
  469. package/dist/chunk-Y4JVIPQZ.mjs +0 -31
  470. package/dist/chunk-Y4JVIPQZ.mjs.map +0 -1
  471. package/dist/chunk-Y6WOV2LZ.js +0 -95
  472. package/dist/chunk-Y6WOV2LZ.js.map +0 -1
  473. package/dist/chunk-YAEN5SCU.mjs +0 -41
  474. package/dist/chunk-YAEN5SCU.mjs.map +0 -1
  475. package/dist/chunk-YH6XDF3N.js +0 -121
  476. package/dist/chunk-YH6XDF3N.js.map +0 -1
  477. package/dist/chunk-YJKA4D75.mjs +0 -124
  478. package/dist/chunk-YJKA4D75.mjs.map +0 -1
  479. package/dist/chunk-ZANAF7WB.js +0 -88
  480. package/dist/chunk-ZANAF7WB.js.map +0 -1
  481. package/dist/chunk-ZDBWNPLO.js +0 -30
  482. package/dist/chunk-ZDBWNPLO.js.map +0 -1
  483. package/dist/chunk-ZDT2IOK2.js +0 -56
  484. package/dist/chunk-ZDT2IOK2.js.map +0 -1
  485. package/dist/chunk-ZKGVLTSI.js +0 -25
  486. package/dist/chunk-ZKGVLTSI.js.map +0 -1
  487. package/dist/chunk-ZLELESO7.js +0 -34
  488. package/dist/chunk-ZLELESO7.js.map +0 -1
  489. package/dist/chunk-ZUFUEQTX.mjs +0 -157
  490. package/dist/chunk-ZUFUEQTX.mjs.map +0 -1
  491. package/dist/chunk-ZZZWRQQE.mjs +0 -42
  492. package/dist/chunk-ZZZWRQQE.mjs.map +0 -1
  493. package/dist/command/index.js +0 -138
  494. package/dist/command/index.js.map +0 -1
  495. package/dist/command/index.mjs +0 -128
  496. package/dist/command/index.mjs.map +0 -1
  497. package/dist/components/accordion.js +0 -25
  498. package/dist/components/accordion.js.map +0 -1
  499. package/dist/components/accordion.mjs +0 -4
  500. package/dist/components/accordion.mjs.map +0 -1
  501. package/dist/components/alert.js +0 -21
  502. package/dist/components/alert.js.map +0 -1
  503. package/dist/components/alert.mjs +0 -4
  504. package/dist/components/alert.mjs.map +0 -1
  505. package/dist/components/aspect-ratio.js +0 -12
  506. package/dist/components/aspect-ratio.js.map +0 -1
  507. package/dist/components/aspect-ratio.mjs +0 -3
  508. package/dist/components/aspect-ratio.mjs.map +0 -1
  509. package/dist/components/avatar.js +0 -21
  510. package/dist/components/avatar.js.map +0 -1
  511. package/dist/components/avatar.mjs +0 -4
  512. package/dist/components/avatar.mjs.map +0 -1
  513. package/dist/components/badge.js +0 -17
  514. package/dist/components/badge.js.map +0 -1
  515. package/dist/components/badge.mjs +0 -4
  516. package/dist/components/badge.mjs.map +0 -1
  517. package/dist/components/breadcrumb.js +0 -37
  518. package/dist/components/breadcrumb.js.map +0 -1
  519. package/dist/components/breadcrumb.mjs +0 -4
  520. package/dist/components/breadcrumb.mjs.map +0 -1
  521. package/dist/components/button.js +0 -17
  522. package/dist/components/button.js.map +0 -1
  523. package/dist/components/button.mjs +0 -4
  524. package/dist/components/button.mjs.map +0 -1
  525. package/dist/components/card.js +0 -37
  526. package/dist/components/card.js.map +0 -1
  527. package/dist/components/card.mjs +0 -4
  528. package/dist/components/card.mjs.map +0 -1
  529. package/dist/components/checkbox.js +0 -13
  530. package/dist/components/checkbox.js.map +0 -1
  531. package/dist/components/checkbox.mjs +0 -4
  532. package/dist/components/checkbox.mjs.map +0 -1
  533. package/dist/components/collapsible.js +0 -20
  534. package/dist/components/collapsible.js.map +0 -1
  535. package/dist/components/collapsible.mjs +0 -3
  536. package/dist/components/collapsible.mjs.map +0 -1
  537. package/dist/components/context-menu.js +0 -69
  538. package/dist/components/context-menu.js.map +0 -1
  539. package/dist/components/context-menu.mjs +0 -4
  540. package/dist/components/context-menu.mjs.map +0 -1
  541. package/dist/components/dialog.js +0 -49
  542. package/dist/components/dialog.js.map +0 -1
  543. package/dist/components/dialog.mjs +0 -4
  544. package/dist/components/dialog.mjs.map +0 -1
  545. package/dist/components/drawer.js +0 -49
  546. package/dist/components/drawer.js.map +0 -1
  547. package/dist/components/drawer.mjs +0 -4
  548. package/dist/components/drawer.mjs.map +0 -1
  549. package/dist/components/dropdown-menu.js +0 -69
  550. package/dist/components/dropdown-menu.js.map +0 -1
  551. package/dist/components/dropdown-menu.mjs +0 -4
  552. package/dist/components/dropdown-menu.mjs.map +0 -1
  553. package/dist/components/form.js +0 -42
  554. package/dist/components/form.js.map +0 -1
  555. package/dist/components/form.mjs +0 -5
  556. package/dist/components/form.mjs.map +0 -1
  557. package/dist/components/hover-card.js +0 -21
  558. package/dist/components/hover-card.js.map +0 -1
  559. package/dist/components/hover-card.mjs +0 -4
  560. package/dist/components/hover-card.mjs.map +0 -1
  561. package/dist/components/index.js +0 -1047
  562. package/dist/components/index.js.map +0 -1
  563. package/dist/components/index.mjs +0 -46
  564. package/dist/components/index.mjs.map +0 -1
  565. package/dist/components/input-otp.js +0 -25
  566. package/dist/components/input-otp.js.map +0 -1
  567. package/dist/components/input-otp.mjs +0 -4
  568. package/dist/components/input-otp.mjs.map +0 -1
  569. package/dist/components/input.js +0 -13
  570. package/dist/components/input.js.map +0 -1
  571. package/dist/components/input.mjs +0 -4
  572. package/dist/components/input.mjs.map +0 -1
  573. package/dist/components/label.js +0 -13
  574. package/dist/components/label.js.map +0 -1
  575. package/dist/components/label.mjs +0 -4
  576. package/dist/components/label.mjs.map +0 -1
  577. package/dist/components/menubar.js +0 -73
  578. package/dist/components/menubar.js.map +0 -1
  579. package/dist/components/menubar.mjs +0 -4
  580. package/dist/components/menubar.mjs.map +0 -1
  581. package/dist/components/navigation-menu.js +0 -45
  582. package/dist/components/navigation-menu.js.map +0 -1
  583. package/dist/components/navigation-menu.mjs +0 -4
  584. package/dist/components/navigation-menu.mjs.map +0 -1
  585. package/dist/components/pagination.js +0 -38
  586. package/dist/components/pagination.js.map +0 -1
  587. package/dist/components/pagination.mjs +0 -5
  588. package/dist/components/pagination.mjs.map +0 -1
  589. package/dist/components/popover.js +0 -25
  590. package/dist/components/popover.js.map +0 -1
  591. package/dist/components/popover.mjs +0 -4
  592. package/dist/components/popover.mjs.map +0 -1
  593. package/dist/components/progress.js +0 -13
  594. package/dist/components/progress.js.map +0 -1
  595. package/dist/components/progress.mjs +0 -4
  596. package/dist/components/progress.mjs.map +0 -1
  597. package/dist/components/radio-group.js +0 -17
  598. package/dist/components/radio-group.js.map +0 -1
  599. package/dist/components/radio-group.mjs +0 -4
  600. package/dist/components/radio-group.mjs.map +0 -1
  601. package/dist/components/resizable.js +0 -21
  602. package/dist/components/resizable.js.map +0 -1
  603. package/dist/components/resizable.mjs +0 -4
  604. package/dist/components/resizable.mjs.map +0 -1
  605. package/dist/components/scroll-area.js +0 -17
  606. package/dist/components/scroll-area.js.map +0 -1
  607. package/dist/components/scroll-area.mjs +0 -4
  608. package/dist/components/scroll-area.mjs.map +0 -1
  609. package/dist/components/select.js +0 -49
  610. package/dist/components/select.js.map +0 -1
  611. package/dist/components/select.mjs +0 -4
  612. package/dist/components/select.mjs.map +0 -1
  613. package/dist/components/separator.js +0 -13
  614. package/dist/components/separator.js.map +0 -1
  615. package/dist/components/separator.mjs +0 -4
  616. package/dist/components/separator.mjs.map +0 -1
  617. package/dist/components/sheet.js +0 -49
  618. package/dist/components/sheet.js.map +0 -1
  619. package/dist/components/sheet.mjs +0 -4
  620. package/dist/components/sheet.mjs.map +0 -1
  621. package/dist/components/sidebar.js +0 -111
  622. package/dist/components/sidebar.js.map +0 -1
  623. package/dist/components/sidebar.mjs +0 -10
  624. package/dist/components/sidebar.mjs.map +0 -1
  625. package/dist/components/skeleton.js +0 -13
  626. package/dist/components/skeleton.js.map +0 -1
  627. package/dist/components/skeleton.mjs +0 -4
  628. package/dist/components/skeleton.mjs.map +0 -1
  629. package/dist/components/slider.js +0 -13
  630. package/dist/components/slider.js.map +0 -1
  631. package/dist/components/slider.mjs +0 -4
  632. package/dist/components/slider.mjs.map +0 -1
  633. package/dist/components/switch.js +0 -13
  634. package/dist/components/switch.js.map +0 -1
  635. package/dist/components/switch.mjs +0 -4
  636. package/dist/components/switch.mjs.map +0 -1
  637. package/dist/components/table.js +0 -41
  638. package/dist/components/table.js.map +0 -1
  639. package/dist/components/table.mjs +0 -4
  640. package/dist/components/table.mjs.map +0 -1
  641. package/dist/components/tabs.js +0 -25
  642. package/dist/components/tabs.js.map +0 -1
  643. package/dist/components/tabs.mjs +0 -4
  644. package/dist/components/tabs.mjs.map +0 -1
  645. package/dist/components/textarea.js +0 -13
  646. package/dist/components/textarea.js.map +0 -1
  647. package/dist/components/textarea.mjs +0 -4
  648. package/dist/components/textarea.mjs.map +0 -1
  649. package/dist/components/toast.js +0 -37
  650. package/dist/components/toast.js.map +0 -1
  651. package/dist/components/toast.mjs +0 -4
  652. package/dist/components/toast.mjs.map +0 -1
  653. package/dist/components/toggle-group.js +0 -18
  654. package/dist/components/toggle-group.js.map +0 -1
  655. package/dist/components/toggle-group.mjs +0 -5
  656. package/dist/components/toggle-group.mjs.map +0 -1
  657. package/dist/components/toggle.js +0 -17
  658. package/dist/components/toggle.js.map +0 -1
  659. package/dist/components/toggle.mjs +0 -4
  660. package/dist/components/toggle.mjs.map +0 -1
  661. package/dist/components/tooltip.js +0 -25
  662. package/dist/components/tooltip.js.map +0 -1
  663. package/dist/components/tooltip.mjs +0 -4
  664. package/dist/components/tooltip.mjs.map +0 -1
  665. package/dist/effects/index.js +0 -162
  666. package/dist/effects/index.js.map +0 -1
  667. package/dist/effects/index.mjs +0 -156
  668. package/dist/effects/index.mjs.map +0 -1
  669. package/dist/lib/utils.js +0 -12
  670. package/dist/lib/utils.js.map +0 -1
  671. package/dist/lib/utils.mjs +0 -3
  672. package/dist/lib/utils.mjs.map +0 -1
  673. package/dist/markdown/index.js +0 -669
  674. package/dist/markdown/index.js.map +0 -1
  675. package/dist/markdown/index.mjs +0 -635
  676. package/dist/markdown/index.mjs.map +0 -1
  677. package/dist/qr/index.js +0 -101
  678. package/dist/qr/index.js.map +0 -1
  679. package/dist/qr/index.mjs +0 -98
  680. package/dist/qr/index.mjs.map +0 -1
  681. package/dist/upload/index.js +0 -166
  682. package/dist/upload/index.js.map +0 -1
  683. package/dist/upload/index.mjs +0 -163
  684. package/dist/upload/index.mjs.map +0 -1
  685. package/publish.sh +0 -27
@@ -0,0 +1,518 @@
1
+ import { registrySchema, Registry, RegistryItem } from "../registry"
2
+ import { fetchRegistry, getRegistryItem, getRegistryItemUrl } from "../registry/api"
3
+ import { Server } from "@modelcontextprotocol/sdk/server/index.js"
4
+ import {
5
+ CallToolRequestSchema,
6
+ ListToolsRequestSchema,
7
+ } from "@modelcontextprotocol/sdk/types.js"
8
+ import { z } from "zod"
9
+ import { zodToJsonSchema } from "zod-to-json-schema"
10
+
11
+ // Get package version
12
+ let packageVersion = "4.5.0"
13
+ try {
14
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
15
+ const packageJson = require("../../package.json")
16
+ packageVersion = packageJson.version || packageVersion
17
+ } catch (error) {
18
+ console.error("Could not load package.json for version", error)
19
+ }
20
+
21
+ /**
22
+ * MCP Server implementation for @hanzo/ui registry
23
+ * Provides tools for interacting with the registry
24
+ */
25
+ export const server = new Server(
26
+ {
27
+ name: "hanzo-ui",
28
+ version: packageVersion,
29
+ },
30
+ {
31
+ capabilities: {
32
+ resources: {},
33
+ tools: {},
34
+ },
35
+ }
36
+ )
37
+
38
+ // Register the available tools
39
+ server.setRequestHandler(ListToolsRequestSchema, async () => {
40
+ return {
41
+ tools: [
42
+ {
43
+ name: "init",
44
+ description:
45
+ "Initialize a new project using @hanzo/ui components and styles.",
46
+ inputSchema: zodToJsonSchema(z.object({
47
+ style: z.string().optional().describe("The style to use for the project (e.g., 'default' or 'new-york')"),
48
+ })),
49
+ },
50
+ {
51
+ name: "list_components",
52
+ description: "List all available components in the registry",
53
+ inputSchema: zodToJsonSchema(z.object({
54
+ type: z.string().optional().describe("Filter components by type (e.g., 'ui', 'block')"),
55
+ category: z.string().optional().describe("Filter components by category"),
56
+ })),
57
+ },
58
+ {
59
+ name: "get_component",
60
+ description: "Get detailed information about a specific component",
61
+ inputSchema: zodToJsonSchema(
62
+ z.object({
63
+ name: z
64
+ .string()
65
+ .describe("The name of the component to get from the registry"),
66
+ })
67
+ ),
68
+ },
69
+ {
70
+ name: "add_component",
71
+ description: "Get instructions for adding a component to a project",
72
+ inputSchema: zodToJsonSchema(
73
+ z.object({
74
+ name: z
75
+ .string()
76
+ .describe("The name of the component to add"),
77
+ style: z
78
+ .string()
79
+ .optional()
80
+ .describe("The style to use (default, new-york, etc.)"),
81
+ })
82
+ ),
83
+ },
84
+ {
85
+ name: "list_styles",
86
+ description: "List all available styles in the registry",
87
+ inputSchema: zodToJsonSchema(z.object({})),
88
+ },
89
+ {
90
+ name: "search_registry",
91
+ description: "Search the registry for components matching criteria",
92
+ inputSchema: zodToJsonSchema(
93
+ z.object({
94
+ query: z
95
+ .string()
96
+ .describe("Search term to look for in component names and descriptions"),
97
+ })
98
+ ),
99
+ },
100
+ ],
101
+ }
102
+ })
103
+
104
+ // Handle tool calls
105
+ server.setRequestHandler(CallToolRequestSchema, async (request) => {
106
+ try {
107
+ // Ensure we have arguments
108
+ const args = request.params.arguments || {}
109
+
110
+ // Get registry URL from environment variable or use default
111
+ const REGISTRY_URL = process.env.REGISTRY_URL || "https://ui.hanzo.ai/registry/registry.json"
112
+ const registry = await getRegistry(REGISTRY_URL)
113
+
114
+ switch (request.params.name) {
115
+ case "init": {
116
+ const style = args.style || "default"
117
+
118
+ let text = `# Initialize a new project with @hanzo/ui
119
+
120
+ To create a new project with @hanzo/ui components, follow these steps:
121
+
122
+ 1. Create a new project first:
123
+ \`\`\`bash
124
+ # Using npm
125
+ npm create next-app@latest my-app
126
+
127
+ # Or using yarn
128
+ yarn create next-app my-app
129
+
130
+ # Or using pnpm
131
+ pnpm create next-app my-app
132
+ \`\`\`
133
+
134
+ 2. Navigate to your project directory:
135
+ \`\`\`bash
136
+ cd my-app
137
+ \`\`\`
138
+
139
+ 3. Install @hanzo/ui and initialize it:
140
+ \`\`\`bash
141
+ npx @hanzo/ui@latest init${style ? ` --style=${style}` : ""}
142
+ \`\`\`
143
+
144
+ This will:
145
+ - Install all necessary dependencies
146
+ - Set up the project structure for @hanzo/ui
147
+ - Configure tailwind.css with the appropriate theme
148
+ - Add component configuration
149
+ `
150
+
151
+ // Check if the registry has any additional setup instructions
152
+ const setupConfig = registry.items.find(
153
+ (item) => item.type === "registry:config" && item.name === "setup"
154
+ )
155
+
156
+ if (setupConfig) {
157
+ text += `
158
+ ## Additional Setup
159
+
160
+ ${setupConfig.description || "Follow any additional setup instructions provided during initialization."}
161
+ `
162
+ }
163
+
164
+ return {
165
+ content: [
166
+ { type: "text", text }
167
+ ],
168
+ }
169
+ }
170
+
171
+ case "list_components": {
172
+ // Filter components based on type and category if provided
173
+ const typeFilter = args.type ? `ui:${args.type}` : null
174
+ const categoryFilter = args.category || null
175
+
176
+ let components = registry.items.filter(item => {
177
+ // Filter by type if specified
178
+ if (typeFilter && !item.type.includes(typeFilter)) {
179
+ return false
180
+ }
181
+
182
+ // Filter by category if specified
183
+ if (categoryFilter && item.category !== categoryFilter) {
184
+ return false
185
+ }
186
+
187
+ return true
188
+ })
189
+
190
+ // Group components by category if they have categories
191
+ const hasCategories = components.some(item => item.category)
192
+ let responseText = "# Available Components\n\n"
193
+
194
+ if (hasCategories) {
195
+ // Group by category
196
+ const categorized = components.reduce((acc, item) => {
197
+ const category = item.category || "Uncategorized"
198
+ if (!acc[category]) {
199
+ acc[category] = []
200
+ }
201
+ acc[category].push(item)
202
+ return acc
203
+ }, {} as Record<string, RegistryItem[]>)
204
+
205
+ // Build response
206
+ for (const [category, items] of Object.entries(categorized)) {
207
+ responseText += `## ${category}\n\n`
208
+
209
+ items.forEach(item => {
210
+ responseText += `- **${item.name}** - ${item.description || 'No description available'}\n`
211
+ })
212
+
213
+ responseText += "\n"
214
+ }
215
+ } else {
216
+ // Simple list
217
+ components.forEach(item => {
218
+ responseText += `- **${item.name}** (${item.type}) - ${item.description || 'No description available'}\n`
219
+ })
220
+ }
221
+
222
+ responseText += "\nTo get detailed information about a specific component, use the `get_component` tool.\n"
223
+ responseText += "To add a component to your project, use the `add_component` tool.\n"
224
+
225
+ return {
226
+ content: [{ type: "text", text: responseText }],
227
+ }
228
+ }
229
+
230
+ case "get_component": {
231
+ const name = z.string().parse(args.name)
232
+
233
+ if (!name) {
234
+ throw new Error("Component name is required")
235
+ }
236
+
237
+ const itemUrl = getRegistryItemUrl(name, REGISTRY_URL)
238
+ const component = await getRegistryItem(itemUrl, "")
239
+
240
+ if (!component) {
241
+ return {
242
+ content: [
243
+ {
244
+ type: "text",
245
+ text: `Component '${name}' not found in the registry.`,
246
+ },
247
+ ],
248
+ }
249
+ }
250
+
251
+ // Build a markdown description of the component
252
+ let componentDetails = `# ${component.name}\n\n`
253
+
254
+ if (component.description) {
255
+ componentDetails += `${component.description}\n\n`
256
+ }
257
+
258
+ componentDetails += `**Type:** ${component.type}\n`
259
+
260
+ if (component.category) {
261
+ componentDetails += `**Category:** ${component.category}\n`
262
+ }
263
+
264
+ // Dependencies
265
+ if (component.dependencies && component.dependencies.length > 0) {
266
+ componentDetails += `\n## Dependencies\n\n`
267
+ component.dependencies.forEach(dep => {
268
+ componentDetails += `- ${dep}\n`
269
+ })
270
+ }
271
+
272
+ // Registry Dependencies
273
+ if (component.registryDependencies && component.registryDependencies.length > 0) {
274
+ componentDetails += `\n## Required Components\n\n`
275
+ componentDetails += `This component requires the following components that will be installed automatically:\n\n`
276
+ component.registryDependencies.forEach(dep => {
277
+ componentDetails += `- ${dep}\n`
278
+ })
279
+ }
280
+
281
+ // Files
282
+ if (component.files && component.files.length > 0) {
283
+ componentDetails += `\n## Files\n\n`
284
+ component.files.forEach(file => {
285
+ componentDetails += `- ${file.path} (${file.type})\n`
286
+ })
287
+ }
288
+
289
+ // Show example usage if available
290
+ const exampleFile = component.files?.find(file => file.type === "registry:example")
291
+ if (exampleFile && exampleFile.content) {
292
+ componentDetails += `\n## Example Usage\n\n\`\`\`tsx\n${exampleFile.content}\n\`\`\`\n`
293
+ }
294
+
295
+ // Add installation instructions
296
+ componentDetails += `\n## Installation\n\n`
297
+ componentDetails += `Run the following command to add this component to your project:\n\n`
298
+ componentDetails += `\`\`\`bash\n`
299
+ componentDetails += `npx @hanzo/ui@latest add ${name}\n`
300
+ componentDetails += `\`\`\`\n`
301
+
302
+ return {
303
+ content: [{ type: "text", text: componentDetails }],
304
+ }
305
+ }
306
+
307
+ case "add_component": {
308
+ const name = z.string().parse(args.name)
309
+ const style = args.style || "default"
310
+
311
+ if (!name) {
312
+ throw new Error("Component name is required")
313
+ }
314
+
315
+ const itemUrl = getRegistryItemUrl(name, REGISTRY_URL)
316
+ const component = await getRegistryItem(itemUrl, "")
317
+
318
+ if (!component) {
319
+ return {
320
+ content: [
321
+ {
322
+ type: "text",
323
+ text: `Component '${name}' not found in the registry.`,
324
+ },
325
+ ],
326
+ }
327
+ }
328
+
329
+ // Check if the component has dependencies
330
+ const hasDeps = component.registryDependencies && component.registryDependencies.length > 0
331
+
332
+ let instructions = `# Adding the ${name} Component\n\n`
333
+
334
+ // Main installation command
335
+ instructions += `Run the following command to add the \`${name}\` component to your project:\n\n`
336
+ instructions += `\`\`\`bash\n`
337
+ instructions += `npx @hanzo/ui@latest add ${name} --style=${style}\n`
338
+ instructions += `\`\`\`\n\n`
339
+
340
+ // Explain what this will do
341
+ instructions += `This will:\n`
342
+ instructions += `- Add the component file(s) to your project\n`
343
+ instructions += `- Install any required npm dependencies\n`
344
+
345
+ if (hasDeps) {
346
+ instructions += `- Install required component dependencies: ${component.registryDependencies!.join(", ")}\n`
347
+ }
348
+
349
+ // Usage example
350
+ instructions += `\n## Usage\n\nAfter adding the component, you can import it in your project:\n\n`
351
+ instructions += `\`\`\`tsx\n`
352
+ instructions += `import { ${name.charAt(0).toUpperCase() + name.slice(1)} } from "@/components/ui/${name}"\n\n`
353
+
354
+ // Add a simple example if possible
355
+ if (component.type.includes("ui:")) {
356
+ instructions += `export default function Example() {\n`
357
+ instructions += ` return <${name.charAt(0).toUpperCase() + name.slice(1)} />\n`
358
+ instructions += `}\n`
359
+ }
360
+
361
+ instructions += `\`\`\`\n`
362
+
363
+ return {
364
+ content: [
365
+ {
366
+ type: "text",
367
+ text: instructions,
368
+ },
369
+ ],
370
+ }
371
+ }
372
+
373
+ case "list_styles": {
374
+ // Find all style-related items in the registry
375
+ const styles = registry.items.filter(item =>
376
+ item.type === "registry:style" || item.type.includes("style")
377
+ )
378
+
379
+ let styleInfo = "# Available Styles\n\n"
380
+
381
+ if (styles.length === 0) {
382
+ styleInfo += "The registry does not define any specific styles.\n\n"
383
+ styleInfo += "The default style will be used when installing components.\n"
384
+ } else {
385
+ styles.forEach(style => {
386
+ styleInfo += `## ${style.name}\n\n`
387
+ styleInfo += `${style.description || 'No description available'}\n\n`
388
+
389
+ // Add usage info
390
+ styleInfo += `**Usage:**\n\n`
391
+ styleInfo += `\`\`\`bash\n`
392
+ styleInfo += `# Initialize with this style\n`
393
+ styleInfo += `npx @hanzo/ui@latest init --style=${style.name}\n\n`
394
+ styleInfo += `# Install components with this style\n`
395
+ styleInfo += `npx @hanzo/ui@latest add [component] --style=${style.name}\n`
396
+ styleInfo += `\`\`\`\n\n`
397
+ })
398
+ }
399
+
400
+ return {
401
+ content: [{ type: "text", text: styleInfo }],
402
+ }
403
+ }
404
+
405
+ case "search_registry": {
406
+ const query = z.string().parse(args.query).toLowerCase()
407
+
408
+ if (!query || query.length < 2) {
409
+ return {
410
+ content: [
411
+ {
412
+ type: "text",
413
+ text: "Please provide a search term with at least 2 characters.",
414
+ },
415
+ ],
416
+ }
417
+ }
418
+
419
+ // Search through all items in the registry
420
+ const results = registry.items.filter(item => {
421
+ // Search in name
422
+ if (item.name.toLowerCase().includes(query)) {
423
+ return true
424
+ }
425
+
426
+ // Search in description
427
+ if (item.description?.toLowerCase().includes(query)) {
428
+ return true
429
+ }
430
+
431
+ // Search in category
432
+ if (item.category?.toLowerCase().includes(query)) {
433
+ return true
434
+ }
435
+
436
+ return false
437
+ })
438
+
439
+ if (results.length === 0) {
440
+ return {
441
+ content: [
442
+ {
443
+ type: "text",
444
+ text: `No components found matching '${query}'. Try a different search term.`,
445
+ },
446
+ ],
447
+ }
448
+ }
449
+
450
+ // Format the results
451
+ let searchResults = `# Search Results for '${query}'\n\n`
452
+ searchResults += `Found ${results.length} matching components\n\n`
453
+
454
+ results.forEach(item => {
455
+ searchResults += `## ${item.name}\n\n`
456
+ searchResults += `**Type:** ${item.type}\n`
457
+
458
+ if (item.category) {
459
+ searchResults += `**Category:** ${item.category}\n`
460
+ }
461
+
462
+ if (item.description) {
463
+ searchResults += `\n${item.description}\n`
464
+ }
465
+
466
+ searchResults += `\n**Installation:**\n\n`
467
+ searchResults += `\`\`\`bash\nnpx @hanzo/ui@latest add ${item.name}\n\`\`\`\n\n`
468
+ })
469
+
470
+ return {
471
+ content: [{ type: "text", text: searchResults }],
472
+ }
473
+ }
474
+
475
+ default:
476
+ throw new Error(`Tool ${request.params.name} not found`)
477
+ }
478
+ } catch (error) {
479
+ if (error instanceof z.ZodError) {
480
+ return {
481
+ content: [
482
+ {
483
+ type: "text",
484
+ text: `Invalid input: ${JSON.stringify(error.errors)}`,
485
+ },
486
+ ],
487
+ }
488
+ }
489
+
490
+ throw error
491
+ }
492
+ })
493
+
494
+ /**
495
+ * Fetches and parses the registry from the given URL
496
+ * @param registryUrl - URL to the registry.json file
497
+ * @returns The parsed registry object
498
+ */
499
+ async function getRegistry(registryUrl: string): Promise<Registry> {
500
+ try {
501
+ const [registryJson] = await fetchRegistry([registryUrl], {
502
+ useCache: false,
503
+ })
504
+ return registrySchema.parse(registryJson)
505
+ } catch (error) {
506
+ console.error(`Failed to fetch registry from ${registryUrl}:`, error)
507
+ // Return a minimal valid registry if we can't fetch the real one
508
+ return {
509
+ name: "hanzo-ui",
510
+ items: [],
511
+ }
512
+ }
513
+ }
514
+
515
+ // Support CommonJS
516
+ if (typeof module !== 'undefined') {
517
+ module.exports = { server }
518
+ }
@@ -0,0 +1,10 @@
1
+ {
2
+ "name": "@hanzo/ui-mcp",
3
+ "private": true,
4
+ "type": "module",
5
+ "main": "../dist/mcp/index.js",
6
+ "types": "../dist/mcp/index.d.ts",
7
+ "scripts": {
8
+ "build": "tsc"
9
+ }
10
+ }
@@ -0,0 +1,164 @@
1
+ import { registryItemSchema, RegistryItem, Registry } from "./index"
2
+ import { z } from "zod"
3
+
4
+ const registryCache = new Map<string, Promise<any>>()
5
+
6
+ /**
7
+ * Gets the full registry URL based on the registry name or URL provided
8
+ * @param registry - Registry name, URL, or file path
9
+ * @returns The complete registry URL
10
+ */
11
+ export function getRegistryUrl(registry: string): string {
12
+ // Check if registry is a full URL
13
+ if (registry.startsWith("http")) {
14
+ return registry
15
+ }
16
+
17
+ // Default to Hanzo registry if REGISTRY_BASE_URL is defined, otherwise use hanzo
18
+ const baseUrl = process.env.REGISTRY_BASE_URL || "https://ui.hanzo.com/registry"
19
+
20
+ // Check if registry is a path to a JSON file
21
+ if (registry.endsWith(".json")) {
22
+ return `${baseUrl}/${registry}`
23
+ }
24
+
25
+ // Assume registry is a registry style
26
+ return `${baseUrl}/${registry}/registry.json`
27
+ }
28
+
29
+ /**
30
+ * Fetches a specific registry item by URL
31
+ * @param itemUrl - The URL of the item to fetch
32
+ * @param basePath - Base path for resolving imports
33
+ * @returns The registry item or null if not found
34
+ */
35
+ export async function getRegistryItem(
36
+ itemUrl: string,
37
+ basePath: string
38
+ ): Promise<RegistryItem | null> {
39
+ try {
40
+ const response = await fetch(itemUrl)
41
+
42
+ if (!response.ok) {
43
+ console.error(`Failed to fetch registry item from ${itemUrl}: ${response.status} ${response.statusText}`)
44
+ return null
45
+ }
46
+
47
+ const item = await response.json()
48
+ const validatedItem = registryItemSchema.safeParse(item)
49
+
50
+ if (!validatedItem.success) {
51
+ console.error(`Invalid registry item format: ${JSON.stringify(validatedItem.error)}`)
52
+ return null
53
+ }
54
+
55
+ // Process and resolve file paths
56
+ if (validatedItem.data.files) {
57
+ for (const file of validatedItem.data.files) {
58
+ if (!file.content) {
59
+ continue
60
+ }
61
+
62
+ // If the file has a target, we resolve it from the target
63
+ if (file.target) {
64
+ file.target = resolveImport(file.target, basePath)
65
+ }
66
+ }
67
+ }
68
+
69
+ return validatedItem.data
70
+ } catch (error) {
71
+ console.error(`Error fetching registry item: ${error}`)
72
+ return null
73
+ }
74
+ }
75
+
76
+ /**
77
+ * Resolves an import path relative to a base path
78
+ * @param importPath - The import path to resolve
79
+ * @param basePath - The base path to resolve against
80
+ * @returns The resolved import path
81
+ */
82
+ export function resolveImport(importPath: string, basePath: string): string {
83
+ const importParts = importPath?.split("/")
84
+
85
+ // Check if it's a relative import
86
+ if (importPath.startsWith(".")) {
87
+ return [basePath.replace(/^@/, ""), ...importParts].filter(Boolean).join("/")
88
+ }
89
+
90
+ // Check if it's a scope package
91
+ if (importParts?.[0]?.startsWith("@")) {
92
+ return importPath
93
+ }
94
+
95
+ return importPath
96
+ }
97
+
98
+ /**
99
+ * Fetches registry data from one or more paths
100
+ * @param paths - Array of registry paths to fetch
101
+ * @param options - Options for fetching the registry
102
+ * @returns Array of registry data
103
+ */
104
+ export async function fetchRegistry(
105
+ paths: string[],
106
+ options: { useCache?: boolean } = {}
107
+ ): Promise<Registry[]> {
108
+ options = {
109
+ useCache: true,
110
+ ...options,
111
+ }
112
+
113
+ try {
114
+ const results = await Promise.all(
115
+ paths.map(async (path) => {
116
+ const url = getRegistryUrl(path)
117
+
118
+ // Check cache first if caching is enabled
119
+ if (options.useCache && registryCache.has(url)) {
120
+ return registryCache.get(url)
121
+ }
122
+
123
+ // Store the promise in the cache before awaiting if caching is enabled
124
+ const fetchPromise = (async () => {
125
+ const response = await fetch(url)
126
+
127
+ if (!response.ok) {
128
+ throw new Error(
129
+ `Failed to fetch registry from ${url}. ${response.status} ${response.statusText}`
130
+ )
131
+ }
132
+
133
+ return response.json()
134
+ })()
135
+
136
+ if (options.useCache) {
137
+ registryCache.set(url, fetchPromise)
138
+ }
139
+ return fetchPromise
140
+ })
141
+ )
142
+
143
+ return results
144
+ } catch (error) {
145
+ console.error(`Error fetching registry: ${error}`)
146
+ throw error
147
+ }
148
+ }
149
+
150
+ /**
151
+ * Gets the URL for a specific registry item
152
+ * @param itemName - The name of the registry item
153
+ * @param registryUrl - The base registry URL
154
+ * @returns The URL for the specific registry item
155
+ */
156
+ export function getRegistryItemUrl(itemName: string, registryUrl: string): string {
157
+ const registryBaseUrl = registryUrl.replace(/\/registry\.json$/, "")
158
+ return `${registryBaseUrl}/r/${itemName}.json`
159
+ }
160
+
161
+ // Support CommonJS
162
+ if (typeof module !== 'undefined') {
163
+ module.exports = { getRegistryUrl, getRegistryItem, resolveImport, fetchRegistry, getRegistryItemUrl }
164
+ }