@zentauri-ui/zentauri-components 1.6.2 → 1.7.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 (492) hide show
  1. package/README.md +105 -0
  2. package/cli/cli.integration.test.ts +8 -0
  3. package/cli/index.mjs +46 -1
  4. package/dist/charts/area.js +11 -10
  5. package/dist/charts/area.js.map +1 -1
  6. package/dist/charts/area.mjs +4 -3
  7. package/dist/charts/area.mjs.map +1 -1
  8. package/dist/charts/bar.js +10 -9
  9. package/dist/charts/bar.js.map +1 -1
  10. package/dist/charts/bar.mjs +4 -3
  11. package/dist/charts/bar.mjs.map +1 -1
  12. package/dist/charts/bubble.js +10 -9
  13. package/dist/charts/bubble.js.map +1 -1
  14. package/dist/charts/bubble.mjs +4 -3
  15. package/dist/charts/bubble.mjs.map +1 -1
  16. package/dist/charts/line.js +10 -9
  17. package/dist/charts/line.js.map +1 -1
  18. package/dist/charts/line.mjs +4 -3
  19. package/dist/charts/line.mjs.map +1 -1
  20. package/dist/charts/pie.js +6 -5
  21. package/dist/charts/pie.js.map +1 -1
  22. package/dist/charts/pie.mjs +3 -2
  23. package/dist/charts/pie.mjs.map +1 -1
  24. package/dist/charts/shared/chart-frame.d.ts.map +1 -1
  25. package/dist/{chunk-QSIJKHC5.mjs → chunk-4XVNQ7IY.mjs} +223 -214
  26. package/dist/chunk-4XVNQ7IY.mjs.map +1 -0
  27. package/dist/chunk-4ZKBLVQX.js +248 -0
  28. package/dist/chunk-4ZKBLVQX.js.map +1 -0
  29. package/dist/chunk-ABOZ5QIX.js +84 -0
  30. package/dist/chunk-ABOZ5QIX.js.map +1 -0
  31. package/dist/chunk-ACGVDY5J.mjs +220 -0
  32. package/dist/chunk-ACGVDY5J.mjs.map +1 -0
  33. package/dist/{chunk-PPVJ4INP.mjs → chunk-ASJQP53L.mjs} +3 -3
  34. package/dist/{chunk-PPVJ4INP.mjs.map → chunk-ASJQP53L.mjs.map} +1 -1
  35. package/dist/{chunk-D55YIHBN.js → chunk-BTJYXKCW.js} +223 -214
  36. package/dist/chunk-BTJYXKCW.js.map +1 -0
  37. package/dist/{chunk-MM3P52WS.js → chunk-CL55KGDF.js} +56 -52
  38. package/dist/chunk-CL55KGDF.js.map +1 -0
  39. package/dist/chunk-CSFLMMAT.mjs +198 -0
  40. package/dist/chunk-CSFLMMAT.mjs.map +1 -0
  41. package/dist/chunk-EDARAO7X.js +206 -0
  42. package/dist/chunk-EDARAO7X.js.map +1 -0
  43. package/dist/chunk-EIRCCTNA.js +175 -0
  44. package/dist/chunk-EIRCCTNA.js.map +1 -0
  45. package/dist/chunk-EN4VLNBF.js +197 -0
  46. package/dist/chunk-EN4VLNBF.js.map +1 -0
  47. package/dist/chunk-FHLZH3PB.mjs +326 -0
  48. package/dist/chunk-FHLZH3PB.mjs.map +1 -0
  49. package/dist/chunk-FXYPRPAT.mjs +35 -0
  50. package/dist/chunk-FXYPRPAT.mjs.map +1 -0
  51. package/dist/{chunk-SPX2QDIB.mjs → chunk-G2WARVAM.mjs} +8 -4
  52. package/dist/chunk-G2WARVAM.mjs.map +1 -0
  53. package/dist/chunk-HCGSEPOD.mjs +196 -0
  54. package/dist/chunk-HCGSEPOD.mjs.map +1 -0
  55. package/dist/chunk-HDO5ZM2S.mjs +82 -0
  56. package/dist/chunk-HDO5ZM2S.mjs.map +1 -0
  57. package/dist/chunk-HMNIH3KJ.mjs +277 -0
  58. package/dist/chunk-HMNIH3KJ.mjs.map +1 -0
  59. package/dist/chunk-HNLQXHSQ.mjs +263 -0
  60. package/dist/chunk-HNLQXHSQ.mjs.map +1 -0
  61. package/dist/{chunk-M6FS7X54.mjs → chunk-ITVMSCOJ.mjs} +56 -52
  62. package/dist/chunk-ITVMSCOJ.mjs.map +1 -0
  63. package/dist/chunk-K7TCW5PJ.js +338 -0
  64. package/dist/chunk-K7TCW5PJ.js.map +1 -0
  65. package/dist/chunk-KTGV76M3.mjs +325 -0
  66. package/dist/chunk-KTGV76M3.mjs.map +1 -0
  67. package/dist/{chunk-JOMSI4WH.js → chunk-NFEA5TN2.js} +52 -47
  68. package/dist/chunk-NFEA5TN2.js.map +1 -0
  69. package/dist/chunk-NHQ3S4Y6.mjs +282 -0
  70. package/dist/chunk-NHQ3S4Y6.mjs.map +1 -0
  71. package/dist/{chunk-OVTWPGMW.mjs → chunk-NMQAHUYA.mjs} +52 -47
  72. package/dist/chunk-NMQAHUYA.mjs.map +1 -0
  73. package/dist/{chunk-MWR5DIA5.mjs → chunk-OULU7OC4.mjs} +3 -3
  74. package/dist/{chunk-MWR5DIA5.mjs.map → chunk-OULU7OC4.mjs.map} +1 -1
  75. package/dist/chunk-OZHETX4J.mjs +169 -0
  76. package/dist/chunk-OZHETX4J.mjs.map +1 -0
  77. package/dist/chunk-OZMSE44N.mjs +235 -0
  78. package/dist/chunk-OZMSE44N.mjs.map +1 -0
  79. package/dist/chunk-P5WLYJ2C.mjs +272 -0
  80. package/dist/chunk-P5WLYJ2C.mjs.map +1 -0
  81. package/dist/chunk-PMWRJ2KS.mjs +192 -0
  82. package/dist/chunk-PMWRJ2KS.mjs.map +1 -0
  83. package/dist/chunk-PR4QXFJT.js +132 -0
  84. package/dist/chunk-PR4QXFJT.js.map +1 -0
  85. package/dist/chunk-QAJOE3HJ.js +281 -0
  86. package/dist/chunk-QAJOE3HJ.js.map +1 -0
  87. package/dist/chunk-QBPVJH4P.mjs +128 -0
  88. package/dist/chunk-QBPVJH4P.mjs.map +1 -0
  89. package/dist/{chunk-MTJRPLMG.js → chunk-QNUDODDX.js} +8 -4
  90. package/dist/chunk-QNUDODDX.js.map +1 -0
  91. package/dist/{chunk-DO2LEXUY.js → chunk-QQ6F4LZK.js} +5 -5
  92. package/dist/{chunk-DO2LEXUY.js.map → chunk-QQ6F4LZK.js.map} +1 -1
  93. package/dist/chunk-QXHS3HHZ.mjs +340 -0
  94. package/dist/chunk-QXHS3HHZ.mjs.map +1 -0
  95. package/dist/chunk-QYLTKBH7.js +338 -0
  96. package/dist/chunk-QYLTKBH7.js.map +1 -0
  97. package/dist/chunk-TTTYW3TR.js +207 -0
  98. package/dist/chunk-TTTYW3TR.js.map +1 -0
  99. package/dist/chunk-W3QRRWQX.js +37 -0
  100. package/dist/chunk-W3QRRWQX.js.map +1 -0
  101. package/dist/chunk-WPXQHWPV.js +232 -0
  102. package/dist/chunk-WPXQHWPV.js.map +1 -0
  103. package/dist/chunk-XRDVD2EN.js +288 -0
  104. package/dist/chunk-XRDVD2EN.js.map +1 -0
  105. package/dist/chunk-XYEMP4K7.js +273 -0
  106. package/dist/chunk-XYEMP4K7.js.map +1 -0
  107. package/dist/chunk-YAO62VH2.js +342 -0
  108. package/dist/chunk-YAO62VH2.js.map +1 -0
  109. package/dist/{chunk-PVTTWOYV.js → chunk-Z6S36PDD.js} +7 -7
  110. package/dist/{chunk-PVTTWOYV.js.map → chunk-Z6S36PDD.js.map} +1 -1
  111. package/dist/chunk-ZYKJC5HH.js +296 -0
  112. package/dist/chunk-ZYKJC5HH.js.map +1 -0
  113. package/dist/design-system/accordion.d.ts +70 -0
  114. package/dist/design-system/accordion.d.ts.map +1 -0
  115. package/dist/design-system/alert.d.ts +39 -0
  116. package/dist/design-system/alert.d.ts.map +1 -0
  117. package/dist/design-system/avatar.d.ts +36 -0
  118. package/dist/design-system/avatar.d.ts.map +1 -0
  119. package/dist/design-system/badge.d.ts +71 -0
  120. package/dist/design-system/badge.d.ts.map +1 -0
  121. package/dist/design-system/breadcrumb.d.ts +27 -0
  122. package/dist/design-system/breadcrumb.d.ts.map +1 -0
  123. package/dist/design-system/button.d.ts +48 -0
  124. package/dist/design-system/button.d.ts.map +1 -0
  125. package/dist/design-system/card.d.ts +65 -0
  126. package/dist/design-system/card.d.ts.map +1 -0
  127. package/dist/design-system/divider.d.ts +45 -0
  128. package/dist/design-system/divider.d.ts.map +1 -0
  129. package/dist/design-system/drawer.d.ts +67 -0
  130. package/dist/design-system/drawer.d.ts.map +1 -0
  131. package/dist/design-system/dropdown.d.ts +79 -0
  132. package/dist/design-system/dropdown.d.ts.map +1 -0
  133. package/dist/design-system/dynamic-stepper.d.ts +29 -0
  134. package/dist/design-system/dynamic-stepper.d.ts.map +1 -0
  135. package/dist/design-system/empty-state.d.ts +29 -0
  136. package/dist/design-system/empty-state.d.ts.map +1 -0
  137. package/dist/design-system/file-upload.d.ts +19 -0
  138. package/dist/design-system/file-upload.d.ts.map +1 -0
  139. package/dist/design-system/index.d.ts +30 -0
  140. package/dist/design-system/index.d.ts.map +1 -0
  141. package/dist/design-system/inputs.d.ts +31 -0
  142. package/dist/design-system/inputs.d.ts.map +1 -0
  143. package/dist/design-system/modal.d.ts +66 -0
  144. package/dist/design-system/modal.d.ts.map +1 -0
  145. package/dist/design-system/pagination.d.ts +65 -0
  146. package/dist/design-system/pagination.d.ts.map +1 -0
  147. package/dist/design-system/progress.d.ts +57 -0
  148. package/dist/design-system/progress.d.ts.map +1 -0
  149. package/dist/design-system/select.d.ts +92 -0
  150. package/dist/design-system/select.d.ts.map +1 -0
  151. package/dist/design-system/skeleton.d.ts +104 -0
  152. package/dist/design-system/skeleton.d.ts.map +1 -0
  153. package/dist/design-system/slider.d.ts +44 -0
  154. package/dist/design-system/slider.d.ts.map +1 -0
  155. package/dist/design-system/spinner.d.ts +39 -0
  156. package/dist/design-system/spinner.d.ts.map +1 -0
  157. package/dist/design-system/stepper.d.ts +42 -0
  158. package/dist/design-system/stepper.d.ts.map +1 -0
  159. package/dist/design-system/table.d.ts +77 -0
  160. package/dist/design-system/table.d.ts.map +1 -0
  161. package/dist/design-system/tabs.d.ts +49 -0
  162. package/dist/design-system/tabs.d.ts.map +1 -0
  163. package/dist/design-system/toast.d.ts +43 -0
  164. package/dist/design-system/toast.d.ts.map +1 -0
  165. package/dist/design-system/toggle.d.ts +73 -0
  166. package/dist/design-system/toggle.d.ts.map +1 -0
  167. package/dist/design-system/tokens.d.ts +15 -0
  168. package/dist/design-system/tokens.d.ts.map +1 -0
  169. package/dist/design-system/tooltip.d.ts +41 -0
  170. package/dist/design-system/tooltip.d.ts.map +1 -0
  171. package/dist/design-system/typography.d.ts +42 -0
  172. package/dist/design-system/typography.d.ts.map +1 -0
  173. package/dist/hooks/useResizeObserver.js +6 -31
  174. package/dist/hooks/useResizeObserver.js.map +1 -1
  175. package/dist/hooks/useResizeObserver.mjs +1 -33
  176. package/dist/hooks/useResizeObserver.mjs.map +1 -1
  177. package/dist/ui/accordion/animated.js +7 -7
  178. package/dist/ui/accordion/animated.mjs +2 -2
  179. package/dist/ui/accordion/variants.d.ts +5 -5
  180. package/dist/ui/accordion/variants.d.ts.map +1 -1
  181. package/dist/ui/accordion.js +9 -9
  182. package/dist/ui/accordion.mjs +2 -2
  183. package/dist/ui/alert/animated.js +2 -2
  184. package/dist/ui/alert/animated.mjs +1 -1
  185. package/dist/ui/alert/variants.d.ts +4 -4
  186. package/dist/ui/alert/variants.d.ts.map +1 -1
  187. package/dist/ui/alert.js +10 -10
  188. package/dist/ui/alert.mjs +2 -2
  189. package/dist/ui/avatar/animated.js +5 -5
  190. package/dist/ui/avatar/animated.mjs +2 -2
  191. package/dist/ui/avatar/variants.d.ts +1 -1
  192. package/dist/ui/avatar/variants.d.ts.map +1 -1
  193. package/dist/ui/avatar.js +9 -9
  194. package/dist/ui/avatar.mjs +2 -2
  195. package/dist/ui/badge/animated.js +2 -2
  196. package/dist/ui/badge/animated.mjs +1 -1
  197. package/dist/ui/badge/variants.d.ts +29 -32
  198. package/dist/ui/badge/variants.d.ts.map +1 -1
  199. package/dist/ui/badge.js +4 -4
  200. package/dist/ui/badge.mjs +2 -2
  201. package/dist/ui/breadcrumb/variants.d.ts +1 -1
  202. package/dist/ui/breadcrumb/variants.d.ts.map +1 -1
  203. package/dist/ui/breadcrumb.js +42 -40
  204. package/dist/ui/breadcrumb.js.map +1 -1
  205. package/dist/ui/breadcrumb.mjs +42 -40
  206. package/dist/ui/breadcrumb.mjs.map +1 -1
  207. package/dist/ui/buttons/animated.js +3 -3
  208. package/dist/ui/buttons/animated.mjs +1 -1
  209. package/dist/ui/buttons/variants.d.ts +2 -2
  210. package/dist/ui/buttons/variants.d.ts.map +1 -1
  211. package/dist/ui/buttons.js +4 -4
  212. package/dist/ui/buttons.mjs +2 -2
  213. package/dist/ui/card/animated.js +7 -7
  214. package/dist/ui/card/animated.mjs +2 -2
  215. package/dist/ui/card/variants.d.ts +7 -7
  216. package/dist/ui/card/variants.d.ts.map +1 -1
  217. package/dist/ui/card.js +12 -12
  218. package/dist/ui/card.mjs +2 -2
  219. package/dist/ui/divider/animated.js +2 -2
  220. package/dist/ui/divider/animated.mjs +1 -1
  221. package/dist/ui/divider/variants.d.ts +4 -4
  222. package/dist/ui/divider/variants.d.ts.map +1 -1
  223. package/dist/ui/divider.js +6 -6
  224. package/dist/ui/divider.mjs +2 -2
  225. package/dist/ui/drawer/animated.js +11 -11
  226. package/dist/ui/drawer/animated.mjs +2 -2
  227. package/dist/ui/drawer/variants.d.ts +1 -1
  228. package/dist/ui/drawer/variants.d.ts.map +1 -1
  229. package/dist/ui/drawer.js +11 -11
  230. package/dist/ui/drawer.mjs +1 -1
  231. package/dist/ui/dropdown/variants.d.ts +4 -4
  232. package/dist/ui/dropdown/variants.d.ts.map +1 -1
  233. package/dist/ui/dropdown.js +106 -104
  234. package/dist/ui/dropdown.js.map +1 -1
  235. package/dist/ui/dropdown.mjs +106 -104
  236. package/dist/ui/dropdown.mjs.map +1 -1
  237. package/dist/ui/dynamic-stepper/variants.d.ts +5 -9
  238. package/dist/ui/dynamic-stepper/variants.d.ts.map +1 -1
  239. package/dist/ui/dynamic-stepper.js +100 -93
  240. package/dist/ui/dynamic-stepper.js.map +1 -1
  241. package/dist/ui/dynamic-stepper.mjs +98 -91
  242. package/dist/ui/dynamic-stepper.mjs.map +1 -1
  243. package/dist/ui/empty-state/animated.js +2 -2
  244. package/dist/ui/empty-state/animated.mjs +1 -1
  245. package/dist/ui/empty-state/variants.d.ts +3 -3
  246. package/dist/ui/empty-state/variants.d.ts.map +1 -1
  247. package/dist/ui/empty-state.js +10 -10
  248. package/dist/ui/empty-state.mjs +2 -2
  249. package/dist/ui/file-upload/variants.d.ts.map +1 -1
  250. package/dist/ui/file-upload.js +28 -26
  251. package/dist/ui/file-upload.js.map +1 -1
  252. package/dist/ui/file-upload.mjs +28 -26
  253. package/dist/ui/file-upload.mjs.map +1 -1
  254. package/dist/ui/inputs/animated.js +3 -3
  255. package/dist/ui/inputs/animated.mjs +1 -1
  256. package/dist/ui/inputs/variants.d.ts +1 -1
  257. package/dist/ui/inputs/variants.d.ts.map +1 -1
  258. package/dist/ui/inputs.js +4 -4
  259. package/dist/ui/inputs.mjs +2 -2
  260. package/dist/ui/modal/animated.js +4 -4
  261. package/dist/ui/modal/animated.mjs +1 -1
  262. package/dist/ui/modal/variants.d.ts +1 -1
  263. package/dist/ui/modal/variants.d.ts.map +1 -1
  264. package/dist/ui/modal.js +12 -12
  265. package/dist/ui/modal.mjs +2 -2
  266. package/dist/ui/pagination/variants.d.ts +3 -7
  267. package/dist/ui/pagination/variants.d.ts.map +1 -1
  268. package/dist/ui/pagination.js +84 -84
  269. package/dist/ui/pagination.js.map +1 -1
  270. package/dist/ui/pagination.mjs +81 -81
  271. package/dist/ui/pagination.mjs.map +1 -1
  272. package/dist/ui/progress/animated.js +8 -8
  273. package/dist/ui/progress/animated.mjs +2 -2
  274. package/dist/ui/progress/variants.d.ts +3 -3
  275. package/dist/ui/progress/variants.d.ts.map +1 -1
  276. package/dist/ui/progress.js +9 -9
  277. package/dist/ui/progress.mjs +2 -2
  278. package/dist/ui/search.js +2 -2
  279. package/dist/ui/search.mjs +1 -1
  280. package/dist/ui/select/variants.d.ts +6 -6
  281. package/dist/ui/select/variants.d.ts.map +1 -1
  282. package/dist/ui/select.js +122 -123
  283. package/dist/ui/select.js.map +1 -1
  284. package/dist/ui/select.mjs +122 -123
  285. package/dist/ui/select.mjs.map +1 -1
  286. package/dist/ui/skeleton/animated.js +8 -8
  287. package/dist/ui/skeleton/animated.mjs +1 -1
  288. package/dist/ui/skeleton/variants.d.ts +5 -4
  289. package/dist/ui/skeleton/variants.d.ts.map +1 -1
  290. package/dist/ui/skeleton.js +9 -9
  291. package/dist/ui/skeleton.mjs +1 -1
  292. package/dist/ui/slider/variants.d.ts +3 -3
  293. package/dist/ui/slider/variants.d.ts.map +1 -1
  294. package/dist/ui/slider.js +69 -67
  295. package/dist/ui/slider.js.map +1 -1
  296. package/dist/ui/slider.mjs +69 -67
  297. package/dist/ui/slider.mjs.map +1 -1
  298. package/dist/ui/spinner/animated/variants.d.ts +2 -2
  299. package/dist/ui/spinner/animated/variants.d.ts.map +1 -1
  300. package/dist/ui/spinner/animated.js +44 -38
  301. package/dist/ui/spinner/animated.js.map +1 -1
  302. package/dist/ui/spinner/animated.mjs +44 -38
  303. package/dist/ui/spinner/animated.mjs.map +1 -1
  304. package/dist/ui/stepper/variants.d.ts +1 -1
  305. package/dist/ui/stepper/variants.d.ts.map +1 -1
  306. package/dist/ui/stepper.js +57 -50
  307. package/dist/ui/stepper.js.map +1 -1
  308. package/dist/ui/stepper.mjs +57 -50
  309. package/dist/ui/stepper.mjs.map +1 -1
  310. package/dist/ui/table/animated.js +8 -8
  311. package/dist/ui/table/animated.mjs +2 -2
  312. package/dist/ui/table/variants.d.ts +2 -2
  313. package/dist/ui/table/variants.d.ts.map +1 -1
  314. package/dist/ui/table.js +14 -14
  315. package/dist/ui/table.mjs +1 -1
  316. package/dist/ui/tabs/animated.js +2 -2
  317. package/dist/ui/tabs/animated.mjs +1 -1
  318. package/dist/ui/tabs/variants.d.ts +2 -2
  319. package/dist/ui/tabs/variants.d.ts.map +1 -1
  320. package/dist/ui/tabs.js +9 -9
  321. package/dist/ui/tabs.mjs +1 -1
  322. package/dist/ui/toast/animated.js +7 -7
  323. package/dist/ui/toast/animated.mjs +1 -1
  324. package/dist/ui/toast/variants.d.ts +3 -3
  325. package/dist/ui/toast/variants.d.ts.map +1 -1
  326. package/dist/ui/toast.js +12 -12
  327. package/dist/ui/toast.mjs +1 -1
  328. package/dist/ui/toggle/animated/toggle-animated.d.ts.map +1 -1
  329. package/dist/ui/toggle/animated.js +13 -6
  330. package/dist/ui/toggle/animated.js.map +1 -1
  331. package/dist/ui/toggle/animated.mjs +12 -5
  332. package/dist/ui/toggle/animated.mjs.map +1 -1
  333. package/dist/ui/toggle/toggle-base.d.ts +2 -0
  334. package/dist/ui/toggle/toggle-base.d.ts.map +1 -1
  335. package/dist/ui/toggle/variants.d.ts +4 -4
  336. package/dist/ui/toggle/variants.d.ts.map +1 -1
  337. package/dist/ui/toggle.js +5 -94
  338. package/dist/ui/toggle.js.map +1 -1
  339. package/dist/ui/toggle.mjs +4 -93
  340. package/dist/ui/toggle.mjs.map +1 -1
  341. package/dist/ui/tooltip/animated.js +3 -3
  342. package/dist/ui/tooltip/animated.mjs +1 -1
  343. package/dist/ui/tooltip/variants.d.ts +3 -3
  344. package/dist/ui/tooltip/variants.d.ts.map +1 -1
  345. package/dist/ui/tooltip.js +7 -7
  346. package/dist/ui/tooltip.mjs +1 -1
  347. package/dist/ui/typography/variants.d.ts +1 -3
  348. package/dist/ui/typography/variants.d.ts.map +1 -1
  349. package/dist/ui/typography.js +51 -41
  350. package/dist/ui/typography.js.map +1 -1
  351. package/dist/ui/typography.mjs +51 -41
  352. package/dist/ui/typography.mjs.map +1 -1
  353. package/package.json +2 -1
  354. package/src/charts/shared/chart-frame.tsx +19 -8
  355. package/src/design-system/accordion.ts +111 -0
  356. package/src/design-system/alert.ts +64 -0
  357. package/src/design-system/avatar.ts +61 -0
  358. package/src/design-system/badge.ts +85 -0
  359. package/src/design-system/breadcrumb.ts +45 -0
  360. package/src/design-system/button.ts +81 -0
  361. package/src/design-system/card.ts +104 -0
  362. package/src/design-system/divider.ts +73 -0
  363. package/src/design-system/drawer.ts +111 -0
  364. package/src/design-system/dropdown.ts +130 -0
  365. package/src/design-system/dynamic-stepper.ts +218 -0
  366. package/src/design-system/empty-state.ts +39 -0
  367. package/src/design-system/file-upload.ts +30 -0
  368. package/src/design-system/index.ts +29 -0
  369. package/src/design-system/inputs.ts +74 -0
  370. package/src/design-system/modal.ts +110 -0
  371. package/src/design-system/pagination.ts +92 -0
  372. package/src/design-system/progress.ts +86 -0
  373. package/src/design-system/select.ts +155 -0
  374. package/src/design-system/skeleton.ts +129 -0
  375. package/src/design-system/slider.ts +70 -0
  376. package/src/design-system/spinner.ts +59 -0
  377. package/src/design-system/stepper.ts +66 -0
  378. package/src/design-system/table.ts +115 -0
  379. package/src/design-system/tabs.ts +73 -0
  380. package/src/design-system/toast.ts +69 -0
  381. package/src/design-system/toggle.ts +120 -0
  382. package/src/design-system/tokens.ts +22 -0
  383. package/src/design-system/tooltip.ts +63 -0
  384. package/src/design-system/typography.ts +64 -0
  385. package/src/ui/accordion/variants.ts +24 -106
  386. package/src/ui/alert/alert.test.tsx +1 -1
  387. package/src/ui/alert/variants.ts +25 -77
  388. package/src/ui/avatar/variants.ts +21 -66
  389. package/src/ui/badge/badge.test.tsx +1 -1
  390. package/src/ui/badge/variants.ts +28 -89
  391. package/src/ui/breadcrumb/variants.ts +24 -40
  392. package/src/ui/buttons/button.test.tsx +25 -5
  393. package/src/ui/buttons/variants.ts +15 -84
  394. package/src/ui/card/card.test.tsx +1 -1
  395. package/src/ui/card/variants.ts +46 -121
  396. package/src/ui/divider/divider-base.tsx +1 -1
  397. package/src/ui/divider/variants.ts +32 -70
  398. package/src/ui/drawer/drawer-base.tsx +1 -1
  399. package/src/ui/drawer/variants.ts +41 -132
  400. package/src/ui/dropdown/variants.ts +36 -142
  401. package/src/ui/dynamic-stepper/variants.ts +32 -216
  402. package/src/ui/empty-state/variants.ts +29 -44
  403. package/src/ui/file-upload/variants.ts +12 -36
  404. package/src/ui/inputs/input.test.tsx +11 -11
  405. package/src/ui/inputs/variants.ts +308 -371
  406. package/src/ui/modal/variants.ts +29 -120
  407. package/src/ui/pagination/pagination.test.tsx +1 -1
  408. package/src/ui/pagination/variants.ts +22 -95
  409. package/src/ui/progress/variants.ts +41 -112
  410. package/src/ui/select/variants.ts +40 -165
  411. package/src/ui/skeleton/variants.ts +154 -250
  412. package/src/ui/slider/variants.ts +34 -67
  413. package/src/ui/spinner/animated/variants.ts +10 -39
  414. package/src/ui/stepper/stepper.test.tsx +12 -4
  415. package/src/ui/stepper/variants.ts +23 -68
  416. package/src/ui/table/variants.ts +36 -106
  417. package/src/ui/tabs/variants.ts +26 -73
  418. package/src/ui/toast/variants.ts +24 -75
  419. package/src/ui/toggle/animated/toggle-animated.tsx +14 -4
  420. package/src/ui/toggle/toggle-base.tsx +3 -7
  421. package/src/ui/toggle/variants.ts +27 -111
  422. package/src/ui/tooltip/variants.ts +18 -57
  423. package/src/ui/typography/typography.test.tsx +1 -1
  424. package/src/ui/typography/variants.ts +17 -54
  425. package/dist/chunk-25EAVVGS.mjs +0 -267
  426. package/dist/chunk-25EAVVGS.mjs.map +0 -1
  427. package/dist/chunk-3OXIZ4ZO.js +0 -175
  428. package/dist/chunk-3OXIZ4ZO.js.map +0 -1
  429. package/dist/chunk-3Z73M5TW.js +0 -273
  430. package/dist/chunk-3Z73M5TW.js.map +0 -1
  431. package/dist/chunk-4F56BLZQ.js +0 -336
  432. package/dist/chunk-4F56BLZQ.js.map +0 -1
  433. package/dist/chunk-4PZIDDC6.js +0 -279
  434. package/dist/chunk-4PZIDDC6.js.map +0 -1
  435. package/dist/chunk-73RHHGIA.mjs +0 -197
  436. package/dist/chunk-73RHHGIA.mjs.map +0 -1
  437. package/dist/chunk-746CV3AN.js +0 -246
  438. package/dist/chunk-746CV3AN.js.map +0 -1
  439. package/dist/chunk-CFTDAGKD.js +0 -130
  440. package/dist/chunk-CFTDAGKD.js.map +0 -1
  441. package/dist/chunk-D55YIHBN.js.map +0 -1
  442. package/dist/chunk-EU63V22F.mjs +0 -126
  443. package/dist/chunk-EU63V22F.mjs.map +0 -1
  444. package/dist/chunk-EZS47EZW.mjs +0 -70
  445. package/dist/chunk-EZS47EZW.mjs.map +0 -1
  446. package/dist/chunk-GHJN3Z3V.js +0 -292
  447. package/dist/chunk-GHJN3Z3V.js.map +0 -1
  448. package/dist/chunk-GIC3J6HR.mjs +0 -196
  449. package/dist/chunk-GIC3J6HR.mjs.map +0 -1
  450. package/dist/chunk-GPAUYUM3.js +0 -232
  451. package/dist/chunk-GPAUYUM3.js.map +0 -1
  452. package/dist/chunk-HARD4NMB.mjs +0 -268
  453. package/dist/chunk-HARD4NMB.mjs.map +0 -1
  454. package/dist/chunk-HV7LVRK3.js +0 -277
  455. package/dist/chunk-HV7LVRK3.js.map +0 -1
  456. package/dist/chunk-J5QJEKY2.mjs +0 -169
  457. package/dist/chunk-J5QJEKY2.mjs.map +0 -1
  458. package/dist/chunk-JE6B3DHW.mjs +0 -220
  459. package/dist/chunk-JE6B3DHW.mjs.map +0 -1
  460. package/dist/chunk-JOMSI4WH.js.map +0 -1
  461. package/dist/chunk-KA5MORDC.js +0 -336
  462. package/dist/chunk-KA5MORDC.js.map +0 -1
  463. package/dist/chunk-LPL6NJ5Q.mjs +0 -264
  464. package/dist/chunk-LPL6NJ5Q.mjs.map +0 -1
  465. package/dist/chunk-M6FS7X54.mjs.map +0 -1
  466. package/dist/chunk-MM3P52WS.js.map +0 -1
  467. package/dist/chunk-MTJRPLMG.js.map +0 -1
  468. package/dist/chunk-OB6TYS5Q.js +0 -205
  469. package/dist/chunk-OB6TYS5Q.js.map +0 -1
  470. package/dist/chunk-OHST7AHC.mjs +0 -99
  471. package/dist/chunk-OHST7AHC.mjs.map +0 -1
  472. package/dist/chunk-OVTWPGMW.mjs.map +0 -1
  473. package/dist/chunk-PSIAOIXJ.mjs +0 -278
  474. package/dist/chunk-PSIAOIXJ.mjs.map +0 -1
  475. package/dist/chunk-QNF4JPFP.js +0 -339
  476. package/dist/chunk-QNF4JPFP.js.map +0 -1
  477. package/dist/chunk-QSIJKHC5.mjs.map +0 -1
  478. package/dist/chunk-RFFGQYDQ.mjs +0 -337
  479. package/dist/chunk-RFFGQYDQ.mjs.map +0 -1
  480. package/dist/chunk-S5H2OMTZ.mjs +0 -233
  481. package/dist/chunk-S5H2OMTZ.mjs.map +0 -1
  482. package/dist/chunk-SPX2QDIB.mjs.map +0 -1
  483. package/dist/chunk-TIPNRH26.js +0 -102
  484. package/dist/chunk-TIPNRH26.js.map +0 -1
  485. package/dist/chunk-V2PEOBAT.mjs +0 -324
  486. package/dist/chunk-V2PEOBAT.mjs.map +0 -1
  487. package/dist/chunk-VGWA26BN.js +0 -72
  488. package/dist/chunk-VGWA26BN.js.map +0 -1
  489. package/dist/chunk-WNLDXBS6.mjs +0 -323
  490. package/dist/chunk-WNLDXBS6.mjs.map +0 -1
  491. package/dist/chunk-YIO7DFUA.js +0 -207
  492. package/dist/chunk-YIO7DFUA.js.map +0 -1
