@hanzo/ui 4.8.5 → 4.9.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 (683) hide show
  1. package/CHANGELOG.md +184 -0
  2. package/LICENSE +21 -0
  3. package/README.md +185 -192
  4. package/dist/ai/index.js +53 -0
  5. package/dist/ai/index.js.map +1 -0
  6. package/dist/ai/index.mjs +4 -0
  7. package/dist/ai/index.mjs.map +1 -0
  8. package/dist/blocks/index.js +983 -0
  9. package/dist/blocks/index.js.map +1 -0
  10. package/dist/blocks/index.mjs +945 -0
  11. package/dist/blocks/index.mjs.map +1 -0
  12. package/dist/calendar/index.js +14 -0
  13. package/dist/calendar/index.js.map +1 -0
  14. package/dist/calendar/index.mjs +5 -0
  15. package/dist/calendar/index.mjs.map +1 -0
  16. package/dist/carousel/index.js +220 -0
  17. package/dist/carousel/index.js.map +1 -0
  18. package/dist/carousel/index.mjs +191 -0
  19. package/dist/carousel/index.mjs.map +1 -0
  20. package/dist/charts/index.js +945 -0
  21. package/dist/charts/index.js.map +1 -0
  22. package/dist/charts/index.mjs +901 -0
  23. package/dist/charts/index.mjs.map +1 -0
  24. package/dist/chunk-26T4V5QU.mjs +111 -0
  25. package/dist/chunk-26T4V5QU.mjs.map +1 -0
  26. package/dist/chunk-2A5KXDLJ.js +22 -0
  27. package/dist/chunk-2A5KXDLJ.js.map +1 -0
  28. package/dist/chunk-2CJ4HMF4.js +79 -0
  29. package/dist/chunk-2CJ4HMF4.js.map +1 -0
  30. package/dist/chunk-2OIQKC5E.js +236 -0
  31. package/dist/chunk-2OIQKC5E.js.map +1 -0
  32. package/dist/chunk-2X3KSYBN.js +44 -0
  33. package/dist/chunk-2X3KSYBN.js.map +1 -0
  34. package/dist/chunk-3PBQGYR7.mjs +100 -0
  35. package/dist/chunk-3PBQGYR7.mjs.map +1 -0
  36. package/dist/chunk-3POQQ6L7.js +62 -0
  37. package/dist/chunk-3POQQ6L7.js.map +1 -0
  38. package/dist/chunk-4B47GITH.mjs +28 -0
  39. package/dist/chunk-4B47GITH.mjs.map +1 -0
  40. package/dist/chunk-4BC2OH6B.js +129 -0
  41. package/dist/chunk-4BC2OH6B.js.map +1 -0
  42. package/dist/chunk-5AQSGH4R.js +130 -0
  43. package/dist/chunk-5AQSGH4R.js.map +1 -0
  44. package/dist/chunk-5IHRJFOO.mjs +102 -0
  45. package/dist/chunk-5IHRJFOO.mjs.map +1 -0
  46. package/dist/chunk-5LDGR7YN.mjs +28 -0
  47. package/dist/chunk-5LDGR7YN.mjs.map +1 -0
  48. package/dist/chunk-5MCN3VYM.mjs +23 -0
  49. package/dist/chunk-5MCN3VYM.mjs.map +1 -0
  50. package/dist/chunk-6AVAMRMB.mjs +47 -0
  51. package/dist/chunk-6AVAMRMB.mjs.map +1 -0
  52. package/dist/chunk-6H62JRNM.mjs +120 -0
  53. package/dist/chunk-6H62JRNM.mjs.map +1 -0
  54. package/dist/chunk-6KCII3F6.mjs +126 -0
  55. package/dist/chunk-6KCII3F6.mjs.map +1 -0
  56. package/dist/chunk-7EHB43BJ.js +155 -0
  57. package/dist/chunk-7EHB43BJ.js.map +1 -0
  58. package/dist/chunk-7LRD23Q5.js +191 -0
  59. package/dist/chunk-7LRD23Q5.js.map +1 -0
  60. package/dist/chunk-7SAHKOJG.mjs +45 -0
  61. package/dist/chunk-7SAHKOJG.mjs.map +1 -0
  62. package/dist/chunk-A3D2YZK3.js +50 -0
  63. package/dist/chunk-A3D2YZK3.js.map +1 -0
  64. package/dist/chunk-AL4QFH7V.js +63 -0
  65. package/dist/chunk-AL4QFH7V.js.map +1 -0
  66. package/dist/chunk-B3WFEG6U.js +69 -0
  67. package/dist/chunk-B3WFEG6U.js.map +1 -0
  68. package/dist/chunk-BDZQJ6GK.js +242 -0
  69. package/dist/chunk-BDZQJ6GK.js.map +1 -0
  70. package/dist/chunk-BRWFYRGX.js +61 -0
  71. package/dist/chunk-BRWFYRGX.js.map +1 -0
  72. package/dist/chunk-C5DNTLBO.js +53 -0
  73. package/dist/chunk-C5DNTLBO.js.map +1 -0
  74. package/dist/chunk-CRALRACO.js +54 -0
  75. package/dist/chunk-CRALRACO.js.map +1 -0
  76. package/dist/chunk-CVACQJRM.js +149 -0
  77. package/dist/chunk-CVACQJRM.js.map +1 -0
  78. package/dist/chunk-DEIUKFPZ.mjs +63 -0
  79. package/dist/chunk-DEIUKFPZ.mjs.map +1 -0
  80. package/dist/chunk-DN2AEEA2.js +13 -0
  81. package/dist/chunk-DN2AEEA2.js.map +1 -0
  82. package/dist/chunk-DTNRWU4B.mjs +35 -0
  83. package/dist/chunk-DTNRWU4B.mjs.map +1 -0
  84. package/dist/chunk-DXIUEWRJ.mjs +31 -0
  85. package/dist/chunk-DXIUEWRJ.mjs.map +1 -0
  86. package/dist/chunk-DYFV66JX.mjs +54 -0
  87. package/dist/chunk-DYFV66JX.mjs.map +1 -0
  88. package/dist/chunk-F3WMAHXV.mjs +86 -0
  89. package/dist/chunk-F3WMAHXV.mjs.map +1 -0
  90. package/dist/chunk-F4RWPBBB.js +79 -0
  91. package/dist/chunk-F4RWPBBB.js.map +1 -0
  92. package/dist/chunk-FEGAPM6U.js +194 -0
  93. package/dist/chunk-FEGAPM6U.js.map +1 -0
  94. package/dist/chunk-G5TS56PW.mjs +160 -0
  95. package/dist/chunk-G5TS56PW.mjs.map +1 -0
  96. package/dist/chunk-GG6VGOEN.mjs +590 -0
  97. package/dist/chunk-GG6VGOEN.mjs.map +1 -0
  98. package/dist/chunk-GLAMGK32.mjs +54 -0
  99. package/dist/chunk-GLAMGK32.mjs.map +1 -0
  100. package/dist/chunk-GNMMUJXD.mjs +200 -0
  101. package/dist/chunk-GNMMUJXD.mjs.map +1 -0
  102. package/dist/chunk-GNPBULLS.mjs +600 -0
  103. package/dist/chunk-GNPBULLS.mjs.map +1 -0
  104. package/dist/chunk-GTE2DELE.js +65 -0
  105. package/dist/chunk-GTE2DELE.js.map +1 -0
  106. package/dist/chunk-GUQAFFTH.js +94 -0
  107. package/dist/chunk-GUQAFFTH.js.map +1 -0
  108. package/dist/chunk-H5VOYZHT.mjs +34 -0
  109. package/dist/chunk-H5VOYZHT.mjs.map +1 -0
  110. package/dist/chunk-HR6PBOGG.mjs +59 -0
  111. package/dist/chunk-HR6PBOGG.mjs.map +1 -0
  112. package/dist/chunk-HROONQS3.js +55 -0
  113. package/dist/chunk-HROONQS3.js.map +1 -0
  114. package/dist/chunk-IAO7SOQ3.mjs +56 -0
  115. package/dist/chunk-IAO7SOQ3.mjs.map +1 -0
  116. package/dist/chunk-K2QKU3K6.mjs +40 -0
  117. package/dist/chunk-K2QKU3K6.mjs.map +1 -0
  118. package/dist/chunk-KEUZZCCP.js +53 -0
  119. package/dist/chunk-KEUZZCCP.js.map +1 -0
  120. package/dist/chunk-KJXSLTG7.mjs +73 -0
  121. package/dist/chunk-KJXSLTG7.mjs.map +1 -0
  122. package/dist/chunk-L5AFUCVH.mjs +26 -0
  123. package/dist/chunk-L5AFUCVH.mjs.map +1 -0
  124. package/dist/chunk-LB3I52KZ.mjs +42 -0
  125. package/dist/chunk-LB3I52KZ.mjs.map +1 -0
  126. package/dist/chunk-LN75MJQ2.js +71 -0
  127. package/dist/chunk-LN75MJQ2.js.map +1 -0
  128. package/dist/chunk-LRBOFJUV.js +60 -0
  129. package/dist/chunk-LRBOFJUV.js.map +1 -0
  130. package/dist/chunk-MMNYRBOU.js +157 -0
  131. package/dist/chunk-MMNYRBOU.js.map +1 -0
  132. package/dist/chunk-MO65YF6P.js +236 -0
  133. package/dist/chunk-MO65YF6P.js.map +1 -0
  134. package/dist/chunk-N4KHP5FC.mjs +33 -0
  135. package/dist/chunk-N4KHP5FC.mjs.map +1 -0
  136. package/dist/chunk-NP2J7AB7.mjs +121 -0
  137. package/dist/chunk-NP2J7AB7.mjs.map +1 -0
  138. package/dist/chunk-OLR6SGYO.js +57 -0
  139. package/dist/chunk-OLR6SGYO.js.map +1 -0
  140. package/dist/chunk-ON7NQ4DY.js +21 -0
  141. package/dist/chunk-ON7NQ4DY.js.map +1 -0
  142. package/dist/chunk-PE3VFRLV.mjs +198 -0
  143. package/dist/chunk-PE3VFRLV.mjs.map +1 -0
  144. package/dist/chunk-Q7LOOIE5.mjs +8 -0
  145. package/dist/chunk-Q7LOOIE5.mjs.map +1 -0
  146. package/dist/chunk-QFA6U75G.mjs +51 -0
  147. package/dist/chunk-QFA6U75G.mjs.map +1 -0
  148. package/dist/chunk-QJQPT4WX.js +638 -0
  149. package/dist/chunk-QJQPT4WX.js.map +1 -0
  150. package/dist/chunk-QKHQPBSR.mjs +20 -0
  151. package/dist/chunk-QKHQPBSR.mjs.map +1 -0
  152. package/dist/chunk-SJD4XRFJ.mjs +141 -0
  153. package/dist/chunk-SJD4XRFJ.mjs.map +1 -0
  154. package/dist/chunk-SOOJLU4C.mjs +19 -0
  155. package/dist/chunk-SOOJLU4C.mjs.map +1 -0
  156. package/dist/chunk-T66B5IM5.js +51 -0
  157. package/dist/chunk-T66B5IM5.js.map +1 -0
  158. package/dist/chunk-T7RPZDO4.js +645 -0
  159. package/dist/chunk-T7RPZDO4.js.map +1 -0
  160. package/dist/chunk-TGRMDGTV.mjs +38 -0
  161. package/dist/chunk-TGRMDGTV.mjs.map +1 -0
  162. package/dist/chunk-TH2UKMCO.mjs +11 -0
  163. package/dist/chunk-TH2UKMCO.mjs.map +1 -0
  164. package/dist/chunk-TMV45OKE.mjs +113 -0
  165. package/dist/chunk-TMV45OKE.mjs.map +1 -0
  166. package/dist/chunk-TUJ7EVEK.js +171 -0
  167. package/dist/chunk-TUJ7EVEK.js.map +1 -0
  168. package/dist/chunk-ULNWDOI7.js +122 -0
  169. package/dist/chunk-ULNWDOI7.js.map +1 -0
  170. package/dist/chunk-UNUTTHCH.mjs +210 -0
  171. package/dist/chunk-UNUTTHCH.mjs.map +1 -0
  172. package/dist/chunk-VJMI6BG4.mjs +10 -0
  173. package/dist/chunk-VJMI6BG4.mjs.map +1 -0
  174. package/dist/chunk-VZVOB5MG.mjs +26 -0
  175. package/dist/chunk-VZVOB5MG.mjs.map +1 -0
  176. package/dist/chunk-WD67O22C.js +50 -0
  177. package/dist/chunk-WD67O22C.js.map +1 -0
  178. package/dist/chunk-WYPMLIJN.js +53 -0
  179. package/dist/chunk-WYPMLIJN.js.map +1 -0
  180. package/dist/chunk-X32I34NH.js +109 -0
  181. package/dist/chunk-X32I34NH.js.map +1 -0
  182. package/dist/chunk-X5MOZ3YL.js +65 -0
  183. package/dist/chunk-X5MOZ3YL.js.map +1 -0
  184. package/dist/chunk-Y4JVIPQZ.mjs +31 -0
  185. package/dist/chunk-Y4JVIPQZ.mjs.map +1 -0
  186. package/dist/chunk-Y6WOV2LZ.js +95 -0
  187. package/dist/chunk-Y6WOV2LZ.js.map +1 -0
  188. package/dist/chunk-YAEN5SCU.mjs +41 -0
  189. package/dist/chunk-YAEN5SCU.mjs.map +1 -0
  190. package/dist/chunk-YH6XDF3N.js +121 -0
  191. package/dist/chunk-YH6XDF3N.js.map +1 -0
  192. package/dist/chunk-YJKA4D75.mjs +124 -0
  193. package/dist/chunk-YJKA4D75.mjs.map +1 -0
  194. package/dist/chunk-ZANAF7WB.js +88 -0
  195. package/dist/chunk-ZANAF7WB.js.map +1 -0
  196. package/dist/chunk-ZDBWNPLO.js +30 -0
  197. package/dist/chunk-ZDBWNPLO.js.map +1 -0
  198. package/dist/chunk-ZDT2IOK2.js +56 -0
  199. package/dist/chunk-ZDT2IOK2.js.map +1 -0
  200. package/dist/chunk-ZKGVLTSI.js +25 -0
  201. package/dist/chunk-ZKGVLTSI.js.map +1 -0
  202. package/dist/chunk-ZLELESO7.js +34 -0
  203. package/dist/chunk-ZLELESO7.js.map +1 -0
  204. package/dist/chunk-ZUFUEQTX.mjs +157 -0
  205. package/dist/chunk-ZUFUEQTX.mjs.map +1 -0
  206. package/dist/chunk-ZZZWRQQE.mjs +42 -0
  207. package/dist/chunk-ZZZWRQQE.mjs.map +1 -0
  208. package/dist/command/index.js +138 -0
  209. package/dist/command/index.js.map +1 -0
  210. package/dist/command/index.mjs +128 -0
  211. package/dist/command/index.mjs.map +1 -0
  212. package/dist/components/accordion.js +25 -0
  213. package/dist/components/accordion.js.map +1 -0
  214. package/dist/components/accordion.mjs +4 -0
  215. package/dist/components/accordion.mjs.map +1 -0
  216. package/dist/components/alert.js +21 -0
  217. package/dist/components/alert.js.map +1 -0
  218. package/dist/components/alert.mjs +4 -0
  219. package/dist/components/alert.mjs.map +1 -0
  220. package/dist/components/aspect-ratio.js +12 -0
  221. package/dist/components/aspect-ratio.js.map +1 -0
  222. package/dist/components/aspect-ratio.mjs +3 -0
  223. package/dist/components/aspect-ratio.mjs.map +1 -0
  224. package/dist/components/avatar.js +21 -0
  225. package/dist/components/avatar.js.map +1 -0
  226. package/dist/components/avatar.mjs +4 -0
  227. package/dist/components/avatar.mjs.map +1 -0
  228. package/dist/components/badge.js +17 -0
  229. package/dist/components/badge.js.map +1 -0
  230. package/dist/components/badge.mjs +4 -0
  231. package/dist/components/badge.mjs.map +1 -0
  232. package/dist/components/breadcrumb.js +37 -0
  233. package/dist/components/breadcrumb.js.map +1 -0
  234. package/dist/components/breadcrumb.mjs +4 -0
  235. package/dist/components/breadcrumb.mjs.map +1 -0
  236. package/dist/components/button.js +17 -0
  237. package/dist/components/button.js.map +1 -0
  238. package/dist/components/button.mjs +4 -0
  239. package/dist/components/button.mjs.map +1 -0
  240. package/dist/components/card.js +37 -0
  241. package/dist/components/card.js.map +1 -0
  242. package/dist/components/card.mjs +4 -0
  243. package/dist/components/card.mjs.map +1 -0
  244. package/dist/components/checkbox.js +13 -0
  245. package/dist/components/checkbox.js.map +1 -0
  246. package/dist/components/checkbox.mjs +4 -0
  247. package/dist/components/checkbox.mjs.map +1 -0
  248. package/dist/components/collapsible.js +20 -0
  249. package/dist/components/collapsible.js.map +1 -0
  250. package/dist/components/collapsible.mjs +3 -0
  251. package/dist/components/collapsible.mjs.map +1 -0
  252. package/dist/components/context-menu.js +69 -0
  253. package/dist/components/context-menu.js.map +1 -0
  254. package/dist/components/context-menu.mjs +4 -0
  255. package/dist/components/context-menu.mjs.map +1 -0
  256. package/dist/components/dialog.js +49 -0
  257. package/dist/components/dialog.js.map +1 -0
  258. package/dist/components/dialog.mjs +4 -0
  259. package/dist/components/dialog.mjs.map +1 -0
  260. package/dist/components/drawer.js +49 -0
  261. package/dist/components/drawer.js.map +1 -0
  262. package/dist/components/drawer.mjs +4 -0
  263. package/dist/components/drawer.mjs.map +1 -0
  264. package/dist/components/dropdown-menu.js +69 -0
  265. package/dist/components/dropdown-menu.js.map +1 -0
  266. package/dist/components/dropdown-menu.mjs +4 -0
  267. package/dist/components/dropdown-menu.mjs.map +1 -0
  268. package/dist/components/form.js +42 -0
  269. package/dist/components/form.js.map +1 -0
  270. package/dist/components/form.mjs +5 -0
  271. package/dist/components/form.mjs.map +1 -0
  272. package/dist/components/hover-card.js +21 -0
  273. package/dist/components/hover-card.js.map +1 -0
  274. package/dist/components/hover-card.mjs +4 -0
  275. package/dist/components/hover-card.mjs.map +1 -0
  276. package/dist/components/index.js +1047 -0
  277. package/dist/components/index.js.map +1 -0
  278. package/dist/components/index.mjs +46 -0
  279. package/dist/components/index.mjs.map +1 -0
  280. package/dist/components/input-otp.js +25 -0
  281. package/dist/components/input-otp.js.map +1 -0
  282. package/dist/components/input-otp.mjs +4 -0
  283. package/dist/components/input-otp.mjs.map +1 -0
  284. package/dist/components/input.js +13 -0
  285. package/dist/components/input.js.map +1 -0
  286. package/dist/components/input.mjs +4 -0
  287. package/dist/components/input.mjs.map +1 -0
  288. package/dist/components/label.js +13 -0
  289. package/dist/components/label.js.map +1 -0
  290. package/dist/components/label.mjs +4 -0
  291. package/dist/components/label.mjs.map +1 -0
  292. package/dist/components/menubar.js +73 -0
  293. package/dist/components/menubar.js.map +1 -0
  294. package/dist/components/menubar.mjs +4 -0
  295. package/dist/components/menubar.mjs.map +1 -0
  296. package/dist/components/navigation-menu.js +45 -0
  297. package/dist/components/navigation-menu.js.map +1 -0
  298. package/dist/components/navigation-menu.mjs +4 -0
  299. package/dist/components/navigation-menu.mjs.map +1 -0
  300. package/dist/components/pagination.js +38 -0
  301. package/dist/components/pagination.js.map +1 -0
  302. package/dist/components/pagination.mjs +5 -0
  303. package/dist/components/pagination.mjs.map +1 -0
  304. package/dist/components/popover.js +25 -0
  305. package/dist/components/popover.js.map +1 -0
  306. package/dist/components/popover.mjs +4 -0
  307. package/dist/components/popover.mjs.map +1 -0
  308. package/dist/components/progress.js +13 -0
  309. package/dist/components/progress.js.map +1 -0
  310. package/dist/components/progress.mjs +4 -0
  311. package/dist/components/progress.mjs.map +1 -0
  312. package/dist/components/radio-group.js +17 -0
  313. package/dist/components/radio-group.js.map +1 -0
  314. package/dist/components/radio-group.mjs +4 -0
  315. package/dist/components/radio-group.mjs.map +1 -0
  316. package/dist/components/resizable.js +21 -0
  317. package/dist/components/resizable.js.map +1 -0
  318. package/dist/components/resizable.mjs +4 -0
  319. package/dist/components/resizable.mjs.map +1 -0
  320. package/dist/components/scroll-area.js +17 -0
  321. package/dist/components/scroll-area.js.map +1 -0
  322. package/dist/components/scroll-area.mjs +4 -0
  323. package/dist/components/scroll-area.mjs.map +1 -0
  324. package/dist/components/select.js +49 -0
  325. package/dist/components/select.js.map +1 -0
  326. package/dist/components/select.mjs +4 -0
  327. package/dist/components/select.mjs.map +1 -0
  328. package/dist/components/separator.js +13 -0
  329. package/dist/components/separator.js.map +1 -0
  330. package/dist/components/separator.mjs +4 -0
  331. package/dist/components/separator.mjs.map +1 -0
  332. package/dist/components/sheet.js +49 -0
  333. package/dist/components/sheet.js.map +1 -0
  334. package/dist/components/sheet.mjs +4 -0
  335. package/dist/components/sheet.mjs.map +1 -0
  336. package/dist/components/sidebar.js +111 -0
  337. package/dist/components/sidebar.js.map +1 -0
  338. package/dist/components/sidebar.mjs +10 -0
  339. package/dist/components/sidebar.mjs.map +1 -0
  340. package/dist/components/skeleton.js +13 -0
  341. package/dist/components/skeleton.js.map +1 -0
  342. package/dist/components/skeleton.mjs +4 -0
  343. package/dist/components/skeleton.mjs.map +1 -0
  344. package/dist/components/slider.js +13 -0
  345. package/dist/components/slider.js.map +1 -0
  346. package/dist/components/slider.mjs +4 -0
  347. package/dist/components/slider.mjs.map +1 -0
  348. package/dist/components/switch.js +13 -0
  349. package/dist/components/switch.js.map +1 -0
  350. package/dist/components/switch.mjs +4 -0
  351. package/dist/components/switch.mjs.map +1 -0
  352. package/dist/components/table.js +41 -0
  353. package/dist/components/table.js.map +1 -0
  354. package/dist/components/table.mjs +4 -0
  355. package/dist/components/table.mjs.map +1 -0
  356. package/dist/components/tabs.js +25 -0
  357. package/dist/components/tabs.js.map +1 -0
  358. package/dist/components/tabs.mjs +4 -0
  359. package/dist/components/tabs.mjs.map +1 -0
  360. package/dist/components/textarea.js +13 -0
  361. package/dist/components/textarea.js.map +1 -0
  362. package/dist/components/textarea.mjs +4 -0
  363. package/dist/components/textarea.mjs.map +1 -0
  364. package/dist/components/toast.js +37 -0
  365. package/dist/components/toast.js.map +1 -0
  366. package/dist/components/toast.mjs +4 -0
  367. package/dist/components/toast.mjs.map +1 -0
  368. package/dist/components/toggle-group.js +18 -0
  369. package/dist/components/toggle-group.js.map +1 -0
  370. package/dist/components/toggle-group.mjs +5 -0
  371. package/dist/components/toggle-group.mjs.map +1 -0
  372. package/dist/components/toggle.js +17 -0
  373. package/dist/components/toggle.js.map +1 -0
  374. package/dist/components/toggle.mjs +4 -0
  375. package/dist/components/toggle.mjs.map +1 -0
  376. package/dist/components/tooltip.js +25 -0
  377. package/dist/components/tooltip.js.map +1 -0
  378. package/dist/components/tooltip.mjs +4 -0
  379. package/dist/components/tooltip.mjs.map +1 -0
  380. package/dist/effects/index.js +162 -0
  381. package/dist/effects/index.js.map +1 -0
  382. package/dist/effects/index.mjs +156 -0
  383. package/dist/effects/index.mjs.map +1 -0
  384. package/dist/index.js +1096 -9353
  385. package/dist/index.js.map +1 -0
  386. package/dist/index.mjs +47 -9342
  387. package/dist/index.mjs.map +1 -0
  388. package/dist/lib/utils.js +10 -45
  389. package/dist/lib/utils.js.map +1 -0
  390. package/dist/lib/utils.mjs +3 -28
  391. package/dist/lib/utils.mjs.map +1 -0
  392. package/dist/markdown/index.js +669 -0
  393. package/dist/markdown/index.js.map +1 -0
  394. package/dist/markdown/index.mjs +635 -0
  395. package/dist/markdown/index.mjs.map +1 -0
  396. package/dist/qr/index.js +101 -0
  397. package/dist/qr/index.js.map +1 -0
  398. package/dist/qr/index.mjs +98 -0
  399. package/dist/qr/index.mjs.map +1 -0
  400. package/dist/upload/index.js +166 -0
  401. package/dist/upload/index.js.map +1 -0
  402. package/dist/upload/index.mjs +163 -0
  403. package/dist/upload/index.mjs.map +1 -0
  404. package/package.json +153 -270
  405. package/publish.sh +27 -0
  406. package/assets/ai-icons.tsx +0 -207
  407. package/assets/crypto.tsx +0 -33
  408. package/assets/file-type-icon.tsx +0 -66
  409. package/assets/file.tsx +0 -45
  410. package/assets/general.tsx +0 -2318
  411. package/assets/hanzo-logo.svg +0 -9
  412. package/assets/hanzo-logo.tsx +0 -17
  413. package/assets/index.ts +0 -122
  414. package/assets/index.tsx +0 -4
  415. package/assets/llm-provider.tsx +0 -1094
  416. package/bin/cli.js +0 -100
  417. package/bin/create-registry.js +0 -108
  418. package/bin/mcp.js +0 -403
  419. package/bin/npx-registry-mcp.js +0 -15
  420. package/bin/registry-mcp-wrapper.sh +0 -19
  421. package/bin/registry-mcp.js +0 -100
  422. package/bin/start-mcp-server.sh +0 -22
  423. package/bin/test-mcp.sh +0 -52
  424. package/bin/update-registry.js +0 -196
  425. package/blocks/auth/index.ts +0 -6
  426. package/blocks/auth/login-2fa.tsx +0 -165
  427. package/blocks/auth/login-basic.tsx +0 -94
  428. package/blocks/auth/login-social.tsx +0 -148
  429. package/blocks/auth/magic-link.tsx +0 -129
  430. package/blocks/auth/password-reset.tsx +0 -97
  431. package/blocks/auth/signup.tsx +0 -157
  432. package/blocks/components/accordian-block.tsx +0 -48
  433. package/blocks/components/block-component-props.ts +0 -11
  434. package/blocks/components/bullet-cards-block.tsx +0 -46
  435. package/blocks/components/card-block/index.tsx +0 -171
  436. package/blocks/components/card-block/link-out-button.tsx +0 -20
  437. package/blocks/components/card-block/util.ts +0 -28
  438. package/blocks/components/carte-blanche-block/index.tsx +0 -127
  439. package/blocks/components/carte-blanche-block/variant-content-left.tsx +0 -49
  440. package/blocks/components/content.tsx +0 -70
  441. package/blocks/components/cta-block.tsx +0 -115
  442. package/blocks/components/enh-heading-block.tsx +0 -204
  443. package/blocks/components/grid-block/grid-block-mutator.ts +0 -12
  444. package/blocks/components/grid-block/index.tsx +0 -83
  445. package/blocks/components/grid-block/mutator-registry.ts +0 -10
  446. package/blocks/components/grid-block/table-borders.mutator.ts +0 -47
  447. package/blocks/components/group-block.tsx +0 -83
  448. package/blocks/components/heading-block.tsx +0 -88
  449. package/blocks/components/image-block.tsx +0 -111
  450. package/blocks/components/index.ts +0 -30
  451. package/blocks/components/screenful-block/content.tsx +0 -123
  452. package/blocks/components/screenful-block/index.tsx +0 -107
  453. package/blocks/components/screenful-block/poster-background.tsx +0 -34
  454. package/blocks/components/screenful-block/video-background.tsx +0 -45
  455. package/blocks/components/space-block.tsx +0 -66
  456. package/blocks/components/video-block.tsx +0 -138
  457. package/blocks/data-display/activity-feed.tsx +0 -242
  458. package/blocks/data-display/data-table.tsx +0 -235
  459. package/blocks/data-display/stats-grid.tsx +0 -194
  460. package/blocks/def/accordian-block.ts +0 -14
  461. package/blocks/def/block.ts +0 -7
  462. package/blocks/def/bullet-cards-block.ts +0 -22
  463. package/blocks/def/card-block.ts +0 -22
  464. package/blocks/def/carte-blanche-block.ts +0 -21
  465. package/blocks/def/cta-block.ts +0 -19
  466. package/blocks/def/element-block.ts +0 -11
  467. package/blocks/def/enh-heading-block.ts +0 -44
  468. package/blocks/def/grid-block.ts +0 -16
  469. package/blocks/def/group-block.ts +0 -11
  470. package/blocks/def/heading-block.ts +0 -15
  471. package/blocks/def/image-block.ts +0 -31
  472. package/blocks/def/index.ts +0 -35
  473. package/blocks/def/screenful-block.ts +0 -54
  474. package/blocks/def/space-block.ts +0 -64
  475. package/blocks/def/video-block.ts +0 -9
  476. package/blocks/ecommerce/checkout.tsx +0 -242
  477. package/blocks/ecommerce/index.ts +0 -7
  478. package/blocks/ecommerce/product-detail.tsx +0 -257
  479. package/blocks/ecommerce/product-grid.tsx +0 -148
  480. package/blocks/ecommerce/shopping-cart.tsx +0 -181
  481. package/blocks/index.ts +0 -2
  482. package/blocks/marketing/cta-section.tsx +0 -207
  483. package/blocks/marketing/faq.tsx +0 -159
  484. package/blocks/marketing/features-grid.tsx +0 -156
  485. package/blocks/marketing/hero-section.tsx +0 -192
  486. package/blocks/marketing/index.ts +0 -6
  487. package/blocks/marketing/pricing-table.tsx +0 -121
  488. package/blocks/marketing/testimonials.tsx +0 -196
  489. package/components/index.ts +0 -9
  490. package/dist/src/utils.js +0 -47
  491. package/dist/src/utils.mjs +0 -28
  492. package/dist/tailwind/index.js +0 -2050
  493. package/dist/tailwind/index.mjs +0 -2019
  494. package/dist/types/index.js +0 -79
  495. package/dist/types/index.mjs +0 -56
  496. package/dist/util/format-text.js +0 -51
  497. package/dist/util/format-text.mjs +0 -32
  498. package/dist/util/index.js +0 -384
  499. package/dist/util/index.mjs +0 -363
  500. package/frameworks/core/index.ts +0 -6
  501. package/frameworks/core/utils/index.ts +0 -64
  502. package/frameworks/react/components/button.tsx +0 -26
  503. package/frameworks/react/components/index.ts +0 -5
  504. package/frameworks/react/hooks/index.ts +0 -5
  505. package/frameworks/react/index.ts +0 -9
  506. package/frameworks/react/package.json +0 -8
  507. package/frameworks/react/utils/index.ts +0 -2
  508. package/frameworks/react-native/index.ts +0 -9
  509. package/frameworks/react-native/package.json +0 -8
  510. package/frameworks/registry.json +0 -371
  511. package/frameworks/setup.sh +0 -69
  512. package/frameworks/svelte/index.ts +0 -9
  513. package/frameworks/svelte/package.json +0 -8
  514. package/frameworks/tracker.json +0 -1854
  515. package/frameworks/vue/index.ts +0 -9
  516. package/frameworks/vue/package.json +0 -8
  517. package/helpers/file.ts +0 -33
  518. package/helpers/memoization.ts +0 -40
  519. package/primitives/accordion.tsx +0 -74
  520. package/primitives/action-button.tsx +0 -42
  521. package/primitives/alert-dialog.tsx +0 -185
  522. package/primitives/alert.tsx +0 -74
  523. package/primitives/apply-typography.tsx +0 -55
  524. package/primitives/aspect-ratio.tsx +0 -5
  525. package/primitives/avatar.tsx +0 -57
  526. package/primitives/background-beams.tsx +0 -142
  527. package/primitives/badge.tsx +0 -45
  528. package/primitives/breadcrumb.tsx +0 -130
  529. package/primitives/breakpoint-indicator.tsx +0 -19
  530. package/primitives/button.tsx +0 -72
  531. package/primitives/calendar.tsx +0 -72
  532. package/primitives/card.tsx +0 -97
  533. package/primitives/carousel.tsx +0 -238
  534. package/primitives/chat/chat-input-area.tsx +0 -88
  535. package/primitives/chat/chat-input.tsx +0 -71
  536. package/primitives/chat/files-preview.tsx +0 -331
  537. package/primitives/chat/index.ts +0 -6
  538. package/primitives/chat/json-form.tsx +0 -8
  539. package/primitives/chat/message-list.tsx +0 -308
  540. package/primitives/chat/message.tsx +0 -569
  541. package/primitives/chat/sqlite-preview.tsx +0 -215
  542. package/primitives/checkbox.tsx +0 -32
  543. package/primitives/collapsible.tsx +0 -9
  544. package/primitives/combobox.tsx +0 -239
  545. package/primitives/command.tsx +0 -151
  546. package/primitives/context-menu.tsx +0 -206
  547. package/primitives/copy-to-clipboard-icon.tsx +0 -60
  548. package/primitives/dialog-video-controller.tsx +0 -38
  549. package/primitives/dialog.tsx +0 -128
  550. package/primitives/dot-pattern.tsx +0 -57
  551. package/primitives/dots-loader.tsx +0 -13
  552. package/primitives/drawer.tsx +0 -113
  553. package/primitives/dropdown-menu.tsx +0 -199
  554. package/primitives/error-message.tsx +0 -19
  555. package/primitives/file-uploader.tsx +0 -203
  556. package/primitives/form.tsx +0 -185
  557. package/primitives/hover-card.tsx +0 -28
  558. package/primitives/icons/github.tsx +0 -14
  559. package/primitives/icons/index.ts +0 -18
  560. package/primitives/icons/youtube-logo.tsx +0 -59
  561. package/primitives/index-client.ts +0 -4
  562. package/primitives/index-common.ts +0 -304
  563. package/primitives/index-next.ts +0 -4
  564. package/primitives/input-otp.tsx +0 -65
  565. package/primitives/input.tsx +0 -128
  566. package/primitives/label.tsx +0 -21
  567. package/primitives/list-adaptor.ts +0 -12
  568. package/primitives/list-box.tsx +0 -74
  569. package/primitives/loading-spinner.tsx +0 -33
  570. package/primitives/markdown-preview.tsx +0 -612
  571. package/primitives/mermaid.tsx +0 -191
  572. package/primitives/navigation-menu.tsx +0 -147
  573. package/primitives/next/image.tsx +0 -91
  574. package/primitives/next/index.ts +0 -7
  575. package/primitives/next/inline-icon.tsx +0 -36
  576. package/primitives/next/link-element.tsx +0 -109
  577. package/primitives/next/mdx-link.tsx +0 -22
  578. package/primitives/next/media-stack.tsx +0 -52
  579. package/primitives/next/nav-items.tsx +0 -45
  580. package/primitives/next/youtube-embed.tsx +0 -83
  581. package/primitives/pagination.tsx +0 -117
  582. package/primitives/popover.tsx +0 -34
  583. package/primitives/pretty-json-print.tsx +0 -28
  584. package/primitives/progress.tsx +0 -27
  585. package/primitives/prompt-textarea.tsx +0 -72
  586. package/primitives/qr-code.tsx +0 -112
  587. package/primitives/radio-group.tsx +0 -42
  588. package/primitives/resizable.tsx +0 -47
  589. package/primitives/scroll-area.tsx +0 -57
  590. package/primitives/search-input.tsx +0 -66
  591. package/primitives/select.tsx +0 -122
  592. package/primitives/separator.tsx +0 -26
  593. package/primitives/sheet.tsx +0 -139
  594. package/primitives/skeleton.tsx +0 -18
  595. package/primitives/slider.tsx +0 -63
  596. package/primitives/sonner.tsx +0 -35
  597. package/primitives/step-indicator.tsx +0 -69
  598. package/primitives/stepper.tsx +0 -272
  599. package/primitives/switch.tsx +0 -27
  600. package/primitives/table.tsx +0 -105
  601. package/primitives/tabs.tsx +0 -50
  602. package/primitives/text-area.tsx +0 -26
  603. package/primitives/text-link.tsx +0 -25
  604. package/primitives/textarea.tsx +0 -64
  605. package/primitives/textfield.tsx +0 -78
  606. package/primitives/toast.tsx +0 -30
  607. package/primitives/toggle-group.tsx +0 -63
  608. package/primitives/toggle.tsx +0 -44
  609. package/primitives/tooltip.tsx +0 -47
  610. package/primitives/video-player.tsx +0 -23
  611. package/src/button.ts +0 -1
  612. package/src/hooks/index.ts +0 -7
  613. package/src/hooks/use-click-away.ts +0 -31
  614. package/src/hooks/use-combined-refs.ts +0 -22
  615. package/src/hooks/use-copy-clipboard.ts +0 -30
  616. package/src/hooks/use-debounce.ts +0 -17
  617. package/src/hooks/use-fill-ids.ts +0 -25
  618. package/src/hooks/use-map.ts +0 -26
  619. package/src/hooks/use-measure.ts +0 -42
  620. package/src/hooks/use-reverse-video-playback.ts +0 -43
  621. package/src/hooks/use-scroll-restoration.ts +0 -50
  622. package/src/index-lean.ts +0 -87
  623. package/src/index.ts +0 -54
  624. package/src/mcp/README.md +0 -141
  625. package/src/mcp/enhanced-server.ts +0 -1208
  626. package/src/mcp/index.ts +0 -518
  627. package/src/mcp/package.json +0 -10
  628. package/src/registry/api.ts +0 -164
  629. package/src/registry/index.ts +0 -60
  630. package/src/registry/package.json +0 -10
  631. package/src/utils.ts +0 -19
  632. package/style/drawer.css +0 -163
  633. package/style/globals.css +0 -13
  634. package/style/hanzo-common.css +0 -31
  635. package/style/hanzo-default-colors.css +0 -82
  636. package/style/theme-provider.tsx +0 -20
  637. package/tailwind/colors.tailwind.js +0 -53
  638. package/tailwind/fontFamily.tailwind.ts +0 -7
  639. package/tailwind/fontSize.tailwind.ts +0 -13
  640. package/tailwind/index.ts +0 -7
  641. package/tailwind/safelist.tailwind.js +0 -26
  642. package/tailwind/screens.tailwind.js +0 -8
  643. package/tailwind/spacing.tailwind.js +0 -65
  644. package/tailwind/tailwind.config.hanzo-preset.d.ts +0 -5
  645. package/tailwind/tailwind.config.hanzo-preset.js +0 -915
  646. package/tailwind/tw-font-desc.ts +0 -15
  647. package/tailwind/typo-plugin/get-plugin-styles.js +0 -679
  648. package/tailwind/typo-plugin/index.d.ts +0 -9
  649. package/tailwind/typo-plugin/index.js +0 -141
  650. package/tailwind/typo-plugin/utils.js +0 -60
  651. package/tailwind/typography-test.mdx +0 -35
  652. package/tailwind/z-index.tailwind.js +0 -71
  653. package/types/animation-def.ts +0 -3
  654. package/types/breakpoints.ts +0 -11
  655. package/types/bullet-item.ts +0 -10
  656. package/types/button-def.ts +0 -39
  657. package/types/dimensions.ts +0 -8
  658. package/types/grid-def.ts +0 -56
  659. package/types/image-def.ts +0 -32
  660. package/types/index.ts +0 -30
  661. package/types/link-def.ts +0 -56
  662. package/types/media-stack-def.ts +0 -31
  663. package/types/t-shirt-size.ts +0 -5
  664. package/types/tshirt-dimensions.ts +0 -20
  665. package/types/video-def.ts +0 -25
  666. package/util/blob.ts +0 -33
  667. package/util/copy-to-clipboard.ts +0 -17
  668. package/util/create-shadow-root.ts +0 -22
  669. package/util/date.ts +0 -84
  670. package/util/debounce.ts +0 -11
  671. package/util/file.ts +0 -15
  672. package/util/format-and-abbreviate-as-currency.ts +0 -125
  673. package/util/format-text.ts +0 -34
  674. package/util/format-to-max-char.ts +0 -68
  675. package/util/index-client.ts +0 -3
  676. package/util/index.ts +0 -112
  677. package/util/number-abbreviate.ts +0 -49
  678. package/util/specifier.ts +0 -43
  679. package/util/spread-to-transform.ts +0 -25
  680. package/util/step-animation.ts +0 -90
  681. package/util/timing.ts +0 -3
  682. package/util/toasts.tsx +0 -17
  683. package/util/two-way-map.ts +0 -19
@@ -0,0 +1,901 @@
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