@hanzo/ui 5.0.3 → 5.1.0

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 (517) hide show
  1. package/README.md +192 -185
  2. package/bin/cli.js +100 -0
  3. package/bin/create-registry.js +108 -0
  4. package/bin/mcp.js +403 -0
  5. package/bin/npx-registry-mcp.js +15 -0
  6. package/bin/registry-mcp-wrapper.sh +19 -0
  7. package/bin/registry-mcp.js +100 -0
  8. package/bin/start-mcp-server.sh +22 -0
  9. package/bin/test-mcp.sh +52 -0
  10. package/bin/update-registry.js +196 -0
  11. package/dist/accordion.js +1 -0
  12. package/dist/accordion.mjs +1 -0
  13. package/dist/alert-dialog.js +1 -0
  14. package/dist/alert-dialog.mjs +1 -0
  15. package/dist/alert.js +1 -0
  16. package/dist/alert.mjs +1 -0
  17. package/dist/avatar.js +1 -0
  18. package/dist/avatar.mjs +1 -0
  19. package/dist/badge.js +1 -0
  20. package/dist/badge.mjs +1 -0
  21. package/dist/breadcrumb.js +1 -0
  22. package/dist/breadcrumb.mjs +1 -0
  23. package/dist/calendar.js +1 -0
  24. package/dist/calendar.mjs +1 -0
  25. package/dist/carousel.js +1 -0
  26. package/dist/carousel.mjs +1 -0
  27. package/dist/checkbox.js +1 -0
  28. package/dist/checkbox.mjs +1 -0
  29. package/dist/chunk-3H5S2OQ3.mjs +1 -0
  30. package/dist/chunk-5GRJ7UQX.js +1 -0
  31. package/dist/chunk-63HNMH7C.js +1 -0
  32. package/dist/chunk-72TOQ4DM.mjs +1 -0
  33. package/dist/chunk-7AEFTV5R.mjs +1 -0
  34. package/dist/chunk-7M4AVV2R.js +1 -0
  35. package/dist/chunk-DKPVJSBC.js +1 -0
  36. package/dist/chunk-EI7MMDWY.js +1 -0
  37. package/dist/chunk-GANGDIZG.mjs +1 -0
  38. package/dist/chunk-GRGT2Z4K.js +1 -0
  39. package/dist/chunk-JCUUC6NY.mjs +1 -0
  40. package/dist/chunk-JUQMWLIN.js +1 -0
  41. package/dist/chunk-PRVEIITE.js +1 -0
  42. package/dist/chunk-SH52AKNZ.js +1 -0
  43. package/dist/chunk-TU67EJEW.mjs +1 -0
  44. package/dist/chunk-WN5KN73U.mjs +1 -0
  45. package/dist/chunk-YSXGDEY5.mjs +1 -0
  46. package/dist/chunk-Z76OOVUE.mjs +1 -0
  47. package/dist/collapsible.js +1 -0
  48. package/dist/collapsible.mjs +1 -0
  49. package/dist/command.js +1 -0
  50. package/dist/command.mjs +1 -0
  51. package/dist/context-menu.js +1 -0
  52. package/dist/context-menu.mjs +1 -0
  53. package/dist/dialog.js +1 -0
  54. package/dist/dialog.mjs +1 -0
  55. package/dist/drawer.js +1 -0
  56. package/dist/drawer.mjs +1 -0
  57. package/dist/dropdown-menu.js +1 -0
  58. package/dist/dropdown-menu.mjs +1 -0
  59. package/dist/form.js +1 -0
  60. package/dist/form.mjs +1 -0
  61. package/dist/hover-card.js +1 -0
  62. package/dist/hover-card.mjs +1 -0
  63. package/dist/index.js +1 -1096
  64. package/dist/index.mjs +1 -47
  65. package/dist/input-otp.js +1 -0
  66. package/dist/input-otp.mjs +1 -0
  67. package/dist/lib/utils.js +1 -12
  68. package/dist/lib/utils.mjs +1 -3
  69. package/dist/navigation-menu.js +1 -0
  70. package/dist/navigation-menu.mjs +1 -0
  71. package/dist/popover.js +1 -0
  72. package/dist/popover.mjs +1 -0
  73. package/dist/progress.js +1 -0
  74. package/dist/progress.mjs +1 -0
  75. package/dist/radio-group.js +1 -0
  76. package/dist/radio-group.mjs +1 -0
  77. package/dist/resizable.js +1 -0
  78. package/dist/resizable.mjs +1 -0
  79. package/dist/scroll-area.js +1 -0
  80. package/dist/scroll-area.mjs +1 -0
  81. package/dist/select.js +1 -0
  82. package/dist/select.mjs +1 -0
  83. package/dist/separator.js +1 -0
  84. package/dist/separator.mjs +1 -0
  85. package/dist/sheet.js +1 -0
  86. package/dist/sheet.mjs +1 -0
  87. package/dist/skeleton.js +1 -0
  88. package/dist/skeleton.mjs +1 -0
  89. package/dist/slider.js +1 -0
  90. package/dist/slider.mjs +1 -0
  91. package/dist/sonner.js +1 -0
  92. package/dist/sonner.mjs +1 -0
  93. package/dist/src/utils.js +1 -0
  94. package/dist/src/utils.mjs +1 -0
  95. package/dist/switch.js +1 -0
  96. package/dist/switch.mjs +1 -0
  97. package/dist/table.js +1 -0
  98. package/dist/table.mjs +1 -0
  99. package/dist/tabs.js +1 -0
  100. package/dist/tabs.mjs +1 -0
  101. package/dist/tailwind/index.js +1 -0
  102. package/dist/tailwind/index.mjs +1 -0
  103. package/dist/textarea.js +1 -0
  104. package/dist/textarea.mjs +1 -0
  105. package/dist/toggle-group.js +1 -0
  106. package/dist/toggle-group.mjs +1 -0
  107. package/dist/toggle.js +1 -0
  108. package/dist/toggle.mjs +1 -0
  109. package/dist/tooltip.js +1 -0
  110. package/dist/tooltip.mjs +1 -0
  111. package/dist/types/index.js +1 -0
  112. package/dist/types/index.mjs +1 -0
  113. package/package.json +303 -155
  114. package/style/drawer.css +163 -0
  115. package/style/globals.css +13 -0
  116. package/style/hanzo-common.css +31 -0
  117. package/style/hanzo-default-colors.css +82 -0
  118. package/style/theme-provider.tsx +20 -0
  119. package/CHANGELOG.md +0 -184
  120. package/LICENSE +0 -21
  121. package/dist/ai/index.js +0 -53
  122. package/dist/ai/index.js.map +0 -1
  123. package/dist/ai/index.mjs +0 -4
  124. package/dist/ai/index.mjs.map +0 -1
  125. package/dist/blocks/index.js +0 -983
  126. package/dist/blocks/index.js.map +0 -1
  127. package/dist/blocks/index.mjs +0 -945
  128. package/dist/blocks/index.mjs.map +0 -1
  129. package/dist/calendar/index.js +0 -14
  130. package/dist/calendar/index.js.map +0 -1
  131. package/dist/calendar/index.mjs +0 -5
  132. package/dist/calendar/index.mjs.map +0 -1
  133. package/dist/carousel/index.js +0 -220
  134. package/dist/carousel/index.js.map +0 -1
  135. package/dist/carousel/index.mjs +0 -191
  136. package/dist/carousel/index.mjs.map +0 -1
  137. package/dist/charts/index.js +0 -945
  138. package/dist/charts/index.js.map +0 -1
  139. package/dist/charts/index.mjs +0 -901
  140. package/dist/charts/index.mjs.map +0 -1
  141. package/dist/chunk-26T4V5QU.mjs +0 -111
  142. package/dist/chunk-26T4V5QU.mjs.map +0 -1
  143. package/dist/chunk-2A5KXDLJ.js +0 -22
  144. package/dist/chunk-2A5KXDLJ.js.map +0 -1
  145. package/dist/chunk-2CJ4HMF4.js +0 -79
  146. package/dist/chunk-2CJ4HMF4.js.map +0 -1
  147. package/dist/chunk-2OIQKC5E.js +0 -236
  148. package/dist/chunk-2OIQKC5E.js.map +0 -1
  149. package/dist/chunk-2X3KSYBN.js +0 -44
  150. package/dist/chunk-2X3KSYBN.js.map +0 -1
  151. package/dist/chunk-3PBQGYR7.mjs +0 -100
  152. package/dist/chunk-3PBQGYR7.mjs.map +0 -1
  153. package/dist/chunk-3POQQ6L7.js +0 -62
  154. package/dist/chunk-3POQQ6L7.js.map +0 -1
  155. package/dist/chunk-4B47GITH.mjs +0 -28
  156. package/dist/chunk-4B47GITH.mjs.map +0 -1
  157. package/dist/chunk-4BC2OH6B.js +0 -129
  158. package/dist/chunk-4BC2OH6B.js.map +0 -1
  159. package/dist/chunk-5AQSGH4R.js +0 -130
  160. package/dist/chunk-5AQSGH4R.js.map +0 -1
  161. package/dist/chunk-5IHRJFOO.mjs +0 -102
  162. package/dist/chunk-5IHRJFOO.mjs.map +0 -1
  163. package/dist/chunk-5LDGR7YN.mjs +0 -28
  164. package/dist/chunk-5LDGR7YN.mjs.map +0 -1
  165. package/dist/chunk-5MCN3VYM.mjs +0 -23
  166. package/dist/chunk-5MCN3VYM.mjs.map +0 -1
  167. package/dist/chunk-6AVAMRMB.mjs +0 -47
  168. package/dist/chunk-6AVAMRMB.mjs.map +0 -1
  169. package/dist/chunk-6H62JRNM.mjs +0 -120
  170. package/dist/chunk-6H62JRNM.mjs.map +0 -1
  171. package/dist/chunk-6KCII3F6.mjs +0 -126
  172. package/dist/chunk-6KCII3F6.mjs.map +0 -1
  173. package/dist/chunk-7EHB43BJ.js +0 -155
  174. package/dist/chunk-7EHB43BJ.js.map +0 -1
  175. package/dist/chunk-7LRD23Q5.js +0 -191
  176. package/dist/chunk-7LRD23Q5.js.map +0 -1
  177. package/dist/chunk-7SAHKOJG.mjs +0 -45
  178. package/dist/chunk-7SAHKOJG.mjs.map +0 -1
  179. package/dist/chunk-A3D2YZK3.js +0 -50
  180. package/dist/chunk-A3D2YZK3.js.map +0 -1
  181. package/dist/chunk-AL4QFH7V.js +0 -63
  182. package/dist/chunk-AL4QFH7V.js.map +0 -1
  183. package/dist/chunk-B3WFEG6U.js +0 -69
  184. package/dist/chunk-B3WFEG6U.js.map +0 -1
  185. package/dist/chunk-BDZQJ6GK.js +0 -242
  186. package/dist/chunk-BDZQJ6GK.js.map +0 -1
  187. package/dist/chunk-BRWFYRGX.js +0 -61
  188. package/dist/chunk-BRWFYRGX.js.map +0 -1
  189. package/dist/chunk-C5DNTLBO.js +0 -53
  190. package/dist/chunk-C5DNTLBO.js.map +0 -1
  191. package/dist/chunk-CRALRACO.js +0 -54
  192. package/dist/chunk-CRALRACO.js.map +0 -1
  193. package/dist/chunk-CVACQJRM.js +0 -149
  194. package/dist/chunk-CVACQJRM.js.map +0 -1
  195. package/dist/chunk-DEIUKFPZ.mjs +0 -63
  196. package/dist/chunk-DEIUKFPZ.mjs.map +0 -1
  197. package/dist/chunk-DN2AEEA2.js +0 -13
  198. package/dist/chunk-DN2AEEA2.js.map +0 -1
  199. package/dist/chunk-DTNRWU4B.mjs +0 -35
  200. package/dist/chunk-DTNRWU4B.mjs.map +0 -1
  201. package/dist/chunk-DXIUEWRJ.mjs +0 -31
  202. package/dist/chunk-DXIUEWRJ.mjs.map +0 -1
  203. package/dist/chunk-DYFV66JX.mjs +0 -54
  204. package/dist/chunk-DYFV66JX.mjs.map +0 -1
  205. package/dist/chunk-F3WMAHXV.mjs +0 -86
  206. package/dist/chunk-F3WMAHXV.mjs.map +0 -1
  207. package/dist/chunk-F4RWPBBB.js +0 -79
  208. package/dist/chunk-F4RWPBBB.js.map +0 -1
  209. package/dist/chunk-FEGAPM6U.js +0 -194
  210. package/dist/chunk-FEGAPM6U.js.map +0 -1
  211. package/dist/chunk-G5TS56PW.mjs +0 -160
  212. package/dist/chunk-G5TS56PW.mjs.map +0 -1
  213. package/dist/chunk-GG6VGOEN.mjs +0 -590
  214. package/dist/chunk-GG6VGOEN.mjs.map +0 -1
  215. package/dist/chunk-GLAMGK32.mjs +0 -54
  216. package/dist/chunk-GLAMGK32.mjs.map +0 -1
  217. package/dist/chunk-GNMMUJXD.mjs +0 -200
  218. package/dist/chunk-GNMMUJXD.mjs.map +0 -1
  219. package/dist/chunk-GNPBULLS.mjs +0 -600
  220. package/dist/chunk-GNPBULLS.mjs.map +0 -1
  221. package/dist/chunk-GTE2DELE.js +0 -65
  222. package/dist/chunk-GTE2DELE.js.map +0 -1
  223. package/dist/chunk-GUQAFFTH.js +0 -94
  224. package/dist/chunk-GUQAFFTH.js.map +0 -1
  225. package/dist/chunk-H5VOYZHT.mjs +0 -34
  226. package/dist/chunk-H5VOYZHT.mjs.map +0 -1
  227. package/dist/chunk-HR6PBOGG.mjs +0 -59
  228. package/dist/chunk-HR6PBOGG.mjs.map +0 -1
  229. package/dist/chunk-HROONQS3.js +0 -55
  230. package/dist/chunk-HROONQS3.js.map +0 -1
  231. package/dist/chunk-IAO7SOQ3.mjs +0 -56
  232. package/dist/chunk-IAO7SOQ3.mjs.map +0 -1
  233. package/dist/chunk-K2QKU3K6.mjs +0 -40
  234. package/dist/chunk-K2QKU3K6.mjs.map +0 -1
  235. package/dist/chunk-KEUZZCCP.js +0 -53
  236. package/dist/chunk-KEUZZCCP.js.map +0 -1
  237. package/dist/chunk-KJXSLTG7.mjs +0 -73
  238. package/dist/chunk-KJXSLTG7.mjs.map +0 -1
  239. package/dist/chunk-L5AFUCVH.mjs +0 -26
  240. package/dist/chunk-L5AFUCVH.mjs.map +0 -1
  241. package/dist/chunk-LB3I52KZ.mjs +0 -42
  242. package/dist/chunk-LB3I52KZ.mjs.map +0 -1
  243. package/dist/chunk-LN75MJQ2.js +0 -71
  244. package/dist/chunk-LN75MJQ2.js.map +0 -1
  245. package/dist/chunk-LRBOFJUV.js +0 -60
  246. package/dist/chunk-LRBOFJUV.js.map +0 -1
  247. package/dist/chunk-MMNYRBOU.js +0 -157
  248. package/dist/chunk-MMNYRBOU.js.map +0 -1
  249. package/dist/chunk-MO65YF6P.js +0 -236
  250. package/dist/chunk-MO65YF6P.js.map +0 -1
  251. package/dist/chunk-N4KHP5FC.mjs +0 -33
  252. package/dist/chunk-N4KHP5FC.mjs.map +0 -1
  253. package/dist/chunk-NP2J7AB7.mjs +0 -121
  254. package/dist/chunk-NP2J7AB7.mjs.map +0 -1
  255. package/dist/chunk-OLR6SGYO.js +0 -57
  256. package/dist/chunk-OLR6SGYO.js.map +0 -1
  257. package/dist/chunk-ON7NQ4DY.js +0 -21
  258. package/dist/chunk-ON7NQ4DY.js.map +0 -1
  259. package/dist/chunk-PE3VFRLV.mjs +0 -198
  260. package/dist/chunk-PE3VFRLV.mjs.map +0 -1
  261. package/dist/chunk-Q7LOOIE5.mjs +0 -8
  262. package/dist/chunk-Q7LOOIE5.mjs.map +0 -1
  263. package/dist/chunk-QFA6U75G.mjs +0 -51
  264. package/dist/chunk-QFA6U75G.mjs.map +0 -1
  265. package/dist/chunk-QJQPT4WX.js +0 -638
  266. package/dist/chunk-QJQPT4WX.js.map +0 -1
  267. package/dist/chunk-QKHQPBSR.mjs +0 -20
  268. package/dist/chunk-QKHQPBSR.mjs.map +0 -1
  269. package/dist/chunk-SJD4XRFJ.mjs +0 -141
  270. package/dist/chunk-SJD4XRFJ.mjs.map +0 -1
  271. package/dist/chunk-SOOJLU4C.mjs +0 -19
  272. package/dist/chunk-SOOJLU4C.mjs.map +0 -1
  273. package/dist/chunk-T66B5IM5.js +0 -51
  274. package/dist/chunk-T66B5IM5.js.map +0 -1
  275. package/dist/chunk-T7RPZDO4.js +0 -645
  276. package/dist/chunk-T7RPZDO4.js.map +0 -1
  277. package/dist/chunk-TGRMDGTV.mjs +0 -38
  278. package/dist/chunk-TGRMDGTV.mjs.map +0 -1
  279. package/dist/chunk-TH2UKMCO.mjs +0 -11
  280. package/dist/chunk-TH2UKMCO.mjs.map +0 -1
  281. package/dist/chunk-TMV45OKE.mjs +0 -113
  282. package/dist/chunk-TMV45OKE.mjs.map +0 -1
  283. package/dist/chunk-TUJ7EVEK.js +0 -171
  284. package/dist/chunk-TUJ7EVEK.js.map +0 -1
  285. package/dist/chunk-ULNWDOI7.js +0 -122
  286. package/dist/chunk-ULNWDOI7.js.map +0 -1
  287. package/dist/chunk-UNUTTHCH.mjs +0 -210
  288. package/dist/chunk-UNUTTHCH.mjs.map +0 -1
  289. package/dist/chunk-VJMI6BG4.mjs +0 -10
  290. package/dist/chunk-VJMI6BG4.mjs.map +0 -1
  291. package/dist/chunk-VZVOB5MG.mjs +0 -26
  292. package/dist/chunk-VZVOB5MG.mjs.map +0 -1
  293. package/dist/chunk-WD67O22C.js +0 -50
  294. package/dist/chunk-WD67O22C.js.map +0 -1
  295. package/dist/chunk-WYPMLIJN.js +0 -53
  296. package/dist/chunk-WYPMLIJN.js.map +0 -1
  297. package/dist/chunk-X32I34NH.js +0 -109
  298. package/dist/chunk-X32I34NH.js.map +0 -1
  299. package/dist/chunk-X5MOZ3YL.js +0 -65
  300. package/dist/chunk-X5MOZ3YL.js.map +0 -1
  301. package/dist/chunk-Y4JVIPQZ.mjs +0 -31
  302. package/dist/chunk-Y4JVIPQZ.mjs.map +0 -1
  303. package/dist/chunk-Y6WOV2LZ.js +0 -95
  304. package/dist/chunk-Y6WOV2LZ.js.map +0 -1
  305. package/dist/chunk-YAEN5SCU.mjs +0 -41
  306. package/dist/chunk-YAEN5SCU.mjs.map +0 -1
  307. package/dist/chunk-YH6XDF3N.js +0 -121
  308. package/dist/chunk-YH6XDF3N.js.map +0 -1
  309. package/dist/chunk-YJKA4D75.mjs +0 -124
  310. package/dist/chunk-YJKA4D75.mjs.map +0 -1
  311. package/dist/chunk-ZANAF7WB.js +0 -88
  312. package/dist/chunk-ZANAF7WB.js.map +0 -1
  313. package/dist/chunk-ZDBWNPLO.js +0 -30
  314. package/dist/chunk-ZDBWNPLO.js.map +0 -1
  315. package/dist/chunk-ZDT2IOK2.js +0 -56
  316. package/dist/chunk-ZDT2IOK2.js.map +0 -1
  317. package/dist/chunk-ZKGVLTSI.js +0 -25
  318. package/dist/chunk-ZKGVLTSI.js.map +0 -1
  319. package/dist/chunk-ZLELESO7.js +0 -34
  320. package/dist/chunk-ZLELESO7.js.map +0 -1
  321. package/dist/chunk-ZUFUEQTX.mjs +0 -157
  322. package/dist/chunk-ZUFUEQTX.mjs.map +0 -1
  323. package/dist/chunk-ZZZWRQQE.mjs +0 -42
  324. package/dist/chunk-ZZZWRQQE.mjs.map +0 -1
  325. package/dist/command/index.js +0 -138
  326. package/dist/command/index.js.map +0 -1
  327. package/dist/command/index.mjs +0 -128
  328. package/dist/command/index.mjs.map +0 -1
  329. package/dist/components/accordion.js +0 -25
  330. package/dist/components/accordion.js.map +0 -1
  331. package/dist/components/accordion.mjs +0 -4
  332. package/dist/components/accordion.mjs.map +0 -1
  333. package/dist/components/alert.js +0 -21
  334. package/dist/components/alert.js.map +0 -1
  335. package/dist/components/alert.mjs +0 -4
  336. package/dist/components/alert.mjs.map +0 -1
  337. package/dist/components/aspect-ratio.js +0 -12
  338. package/dist/components/aspect-ratio.js.map +0 -1
  339. package/dist/components/aspect-ratio.mjs +0 -3
  340. package/dist/components/aspect-ratio.mjs.map +0 -1
  341. package/dist/components/avatar.js +0 -21
  342. package/dist/components/avatar.js.map +0 -1
  343. package/dist/components/avatar.mjs +0 -4
  344. package/dist/components/avatar.mjs.map +0 -1
  345. package/dist/components/badge.js +0 -17
  346. package/dist/components/badge.js.map +0 -1
  347. package/dist/components/badge.mjs +0 -4
  348. package/dist/components/badge.mjs.map +0 -1
  349. package/dist/components/breadcrumb.js +0 -37
  350. package/dist/components/breadcrumb.js.map +0 -1
  351. package/dist/components/breadcrumb.mjs +0 -4
  352. package/dist/components/breadcrumb.mjs.map +0 -1
  353. package/dist/components/button.js +0 -17
  354. package/dist/components/button.js.map +0 -1
  355. package/dist/components/button.mjs +0 -4
  356. package/dist/components/button.mjs.map +0 -1
  357. package/dist/components/card.js +0 -37
  358. package/dist/components/card.js.map +0 -1
  359. package/dist/components/card.mjs +0 -4
  360. package/dist/components/card.mjs.map +0 -1
  361. package/dist/components/checkbox.js +0 -13
  362. package/dist/components/checkbox.js.map +0 -1
  363. package/dist/components/checkbox.mjs +0 -4
  364. package/dist/components/checkbox.mjs.map +0 -1
  365. package/dist/components/collapsible.js +0 -20
  366. package/dist/components/collapsible.js.map +0 -1
  367. package/dist/components/collapsible.mjs +0 -3
  368. package/dist/components/collapsible.mjs.map +0 -1
  369. package/dist/components/context-menu.js +0 -69
  370. package/dist/components/context-menu.js.map +0 -1
  371. package/dist/components/context-menu.mjs +0 -4
  372. package/dist/components/context-menu.mjs.map +0 -1
  373. package/dist/components/dialog.js +0 -49
  374. package/dist/components/dialog.js.map +0 -1
  375. package/dist/components/dialog.mjs +0 -4
  376. package/dist/components/dialog.mjs.map +0 -1
  377. package/dist/components/drawer.js +0 -49
  378. package/dist/components/drawer.js.map +0 -1
  379. package/dist/components/drawer.mjs +0 -4
  380. package/dist/components/drawer.mjs.map +0 -1
  381. package/dist/components/dropdown-menu.js +0 -69
  382. package/dist/components/dropdown-menu.js.map +0 -1
  383. package/dist/components/dropdown-menu.mjs +0 -4
  384. package/dist/components/dropdown-menu.mjs.map +0 -1
  385. package/dist/components/form.js +0 -42
  386. package/dist/components/form.js.map +0 -1
  387. package/dist/components/form.mjs +0 -5
  388. package/dist/components/form.mjs.map +0 -1
  389. package/dist/components/hover-card.js +0 -21
  390. package/dist/components/hover-card.js.map +0 -1
  391. package/dist/components/hover-card.mjs +0 -4
  392. package/dist/components/hover-card.mjs.map +0 -1
  393. package/dist/components/index.js +0 -1047
  394. package/dist/components/index.js.map +0 -1
  395. package/dist/components/index.mjs +0 -46
  396. package/dist/components/index.mjs.map +0 -1
  397. package/dist/components/input-otp.js +0 -25
  398. package/dist/components/input-otp.js.map +0 -1
  399. package/dist/components/input-otp.mjs +0 -4
  400. package/dist/components/input-otp.mjs.map +0 -1
  401. package/dist/components/input.js +0 -13
  402. package/dist/components/input.js.map +0 -1
  403. package/dist/components/input.mjs +0 -4
  404. package/dist/components/input.mjs.map +0 -1
  405. package/dist/components/label.js +0 -13
  406. package/dist/components/label.js.map +0 -1
  407. package/dist/components/label.mjs +0 -4
  408. package/dist/components/label.mjs.map +0 -1
  409. package/dist/components/menubar.js +0 -73
  410. package/dist/components/menubar.js.map +0 -1
  411. package/dist/components/menubar.mjs +0 -4
  412. package/dist/components/menubar.mjs.map +0 -1
  413. package/dist/components/navigation-menu.js +0 -45
  414. package/dist/components/navigation-menu.js.map +0 -1
  415. package/dist/components/navigation-menu.mjs +0 -4
  416. package/dist/components/navigation-menu.mjs.map +0 -1
  417. package/dist/components/pagination.js +0 -38
  418. package/dist/components/pagination.js.map +0 -1
  419. package/dist/components/pagination.mjs +0 -5
  420. package/dist/components/pagination.mjs.map +0 -1
  421. package/dist/components/popover.js +0 -25
  422. package/dist/components/popover.js.map +0 -1
  423. package/dist/components/popover.mjs +0 -4
  424. package/dist/components/popover.mjs.map +0 -1
  425. package/dist/components/progress.js +0 -13
  426. package/dist/components/progress.js.map +0 -1
  427. package/dist/components/progress.mjs +0 -4
  428. package/dist/components/progress.mjs.map +0 -1
  429. package/dist/components/radio-group.js +0 -17
  430. package/dist/components/radio-group.js.map +0 -1
  431. package/dist/components/radio-group.mjs +0 -4
  432. package/dist/components/radio-group.mjs.map +0 -1
  433. package/dist/components/resizable.js +0 -21
  434. package/dist/components/resizable.js.map +0 -1
  435. package/dist/components/resizable.mjs +0 -4
  436. package/dist/components/resizable.mjs.map +0 -1
  437. package/dist/components/scroll-area.js +0 -17
  438. package/dist/components/scroll-area.js.map +0 -1
  439. package/dist/components/scroll-area.mjs +0 -4
  440. package/dist/components/scroll-area.mjs.map +0 -1
  441. package/dist/components/select.js +0 -49
  442. package/dist/components/select.js.map +0 -1
  443. package/dist/components/select.mjs +0 -4
  444. package/dist/components/select.mjs.map +0 -1
  445. package/dist/components/separator.js +0 -13
  446. package/dist/components/separator.js.map +0 -1
  447. package/dist/components/separator.mjs +0 -4
  448. package/dist/components/separator.mjs.map +0 -1
  449. package/dist/components/sheet.js +0 -49
  450. package/dist/components/sheet.js.map +0 -1
  451. package/dist/components/sheet.mjs +0 -4
  452. package/dist/components/sheet.mjs.map +0 -1
  453. package/dist/components/sidebar.js +0 -111
  454. package/dist/components/sidebar.js.map +0 -1
  455. package/dist/components/sidebar.mjs +0 -10
  456. package/dist/components/sidebar.mjs.map +0 -1
  457. package/dist/components/skeleton.js +0 -13
  458. package/dist/components/skeleton.js.map +0 -1
  459. package/dist/components/skeleton.mjs +0 -4
  460. package/dist/components/skeleton.mjs.map +0 -1
  461. package/dist/components/slider.js +0 -13
  462. package/dist/components/slider.js.map +0 -1
  463. package/dist/components/slider.mjs +0 -4
  464. package/dist/components/slider.mjs.map +0 -1
  465. package/dist/components/switch.js +0 -13
  466. package/dist/components/switch.js.map +0 -1
  467. package/dist/components/switch.mjs +0 -4
  468. package/dist/components/switch.mjs.map +0 -1
  469. package/dist/components/table.js +0 -41
  470. package/dist/components/table.js.map +0 -1
  471. package/dist/components/table.mjs +0 -4
  472. package/dist/components/table.mjs.map +0 -1
  473. package/dist/components/tabs.js +0 -25
  474. package/dist/components/tabs.js.map +0 -1
  475. package/dist/components/tabs.mjs +0 -4
  476. package/dist/components/tabs.mjs.map +0 -1
  477. package/dist/components/textarea.js +0 -13
  478. package/dist/components/textarea.js.map +0 -1
  479. package/dist/components/textarea.mjs +0 -4
  480. package/dist/components/textarea.mjs.map +0 -1
  481. package/dist/components/toast.js +0 -37
  482. package/dist/components/toast.js.map +0 -1
  483. package/dist/components/toast.mjs +0 -4
  484. package/dist/components/toast.mjs.map +0 -1
  485. package/dist/components/toggle-group.js +0 -18
  486. package/dist/components/toggle-group.js.map +0 -1
  487. package/dist/components/toggle-group.mjs +0 -5
  488. package/dist/components/toggle-group.mjs.map +0 -1
  489. package/dist/components/toggle.js +0 -17
  490. package/dist/components/toggle.js.map +0 -1
  491. package/dist/components/toggle.mjs +0 -4
  492. package/dist/components/toggle.mjs.map +0 -1
  493. package/dist/components/tooltip.js +0 -25
  494. package/dist/components/tooltip.js.map +0 -1
  495. package/dist/components/tooltip.mjs +0 -4
  496. package/dist/components/tooltip.mjs.map +0 -1
  497. package/dist/effects/index.js +0 -162
  498. package/dist/effects/index.js.map +0 -1
  499. package/dist/effects/index.mjs +0 -156
  500. package/dist/effects/index.mjs.map +0 -1
  501. package/dist/index.js.map +0 -1
  502. package/dist/index.mjs.map +0 -1
  503. package/dist/lib/utils.js.map +0 -1
  504. package/dist/lib/utils.mjs.map +0 -1
  505. package/dist/markdown/index.js +0 -669
  506. package/dist/markdown/index.js.map +0 -1
  507. package/dist/markdown/index.mjs +0 -635
  508. package/dist/markdown/index.mjs.map +0 -1
  509. package/dist/qr/index.js +0 -101
  510. package/dist/qr/index.js.map +0 -1
  511. package/dist/qr/index.mjs +0 -98
  512. package/dist/qr/index.mjs.map +0 -1
  513. package/dist/upload/index.js +0 -166
  514. package/dist/upload/index.js.map +0 -1
  515. package/dist/upload/index.mjs +0 -163
  516. package/dist/upload/index.mjs.map +0 -1
  517. package/publish.sh +0 -27