@@ -0,0 +1,207 @@
1
+ 'use strict';
2
+
3
+ var chunkZS5756ZC_js = require('./chunk-ZS5756ZC.js');
4
+ var classVarianceAuthority = require('class-variance-authority');
5
+ var react = require('react');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+
8
+ // src/design-system/avatar.ts
9
+ var zuiAvatarBase = "relative flex shrink-0 overflow-hidden rounded-full border border-[color:var(--zui-avatar-border,#0000001a)] dark:border-[color:var(--zui-avatar-border-dark,#ffffff1a)] text-[color:var(--zui-avatar-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-fg-dark,oklch(92.9%_0.013_255.508))]";
10
+ var zuiAvatarAppearances = {
11
+ default: "border-[color:var(--zui-avatar-default-border,#0000001a)] dark:border-[color:var(--zui-avatar-default-border-dark,#ffffff1a)] bg-[var(--zui-avatar-default-bg,#0000001a)] dark:bg-[var(--zui-avatar-default-bg-dark,#ffffff1a)] text-[color:var(--zui-avatar-default-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-default-fg-dark,oklch(92.9%_0.013_255.508))]",
12
+ muted: "border-[color:var(--zui-avatar-muted-border,#00000066)] bg-[var(--zui-avatar-muted-bg,oklch(98.4%_0.003_247.858))] dark:border-[color:var(--zui-avatar-muted-border-dark,#ffffff1a)] dark:bg-[var(--zui-avatar-muted-bg-dark,oklch(12.9%_0.042_264.695_/_0.4))] text-[color:var(--zui-avatar-muted-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-muted-fg-dark,oklch(92.9%_0.013_255.508))]",
13
+ sky: "border-[color:var(--zui-avatar-sky-border,oklch(44.3%_0.11_240.79))] dark:border-[color:var(--zui-avatar-sky-border-dark,oklch(58.8%_0.158_241.966))] bg-[var(--zui-avatar-sky-bg,oklch(95.1%_0.026_236.824_/_0.5))] dark:bg-[var(--zui-avatar-sky-bg-dark,oklch(58.8%_0.158_241.966_/_0.03))] text-[color:var(--zui-avatar-sky-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-sky-fg-dark,oklch(92.9%_0.013_255.508))]",
14
+ rose: "border-[color:var(--zui-avatar-rose-border,oklch(45.5%_0.188_13.697))] dark:border-[color:var(--zui-avatar-rose-border-dark,oklch(58.6%_0.253_17.585))] bg-[var(--zui-avatar-rose-bg,oklch(94.1%_0.03_12.58_/_0.5))] dark:bg-[var(--zui-avatar-rose-bg-dark,oklch(58.6%_0.253_17.585_/_0.03))] text-[color:var(--zui-avatar-rose-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-rose-fg-dark,oklch(92.9%_0.013_255.508))]",
15
+ purple: "border-[color:var(--zui-avatar-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-avatar-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-[var(--zui-avatar-purple-bg,oklch(94.6%_0.033_307.174_/_0.5))] dark:bg-[var(--zui-avatar-purple-bg-dark,oklch(55.8%_0.288_302.321_/_0.03))] text-[color:var(--zui-avatar-purple-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-purple-fg-dark,oklch(92.9%_0.013_255.508))]",
16
+ pink: "border-[color:var(--zui-avatar-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-avatar-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-[var(--zui-avatar-pink-bg,oklch(94.8%_0.028_342.258_/_0.5))] dark:bg-[var(--zui-avatar-pink-bg-dark,oklch(59.2%_0.249_0.584_/_0.03))] text-[color:var(--zui-avatar-pink-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-pink-fg-dark,oklch(92.9%_0.013_255.508))]",
17
+ orange: "border-[color:var(--zui-avatar-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-avatar-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-[var(--zui-avatar-orange-bg,oklch(95.4%_0.038_75.164_/_0.5))] dark:bg-[var(--zui-avatar-orange-bg-dark,oklch(64.6%_0.222_41.116_/_0.03))] text-[color:var(--zui-avatar-orange-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-orange-fg-dark,oklch(92.9%_0.013_255.508))]",
18
+ yellow: "border-[color:var(--zui-avatar-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-avatar-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-[var(--zui-avatar-yellow-bg,oklch(97.3%_0.071_103.193_/_0.5))] dark:bg-[var(--zui-avatar-yellow-bg-dark,oklch(68.1%_0.162_75.834_/_0.03))] text-[color:var(--zui-avatar-yellow-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-yellow-fg-dark,oklch(92.9%_0.013_255.508))]",
19
+ teal: "border-[color:var(--zui-avatar-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-avatar-teal-border-dark,oklch(60%_0.118_184.704))] bg-[var(--zui-avatar-teal-bg,oklch(95.3%_0.051_180.801_/_0.5))] dark:bg-[var(--zui-avatar-teal-bg-dark,oklch(60%_0.118_184.704_/_0.03))] text-[color:var(--zui-avatar-teal-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-teal-fg-dark,oklch(92.9%_0.013_255.508))]",
20
+ indigo: "border-[color:var(--zui-avatar-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-avatar-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-[var(--zui-avatar-indigo-bg,oklch(93%_0.034_272.788_/_0.5))] dark:bg-[var(--zui-avatar-indigo-bg-dark,oklch(51.1%_0.262_276.966_/_0.03))] text-[color:var(--zui-avatar-indigo-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-indigo-fg-dark,oklch(92.9%_0.013_255.508))]",
21
+ emerald: "border-[color:var(--zui-avatar-emerald-border,oklch(43.2%_0.095_166.913))] dark:border-[color:var(--zui-avatar-emerald-border-dark,oklch(59.6%_0.145_163.225))] bg-[var(--zui-avatar-emerald-bg,oklch(95%_0.052_163.051_/_0.5))] dark:bg-[var(--zui-avatar-emerald-bg-dark,oklch(59.6%_0.145_163.225_/_0.03))] text-[color:var(--zui-avatar-emerald-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-emerald-fg-dark,oklch(92.9%_0.013_255.508))]",
22
+ gray: "border-[color:var(--zui-avatar-gray-border,oklch(27.8%_0.033_256.848))] dark:border-[color:var(--zui-avatar-gray-border-dark,oklch(44.6%_0.03_256.802))] bg-[var(--zui-avatar-gray-bg,oklch(96.7%_0.003_264.542_/_0.5))] dark:bg-[var(--zui-avatar-gray-bg-dark,oklch(44.6%_0.03_256.802_/_0.03))] text-[color:var(--zui-avatar-gray-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gray-fg-dark,oklch(92.9%_0.013_255.508))]",
23
+ amber: "border-[color:var(--zui-avatar-amber-border,oklch(47.3%_0.137_46.201))] dark:border-[color:var(--zui-avatar-amber-border-dark,oklch(66.6%_0.179_58.318))] bg-[var(--zui-avatar-amber-bg,oklch(96.2%_0.059_95.617_/_0.5))] dark:bg-[var(--zui-avatar-amber-bg-dark,oklch(66.6%_0.179_58.318_/_0.03))] text-[color:var(--zui-avatar-amber-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-amber-fg-dark,oklch(92.9%_0.013_255.508))]",
24
+ violet: "border-[color:var(--zui-avatar-violet-border,oklch(43.2%_0.232_292.759))] dark:border-[color:var(--zui-avatar-violet-border-dark,oklch(54.1%_0.281_293.009))] bg-[var(--zui-avatar-violet-bg,oklch(94.3%_0.029_294.588_/_0.5))] dark:bg-[var(--zui-avatar-violet-bg-dark,oklch(54.1%_0.281_293.009_/_0.03))] text-[color:var(--zui-avatar-violet-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-violet-fg-dark,oklch(92.9%_0.013_255.508))]",
25
+ "gradient-blue": "bg-linear-to-r from-[var(--zui-avatar-gradient-blue-from,oklch(62.3%_0.214_259.815))] dark:from-[var(--zui-avatar-gradient-blue-from-dark,oklch(54.6%_0.245_262.881))] to-[var(--zui-avatar-gradient-blue-to,oklch(62.7%_0.265_303.9))] dark:to-[var(--zui-avatar-gradient-blue-to-dark,oklch(55.8%_0.288_302.321))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-blue-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-blue-fg-dark,oklch(92.9%_0.013_255.508))]",
26
+ "gradient-green": "bg-linear-to-r from-[var(--zui-avatar-gradient-green-from,oklch(72.3%_0.219_149.579))] dark:from-[var(--zui-avatar-gradient-green-from-dark,oklch(62.7%_0.194_149.214))] to-[var(--zui-avatar-gradient-green-to,oklch(76.8%_0.233_130.85))] dark:to-[var(--zui-avatar-gradient-green-to-dark,oklch(64.8%_0.2_131.684))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-green-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-green-fg-dark,oklch(92.9%_0.013_255.508))]",
27
+ "gradient-red": "bg-linear-to-r from-[var(--zui-avatar-gradient-red-from,oklch(63.7%_0.237_25.331))] dark:from-[var(--zui-avatar-gradient-red-from-dark,oklch(57.7%_0.245_27.325))] to-[var(--zui-avatar-gradient-red-to,oklch(65.6%_0.241_354.308))] dark:to-[var(--zui-avatar-gradient-red-to-dark,oklch(59.2%_0.249_0.584))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-red-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-red-fg-dark,oklch(92.9%_0.013_255.508))]",
28
+ "gradient-yellow": "bg-linear-to-r from-[var(--zui-avatar-gradient-yellow-from,oklch(79.5%_0.184_86.047))] dark:from-[var(--zui-avatar-gradient-yellow-from-dark,oklch(68.1%_0.162_75.834))] to-[var(--zui-avatar-gradient-yellow-to,oklch(70.5%_0.213_47.604))] dark:to-[var(--zui-avatar-gradient-yellow-to-dark,oklch(64.6%_0.222_41.116))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-yellow-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-yellow-fg-dark,oklch(92.9%_0.013_255.508))]",
29
+ "gradient-purple": "bg-linear-to-r from-[var(--zui-avatar-gradient-purple-from,oklch(62.7%_0.265_303.9))] dark:from-[var(--zui-avatar-gradient-purple-from-dark,oklch(55.8%_0.288_302.321))] to-[var(--zui-avatar-gradient-purple-to,oklch(65.6%_0.241_354.308))] dark:to-[var(--zui-avatar-gradient-purple-to-dark,oklch(59.2%_0.249_0.584))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-purple-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-purple-fg-dark,oklch(92.9%_0.013_255.508))]",
30
+ "gradient-teal": "bg-linear-to-r from-[var(--zui-avatar-gradient-teal-from,oklch(70.4%_0.14_182.503))] dark:from-[var(--zui-avatar-gradient-teal-from-dark,oklch(60%_0.118_184.704))] to-[var(--zui-avatar-gradient-teal-to,oklch(71.5%_0.143_215.221))] dark:to-[var(--zui-avatar-gradient-teal-to-dark,oklch(60.9%_0.126_221.723))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-teal-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-teal-fg-dark,oklch(92.9%_0.013_255.508))]",
31
+ "gradient-indigo": "bg-linear-to-r from-[var(--zui-avatar-gradient-indigo-from,oklch(58.5%_0.233_277.117))] dark:from-[var(--zui-avatar-gradient-indigo-from-dark,oklch(51.1%_0.262_276.966))] to-[var(--zui-avatar-gradient-indigo-to,oklch(62.7%_0.265_303.9))] dark:to-[var(--zui-avatar-gradient-indigo-to-dark,oklch(55.8%_0.288_302.321))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-indigo-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-indigo-fg-dark,oklch(92.9%_0.013_255.508))]",
32
+ "gradient-pink": "bg-linear-to-r from-[var(--zui-avatar-gradient-pink-from,oklch(65.6%_0.241_354.308))] dark:from-[var(--zui-avatar-gradient-pink-from-dark,oklch(59.2%_0.249_0.584))] to-[var(--zui-avatar-gradient-pink-to,oklch(64.5%_0.246_16.439))] dark:to-[var(--zui-avatar-gradient-pink-to-dark,oklch(58.6%_0.253_17.585))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-pink-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-pink-fg-dark,oklch(92.9%_0.013_255.508))]",
33
+ "gradient-orange": "bg-linear-to-r from-[var(--zui-avatar-gradient-orange-from,oklch(70.5%_0.213_47.604))] dark:from-[var(--zui-avatar-gradient-orange-from-dark,oklch(64.6%_0.222_41.116))] to-[var(--zui-avatar-gradient-orange-to,oklch(63.7%_0.237_25.331))] dark:to-[var(--zui-avatar-gradient-orange-to-dark,oklch(57.7%_0.245_27.325))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-orange-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-orange-fg-dark,oklch(92.9%_0.013_255.508))]"
34
+ };
35
+ var zuiAvatarSizes = {
36
+ sm: "size-8 text-xs",
37
+ md: "size-10 text-sm",
38
+ lg: "size-12 text-base",
39
+ xl: "size-16 text-lg"
40
+ };
41
+ var zuiAvatarImageBase = "aspect-square size-full object-cover";
42
+ var zuiAvatarFallbackBase = "flex size-full items-center justify-center bg-[var(--zui-avatar-fallback-bg,oklch(92.9%_0.013_255.508))] dark:bg-[var(--zui-avatar-fallback-bg-dark,oklch(27.9%_0.041_260.031))] font-medium text-[color:var(--zui-avatar-fallback-fg,oklch(27.9%_0.041_260.031))] dark:text-[color:var(--zui-avatar-fallback-fg-dark,oklch(96.8%_0.007_247.896))]";
43
+ var zuiAvatarGroupBase = "flex items-center [&_[data-slot=avatar]]:-ml-2 [&_[data-slot=avatar]]:ring-2 [&_[data-slot=avatar]]:ring-[var(--zui-avatar-group-ring,#ffffff)] dark:[&_[data-slot=avatar]]:ring-[var(--zui-avatar-group-ring-dark,oklch(12.9%_0.042_264.695))] [&_[data-slot=avatar]]:first:ml-0";
44
+
45
+ // src/ui/avatar/variants.ts
46
+ var avatarVariants = classVarianceAuthority.cva(zuiAvatarBase, {
47
+ variants: {
48
+ appearance: zuiAvatarAppearances,
49
+ size: zuiAvatarSizes
50
+ },
51
+ defaultVariants: {
52
+ size: "md",
53
+ appearance: "default"
54
+ }
55
+ });
56
+ var avatarImageVariants = classVarianceAuthority.cva(zuiAvatarImageBase);
57
+ var avatarFallbackVariants = classVarianceAuthority.cva(zuiAvatarFallbackBase);
58
+ var avatarGroupVariants = classVarianceAuthority.cva(zuiAvatarGroupBase);
59
+ var AvatarContext = react.createContext(null);
60
+ function useAvatarContext(component) {
61
+ const ctx = react.useContext(AvatarContext);
62
+ if (!ctx) {
63
+ throw new Error(`${component} must be used within <Avatar>`);
64
+ }
65
+ return ctx;
66
+ }
67
+ function AvatarBase({
68
+ className,
69
+ size,
70
+ appearance,
71
+ children,
72
+ ref,
73
+ as: Wrapper = "span",
74
+ ...rest
75
+ }) {
76
+ const [imageStatus, setImageStatus] = react.useState("idle");
77
+ const ctx = react.useMemo(() => ({ imageStatus, setImageStatus }), [imageStatus]);
78
+ return /* @__PURE__ */ jsxRuntime.jsx(AvatarContext.Provider, { value: ctx, children: /* @__PURE__ */ jsxRuntime.jsx(
79
+ Wrapper,
80
+ {
81
+ ref,
82
+ "data-slot": "avatar",
83
+ className: chunkZS5756ZC_js.cn(avatarVariants({ size, appearance }), className),
84
+ ...rest,
85
+ children
86
+ }
87
+ ) });
88
+ }
89
+ AvatarBase.displayName = "Avatar";
90
+ function AvatarImage({
91
+ className,
92
+ onLoad,
93
+ onError,
94
+ ref,
95
+ ...rest
96
+ }) {
97
+ const { setImageStatus } = useAvatarContext("AvatarImage");
98
+ return /* @__PURE__ */ jsxRuntime.jsx(
99
+ "img",
100
+ {
101
+ ref,
102
+ "data-slot": "avatar-image",
103
+ className: chunkZS5756ZC_js.cn(avatarImageVariants(), className),
104
+ onLoad: (e) => {
105
+ setImageStatus("loaded");
106
+ onLoad?.(e);
107
+ },
108
+ onError: (e) => {
109
+ setImageStatus("error");
110
+ onError?.(e);
111
+ },
112
+ ...rest
113
+ }
114
+ );
115
+ }
116
+ AvatarImage.displayName = "AvatarImage";
117
+ function AvatarFallback({
118
+ className,
119
+ delayMs = 0,
120
+ ref,
121
+ ...rest
122
+ }) {
123
+ const { imageStatus } = useAvatarContext("AvatarFallback");
124
+ const [show, setShow] = react.useState(delayMs === 0);
125
+ react.useEffect(() => {
126
+ if (imageStatus === "loaded") {
127
+ setShow(false);
128
+ return;
129
+ }
130
+ if (imageStatus === "error") {
131
+ setShow(true);
132
+ return;
133
+ }
134
+ if (delayMs <= 0) {
135
+ setShow(true);
136
+ return;
137
+ }
138
+ const t = window.setTimeout(() => setShow(true), delayMs);
139
+ return () => window.clearTimeout(t);
140
+ }, [delayMs, imageStatus]);
141
+ if (!show) {
142
+ return null;
143
+ }
144
+ return /* @__PURE__ */ jsxRuntime.jsx(
145
+ "span",
146
+ {
147
+ ref,
148
+ "data-slot": "avatar-fallback",
149
+ className: chunkZS5756ZC_js.cn(avatarFallbackVariants(), className),
150
+ ...rest
151
+ }
152
+ );
153
+ }
154
+ AvatarFallback.displayName = "AvatarFallback";
155
+ function AvatarGroup({
156
+ className,
157
+ max,
158
+ children,
159
+ ref,
160
+ ...rest
161
+ }) {
162
+ const childArray = react.useMemo(
163
+ () => react.Children.toArray(children).filter(react.isValidElement),
164
+ [children]
165
+ );
166
+ const visible = max !== void 0 ? childArray.slice(0, max) : childArray;
167
+ const overflow = max !== void 0 && childArray.length > max ? childArray.length - max : 0;
168
+ return /* @__PURE__ */ jsxRuntime.jsxs(
169
+ "div",
170
+ {
171
+ ref,
172
+ "data-slot": "avatar-group",
173
+ className: chunkZS5756ZC_js.cn(avatarGroupVariants(), className),
174
+ ...rest,
175
+ children: [
176
+ visible,
177
+ overflow > 0 ? /* @__PURE__ */ jsxRuntime.jsxs(
178
+ "span",
179
+ {
180
+ "data-slot": "avatar-group-overflow",
181
+ className: chunkZS5756ZC_js.cn(
182
+ avatarVariants({ size: "md" }),
183
+ "z-10 grid place-items-center bg-slate-800 text-xs font-semibold text-white"
184
+ ),
185
+ "aria-label": `${overflow} more`,
186
+ children: [
187
+ "+",
188
+ overflow
189
+ ]
190
+ }
191
+ ) : null
192
+ ]
193
+ }
194
+ );
195
+ }
196
+ AvatarGroup.displayName = "AvatarGroup";
197
+
198
+ exports.AvatarBase = AvatarBase;
199
+ exports.AvatarFallback = AvatarFallback;
200
+ exports.AvatarGroup = AvatarGroup;
201
+ exports.AvatarImage = AvatarImage;
202
+ exports.avatarFallbackVariants = avatarFallbackVariants;
203
+ exports.avatarGroupVariants = avatarGroupVariants;
204
+ exports.avatarImageVariants = avatarImageVariants;
205
+ exports.avatarVariants = avatarVariants;
206
+ //# sourceMappingURL=chunk-TTTYW3TR.js.map
207
+ //# sourceMappingURL=chunk-TTTYW3TR.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/design-system/avatar.ts","../src/ui/avatar/variants.ts","../src/ui/avatar/avatar-base.tsx"],"names":["cva","createContext","useContext","useState","useMemo","jsx","cn","useEffect","Children","isValidElement","jsxs"],"mappings":"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","file":"chunk-TTTYW3TR.js","sourcesContent":["export const zuiAvatarBase =\n \"relative flex shrink-0 overflow-hidden rounded-full border border-[color:var(--zui-avatar-border,#0000001a)] dark:border-[color:var(--zui-avatar-border-dark,#ffffff1a)] text-[color:var(--zui-avatar-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-fg-dark,oklch(92.9%_0.013_255.508))]\";\n\nexport const zuiAvatarAppearances = {\n default:\n \"border-[color:var(--zui-avatar-default-border,#0000001a)] dark:border-[color:var(--zui-avatar-default-border-dark,#ffffff1a)] bg-[var(--zui-avatar-default-bg,#0000001a)] dark:bg-[var(--zui-avatar-default-bg-dark,#ffffff1a)] text-[color:var(--zui-avatar-default-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-default-fg-dark,oklch(92.9%_0.013_255.508))]\",\n muted:\n \"border-[color:var(--zui-avatar-muted-border,#00000066)] bg-[var(--zui-avatar-muted-bg,oklch(98.4%_0.003_247.858))] dark:border-[color:var(--zui-avatar-muted-border-dark,#ffffff1a)] dark:bg-[var(--zui-avatar-muted-bg-dark,oklch(12.9%_0.042_264.695_/_0.4))] text-[color:var(--zui-avatar-muted-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-muted-fg-dark,oklch(92.9%_0.013_255.508))]\",\n sky: \"border-[color:var(--zui-avatar-sky-border,oklch(44.3%_0.11_240.79))] dark:border-[color:var(--zui-avatar-sky-border-dark,oklch(58.8%_0.158_241.966))] bg-[var(--zui-avatar-sky-bg,oklch(95.1%_0.026_236.824_/_0.5))] dark:bg-[var(--zui-avatar-sky-bg-dark,oklch(58.8%_0.158_241.966_/_0.03))] text-[color:var(--zui-avatar-sky-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-sky-fg-dark,oklch(92.9%_0.013_255.508))]\",\n rose: \"border-[color:var(--zui-avatar-rose-border,oklch(45.5%_0.188_13.697))] dark:border-[color:var(--zui-avatar-rose-border-dark,oklch(58.6%_0.253_17.585))] bg-[var(--zui-avatar-rose-bg,oklch(94.1%_0.03_12.58_/_0.5))] dark:bg-[var(--zui-avatar-rose-bg-dark,oklch(58.6%_0.253_17.585_/_0.03))] text-[color:var(--zui-avatar-rose-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-rose-fg-dark,oklch(92.9%_0.013_255.508))]\",\n purple:\n \"border-[color:var(--zui-avatar-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-avatar-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-[var(--zui-avatar-purple-bg,oklch(94.6%_0.033_307.174_/_0.5))] dark:bg-[var(--zui-avatar-purple-bg-dark,oklch(55.8%_0.288_302.321_/_0.03))] text-[color:var(--zui-avatar-purple-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-purple-fg-dark,oklch(92.9%_0.013_255.508))]\",\n pink: \"border-[color:var(--zui-avatar-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-avatar-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-[var(--zui-avatar-pink-bg,oklch(94.8%_0.028_342.258_/_0.5))] dark:bg-[var(--zui-avatar-pink-bg-dark,oklch(59.2%_0.249_0.584_/_0.03))] text-[color:var(--zui-avatar-pink-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-pink-fg-dark,oklch(92.9%_0.013_255.508))]\",\n orange:\n \"border-[color:var(--zui-avatar-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-avatar-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-[var(--zui-avatar-orange-bg,oklch(95.4%_0.038_75.164_/_0.5))] dark:bg-[var(--zui-avatar-orange-bg-dark,oklch(64.6%_0.222_41.116_/_0.03))] text-[color:var(--zui-avatar-orange-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-orange-fg-dark,oklch(92.9%_0.013_255.508))]\",\n yellow:\n \"border-[color:var(--zui-avatar-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-avatar-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-[var(--zui-avatar-yellow-bg,oklch(97.3%_0.071_103.193_/_0.5))] dark:bg-[var(--zui-avatar-yellow-bg-dark,oklch(68.1%_0.162_75.834_/_0.03))] text-[color:var(--zui-avatar-yellow-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-yellow-fg-dark,oklch(92.9%_0.013_255.508))]\",\n teal: \"border-[color:var(--zui-avatar-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-avatar-teal-border-dark,oklch(60%_0.118_184.704))] bg-[var(--zui-avatar-teal-bg,oklch(95.3%_0.051_180.801_/_0.5))] dark:bg-[var(--zui-avatar-teal-bg-dark,oklch(60%_0.118_184.704_/_0.03))] text-[color:var(--zui-avatar-teal-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-teal-fg-dark,oklch(92.9%_0.013_255.508))]\",\n indigo:\n \"border-[color:var(--zui-avatar-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-avatar-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-[var(--zui-avatar-indigo-bg,oklch(93%_0.034_272.788_/_0.5))] dark:bg-[var(--zui-avatar-indigo-bg-dark,oklch(51.1%_0.262_276.966_/_0.03))] text-[color:var(--zui-avatar-indigo-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-indigo-fg-dark,oklch(92.9%_0.013_255.508))]\",\n emerald:\n \"border-[color:var(--zui-avatar-emerald-border,oklch(43.2%_0.095_166.913))] dark:border-[color:var(--zui-avatar-emerald-border-dark,oklch(59.6%_0.145_163.225))] bg-[var(--zui-avatar-emerald-bg,oklch(95%_0.052_163.051_/_0.5))] dark:bg-[var(--zui-avatar-emerald-bg-dark,oklch(59.6%_0.145_163.225_/_0.03))] text-[color:var(--zui-avatar-emerald-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-emerald-fg-dark,oklch(92.9%_0.013_255.508))]\",\n gray: \"border-[color:var(--zui-avatar-gray-border,oklch(27.8%_0.033_256.848))] dark:border-[color:var(--zui-avatar-gray-border-dark,oklch(44.6%_0.03_256.802))] bg-[var(--zui-avatar-gray-bg,oklch(96.7%_0.003_264.542_/_0.5))] dark:bg-[var(--zui-avatar-gray-bg-dark,oklch(44.6%_0.03_256.802_/_0.03))] text-[color:var(--zui-avatar-gray-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gray-fg-dark,oklch(92.9%_0.013_255.508))]\",\n amber:\n \"border-[color:var(--zui-avatar-amber-border,oklch(47.3%_0.137_46.201))] dark:border-[color:var(--zui-avatar-amber-border-dark,oklch(66.6%_0.179_58.318))] bg-[var(--zui-avatar-amber-bg,oklch(96.2%_0.059_95.617_/_0.5))] dark:bg-[var(--zui-avatar-amber-bg-dark,oklch(66.6%_0.179_58.318_/_0.03))] text-[color:var(--zui-avatar-amber-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-amber-fg-dark,oklch(92.9%_0.013_255.508))]\",\n violet:\n \"border-[color:var(--zui-avatar-violet-border,oklch(43.2%_0.232_292.759))] dark:border-[color:var(--zui-avatar-violet-border-dark,oklch(54.1%_0.281_293.009))] bg-[var(--zui-avatar-violet-bg,oklch(94.3%_0.029_294.588_/_0.5))] dark:bg-[var(--zui-avatar-violet-bg-dark,oklch(54.1%_0.281_293.009_/_0.03))] text-[color:var(--zui-avatar-violet-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-violet-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-blue\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-blue-from,oklch(62.3%_0.214_259.815))] dark:from-[var(--zui-avatar-gradient-blue-from-dark,oklch(54.6%_0.245_262.881))] to-[var(--zui-avatar-gradient-blue-to,oklch(62.7%_0.265_303.9))] dark:to-[var(--zui-avatar-gradient-blue-to-dark,oklch(55.8%_0.288_302.321))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-blue-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-blue-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-green\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-green-from,oklch(72.3%_0.219_149.579))] dark:from-[var(--zui-avatar-gradient-green-from-dark,oklch(62.7%_0.194_149.214))] to-[var(--zui-avatar-gradient-green-to,oklch(76.8%_0.233_130.85))] dark:to-[var(--zui-avatar-gradient-green-to-dark,oklch(64.8%_0.2_131.684))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-green-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-green-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-red\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-red-from,oklch(63.7%_0.237_25.331))] dark:from-[var(--zui-avatar-gradient-red-from-dark,oklch(57.7%_0.245_27.325))] to-[var(--zui-avatar-gradient-red-to,oklch(65.6%_0.241_354.308))] dark:to-[var(--zui-avatar-gradient-red-to-dark,oklch(59.2%_0.249_0.584))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-red-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-red-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-yellow\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-yellow-from,oklch(79.5%_0.184_86.047))] dark:from-[var(--zui-avatar-gradient-yellow-from-dark,oklch(68.1%_0.162_75.834))] to-[var(--zui-avatar-gradient-yellow-to,oklch(70.5%_0.213_47.604))] dark:to-[var(--zui-avatar-gradient-yellow-to-dark,oklch(64.6%_0.222_41.116))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-yellow-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-yellow-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-purple\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-purple-from,oklch(62.7%_0.265_303.9))] dark:from-[var(--zui-avatar-gradient-purple-from-dark,oklch(55.8%_0.288_302.321))] to-[var(--zui-avatar-gradient-purple-to,oklch(65.6%_0.241_354.308))] dark:to-[var(--zui-avatar-gradient-purple-to-dark,oklch(59.2%_0.249_0.584))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-purple-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-purple-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-teal\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-teal-from,oklch(70.4%_0.14_182.503))] dark:from-[var(--zui-avatar-gradient-teal-from-dark,oklch(60%_0.118_184.704))] to-[var(--zui-avatar-gradient-teal-to,oklch(71.5%_0.143_215.221))] dark:to-[var(--zui-avatar-gradient-teal-to-dark,oklch(60.9%_0.126_221.723))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-teal-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-teal-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-indigo\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-indigo-from,oklch(58.5%_0.233_277.117))] dark:from-[var(--zui-avatar-gradient-indigo-from-dark,oklch(51.1%_0.262_276.966))] to-[var(--zui-avatar-gradient-indigo-to,oklch(62.7%_0.265_303.9))] dark:to-[var(--zui-avatar-gradient-indigo-to-dark,oklch(55.8%_0.288_302.321))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-indigo-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-indigo-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-pink\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-pink-from,oklch(65.6%_0.241_354.308))] dark:from-[var(--zui-avatar-gradient-pink-from-dark,oklch(59.2%_0.249_0.584))] to-[var(--zui-avatar-gradient-pink-to,oklch(64.5%_0.246_16.439))] dark:to-[var(--zui-avatar-gradient-pink-to-dark,oklch(58.6%_0.253_17.585))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-pink-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-pink-fg-dark,oklch(92.9%_0.013_255.508))]\",\n \"gradient-orange\":\n \"bg-linear-to-r from-[var(--zui-avatar-gradient-orange-from,oklch(70.5%_0.213_47.604))] dark:from-[var(--zui-avatar-gradient-orange-from-dark,oklch(64.6%_0.222_41.116))] to-[var(--zui-avatar-gradient-orange-to,oklch(63.7%_0.237_25.331))] dark:to-[var(--zui-avatar-gradient-orange-to-dark,oklch(57.7%_0.245_27.325))] backdrop-blur-xl text-[color:var(--zui-avatar-gradient-orange-fg,oklch(37.2%_0.044_257.287))] dark:text-[color:var(--zui-avatar-gradient-orange-fg-dark,oklch(92.9%_0.013_255.508))]\",\n} as const;\n\nexport const zuiAvatarSizes = {\n sm: \"size-8 text-xs\",\n md: \"size-10 text-sm\",\n lg: \"size-12 text-base\",\n xl: \"size-16 text-lg\",\n} as const;\n\nexport const zuiAvatarImageBase = \"aspect-square size-full object-cover\";\n\nexport const zuiAvatarFallbackBase =\n \"flex size-full items-center justify-center bg-[var(--zui-avatar-fallback-bg,oklch(92.9%_0.013_255.508))] dark:bg-[var(--zui-avatar-fallback-bg-dark,oklch(27.9%_0.041_260.031))] font-medium text-[color:var(--zui-avatar-fallback-fg,oklch(27.9%_0.041_260.031))] dark:text-[color:var(--zui-avatar-fallback-fg-dark,oklch(96.8%_0.007_247.896))]\";\n\nexport const zuiAvatarGroupBase =\n \"flex items-center [&_[data-slot=avatar]]:-ml-2 [&_[data-slot=avatar]]:ring-2 [&_[data-slot=avatar]]:ring-[var(--zui-avatar-group-ring,#ffffff)] dark:[&_[data-slot=avatar]]:ring-[var(--zui-avatar-group-ring-dark,oklch(12.9%_0.042_264.695))] [&_[data-slot=avatar]]:first:ml-0\";\n","import { cva } from \"class-variance-authority\";\n\nimport {\n zuiAvatarAppearances,\n zuiAvatarBase,\n zuiAvatarFallbackBase,\n zuiAvatarGroupBase,\n zuiAvatarImageBase,\n zuiAvatarSizes,\n} from \"../../design-system/avatar\";\n\nexport const avatarVariants = cva(zuiAvatarBase, {\n variants: {\n appearance: zuiAvatarAppearances,\n size: zuiAvatarSizes,\n },\n defaultVariants: {\n size: \"md\",\n appearance: \"default\",\n },\n});\n\nexport const avatarImageVariants = cva(zuiAvatarImageBase);\n\nexport const avatarFallbackVariants = cva(zuiAvatarFallbackBase);\n\nexport const avatarGroupVariants = cva(zuiAvatarGroupBase);\n","\"use client\";\n\nimport {\n Children,\n createContext,\n isValidElement,\n useContext,\n useEffect,\n useMemo,\n useState,\n type Ref,\n} from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type {\n AvatarBaseProps,\n AvatarCtx,\n AvatarFallbackProps,\n AvatarGroupProps,\n AvatarImageProps,\n ImageStatus,\n} from \"./types\";\nimport {\n avatarFallbackVariants,\n avatarGroupVariants,\n avatarImageVariants,\n avatarVariants,\n} from \"./variants\";\n\nconst AvatarContext = createContext<AvatarCtx | null>(null);\n\nfunction useAvatarContext(component: string): AvatarCtx {\n const ctx = useContext(AvatarContext);\n if (!ctx) {\n throw new Error(`${component} must be used within <Avatar>`);\n }\n return ctx;\n}\n\nexport function AvatarBase({\n className,\n size,\n appearance,\n children,\n ref,\n as: Wrapper = \"span\",\n ...rest\n}: AvatarBaseProps) {\n const [imageStatus, setImageStatus] = useState<ImageStatus>(\"idle\");\n const ctx = useMemo(() => ({ imageStatus, setImageStatus }), [imageStatus]);\n\n return (\n <AvatarContext.Provider value={ctx}>\n <Wrapper\n ref={ref}\n data-slot=\"avatar\"\n className={cn(avatarVariants({ size, appearance }), className)}\n {...rest}\n >\n {children}\n </Wrapper>\n </AvatarContext.Provider>\n );\n}\n\nAvatarBase.displayName = \"Avatar\";\n\nexport function AvatarImage({\n className,\n onLoad,\n onError,\n ref,\n ...rest\n}: AvatarImageProps & { ref?: Ref<HTMLImageElement> }) {\n const { setImageStatus } = useAvatarContext(\"AvatarImage\");\n\n return (\n <img\n ref={ref}\n data-slot=\"avatar-image\"\n className={cn(avatarImageVariants(), className)}\n onLoad={(e) => {\n setImageStatus(\"loaded\");\n onLoad?.(e);\n }}\n onError={(e) => {\n setImageStatus(\"error\");\n onError?.(e);\n }}\n {...rest}\n />\n );\n}\n\nAvatarImage.displayName = \"AvatarImage\";\n\nexport function AvatarFallback({\n className,\n delayMs = 0,\n ref,\n ...rest\n}: AvatarFallbackProps & { ref?: Ref<HTMLSpanElement> }) {\n const { imageStatus } = useAvatarContext(\"AvatarFallback\");\n const [show, setShow] = useState(delayMs === 0);\n\n useEffect(() => {\n if (imageStatus === \"loaded\") {\n setShow(false);\n return;\n }\n if (imageStatus === \"error\") {\n setShow(true);\n return;\n }\n if (delayMs <= 0) {\n setShow(true);\n return;\n }\n const t = window.setTimeout(() => setShow(true), delayMs);\n return () => window.clearTimeout(t);\n }, [delayMs, imageStatus]);\n\n if (!show) {\n return null;\n }\n\n return (\n <span\n ref={ref}\n data-slot=\"avatar-fallback\"\n className={cn(avatarFallbackVariants(), className)}\n {...rest}\n />\n );\n}\n\nAvatarFallback.displayName = \"AvatarFallback\";\n\nexport function AvatarGroup({\n className,\n max,\n children,\n ref,\n ...rest\n}: AvatarGroupProps & { ref?: Ref<HTMLDivElement> }) {\n const childArray = useMemo(\n () => Children.toArray(children).filter(isValidElement),\n [children],\n );\n const visible = max !== undefined ? childArray.slice(0, max) : childArray;\n const overflow =\n max !== undefined && childArray.length > max ? childArray.length - max : 0;\n\n return (\n <div\n ref={ref}\n data-slot=\"avatar-group\"\n className={cn(avatarGroupVariants(), className)}\n {...rest}\n >\n {visible}\n {overflow > 0 ? (\n <span\n data-slot=\"avatar-group-overflow\"\n className={cn(\n avatarVariants({ size: \"md\" }),\n \"z-10 grid place-items-center bg-slate-800 text-xs font-semibold text-white\",\n )}\n aria-label={`${overflow} more`}\n >\n +{overflow}\n </span>\n ) : null}\n </div>\n );\n}\n\nAvatarGroup.displayName = \"AvatarGroup\";\n"]}
@@ -0,0 +1,37 @@
1
+ 'use strict';
2
+
3
+ var react = require('react');
4
+
5
+ // src/hooks/useResizeObserver/useResizeObserver.ts
6
+ function useResizeObserver(params = {}) {
7
+ const { enabled = true } = params;
8
+ const [element, setElement] = react.useState(null);
9
+ const [size, setSize] = react.useState(void 0);
10
+ const setRef = react.useCallback((node) => {
11
+ setElement(node);
12
+ }, []);
13
+ react.useEffect(() => {
14
+ if (!enabled || element == null) {
15
+ return;
16
+ }
17
+ if (typeof ResizeObserver === "undefined") {
18
+ return;
19
+ }
20
+ const observer = new ResizeObserver((entries) => {
21
+ const { width, height } = entries[0]?.contentRect ?? {
22
+ width: 0,
23
+ height: 0
24
+ };
25
+ setSize({ width, height });
26
+ });
27
+ observer.observe(element);
28
+ return () => {
29
+ observer.disconnect();
30
+ };
31
+ }, [element, enabled]);
32
+ return [setRef, size];
33
+ }
34
+
35
+ exports.useResizeObserver = useResizeObserver;
36
+ //# sourceMappingURL=chunk-W3QRRWQX.js.map
37
+ //# sourceMappingURL=chunk-W3QRRWQX.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/hooks/useResizeObserver/useResizeObserver.ts"],"names":["useState","useCallback","useEffect"],"mappings":";;;;;AAyBO,SAAS,iBAAA,CACd,MAAA,GAAkC,EAAC,EACQ;AAC3C,EAAA,MAAM,EAAE,OAAA,GAAU,IAAA,EAAK,GAAI,MAAA;AAC3B,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAIA,eAAmB,IAAI,CAAA;AACrD,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAIA,eAAkC,MAAS,CAAA;AAEnE,EAAA,MAAM,MAAA,GAASC,iBAAA,CAAY,CAAC,IAAA,KAAmB;AAC7C,IAAA,UAAA,CAAW,IAAI,CAAA;AAAA,EACjB,CAAA,EAAG,EAAE,CAAA;AAEL,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,CAAC,OAAA,IAAW,OAAA,IAAW,IAAA,EAAM;AAC/B,MAAA;AAAA,IACF;AACA,IAAA,IAAI,OAAO,mBAAmB,WAAA,EAAa;AACzC,MAAA;AAAA,IACF;AACA,IAAA,MAAM,QAAA,GAAW,IAAI,cAAA,CAAe,CAAC,OAAA,KAAY;AAC/C,MAAA,MAAM,EAAE,KAAA,EAAO,MAAA,KAAW,OAAA,CAAQ,CAAC,GAAG,WAAA,IAAe;AAAA,QACnD,KAAA,EAAO,CAAA;AAAA,QACP,MAAA,EAAQ;AAAA,OACV;AACA,MAAA,OAAA,CAAQ,EAAE,KAAA,EAAO,MAAA,EAAQ,CAAA;AAAA,IAC3B,CAAC,CAAA;AACD,IAAA,QAAA,CAAS,QAAQ,OAAO,CAAA;AACxB,IAAA,OAAO,MAAM;AACX,MAAA,QAAA,CAAS,UAAA,EAAW;AAAA,IACtB,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,OAAA,EAAS,OAAO,CAAC,CAAA;AAErB,EAAA,OAAO,CAAC,QAAQ,IAAI,CAAA;AACtB","file":"chunk-W3QRRWQX.js","sourcesContent":["\"use client\";\n\nimport type { RefCallback } from \"react\";\nimport { useCallback, useEffect, useState } from \"react\";\n\nexport type ElementSize = {\n width: number;\n height: number;\n};\n\nexport type UseResizeObserverParams = {\n /** When `false`, no `ResizeObserver` is attached. */\n enabled?: boolean;\n};\n\n/**\n * Observes an element’s `contentRect` size via `ResizeObserver` and exposes `{ width, height }`.\n *\n * When `ResizeObserver` is undefined or `enabled` is false, size may remain `undefined`. Uses the first\n * entry from the observer callback (`entries[0]`) aligned with the single observed node.\n *\n * @typeParam T - Observed element type.\n * @param params - Optional `{ enabled }` (default `true`).\n * @returns `[setRef, size]` callback ref and latest measured size.\n */\nexport function useResizeObserver<T extends Element>(\n params: UseResizeObserverParams = {},\n): [RefCallback<T>, ElementSize | undefined] {\n const { enabled = true } = params;\n const [element, setElement] = useState<T | null>(null);\n const [size, setSize] = useState<ElementSize | undefined>(undefined);\n\n const setRef = useCallback((node: T | null) => {\n setElement(node);\n }, []);\n\n useEffect(() => {\n if (!enabled || element == null) {\n return;\n }\n if (typeof ResizeObserver === \"undefined\") {\n return;\n }\n const observer = new ResizeObserver((entries) => {\n const { width, height } = entries[0]?.contentRect ?? {\n width: 0,\n height: 0,\n };\n setSize({ width, height });\n });\n observer.observe(element);\n return () => {\n observer.disconnect();\n };\n }, [element, enabled]);\n\n return [setRef, size];\n}\n"]}
@@ -0,0 +1,232 @@
1
+ 'use strict';
2
+
3
+ var chunkZS5756ZC_js = require('./chunk-ZS5756ZC.js');
4
+ var classVarianceAuthority = require('class-variance-authority');
5
+ var react = require('react');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+
8
+ // src/design-system/card.ts
9
+ var zuiCardBase = [
10
+ "relative flex w-full flex-col overflow-hidden text-[color:var(--zui-card-fg,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-card-fg-dark,oklch(98.4%_0.003_247.858))]",
11
+ "ring-offset-[var(--zui-card-ring-offset,oklch(98.4%_0.003_247.858))] dark:ring-offset-[var(--zui-card-ring-offset-dark,oklch(12.9%_0.042_264.695))] transition-colors",
12
+ "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--zui-card-ring-focus,oklch(44.6%_0.043_257.281))] dark:focus-visible:ring-[var(--zui-card-ring-focus-dark,oklch(86.9%_0.022_252.894))] focus-visible:ring-offset-2"
13
+ ];
14
+ var zuiCardAppearances = {
15
+ default: "border border-[color:var(--zui-card-default-border,#0000001a)] dark:border-[color:var(--zui-card-default-border-dark,#ffffff1a)] bg-[var(--zui-card-default-bg,#0000000d)] dark:bg-[var(--zui-card-default-bg-dark,#ffffff0d)] shadow-[var(--zui-card-default-shadow,0_1px_2px_rgba(15,23,42,0.08))] dark:shadow-[var(--zui-card-default-shadow-dark,0_1px_2px_rgba(15,23,42,0.12))]",
16
+ glass: "border border-[color:var(--zui-card-glass-border,#00000026)] dark:border-[color:var(--zui-card-glass-border-dark,#ffffff26)] bg-[var(--zui-card-glass-bg,#0000001a)] dark:bg-[var(--zui-card-glass-bg-dark,#ffffff1a)] backdrop-blur-md shadow-[var(--zui-card-glass-shadow,0_8px_24px_rgba(15,23,42,0.12))] dark:shadow-[var(--zui-card-glass-shadow-dark,0_18px_48px_rgba(15,23,42,0.35))]",
17
+ outline: "border border-[color:var(--zui-card-outline-border,#00000026)] dark:border-[color:var(--zui-card-outline-border-dark,#ffffff26)] bg-[var(--zui-card-outline-bg,transparent)]",
18
+ ghost: "border border-[color:var(--zui-card-ghost-border,transparent)] bg-[var(--zui-card-ghost-bg,transparent)]",
19
+ elevated: "border border-[color:var(--zui-card-elevated-border,#0000001a)] dark:border-[color:var(--zui-card-elevated-border-dark,#ffffff1a)] bg-[var(--zui-card-elevated-bg,oklch(96.8%_0.007_247.896_/_0.8))] dark:bg-[var(--zui-card-elevated-bg-dark,oklch(20.8%_0.042_265.755_/_0.8))] shadow-[var(--zui-card-elevated-shadow,0_12px_32px_rgba(15,23,42,0.12))] dark:shadow-[var(--zui-card-elevated-shadow-dark,0_24px_64px_rgba(15,23,42,0.45))]",
20
+ sky: "border border-[color:var(--zui-card-sky-border,oklch(44.3%_0.11_240.79))] dark:border-[color:var(--zui-card-sky-border-dark,oklch(58.8%_0.158_241.966))] bg-[var(--zui-card-sky-bg,oklch(97.7%_0.013_236.62))] dark:bg-[var(--zui-card-sky-bg-dark,oklch(29.3%_0.066_243.157_/_0.7))] backdrop-blur-xl",
21
+ rose: "border border-[color:var(--zui-card-rose-border,oklch(45.5%_0.188_13.697))] dark:border-[color:var(--zui-card-rose-border-dark,oklch(58.6%_0.253_17.585))] bg-[var(--zui-card-rose-bg,oklch(96.9%_0.015_12.422))] dark:bg-[var(--zui-card-rose-bg-dark,oklch(27.1%_0.105_12.094_/_0.7))] backdrop-blur-xl",
22
+ purple: "border border-[color:var(--zui-card-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-card-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-[var(--zui-card-purple-bg,oklch(97.7%_0.014_308.299))] dark:bg-[var(--zui-card-purple-bg-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl",
23
+ pink: "border border-[color:var(--zui-card-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-card-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-[var(--zui-card-pink-bg,oklch(97.1%_0.014_343.198))] dark:bg-[var(--zui-card-pink-bg-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl",
24
+ orange: "border border-[color:var(--zui-card-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-card-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-[var(--zui-card-orange-bg,oklch(98%_0.016_73.684))] dark:bg-[var(--zui-card-orange-bg-dark,oklch(26.6%_0.079_36.259_/_0.7))] backdrop-blur-xl",
25
+ yellow: "border border-[color:var(--zui-card-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-card-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-[var(--zui-card-yellow-bg,oklch(98.7%_0.026_102.212))] dark:bg-[var(--zui-card-yellow-bg-dark,oklch(28.6%_0.066_53.813_/_0.7))] backdrop-blur-xl",
26
+ teal: "border border-[color:var(--zui-card-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-card-teal-border-dark,oklch(60%_0.118_184.704))] bg-[var(--zui-card-teal-bg,oklch(98.4%_0.014_180.72))] dark:bg-[var(--zui-card-teal-bg-dark,oklch(27.7%_0.046_192.524_/_0.7))] backdrop-blur-xl",
27
+ indigo: "border border-[color:var(--zui-card-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-card-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-[var(--zui-card-indigo-bg,oklch(96.2%_0.018_272.314))] dark:bg-[var(--zui-card-indigo-bg-dark,oklch(25.7%_0.09_281.288_/_0.7))] backdrop-blur-xl",
28
+ emerald: "border border-[color:var(--zui-card-emerald-border,oklch(43.2%_0.095_166.913))] dark:border-[color:var(--zui-card-emerald-border-dark,oklch(59.6%_0.145_163.225))] bg-[var(--zui-card-emerald-bg,oklch(97.9%_0.021_166.113))] dark:bg-[var(--zui-card-emerald-bg-dark,oklch(26.2%_0.051_172.552_/_0.7))] backdrop-blur-xl",
29
+ gray: "border border-[color:var(--zui-card-gray-border,oklch(27.8%_0.033_256.848))] dark:border-[color:var(--zui-card-gray-border-dark,oklch(44.6%_0.03_256.802))] bg-[var(--zui-card-gray-bg,oklch(98.5%_0.002_247.839))] dark:bg-[var(--zui-card-gray-bg-dark,oklch(13%_0.028_261.692_/_0.7))] backdrop-blur-xl",
30
+ amber: "border border-[color:var(--zui-card-amber-border,oklch(47.3%_0.137_46.201))] dark:border-[color:var(--zui-card-amber-border-dark,oklch(66.6%_0.179_58.318))] bg-[var(--zui-card-amber-bg,oklch(98.7%_0.022_95.277))] dark:bg-[var(--zui-card-amber-bg-dark,oklch(27.9%_0.077_45.635_/_0.7))] backdrop-blur-xl",
31
+ violet: "border border-[color:var(--zui-card-violet-border,oklch(43.2%_0.232_292.759))] dark:border-[color:var(--zui-card-violet-border-dark,oklch(54.1%_0.281_293.009))] bg-[var(--zui-card-violet-bg,oklch(96.9%_0.016_293.756))] dark:bg-[var(--zui-card-violet-bg-dark,oklch(28.3%_0.141_291.089_/_0.7))] backdrop-blur-xl",
32
+ "gradient-blue": "border border-[color:var(--zui-card-gradient-blue-border,oklch(42.4%_0.199_265.638))] dark:border-[color:var(--zui-card-gradient-blue-border-dark,oklch(54.6%_0.245_262.881))] bg-linear-to-r from-[var(--zui-card-gradient-blue-from,oklch(97%_0.014_254.604))] dark:from-[var(--zui-card-gradient-blue-from-dark,oklch(28.2%_0.091_267.935_/_0.7))] to-[var(--zui-card-gradient-blue-to,oklch(97.7%_0.014_308.299))] dark:to-[var(--zui-card-gradient-blue-to-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl",
33
+ "gradient-green": "border border-[color:var(--zui-card-gradient-green-border,oklch(44.8%_0.119_151.328))] dark:border-[color:var(--zui-card-gradient-green-border-dark,oklch(62.7%_0.194_149.214))] bg-linear-to-r from-[var(--zui-card-gradient-green-from,oklch(98.2%_0.018_155.826))] dark:from-[var(--zui-card-gradient-green-from-dark,oklch(26.6%_0.065_152.934_/_0.7))] to-[var(--zui-card-gradient-green-to,oklch(98.6%_0.031_120.757))] dark:to-[var(--zui-card-gradient-green-to-dark,oklch(27.4%_0.072_132.109_/_0.7))] backdrop-blur-xl",
34
+ "gradient-red": "border border-[color:var(--zui-card-gradient-red-border,oklch(44.4%_0.177_26.899))] dark:border-[color:var(--zui-card-gradient-red-border-dark,oklch(57.7%_0.245_27.325))] bg-linear-to-r from-[var(--zui-card-gradient-red-from,oklch(97.1%_0.013_17.38))] dark:from-[var(--zui-card-gradient-red-from-dark,oklch(25.8%_0.092_26.042_/_0.7))] to-[var(--zui-card-gradient-red-to,oklch(97.1%_0.014_343.198))] dark:to-[var(--zui-card-gradient-red-to-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl",
35
+ "gradient-yellow": "border border-[color:var(--zui-card-gradient-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-card-gradient-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-linear-to-r from-[var(--zui-card-gradient-yellow-from,oklch(98.7%_0.026_102.212))] dark:from-[var(--zui-card-gradient-yellow-from-dark,oklch(28.6%_0.066_53.813_/_0.7))] to-[var(--zui-card-gradient-yellow-to,oklch(98%_0.016_73.684))] dark:to-[var(--zui-card-gradient-yellow-to-dark,oklch(26.6%_0.079_36.259_/_0.7))] backdrop-blur-xl",
36
+ "gradient-purple": "border border-[color:var(--zui-card-gradient-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-card-gradient-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-linear-to-r from-[var(--zui-card-gradient-purple-from,oklch(97.7%_0.014_308.299))] dark:from-[var(--zui-card-gradient-purple-from-dark,oklch(29.1%_0.149_302.717_/_0.7))] to-[var(--zui-card-gradient-purple-to,oklch(97.1%_0.014_343.198))] dark:to-[var(--zui-card-gradient-purple-to-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl",
37
+ "gradient-teal": "border border-[color:var(--zui-card-gradient-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-card-gradient-teal-border-dark,oklch(60%_0.118_184.704))] bg-linear-to-r from-[var(--zui-card-gradient-teal-from,oklch(98.4%_0.014_180.72))] dark:from-[var(--zui-card-gradient-teal-from-dark,oklch(27.7%_0.046_192.524_/_0.7))] to-[var(--zui-card-gradient-teal-to,oklch(98.4%_0.019_200.873))] dark:to-[var(--zui-card-gradient-teal-to-dark,oklch(30.2%_0.056_229.695_/_0.7))] backdrop-blur-xl",
38
+ "gradient-indigo": "border border-[color:var(--zui-card-gradient-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-card-gradient-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-linear-to-r from-[var(--zui-card-gradient-indigo-from,oklch(96.2%_0.018_272.314))] dark:from-[var(--zui-card-gradient-indigo-from-dark,oklch(25.7%_0.09_281.288_/_0.7))] to-[var(--zui-card-gradient-indigo-to,oklch(97.7%_0.014_308.299))] dark:to-[var(--zui-card-gradient-indigo-to-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl",
39
+ "gradient-pink": "border border-[color:var(--zui-card-gradient-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-card-gradient-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-linear-to-r from-[var(--zui-card-gradient-pink-from,oklch(97.1%_0.014_343.198))] dark:from-[var(--zui-card-gradient-pink-from-dark,oklch(28.4%_0.109_3.907_/_0.7))] to-[var(--zui-card-gradient-pink-to,oklch(96.9%_0.015_12.422))] dark:to-[var(--zui-card-gradient-pink-to-dark,oklch(27.1%_0.105_12.094_/_0.7))] backdrop-blur-xl",
40
+ "gradient-orange": "border border-[color:var(--zui-card-gradient-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-card-gradient-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-linear-to-r from-[var(--zui-card-gradient-orange-from,oklch(98%_0.016_73.684))] dark:from-[var(--zui-card-gradient-orange-from-dark,oklch(26.6%_0.079_36.259_/_0.7))] to-[var(--zui-card-gradient-orange-to,oklch(97.1%_0.013_17.38))] dark:to-[var(--zui-card-gradient-orange-to-dark,oklch(25.8%_0.092_26.042_/_0.7))] backdrop-blur-xl"
41
+ };
42
+ var zuiCardSizes = {
43
+ sm: "gap-2 p-3 text-sm",
44
+ md: "gap-3 p-4 text-sm",
45
+ lg: "gap-4 p-6 text-base"
46
+ };
47
+ var zuiCardRounded = {
48
+ sm: "rounded-lg",
49
+ md: "rounded-xl",
50
+ lg: "rounded-2xl",
51
+ full: "rounded-3xl"
52
+ };
53
+ var zuiCardHeaderBase = "flex flex-col gap-1 border-b border-[color:var(--zui-card-header-border,#0000001a)] dark:border-[color:var(--zui-card-header-border-dark,#ffffff1a)] pb-3";
54
+ var zuiCardHeaderSizes = {
55
+ sm: "pb-2",
56
+ md: "pb-3",
57
+ lg: "pb-4"
58
+ };
59
+ var zuiCardFooterBase = "flex flex-col gap-2 border-t border-[color:var(--zui-card-footer-border,#0000001a)] dark:border-[color:var(--zui-card-footer-border-dark,#ffffff1a)] pt-3";
60
+ var zuiCardFooterSizes = {
61
+ sm: "pt-2",
62
+ md: "pt-3",
63
+ lg: "pt-4"
64
+ };
65
+ var zuiCardTitleBase = "font-semibold tracking-tight text-[color:var(--zui-card-title-fg,oklch(12.9%_0.042_264.695))] dark:text-[color:var(--zui-card-title-fg-dark,#ffffff)]";
66
+ var zuiCardTitleSizes = {
67
+ sm: "text-sm",
68
+ md: "text-base",
69
+ lg: "text-lg"
70
+ };
71
+ var zuiCardDescriptionBase = "text-[color:var(--zui-card-description-fg,oklch(55.4%_0.046_257.417))] dark:text-[color:var(--zui-card-description-fg-dark,oklch(98.4%_0.003_247.858))]";
72
+ var zuiCardDescriptionSizes = {
73
+ sm: "text-xs",
74
+ md: "text-sm",
75
+ lg: "text-base"
76
+ };
77
+
78
+ // src/ui/card/variants.ts
79
+ var cardVariants = classVarianceAuthority.cva(zuiCardBase, {
80
+ variants: {
81
+ appearance: zuiCardAppearances,
82
+ size: zuiCardSizes,
83
+ rounded: zuiCardRounded
84
+ },
85
+ defaultVariants: {
86
+ appearance: "default",
87
+ size: "md",
88
+ rounded: "md"
89
+ }
90
+ });
91
+ var cardHeaderVariants = classVarianceAuthority.cva(zuiCardHeaderBase, {
92
+ variants: {
93
+ size: zuiCardHeaderSizes
94
+ },
95
+ defaultVariants: { size: "md" }
96
+ });
97
+ var cardFooterVariants = classVarianceAuthority.cva(zuiCardFooterBase, {
98
+ variants: {
99
+ size: zuiCardFooterSizes
100
+ },
101
+ defaultVariants: { size: "md" }
102
+ });
103
+ var cardTitleVariants = classVarianceAuthority.cva(zuiCardTitleBase, {
104
+ variants: {
105
+ size: zuiCardTitleSizes
106
+ },
107
+ defaultVariants: { size: "md" }
108
+ });
109
+ var cardDescriptionVariants = classVarianceAuthority.cva(zuiCardDescriptionBase, {
110
+ variants: {
111
+ size: zuiCardDescriptionSizes
112
+ },
113
+ defaultVariants: { size: "md" }
114
+ });
115
+ var CardSizeContext = react.createContext("md");
116
+ function useCardSize() {
117
+ return react.useContext(CardSizeContext);
118
+ }
119
+ function CardBase({
120
+ className,
121
+ appearance,
122
+ size = "md",
123
+ rounded,
124
+ children,
125
+ ref,
126
+ as: Wrapper = "article",
127
+ ...rest
128
+ }) {
129
+ const ctx = react.useMemo(() => size ?? "md", [size]);
130
+ return /* @__PURE__ */ jsxRuntime.jsx(CardSizeContext.Provider, { value: ctx, children: /* @__PURE__ */ jsxRuntime.jsx(
131
+ Wrapper,
132
+ {
133
+ ref,
134
+ "data-slot": "card",
135
+ className: chunkZS5756ZC_js.cn(cardVariants({ appearance, size, rounded }), className),
136
+ ...rest,
137
+ children
138
+ }
139
+ ) });
140
+ }
141
+ CardBase.displayName = "Card";
142
+ function CardHeader({ className, children }) {
143
+ const size = useCardSize();
144
+ return /* @__PURE__ */ jsxRuntime.jsx(
145
+ "header",
146
+ {
147
+ "data-slot": "card-header",
148
+ className: chunkZS5756ZC_js.cn(cardHeaderVariants({ size }), className),
149
+ children
150
+ }
151
+ );
152
+ }
153
+ CardHeader.displayName = "CardHeader";
154
+ function CardBody({ className, children }) {
155
+ return /* @__PURE__ */ jsxRuntime.jsx(
156
+ "div",
157
+ {
158
+ "data-slot": "card-body",
159
+ className: chunkZS5756ZC_js.cn("flex flex-1 flex-col gap-2", className),
160
+ children
161
+ }
162
+ );
163
+ }
164
+ CardBody.displayName = "CardBody";
165
+ function CardFooter({ className, children }) {
166
+ const size = useCardSize();
167
+ return /* @__PURE__ */ jsxRuntime.jsx(
168
+ "footer",
169
+ {
170
+ "data-slot": "card-footer",
171
+ className: chunkZS5756ZC_js.cn(cardFooterVariants({ size }), className),
172
+ children
173
+ }
174
+ );
175
+ }
176
+ CardFooter.displayName = "CardFooter";
177
+ function CardTitle({
178
+ className,
179
+ children,
180
+ as = "h3",
181
+ ref,
182
+ ...rest
183
+ }) {
184
+ const size = useCardSize();
185
+ const Tag = as;
186
+ return /* @__PURE__ */ jsxRuntime.jsx(
187
+ Tag,
188
+ {
189
+ ref,
190
+ "data-slot": "card-title",
191
+ className: chunkZS5756ZC_js.cn(cardTitleVariants({ size }), className),
192
+ ...rest,
193
+ children
194
+ }
195
+ );
196
+ }
197
+ CardTitle.displayName = "CardTitle";
198
+ function CardDescription({
199
+ className,
200
+ children,
201
+ as = "p",
202
+ ref,
203
+ ...rest
204
+ }) {
205
+ const size = useCardSize();
206
+ const Tag = as;
207
+ return /* @__PURE__ */ jsxRuntime.jsx(
208
+ Tag,
209
+ {
210
+ ref,
211
+ "data-slot": "card-description",
212
+ className: chunkZS5756ZC_js.cn(cardDescriptionVariants({ size }), className),
213
+ ...rest,
214
+ children
215
+ }
216
+ );
217
+ }
218
+ CardDescription.displayName = "CardDescription";
219
+
220
+ exports.CardBase = CardBase;
221
+ exports.CardBody = CardBody;
222
+ exports.CardDescription = CardDescription;
223
+ exports.CardFooter = CardFooter;
224
+ exports.CardHeader = CardHeader;
225
+ exports.CardTitle = CardTitle;
226
+ exports.cardDescriptionVariants = cardDescriptionVariants;
227
+ exports.cardFooterVariants = cardFooterVariants;
228
+ exports.cardHeaderVariants = cardHeaderVariants;
229
+ exports.cardTitleVariants = cardTitleVariants;
230
+ exports.cardVariants = cardVariants;
231
+ //# sourceMappingURL=chunk-WPXQHWPV.js.map
232
+ //# sourceMappingURL=chunk-WPXQHWPV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/design-system/card.ts","../src/ui/card/variants.ts","../src/ui/card/card-base.tsx"],"names":["cva","createContext","useContext","useMemo","jsx","cn"],"mappings":"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","file":"chunk-WPXQHWPV.js","sourcesContent":["export const zuiCardBase = [\n \"relative flex w-full flex-col overflow-hidden text-[color:var(--zui-card-fg,oklch(20.8%_0.042_265.755))] dark:text-[color:var(--zui-card-fg-dark,oklch(98.4%_0.003_247.858))]\",\n \"ring-offset-[var(--zui-card-ring-offset,oklch(98.4%_0.003_247.858))] dark:ring-offset-[var(--zui-card-ring-offset-dark,oklch(12.9%_0.042_264.695))] transition-colors\",\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-[var(--zui-card-ring-focus,oklch(44.6%_0.043_257.281))] dark:focus-visible:ring-[var(--zui-card-ring-focus-dark,oklch(86.9%_0.022_252.894))] focus-visible:ring-offset-2\",\n] as const;\n\nexport const zuiCardAppearances = {\n default:\n \"border border-[color:var(--zui-card-default-border,#0000001a)] dark:border-[color:var(--zui-card-default-border-dark,#ffffff1a)] bg-[var(--zui-card-default-bg,#0000000d)] dark:bg-[var(--zui-card-default-bg-dark,#ffffff0d)] shadow-[var(--zui-card-default-shadow,0_1px_2px_rgba(15,23,42,0.08))] dark:shadow-[var(--zui-card-default-shadow-dark,0_1px_2px_rgba(15,23,42,0.12))]\",\n glass:\n \"border border-[color:var(--zui-card-glass-border,#00000026)] dark:border-[color:var(--zui-card-glass-border-dark,#ffffff26)] bg-[var(--zui-card-glass-bg,#0000001a)] dark:bg-[var(--zui-card-glass-bg-dark,#ffffff1a)] backdrop-blur-md shadow-[var(--zui-card-glass-shadow,0_8px_24px_rgba(15,23,42,0.12))] dark:shadow-[var(--zui-card-glass-shadow-dark,0_18px_48px_rgba(15,23,42,0.35))]\",\n outline:\n \"border border-[color:var(--zui-card-outline-border,#00000026)] dark:border-[color:var(--zui-card-outline-border-dark,#ffffff26)] bg-[var(--zui-card-outline-bg,transparent)]\",\n ghost:\n \"border border-[color:var(--zui-card-ghost-border,transparent)] bg-[var(--zui-card-ghost-bg,transparent)]\",\n elevated:\n \"border border-[color:var(--zui-card-elevated-border,#0000001a)] dark:border-[color:var(--zui-card-elevated-border-dark,#ffffff1a)] bg-[var(--zui-card-elevated-bg,oklch(96.8%_0.007_247.896_/_0.8))] dark:bg-[var(--zui-card-elevated-bg-dark,oklch(20.8%_0.042_265.755_/_0.8))] shadow-[var(--zui-card-elevated-shadow,0_12px_32px_rgba(15,23,42,0.12))] dark:shadow-[var(--zui-card-elevated-shadow-dark,0_24px_64px_rgba(15,23,42,0.45))]\",\n sky: \"border border-[color:var(--zui-card-sky-border,oklch(44.3%_0.11_240.79))] dark:border-[color:var(--zui-card-sky-border-dark,oklch(58.8%_0.158_241.966))] bg-[var(--zui-card-sky-bg,oklch(97.7%_0.013_236.62))] dark:bg-[var(--zui-card-sky-bg-dark,oklch(29.3%_0.066_243.157_/_0.7))] backdrop-blur-xl\",\n rose: \"border border-[color:var(--zui-card-rose-border,oklch(45.5%_0.188_13.697))] dark:border-[color:var(--zui-card-rose-border-dark,oklch(58.6%_0.253_17.585))] bg-[var(--zui-card-rose-bg,oklch(96.9%_0.015_12.422))] dark:bg-[var(--zui-card-rose-bg-dark,oklch(27.1%_0.105_12.094_/_0.7))] backdrop-blur-xl\",\n purple:\n \"border border-[color:var(--zui-card-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-card-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-[var(--zui-card-purple-bg,oklch(97.7%_0.014_308.299))] dark:bg-[var(--zui-card-purple-bg-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl\",\n pink: \"border border-[color:var(--zui-card-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-card-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-[var(--zui-card-pink-bg,oklch(97.1%_0.014_343.198))] dark:bg-[var(--zui-card-pink-bg-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl\",\n orange:\n \"border border-[color:var(--zui-card-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-card-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-[var(--zui-card-orange-bg,oklch(98%_0.016_73.684))] dark:bg-[var(--zui-card-orange-bg-dark,oklch(26.6%_0.079_36.259_/_0.7))] backdrop-blur-xl\",\n yellow:\n \"border border-[color:var(--zui-card-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-card-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-[var(--zui-card-yellow-bg,oklch(98.7%_0.026_102.212))] dark:bg-[var(--zui-card-yellow-bg-dark,oklch(28.6%_0.066_53.813_/_0.7))] backdrop-blur-xl\",\n teal: \"border border-[color:var(--zui-card-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-card-teal-border-dark,oklch(60%_0.118_184.704))] bg-[var(--zui-card-teal-bg,oklch(98.4%_0.014_180.72))] dark:bg-[var(--zui-card-teal-bg-dark,oklch(27.7%_0.046_192.524_/_0.7))] backdrop-blur-xl\",\n indigo:\n \"border border-[color:var(--zui-card-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-card-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-[var(--zui-card-indigo-bg,oklch(96.2%_0.018_272.314))] dark:bg-[var(--zui-card-indigo-bg-dark,oklch(25.7%_0.09_281.288_/_0.7))] backdrop-blur-xl\",\n emerald:\n \"border border-[color:var(--zui-card-emerald-border,oklch(43.2%_0.095_166.913))] dark:border-[color:var(--zui-card-emerald-border-dark,oklch(59.6%_0.145_163.225))] bg-[var(--zui-card-emerald-bg,oklch(97.9%_0.021_166.113))] dark:bg-[var(--zui-card-emerald-bg-dark,oklch(26.2%_0.051_172.552_/_0.7))] backdrop-blur-xl\",\n gray: \"border border-[color:var(--zui-card-gray-border,oklch(27.8%_0.033_256.848))] dark:border-[color:var(--zui-card-gray-border-dark,oklch(44.6%_0.03_256.802))] bg-[var(--zui-card-gray-bg,oklch(98.5%_0.002_247.839))] dark:bg-[var(--zui-card-gray-bg-dark,oklch(13%_0.028_261.692_/_0.7))] backdrop-blur-xl\",\n amber:\n \"border border-[color:var(--zui-card-amber-border,oklch(47.3%_0.137_46.201))] dark:border-[color:var(--zui-card-amber-border-dark,oklch(66.6%_0.179_58.318))] bg-[var(--zui-card-amber-bg,oklch(98.7%_0.022_95.277))] dark:bg-[var(--zui-card-amber-bg-dark,oklch(27.9%_0.077_45.635_/_0.7))] backdrop-blur-xl\",\n violet:\n \"border border-[color:var(--zui-card-violet-border,oklch(43.2%_0.232_292.759))] dark:border-[color:var(--zui-card-violet-border-dark,oklch(54.1%_0.281_293.009))] bg-[var(--zui-card-violet-bg,oklch(96.9%_0.016_293.756))] dark:bg-[var(--zui-card-violet-bg-dark,oklch(28.3%_0.141_291.089_/_0.7))] backdrop-blur-xl\",\n \"gradient-blue\":\n \"border border-[color:var(--zui-card-gradient-blue-border,oklch(42.4%_0.199_265.638))] dark:border-[color:var(--zui-card-gradient-blue-border-dark,oklch(54.6%_0.245_262.881))] bg-linear-to-r from-[var(--zui-card-gradient-blue-from,oklch(97%_0.014_254.604))] dark:from-[var(--zui-card-gradient-blue-from-dark,oklch(28.2%_0.091_267.935_/_0.7))] to-[var(--zui-card-gradient-blue-to,oklch(97.7%_0.014_308.299))] dark:to-[var(--zui-card-gradient-blue-to-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl\",\n \"gradient-green\":\n \"border border-[color:var(--zui-card-gradient-green-border,oklch(44.8%_0.119_151.328))] dark:border-[color:var(--zui-card-gradient-green-border-dark,oklch(62.7%_0.194_149.214))] bg-linear-to-r from-[var(--zui-card-gradient-green-from,oklch(98.2%_0.018_155.826))] dark:from-[var(--zui-card-gradient-green-from-dark,oklch(26.6%_0.065_152.934_/_0.7))] to-[var(--zui-card-gradient-green-to,oklch(98.6%_0.031_120.757))] dark:to-[var(--zui-card-gradient-green-to-dark,oklch(27.4%_0.072_132.109_/_0.7))] backdrop-blur-xl\",\n \"gradient-red\":\n \"border border-[color:var(--zui-card-gradient-red-border,oklch(44.4%_0.177_26.899))] dark:border-[color:var(--zui-card-gradient-red-border-dark,oklch(57.7%_0.245_27.325))] bg-linear-to-r from-[var(--zui-card-gradient-red-from,oklch(97.1%_0.013_17.38))] dark:from-[var(--zui-card-gradient-red-from-dark,oklch(25.8%_0.092_26.042_/_0.7))] to-[var(--zui-card-gradient-red-to,oklch(97.1%_0.014_343.198))] dark:to-[var(--zui-card-gradient-red-to-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl\",\n \"gradient-yellow\":\n \"border border-[color:var(--zui-card-gradient-yellow-border,oklch(47.6%_0.114_61.907))] dark:border-[color:var(--zui-card-gradient-yellow-border-dark,oklch(68.1%_0.162_75.834))] bg-linear-to-r from-[var(--zui-card-gradient-yellow-from,oklch(98.7%_0.026_102.212))] dark:from-[var(--zui-card-gradient-yellow-from-dark,oklch(28.6%_0.066_53.813_/_0.7))] to-[var(--zui-card-gradient-yellow-to,oklch(98%_0.016_73.684))] dark:to-[var(--zui-card-gradient-yellow-to-dark,oklch(26.6%_0.079_36.259_/_0.7))] backdrop-blur-xl\",\n \"gradient-purple\":\n \"border border-[color:var(--zui-card-gradient-purple-border,oklch(43.8%_0.218_303.724))] dark:border-[color:var(--zui-card-gradient-purple-border-dark,oklch(55.8%_0.288_302.321))] bg-linear-to-r from-[var(--zui-card-gradient-purple-from,oklch(97.7%_0.014_308.299))] dark:from-[var(--zui-card-gradient-purple-from-dark,oklch(29.1%_0.149_302.717_/_0.7))] to-[var(--zui-card-gradient-purple-to,oklch(97.1%_0.014_343.198))] dark:to-[var(--zui-card-gradient-purple-to-dark,oklch(28.4%_0.109_3.907_/_0.7))] backdrop-blur-xl\",\n \"gradient-teal\":\n \"border border-[color:var(--zui-card-gradient-teal-border,oklch(43.7%_0.078_188.216))] dark:border-[color:var(--zui-card-gradient-teal-border-dark,oklch(60%_0.118_184.704))] bg-linear-to-r from-[var(--zui-card-gradient-teal-from,oklch(98.4%_0.014_180.72))] dark:from-[var(--zui-card-gradient-teal-from-dark,oklch(27.7%_0.046_192.524_/_0.7))] to-[var(--zui-card-gradient-teal-to,oklch(98.4%_0.019_200.873))] dark:to-[var(--zui-card-gradient-teal-to-dark,oklch(30.2%_0.056_229.695_/_0.7))] backdrop-blur-xl\",\n \"gradient-indigo\":\n \"border border-[color:var(--zui-card-gradient-indigo-border,oklch(39.8%_0.195_277.366))] dark:border-[color:var(--zui-card-gradient-indigo-border-dark,oklch(51.1%_0.262_276.966))] bg-linear-to-r from-[var(--zui-card-gradient-indigo-from,oklch(96.2%_0.018_272.314))] dark:from-[var(--zui-card-gradient-indigo-from-dark,oklch(25.7%_0.09_281.288_/_0.7))] to-[var(--zui-card-gradient-indigo-to,oklch(97.7%_0.014_308.299))] dark:to-[var(--zui-card-gradient-indigo-to-dark,oklch(29.1%_0.149_302.717_/_0.7))] backdrop-blur-xl\",\n \"gradient-pink\":\n \"border border-[color:var(--zui-card-gradient-pink-border,oklch(45.9%_0.187_3.815))] dark:border-[color:var(--zui-card-gradient-pink-border-dark,oklch(59.2%_0.249_0.584))] bg-linear-to-r from-[var(--zui-card-gradient-pink-from,oklch(97.1%_0.014_343.198))] dark:from-[var(--zui-card-gradient-pink-from-dark,oklch(28.4%_0.109_3.907_/_0.7))] to-[var(--zui-card-gradient-pink-to,oklch(96.9%_0.015_12.422))] dark:to-[var(--zui-card-gradient-pink-to-dark,oklch(27.1%_0.105_12.094_/_0.7))] backdrop-blur-xl\",\n \"gradient-orange\":\n \"border border-[color:var(--zui-card-gradient-orange-border,oklch(47%_0.157_37.304))] dark:border-[color:var(--zui-card-gradient-orange-border-dark,oklch(64.6%_0.222_41.116))] bg-linear-to-r from-[var(--zui-card-gradient-orange-from,oklch(98%_0.016_73.684))] dark:from-[var(--zui-card-gradient-orange-from-dark,oklch(26.6%_0.079_36.259_/_0.7))] to-[var(--zui-card-gradient-orange-to,oklch(97.1%_0.013_17.38))] dark:to-[var(--zui-card-gradient-orange-to-dark,oklch(25.8%_0.092_26.042_/_0.7))] backdrop-blur-xl\",\n} as const;\n\nexport const zuiCardSizes = {\n sm: \"gap-2 p-3 text-sm\",\n md: \"gap-3 p-4 text-sm\",\n lg: \"gap-4 p-6 text-base\",\n} as const;\n\nexport const zuiCardRounded = {\n sm: \"rounded-lg\",\n md: \"rounded-xl\",\n lg: \"rounded-2xl\",\n full: \"rounded-3xl\",\n} as const;\n\nexport const zuiCardHeaderBase =\n \"flex flex-col gap-1 border-b border-[color:var(--zui-card-header-border,#0000001a)] dark:border-[color:var(--zui-card-header-border-dark,#ffffff1a)] pb-3\";\n\nexport const zuiCardHeaderSizes = {\n sm: \"pb-2\",\n md: \"pb-3\",\n lg: \"pb-4\",\n} as const;\n\nexport const zuiCardFooterBase =\n \"flex flex-col gap-2 border-t border-[color:var(--zui-card-footer-border,#0000001a)] dark:border-[color:var(--zui-card-footer-border-dark,#ffffff1a)] pt-3\";\n\nexport const zuiCardFooterSizes = {\n sm: \"pt-2\",\n md: \"pt-3\",\n lg: \"pt-4\",\n} as const;\n\nexport const zuiCardTitleBase =\n \"font-semibold tracking-tight text-[color:var(--zui-card-title-fg,oklch(12.9%_0.042_264.695))] dark:text-[color:var(--zui-card-title-fg-dark,#ffffff)]\";\n\nexport const zuiCardTitleSizes = {\n sm: \"text-sm\",\n md: \"text-base\",\n lg: \"text-lg\",\n} as const;\n\nexport const zuiCardDescriptionBase =\n \"text-[color:var(--zui-card-description-fg,oklch(55.4%_0.046_257.417))] dark:text-[color:var(--zui-card-description-fg-dark,oklch(98.4%_0.003_247.858))]\";\n\nexport const zuiCardDescriptionSizes = {\n sm: \"text-xs\",\n md: \"text-sm\",\n lg: \"text-base\",\n} as const;\n","import { cva } from \"class-variance-authority\";\n\nimport {\n zuiCardAppearances,\n zuiCardBase,\n zuiCardDescriptionBase,\n zuiCardDescriptionSizes,\n zuiCardFooterBase,\n zuiCardFooterSizes,\n zuiCardHeaderBase,\n zuiCardHeaderSizes,\n zuiCardRounded,\n zuiCardSizes,\n zuiCardTitleBase,\n zuiCardTitleSizes,\n} from \"../../design-system/card\";\n\nexport const cardVariants = cva(zuiCardBase, {\n variants: {\n appearance: zuiCardAppearances,\n size: zuiCardSizes,\n rounded: zuiCardRounded,\n },\n defaultVariants: {\n appearance: \"default\",\n size: \"md\",\n rounded: \"md\",\n },\n});\n\nexport const cardHeaderVariants = cva(zuiCardHeaderBase, {\n variants: {\n size: zuiCardHeaderSizes,\n },\n defaultVariants: { size: \"md\" },\n});\n\nexport const cardFooterVariants = cva(zuiCardFooterBase, {\n variants: {\n size: zuiCardFooterSizes,\n },\n defaultVariants: { size: \"md\" },\n});\n\nexport const cardTitleVariants = cva(zuiCardTitleBase, {\n variants: {\n size: zuiCardTitleSizes,\n },\n defaultVariants: { size: \"md\" },\n});\n\nexport const cardDescriptionVariants = cva(zuiCardDescriptionBase, {\n variants: {\n size: zuiCardDescriptionSizes,\n },\n defaultVariants: { size: \"md\" },\n});\n","\"use client\";\n\nimport { createContext, useContext, useMemo, type ElementType } from \"react\";\n\nimport { cn } from \"../../lib/utils\";\n\nimport type {\n CardBaseProps,\n CardDescriptionProps,\n CardSectionProps,\n CardSize,\n CardTitleProps,\n} from \"./types\";\nimport {\n cardDescriptionVariants,\n cardFooterVariants,\n cardHeaderVariants,\n cardTitleVariants,\n cardVariants,\n} from \"./variants\";\n\nconst CardSizeContext = createContext<CardSize>(\"md\");\n\nfunction useCardSize(): CardSize {\n return useContext(CardSizeContext);\n}\n\nexport function CardBase({\n className,\n appearance,\n size = \"md\",\n rounded,\n children,\n ref,\n as: Wrapper = \"article\",\n ...rest\n}: CardBaseProps) {\n const ctx = useMemo(() => size ?? \"md\", [size]);\n\n return (\n <CardSizeContext.Provider value={ctx}>\n <Wrapper\n ref={ref}\n data-slot=\"card\"\n className={cn(cardVariants({ appearance, size, rounded }), className)}\n {...rest}\n >\n {children}\n </Wrapper>\n </CardSizeContext.Provider>\n );\n}\n\nCardBase.displayName = \"Card\";\n\nexport function CardHeader({ className, children }: CardSectionProps) {\n const size = useCardSize();\n return (\n <header\n data-slot=\"card-header\"\n className={cn(cardHeaderVariants({ size }), className)}\n >\n {children}\n </header>\n );\n}\n\nCardHeader.displayName = \"CardHeader\";\n\nexport function CardBody({ className, children }: CardSectionProps) {\n return (\n <div\n data-slot=\"card-body\"\n className={cn(\"flex flex-1 flex-col gap-2\", className)}\n >\n {children}\n </div>\n );\n}\n\nCardBody.displayName = \"CardBody\";\n\nexport function CardFooter({ className, children }: CardSectionProps) {\n const size = useCardSize();\n return (\n <footer\n data-slot=\"card-footer\"\n className={cn(cardFooterVariants({ size }), className)}\n >\n {children}\n </footer>\n );\n}\n\nCardFooter.displayName = \"CardFooter\";\n\nexport function CardTitle({\n className,\n children,\n as = \"h3\",\n ref,\n ...rest\n}: CardTitleProps) {\n const size = useCardSize();\n const Tag = as as ElementType;\n return (\n <Tag\n ref={ref as never}\n data-slot=\"card-title\"\n className={cn(cardTitleVariants({ size }), className)}\n {...rest}\n >\n {children}\n </Tag>\n );\n}\n\nCardTitle.displayName = \"CardTitle\";\n\nexport function CardDescription({\n className,\n children,\n as = \"p\",\n ref,\n ...rest\n}: CardDescriptionProps) {\n const size = useCardSize();\n const Tag = as as ElementType;\n return (\n <Tag\n ref={ref as never}\n data-slot=\"card-description\"\n className={cn(cardDescriptionVariants({ size }), className)}\n {...rest}\n >\n {children}\n </Tag>\n );\n}\n\nCardDescription.displayName = \"CardDescription\";\n"]}