@@ -1,901 +0,0 @@
1
- import { cn } from '../chunk-TH2UKMCO.mjs';
2
- import * as React from 'react';
3
- import * as RechartsPrimitive from 'recharts';
4
- import { AreaChart as AreaChart$1, CartesianGrid, XAxis, YAxis, Area, BarChart as BarChart$1, Bar, LineChart as LineChart$1, Line, PieChart as PieChart$1, Pie, Cell, RadarChart as RadarChart$1, PolarGrid, PolarAngleAxis, PolarRadiusAxis, Radar, RadialBarChart, RadialBar } from 'recharts';
5
- import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
6
-
7
- var THEMES = { light: "", dark: ".dark" };
8
- var ChartContext = React.createContext(null);
9
- function useChart() {
10
- const context = React.useContext(ChartContext);
11
- if (!context) {
12
- throw new Error("useChart must be used within a <ChartContainer />");
13
- }
14
- return context;
15
- }
16
- var ChartContainer = React.forwardRef(({ id, className, children, config, brand = "hanzo", ...props }, ref) => {
17
- const uniqueId = React.useId();
18
- const chartId = `chart-${id || uniqueId.replace(/:/g, "")}`;
19
- return /* @__PURE__ */ jsx(ChartContext.Provider, { value: { config, brand }, children: /* @__PURE__ */ jsxs(
20
- "div",
21
- {
22
- "data-chart": chartId,
23
- "data-brand": brand,
24
- ref,
25
- className: cn(
26
- "flex aspect-video justify-center text-xs [&_.recharts-cartesian-axis-tick_text]:fill-muted-foreground [&_.recharts-cartesian-grid_line[stroke='#ccc']]:stroke-border/50 [&_.recharts-curve.recharts-tooltip-cursor]:stroke-border [&_.recharts-dot[stroke='#fff']]:stroke-transparent [&_.recharts-layer]:outline-none [&_.recharts-polar-grid_[stroke='#ccc']]:stroke-border [&_.recharts-radial-bar-background-sector]:fill-muted [&_.recharts-rectangle.recharts-tooltip-cursor]:fill-muted [&_.recharts-reference-line_[stroke='#ccc']]:stroke-border [&_.recharts-sector[stroke='#fff']]:stroke-transparent [&_.recharts-sector]:outline-none [&_.recharts-surface]:outline-none",
27
- className
28
- ),
29
- ...props,
30
- children: [
31
- /* @__PURE__ */ jsx(ChartStyle, { id: chartId, config }),
32
- /* @__PURE__ */ jsx(RechartsPrimitive.ResponsiveContainer, { children })
33
- ]
34
- }
35
- ) });
36
- });
37
- ChartContainer.displayName = "Chart";
38
- var ChartStyle = ({ id, config }) => {
39
- const colorConfig = Object.entries(config).filter(
40
- ([, config2]) => config2.theme || config2.color
41
- );
42
- if (!colorConfig.length) {
43
- return null;
44
- }
45
- return /* @__PURE__ */ jsx(
46
- "style",
47
- {
48
- dangerouslySetInnerHTML: {
49
- __html: Object.entries(THEMES).map(
50
- ([theme, prefix]) => `
51
- ${prefix} [data-chart=${id}] {
52
- ${colorConfig.map(([key, itemConfig]) => {
53
- const color = itemConfig.theme?.[theme] || itemConfig.color;
54
- return color ? ` --color-${key}: ${color};` : null;
55
- }).join("\n")}
56
- }
57
- `
58
- ).join("\n")
59
- }
60
- }
61
- );
62
- };
63
- var ChartTooltip = RechartsPrimitive.Tooltip;
64
- var ChartTooltipContent = React.forwardRef(
65
- ({
66
- active,
67
- payload,
68
- className,
69
- indicator = "dot",
70
- hideLabel = false,
71
- hideIndicator = false,
72
- label,
73
- labelFormatter,
74
- labelClassName,
75
- formatter,
76
- color,
77
- nameKey,
78
- labelKey
79
- }, ref) => {
80
- const { config } = useChart();
81
- const tooltipLabel = React.useMemo(() => {
82
- if (hideLabel || !payload?.length) {
83
- return null;
84
- }
85
- const [item] = payload;
86
- const key = `${labelKey || item?.dataKey || item?.name || "value"}`;
87
- const itemConfig = getPayloadConfigFromPayload(config, item, key);
88
- const value = !labelKey && typeof label === "string" ? config[label]?.label || label : itemConfig?.label;
89
- if (labelFormatter) {
90
- return /* @__PURE__ */ jsx("div", { className: cn("font-medium", labelClassName), children: labelFormatter(value, payload) });
91
- }
92
- if (!value) {
93
- return null;
94
- }
95
- return /* @__PURE__ */ jsx("div", { className: cn("font-medium", labelClassName), children: value });
96
- }, [
97
- label,
98
- labelFormatter,
99
- payload,
100
- hideLabel,
101
- labelClassName,
102
- config,
103
- labelKey
104
- ]);
105
- if (!active || !payload?.length) {
106
- return null;
107
- }
108
- const nestLabel = payload.length === 1 && indicator !== "dot";
109
- return /* @__PURE__ */ jsxs(
110
- "div",
111
- {
112
- ref,
113
- className: cn(
114
- "grid min-w-[8rem] items-start gap-1.5 rounded-lg border border-border/50 bg-background px-2.5 py-1.5 text-xs shadow-xl",
115
- className
116
- ),
117
- children: [
118
- !nestLabel ? tooltipLabel : null,
119
- /* @__PURE__ */ jsx("div", { className: "grid gap-1.5", children: payload.filter((item) => item.type !== "none").map((item, index) => {
120
- const key = `${nameKey || item.name || item.dataKey || "value"}`;
121
- const itemConfig = getPayloadConfigFromPayload(config, item, key);
122
- const indicatorColor = color || item.payload.fill || item.color;
123
- return /* @__PURE__ */ jsx(
124
- "div",
125
- {
126
- className: cn(
127
- "flex w-full flex-wrap items-stretch gap-2 [&>svg]:h-2.5 [&>svg]:w-2.5 [&>svg]:text-muted-foreground",
128
- indicator === "dot" && "items-center"
129
- ),
130
- children: formatter && item?.value !== void 0 && item.name ? formatter(item.value, item.name, item, index, item.payload) : /* @__PURE__ */ jsxs(Fragment, { children: [
131
- itemConfig?.icon ? /* @__PURE__ */ jsx(itemConfig.icon, {}) : !hideIndicator && /* @__PURE__ */ jsx(
132
- "div",
133
- {
134
- className: cn(
135
- "shrink-0 rounded-[2px] border-[--color-border] bg-[--color-bg]",
136
- {
137
- "h-2.5 w-2.5": indicator === "dot",
138
- "w-1": indicator === "line",
139
- "w-0 border-[1.5px] border-dashed bg-transparent": indicator === "dashed",
140
- "my-0.5": nestLabel && indicator === "dashed"
141
- }
142
- ),
143
- style: {
144
- "--color-bg": indicatorColor,
145
- "--color-border": indicatorColor
146
- }
147
- }
148
- ),
149
- /* @__PURE__ */ jsxs(
150
- "div",
151
- {
152
- className: cn(
153
- "flex flex-1 justify-between leading-none",
154
- nestLabel ? "items-end" : "items-center"
155
- ),
156
- children: [
157
- /* @__PURE__ */ jsxs("div", { className: "grid gap-1.5", children: [
158
- nestLabel ? tooltipLabel : null,
159
- /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: itemConfig?.label || item.name })
160
- ] }),
161
- item.value && /* @__PURE__ */ jsx("span", { className: "font-mono font-medium tabular-nums text-foreground", children: item.value.toLocaleString() })
162
- ]
163
- }
164
- )
165
- ] })
166
- },
167
- item.dataKey
168
- );
169
- }) })
170
- ]
171
- }
172
- );
173
- }
174
- );
175
- ChartTooltipContent.displayName = "ChartTooltip";
176
- var ChartLegend = RechartsPrimitive.Legend;
177
- var ChartLegendContent = React.forwardRef(
178
- ({ className, hideIcon = false, payload, verticalAlign = "bottom", nameKey }, ref) => {
179
- const { config } = useChart();
180
- if (!payload?.length) {
181
- return null;
182
- }
183
- return /* @__PURE__ */ jsx(
184
- "div",
185
- {
186
- ref,
187
- className: cn(
188
- "flex items-center justify-center gap-4",
189
- verticalAlign === "top" ? "pb-3" : "pt-3",
190
- className
191
- ),
192
- children: payload.filter((item) => item.type !== "none").map((item) => {
193
- const key = `${nameKey || item.dataKey || "value"}`;
194
- const itemConfig = getPayloadConfigFromPayload(config, item, key);
195
- return /* @__PURE__ */ jsxs(
196
- "div",
197
- {
198
- className: cn(
199
- "flex items-center gap-1.5 [&>svg]:h-3 [&>svg]:w-3 [&>svg]:text-muted-foreground"
200
- ),
201
- children: [
202
- itemConfig?.icon && !hideIcon ? /* @__PURE__ */ jsx(itemConfig.icon, {}) : /* @__PURE__ */ jsx(
203
- "div",
204
- {
205
- className: "h-2 w-2 shrink-0 rounded-[2px]",
206
- style: {
207
- backgroundColor: item.color
208
- }
209
- }
210
- ),
211
- itemConfig?.label
212
- ]
213
- },
214
- item.value
215
- );
216
- })
217
- }
218
- );
219
- }
220
- );
221
- ChartLegendContent.displayName = "ChartLegend";
222
- function getPayloadConfigFromPayload(config, payload, key) {
223
- if (typeof payload !== "object" || payload === null) {
224
- return void 0;
225
- }
226
- const payloadPayload = "payload" in payload && typeof payload.payload === "object" && payload.payload !== null ? payload.payload : void 0;
227
- let configLabelKey = key;
228
- if (key in payload && typeof payload[key] === "string") {
229
- configLabelKey = payload[key];
230
- } else if (payloadPayload && key in payloadPayload && typeof payloadPayload[key] === "string") {
231
- configLabelKey = payloadPayload[key];
232
- }
233
- return configLabelKey in config ? config[configLabelKey] : config[key];
234
- }
235
- var AreaChart = React.forwardRef(
236
- ({
237
- data,
238
- config,
239
- dataKey,
240
- xAxisKey = "name",
241
- yAxisKey,
242
- margin = { left: 12, right: 12 },
243
- showGrid = true,
244
- showXAxis = true,
245
- showYAxis = false,
246
- showTooltip = true,
247
- gradient = false,
248
- stacked = false,
249
- strokeWidth = 2,
250
- fillOpacity = 0.4,
251
- type = "natural",
252
- className,
253
- ...props
254
- }, ref) => {
255
- const chartDataKeys = React.useMemo(() => {
256
- if (Array.isArray(dataKey)) return dataKey;
257
- return [dataKey];
258
- }, [dataKey]);
259
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(
260
- AreaChart$1,
261
- {
262
- data,
263
- margin,
264
- accessibilityLayer: true,
265
- children: [
266
- showGrid && /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", vertical: false }),
267
- showXAxis && /* @__PURE__ */ jsx(
268
- XAxis,
269
- {
270
- dataKey: xAxisKey,
271
- tickLine: false,
272
- axisLine: false,
273
- tickMargin: 8,
274
- tickFormatter: (value) => value?.toString().slice(0, 3)
275
- }
276
- ),
277
- showYAxis && yAxisKey && /* @__PURE__ */ jsx(
278
- YAxis,
279
- {
280
- dataKey: yAxisKey,
281
- tickLine: false,
282
- axisLine: false,
283
- tickMargin: 8
284
- }
285
- ),
286
- showTooltip && /* @__PURE__ */ jsx(
287
- ChartTooltip,
288
- {
289
- cursor: false,
290
- content: /* @__PURE__ */ jsx(ChartTooltipContent, { indicator: "line" })
291
- }
292
- ),
293
- chartDataKeys.map((key, index) => /* @__PURE__ */ jsx(
294
- Area,
295
- {
296
- dataKey: key,
297
- type,
298
- fill: `var(--color-${key})`,
299
- fillOpacity,
300
- stroke: `var(--color-${key})`,
301
- strokeWidth,
302
- stackId: stacked ? "a" : void 0
303
- },
304
- key
305
- )),
306
- gradient && /* @__PURE__ */ jsx("defs", { children: chartDataKeys.map((key) => /* @__PURE__ */ jsxs("linearGradient", { id: `gradient-${key}`, x1: "0", y1: "0", x2: "0", y2: "1", children: [
307
- /* @__PURE__ */ jsx("stop", { offset: "5%", stopColor: `var(--color-${key})`, stopOpacity: 0.8 }),
308
- /* @__PURE__ */ jsx("stop", { offset: "95%", stopColor: `var(--color-${key})`, stopOpacity: 0.1 })
309
- ] }, key)) })
310
- ]
311
- }
312
- ) }) });
313
- }
314
- );
315
- AreaChart.displayName = "AreaChart";
316
- var BarChart = React.forwardRef(
317
- ({
318
- data,
319
- config,
320
- dataKey,
321
- xAxisKey = "name",
322
- yAxisKey,
323
- margin = { left: 12, right: 12 },
324
- showGrid = true,
325
- showXAxis = true,
326
- showYAxis = false,
327
- showTooltip = true,
328
- horizontal = false,
329
- stacked = false,
330
- radius = 8,
331
- barGap = 4,
332
- barCategoryGap = "10%",
333
- className,
334
- ...props
335
- }, ref) => {
336
- const chartDataKeys = React.useMemo(() => {
337
- if (Array.isArray(dataKey)) return dataKey;
338
- return [dataKey];
339
- }, [dataKey]);
340
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(
341
- BarChart$1,
342
- {
343
- data,
344
- margin,
345
- accessibilityLayer: true,
346
- layout: horizontal ? "horizontal" : "vertical",
347
- barGap,
348
- barCategoryGap,
349
- children: [
350
- showGrid && /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", vertical: !horizontal }),
351
- showXAxis && /* @__PURE__ */ jsx(
352
- XAxis,
353
- {
354
- type: horizontal ? "number" : "category",
355
- dataKey: horizontal ? void 0 : xAxisKey,
356
- tickLine: false,
357
- tickMargin: 10,
358
- axisLine: false,
359
- tickFormatter: horizontal ? void 0 : (value) => value?.toString().slice(0, 3)
360
- }
361
- ),
362
- showYAxis && /* @__PURE__ */ jsx(
363
- YAxis,
364
- {
365
- type: horizontal ? "category" : "number",
366
- dataKey: horizontal ? xAxisKey : yAxisKey,
367
- tickLine: false,
368
- axisLine: false,
369
- tickMargin: 8,
370
- tickFormatter: horizontal ? (value) => value?.toString().slice(0, 3) : void 0
371
- }
372
- ),
373
- showTooltip && /* @__PURE__ */ jsx(
374
- ChartTooltip,
375
- {
376
- cursor: false,
377
- content: /* @__PURE__ */ jsx(ChartTooltipContent, { hideLabel: !stacked })
378
- }
379
- ),
380
- chartDataKeys.map((key, index) => /* @__PURE__ */ jsx(
381
- Bar,
382
- {
383
- dataKey: key,
384
- fill: `var(--color-${key})`,
385
- radius,
386
- stackId: stacked ? "a" : void 0
387
- },
388
- key
389
- ))
390
- ]
391
- }
392
- ) }) });
393
- }
394
- );
395
- BarChart.displayName = "BarChart";
396
- var LineChart = React.forwardRef(
397
- ({
398
- data,
399
- config,
400
- dataKey,
401
- xAxisKey = "name",
402
- yAxisKey,
403
- margin = { left: 12, right: 12 },
404
- showGrid = true,
405
- showXAxis = true,
406
- showYAxis = false,
407
- showTooltip = true,
408
- showDots = false,
409
- strokeWidth = 2,
410
- type = "monotone",
411
- connectNulls = false,
412
- activeDot = true,
413
- className,
414
- ...props
415
- }, ref) => {
416
- const chartDataKeys = React.useMemo(() => {
417
- if (Array.isArray(dataKey)) return dataKey;
418
- return [dataKey];
419
- }, [dataKey]);
420
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(
421
- LineChart$1,
422
- {
423
- data,
424
- margin,
425
- accessibilityLayer: true,
426
- children: [
427
- showGrid && /* @__PURE__ */ jsx(CartesianGrid, { strokeDasharray: "3 3", vertical: false }),
428
- showXAxis && /* @__PURE__ */ jsx(
429
- XAxis,
430
- {
431
- dataKey: xAxisKey,
432
- tickLine: false,
433
- axisLine: false,
434
- tickMargin: 8,
435
- tickFormatter: (value) => value?.toString().slice(0, 3)
436
- }
437
- ),
438
- showYAxis && yAxisKey && /* @__PURE__ */ jsx(
439
- YAxis,
440
- {
441
- dataKey: yAxisKey,
442
- tickLine: false,
443
- axisLine: false,
444
- tickMargin: 8
445
- }
446
- ),
447
- showTooltip && /* @__PURE__ */ jsx(
448
- ChartTooltip,
449
- {
450
- cursor: false,
451
- content: /* @__PURE__ */ jsx(ChartTooltipContent, {})
452
- }
453
- ),
454
- chartDataKeys.map((key, index) => /* @__PURE__ */ jsx(
455
- Line,
456
- {
457
- dataKey: key,
458
- type,
459
- stroke: `var(--color-${key})`,
460
- strokeWidth,
461
- dot: showDots ? { fill: `var(--color-${key})`, strokeWidth: 2 } : false,
462
- activeDot: activeDot ? { r: 6, fill: `var(--color-${key})` } : false,
463
- connectNulls
464
- },
465
- key
466
- ))
467
- ]
468
- }
469
- ) }) });
470
- }
471
- );
472
- LineChart.displayName = "LineChart";
473
- var PieChart = React.forwardRef(
474
- ({
475
- data,
476
- config,
477
- dataKey,
478
- nameKey = "name",
479
- cx = "50%",
480
- cy = "50%",
481
- innerRadius = 0,
482
- outerRadius = 80,
483
- showTooltip = true,
484
- showLegend = false,
485
- startAngle = 90,
486
- endAngle = 450,
487
- paddingAngle = 0,
488
- stroke = "transparent",
489
- strokeWidth = 1,
490
- className,
491
- ...props
492
- }, ref) => {
493
- const enhancedData = React.useMemo(() => {
494
- return data.map((item, index) => {
495
- const itemKey = item[nameKey] || index.toString();
496
- const configItem = config[itemKey];
497
- return {
498
- ...item,
499
- fill: item.fill || configItem?.color || `var(--color-${itemKey})` || `hsl(var(--chart-${index % 5 + 1}))`
500
- };
501
- });
502
- }, [data, config, nameKey]);
503
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(PieChart$1, { accessibilityLayer: true, children: [
504
- showTooltip && /* @__PURE__ */ jsx(
505
- ChartTooltip,
506
- {
507
- cursor: false,
508
- content: /* @__PURE__ */ jsx(ChartTooltipContent, { hideLabel: true })
509
- }
510
- ),
511
- /* @__PURE__ */ jsx(
512
- Pie,
513
- {
514
- data: enhancedData,
515
- dataKey,
516
- nameKey,
517
- cx,
518
- cy,
519
- innerRadius,
520
- outerRadius,
521
- startAngle,
522
- endAngle,
523
- paddingAngle,
524
- stroke,
525
- strokeWidth,
526
- children: enhancedData.map((entry, index) => /* @__PURE__ */ jsx(Cell, { fill: entry.fill }, `cell-${index}`))
527
- }
528
- ),
529
- showLegend && /* @__PURE__ */ jsx(
530
- ChartLegend,
531
- {
532
- content: /* @__PURE__ */ jsx(ChartLegendContent, { nameKey }),
533
- verticalAlign: "bottom"
534
- }
535
- )
536
- ] }) }) });
537
- }
538
- );
539
- PieChart.displayName = "PieChart";
540
- var DonutChart = React.forwardRef(
541
- ({ innerRadius = 60, ...props }, ref) => {
542
- return /* @__PURE__ */ jsx(PieChart, { ref, innerRadius, ...props });
543
- }
544
- );
545
- DonutChart.displayName = "DonutChart";
546
- var RadarChart = React.forwardRef(
547
- ({
548
- data,
549
- config,
550
- dataKey,
551
- angleKey = "name",
552
- radiusKey,
553
- cx = "50%",
554
- cy = "50%",
555
- outerRadius = "80%",
556
- showTooltip = true,
557
- showLegend = false,
558
- showGrid = true,
559
- showAngleAxis = true,
560
- showRadiusAxis = false,
561
- fillOpacity = 0.6,
562
- strokeWidth = 2,
563
- gridType = "polygon",
564
- tick = true,
565
- tickCount = 5,
566
- className,
567
- ...props
568
- }, ref) => {
569
- const chartDataKeys = React.useMemo(() => {
570
- if (Array.isArray(dataKey)) return dataKey;
571
- return [dataKey];
572
- }, [dataKey]);
573
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(
574
- RadarChart$1,
575
- {
576
- data,
577
- cx,
578
- cy,
579
- outerRadius,
580
- accessibilityLayer: true,
581
- children: [
582
- showGrid && /* @__PURE__ */ jsx(
583
- PolarGrid,
584
- {
585
- gridType,
586
- radialLines: gridType === "polygon"
587
- }
588
- ),
589
- showAngleAxis && /* @__PURE__ */ jsx(
590
- PolarAngleAxis,
591
- {
592
- dataKey: angleKey,
593
- tick,
594
- tickFormatter: (value) => value?.toString().slice(0, 3)
595
- }
596
- ),
597
- showRadiusAxis && /* @__PURE__ */ jsx(
598
- PolarRadiusAxis,
599
- {
600
- dataKey: radiusKey,
601
- tick,
602
- tickCount,
603
- angle: 90,
604
- domain: [0, "dataMax"]
605
- }
606
- ),
607
- showTooltip && /* @__PURE__ */ jsx(
608
- ChartTooltip,
609
- {
610
- cursor: false,
611
- content: /* @__PURE__ */ jsx(ChartTooltipContent, {})
612
- }
613
- ),
614
- chartDataKeys.map((key, index) => /* @__PURE__ */ jsx(
615
- Radar,
616
- {
617
- dataKey: key,
618
- stroke: `var(--color-${key})`,
619
- fill: `var(--color-${key})`,
620
- fillOpacity,
621
- strokeWidth,
622
- dot: {
623
- r: 4,
624
- fill: `var(--color-${key})`,
625
- strokeWidth: 2,
626
- stroke: "var(--background)"
627
- }
628
- },
629
- key
630
- )),
631
- showLegend && /* @__PURE__ */ jsx(
632
- ChartLegend,
633
- {
634
- content: /* @__PURE__ */ jsx(ChartLegendContent, {}),
635
- verticalAlign: "bottom"
636
- }
637
- )
638
- ]
639
- }
640
- ) }) });
641
- }
642
- );
643
- RadarChart.displayName = "RadarChart";
644
- var RadialChart = React.forwardRef(
645
- ({
646
- data,
647
- config,
648
- dataKey,
649
- nameKey = "name",
650
- cx = "50%",
651
- cy = "50%",
652
- innerRadius = "30%",
653
- outerRadius = "80%",
654
- startAngle = 90,
655
- endAngle = -270,
656
- showTooltip = true,
657
- showLegend = false,
658
- showBackground = true,
659
- cornerRadius = 4,
660
- stackId,
661
- label = false,
662
- className,
663
- ...props
664
- }, ref) => {
665
- const chartDataKeys = React.useMemo(() => {
666
- if (Array.isArray(dataKey)) return dataKey;
667
- return [dataKey];
668
- }, [dataKey]);
669
- const enhancedData = React.useMemo(() => {
670
- return data.map((item, index) => {
671
- const itemKey = item[nameKey] || index.toString();
672
- const configItem = config[itemKey];
673
- return {
674
- ...item,
675
- fill: item.fill || configItem?.color || `var(--color-${itemKey})` || `hsl(var(--chart-${index % 5 + 1}))`
676
- };
677
- });
678
- }, [data, config, nameKey]);
679
- return /* @__PURE__ */ jsx("div", { ref, className: cn("w-full", className), ...props, children: /* @__PURE__ */ jsx(ChartContainer, { config, children: /* @__PURE__ */ jsxs(
680
- RadialBarChart,
681
- {
682
- data: enhancedData,
683
- cx,
684
- cy,
685
- innerRadius,
686
- outerRadius,
687
- startAngle,
688
- endAngle,
689
- accessibilityLayer: true,
690
- children: [
691
- /* @__PURE__ */ jsx(
692
- PolarAngleAxis,
693
- {
694
- type: "number",
695
- domain: [0, 100],
696
- angleAxisId: 0,
697
- tick: false
698
- }
699
- ),
700
- showTooltip && /* @__PURE__ */ jsx(
701
- ChartTooltip,
702
- {
703
- cursor: false,
704
- content: /* @__PURE__ */ jsx(ChartTooltipContent, { hideLabel: true })
705
- }
706
- ),
707
- chartDataKeys.map((key, index) => /* @__PURE__ */ jsx(
708
- RadialBar,
709
- {
710
- dataKey: key,
711
- stackId,
712
- cornerRadius,
713
- fill: `var(--color-${key})`,
714
- className: "stroke-transparent stroke-2",
715
- background: showBackground ? { fill: "var(--muted)" } : false,
716
- label
717
- },
718
- key
719
- )),
720
- showLegend && /* @__PURE__ */ jsx(
721
- ChartLegend,
722
- {
723
- content: /* @__PURE__ */ jsx(ChartLegendContent, { nameKey }),
724
- verticalAlign: "bottom"
725
- }
726
- )
727
- ]
728
- }
729
- ) }) });
730
- }
731
- );
732
- RadialChart.displayName = "RadialChart";
733
-
734
- // src/charts/chart-config.tsx
735
- var chartColorPalettes = {
736
- hanzo: {
737
- light: [
738
- "oklch(0.65 0.18 35)",
739
- // Neutral warm
740
- "oklch(0.55 0.15 165)",
741
- // Neutral cool
742
- "oklch(0.45 0.12 195)",
743
- // Neutral blue
744
- "oklch(0.7 0.18 55)",
745
- // Neutral yellow
746
- "oklch(0.65 0.22 40)",
747
- // Neutral orange
748
- "oklch(0.5 0.1 220)",
749
- // Neutral indigo
750
- "oklch(0.6 0.15 280)",
751
- // Neutral purple
752
- "oklch(0.55 0.2 340)"
753
- // Neutral pink
754
- ],
755
- dark: [
756
- "oklch(0.5 0.17 220)",
757
- // Cool blue
758
- "oklch(0.45 0.15 160)",
759
- // Cool green
760
- "oklch(0.55 0.2 30)",
761
- // Warm orange
762
- "oklch(0.6 0.16 280)",
763
- // Cool purple
764
- "oklch(0.55 0.18 340)",
765
- // Cool pink
766
- "oklch(0.5 0.15 100)",
767
- // Neutral green
768
- "oklch(0.45 0.18 60)",
769
- // Warm yellow
770
- "oklch(0.6 0.12 200)"
771
- // Cool cyan
772
- ]
773
- },
774
- lux: {
775
- light: [
776
- "oklch(0.15 0 0)",
777
- // Deep black
778
- "oklch(0.35 0 0)",
779
- // Dark gray
780
- "oklch(0.55 0 0)",
781
- // Medium gray
782
- "oklch(0.75 0 0)",
783
- // Light gray
784
- "oklch(0.25 0 0)",
785
- // Charcoal
786
- "oklch(0.45 0 0)",
787
- // Medium-dark gray
788
- "oklch(0.85 0 0)",
789
- // Very light gray
790
- "oklch(0.65 0 0)"
791
- // Medium-light gray
792
- ],
793
- dark: [
794
- "oklch(0.985 0 0)",
795
- // Pure white
796
- "oklch(0.75 0 0)",
797
- // Light gray
798
- "oklch(0.55 0 0)",
799
- // Medium gray
800
- "oklch(0.35 0 0)",
801
- // Dark gray
802
- "oklch(0.85 0 0)",
803
- // Very light gray
804
- "oklch(0.65 0 0)",
805
- // Medium-light gray
806
- "oklch(0.25 0 0)",
807
- // Charcoal
808
- "oklch(0.45 0 0)"
809
- // Medium-dark gray
810
- ]
811
- },
812
- zoo: {
813
- light: [
814
- "oklch(0.6 0.35 0)",
815
- // Red
816
- "oklch(0.65 0.35 120)",
817
- // Green
818
- "oklch(0.55 0.35 240)",
819
- // Blue
820
- "oklch(0.7 0.35 180)",
821
- // Cyan
822
- "oklch(0.65 0.35 300)",
823
- // Magenta
824
- "oklch(0.75 0.35 60)",
825
- // Yellow
826
- "oklch(0.6 0.35 30)",
827
- // Orange
828
- "oklch(0.55 0.35 270)"
829
- // Violet
830
- ],
831
- dark: [
832
- "oklch(0.7 0.4 0)",
833
- // Bright red
834
- "oklch(0.75 0.4 120)",
835
- // Bright green
836
- "oklch(0.65 0.4 240)",
837
- // Bright blue
838
- "oklch(0.8 0.4 180)",
839
- // Bright cyan
840
- "oklch(0.75 0.4 300)",
841
- // Bright magenta
842
- "oklch(0.85 0.4 60)",
843
- // Bright yellow
844
- "oklch(0.7 0.4 30)",
845
- // Bright orange
846
- "oklch(0.65 0.4 270)"
847
- // Bright violet
848
- ]
849
- }
850
- };
851
- function createBrandChartConfig(brand = "hanzo", mode = "light", variables = []) {
852
- const palette = chartColorPalettes[brand][mode];
853
- const config = {};
854
- for (let i = 1; i <= 8; i++) {
855
- config[`chart-${i}`] = {
856
- color: palette[i - 1] || palette[0]
857
- };
858
- }
859
- variables.forEach((variable, index) => {
860
- config[variable] = {
861
- color: palette[index % palette.length]
862
- };
863
- });
864
- return config;
865
- }
866
- function getChartColor(key, brand = "hanzo", mode = "light", index = 0) {
867
- const palette = chartColorPalettes[brand][mode];
868
- return palette[index % palette.length];
869
- }
870
- var hanzoChartConfig = createBrandChartConfig("hanzo");
871
- var luxChartConfig = createBrandChartConfig("lux");
872
- var zooChartConfig = createBrandChartConfig("zoo");
873
- function createEnhancedChartConfig(brand = "hanzo", variables = []) {
874
- const lightPalette = chartColorPalettes[brand].light;
875
- const darkPalette = chartColorPalettes[brand].dark;
876
- const config = {};
877
- for (let i = 1; i <= 8; i++) {
878
- config[`chart-${i}`] = {
879
- theme: {
880
- light: lightPalette[i - 1] || lightPalette[0],
881
- dark: darkPalette[i - 1] || darkPalette[0]
882
- }
883
- };
884
- }
885
- variables.forEach((variable, index) => {
886
- config[variable] = {
887
- theme: {
888
- light: lightPalette[index % lightPalette.length],
889
- dark: darkPalette[index % darkPalette.length]
890
- }
891
- };
892
- });
893
- return config;
894
- }
895
- var enhancedHanzoChartConfig = createEnhancedChartConfig("hanzo");
896
- var enhancedLuxChartConfig = createEnhancedChartConfig("lux");
897
- var enhancedZooChartConfig = createEnhancedChartConfig("zoo");
898
-
899
- export { AreaChart, BarChart, ChartContainer, ChartLegend, ChartLegendContent, ChartStyle, ChartTooltip, ChartTooltipContent, DonutChart, LineChart, PieChart, RadarChart, RadialChart, chartColorPalettes, createBrandChartConfig, createEnhancedChartConfig, enhancedHanzoChartConfig, enhancedLuxChartConfig, enhancedZooChartConfig, getChartColor, hanzoChartConfig, luxChartConfig, zooChartConfig };
900
- //# sourceMappingURL=index.mjs.map
901
- //# sourceMappingURL=index.mjs.map