@misael703/ui 1.0.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 (456) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +462 -0
  3. package/dist/brand.d.mts +46 -0
  4. package/dist/brand.d.ts +46 -0
  5. package/dist/brand.js +24 -0
  6. package/dist/brand.js.map +1 -0
  7. package/dist/brand.mjs +3 -0
  8. package/dist/brand.mjs.map +1 -0
  9. package/dist/chunk-26KJA67X.js +166 -0
  10. package/dist/chunk-26KJA67X.js.map +1 -0
  11. package/dist/chunk-2JTBLDMK.js +274 -0
  12. package/dist/chunk-2JTBLDMK.js.map +1 -0
  13. package/dist/chunk-2RVSLQEA.mjs +171 -0
  14. package/dist/chunk-2RVSLQEA.mjs.map +1 -0
  15. package/dist/chunk-2UV37SEN.mjs +78 -0
  16. package/dist/chunk-2UV37SEN.mjs.map +1 -0
  17. package/dist/chunk-33PU6AH7.mjs +123 -0
  18. package/dist/chunk-33PU6AH7.mjs.map +1 -0
  19. package/dist/chunk-3PXYCXDW.js +32 -0
  20. package/dist/chunk-3PXYCXDW.js.map +1 -0
  21. package/dist/chunk-3TNBETXR.js +116 -0
  22. package/dist/chunk-3TNBETXR.js.map +1 -0
  23. package/dist/chunk-3UHX7ITQ.mjs +76 -0
  24. package/dist/chunk-3UHX7ITQ.mjs.map +1 -0
  25. package/dist/chunk-4REALDR3.js +4 -0
  26. package/dist/chunk-4REALDR3.js.map +1 -0
  27. package/dist/chunk-55TOQMS2.js +142 -0
  28. package/dist/chunk-55TOQMS2.js.map +1 -0
  29. package/dist/chunk-5GEWIK4T.mjs +27 -0
  30. package/dist/chunk-5GEWIK4T.mjs.map +1 -0
  31. package/dist/chunk-5VMZMDJF.js +145 -0
  32. package/dist/chunk-5VMZMDJF.js.map +1 -0
  33. package/dist/chunk-6II4NJQM.js +127 -0
  34. package/dist/chunk-6II4NJQM.js.map +1 -0
  35. package/dist/chunk-6LOJIU3C.js +84 -0
  36. package/dist/chunk-6LOJIU3C.js.map +1 -0
  37. package/dist/chunk-6MEOR4YO.mjs +45 -0
  38. package/dist/chunk-6MEOR4YO.mjs.map +1 -0
  39. package/dist/chunk-6PEC4RRO.mjs +94 -0
  40. package/dist/chunk-6PEC4RRO.mjs.map +1 -0
  41. package/dist/chunk-7AKN7FDA.mjs +103 -0
  42. package/dist/chunk-7AKN7FDA.mjs.map +1 -0
  43. package/dist/chunk-AAQ7KUZH.mjs +352 -0
  44. package/dist/chunk-AAQ7KUZH.mjs.map +1 -0
  45. package/dist/chunk-ADIKHOEG.js +212 -0
  46. package/dist/chunk-ADIKHOEG.js.map +1 -0
  47. package/dist/chunk-ADQM725E.js +141 -0
  48. package/dist/chunk-ADQM725E.js.map +1 -0
  49. package/dist/chunk-AWYCGJJX.js +102 -0
  50. package/dist/chunk-AWYCGJJX.js.map +1 -0
  51. package/dist/chunk-AZBX7UFI.js +100 -0
  52. package/dist/chunk-AZBX7UFI.js.map +1 -0
  53. package/dist/chunk-BCIZLGM3.mjs +78 -0
  54. package/dist/chunk-BCIZLGM3.mjs.map +1 -0
  55. package/dist/chunk-BMZQ6L2C.js +294 -0
  56. package/dist/chunk-BMZQ6L2C.js.map +1 -0
  57. package/dist/chunk-CHVTPN3K.mjs +3 -0
  58. package/dist/chunk-CHVTPN3K.mjs.map +1 -0
  59. package/dist/chunk-CIBJKJV3.mjs +314 -0
  60. package/dist/chunk-CIBJKJV3.mjs.map +1 -0
  61. package/dist/chunk-CPMQ2DFS.js +197 -0
  62. package/dist/chunk-CPMQ2DFS.js.map +1 -0
  63. package/dist/chunk-CVXS7IHA.js +376 -0
  64. package/dist/chunk-CVXS7IHA.js.map +1 -0
  65. package/dist/chunk-DHCJMYFD.mjs +76 -0
  66. package/dist/chunk-DHCJMYFD.mjs.map +1 -0
  67. package/dist/chunk-DW3XAXHR.mjs +146 -0
  68. package/dist/chunk-DW3XAXHR.mjs.map +1 -0
  69. package/dist/chunk-E2XOUDAH.js +215 -0
  70. package/dist/chunk-E2XOUDAH.js.map +1 -0
  71. package/dist/chunk-EJJDJJEM.js +505 -0
  72. package/dist/chunk-EJJDJJEM.js.map +1 -0
  73. package/dist/chunk-FXM7OKDQ.js +146 -0
  74. package/dist/chunk-FXM7OKDQ.js.map +1 -0
  75. package/dist/chunk-GCW5JYWQ.js +69 -0
  76. package/dist/chunk-GCW5JYWQ.js.map +1 -0
  77. package/dist/chunk-GDFYAUHT.mjs +192 -0
  78. package/dist/chunk-GDFYAUHT.mjs.map +1 -0
  79. package/dist/chunk-GT2KVC2P.mjs +267 -0
  80. package/dist/chunk-GT2KVC2P.mjs.map +1 -0
  81. package/dist/chunk-GVYZAOWU.mjs +142 -0
  82. package/dist/chunk-GVYZAOWU.mjs.map +1 -0
  83. package/dist/chunk-HI3JT6SI.mjs +174 -0
  84. package/dist/chunk-HI3JT6SI.mjs.map +1 -0
  85. package/dist/chunk-HPFJ2A24.js +125 -0
  86. package/dist/chunk-HPFJ2A24.js.map +1 -0
  87. package/dist/chunk-HVUNNL3A.mjs +244 -0
  88. package/dist/chunk-HVUNNL3A.mjs.map +1 -0
  89. package/dist/chunk-HYUINOPJ.js +173 -0
  90. package/dist/chunk-HYUINOPJ.js.map +1 -0
  91. package/dist/chunk-IEPCH3JB.mjs +8 -0
  92. package/dist/chunk-IEPCH3JB.mjs.map +1 -0
  93. package/dist/chunk-IIYQO6BL.js +98 -0
  94. package/dist/chunk-IIYQO6BL.js.map +1 -0
  95. package/dist/chunk-IMFQ55KO.js +131 -0
  96. package/dist/chunk-IMFQ55KO.js.map +1 -0
  97. package/dist/chunk-IVL7P3MF.mjs +105 -0
  98. package/dist/chunk-IVL7P3MF.mjs.map +1 -0
  99. package/dist/chunk-JDOXRLZW.js +138 -0
  100. package/dist/chunk-JDOXRLZW.js.map +1 -0
  101. package/dist/chunk-JMFDIN5R.mjs +64 -0
  102. package/dist/chunk-JMFDIN5R.mjs.map +1 -0
  103. package/dist/chunk-KKOJI25C.mjs +11 -0
  104. package/dist/chunk-KKOJI25C.mjs.map +1 -0
  105. package/dist/chunk-L353APIO.js +131 -0
  106. package/dist/chunk-L353APIO.js.map +1 -0
  107. package/dist/chunk-LIGJBHXU.js +13 -0
  108. package/dist/chunk-LIGJBHXU.js.map +1 -0
  109. package/dist/chunk-LUXTZOTJ.js +204 -0
  110. package/dist/chunk-LUXTZOTJ.js.map +1 -0
  111. package/dist/chunk-ML5IYW5D.mjs +82 -0
  112. package/dist/chunk-ML5IYW5D.mjs.map +1 -0
  113. package/dist/chunk-NLCKWF3Y.mjs +88 -0
  114. package/dist/chunk-NLCKWF3Y.mjs.map +1 -0
  115. package/dist/chunk-NU4GAGUV.js +86 -0
  116. package/dist/chunk-NU4GAGUV.js.map +1 -0
  117. package/dist/chunk-NUURPO3J.mjs +120 -0
  118. package/dist/chunk-NUURPO3J.mjs.map +1 -0
  119. package/dist/chunk-O6FCBNWN.mjs +191 -0
  120. package/dist/chunk-O6FCBNWN.mjs.map +1 -0
  121. package/dist/chunk-OCE4ODTM.mjs +116 -0
  122. package/dist/chunk-OCE4ODTM.mjs.map +1 -0
  123. package/dist/chunk-ORUQ5GCU.mjs +120 -0
  124. package/dist/chunk-ORUQ5GCU.mjs.map +1 -0
  125. package/dist/chunk-PASF6T4H.js +10 -0
  126. package/dist/chunk-PASF6T4H.js.map +1 -0
  127. package/dist/chunk-PCRNKITV.mjs +106 -0
  128. package/dist/chunk-PCRNKITV.mjs.map +1 -0
  129. package/dist/chunk-PSJVU4E4.js +72 -0
  130. package/dist/chunk-PSJVU4E4.js.map +1 -0
  131. package/dist/chunk-PXCH5Z76.mjs +82 -0
  132. package/dist/chunk-PXCH5Z76.mjs.map +1 -0
  133. package/dist/chunk-QHRP73CS.js +106 -0
  134. package/dist/chunk-QHRP73CS.js.map +1 -0
  135. package/dist/chunk-QI6TVWWF.js +121 -0
  136. package/dist/chunk-QI6TVWWF.js.map +1 -0
  137. package/dist/chunk-QSCJ2CER.mjs +480 -0
  138. package/dist/chunk-QSCJ2CER.mjs.map +1 -0
  139. package/dist/chunk-R76YER7O.js +458 -0
  140. package/dist/chunk-R76YER7O.js.map +1 -0
  141. package/dist/chunk-RBJRQ44B.mjs +108 -0
  142. package/dist/chunk-RBJRQ44B.mjs.map +1 -0
  143. package/dist/chunk-RQOTH7I7.js +401 -0
  144. package/dist/chunk-RQOTH7I7.js.map +1 -0
  145. package/dist/chunk-SYX4GZ7E.mjs +134 -0
  146. package/dist/chunk-SYX4GZ7E.mjs.map +1 -0
  147. package/dist/chunk-T4R2LSRL.js +148 -0
  148. package/dist/chunk-T4R2LSRL.js.map +1 -0
  149. package/dist/chunk-TB6EHWRF.mjs +92 -0
  150. package/dist/chunk-TB6EHWRF.mjs.map +1 -0
  151. package/dist/chunk-TEQ67JKX.js +181 -0
  152. package/dist/chunk-TEQ67JKX.js.map +1 -0
  153. package/dist/chunk-TXKFCVCN.mjs +426 -0
  154. package/dist/chunk-TXKFCVCN.mjs.map +1 -0
  155. package/dist/chunk-TZG34EYW.js +74 -0
  156. package/dist/chunk-TZG34EYW.js.map +1 -0
  157. package/dist/chunk-UB2XEZ7C.mjs +72 -0
  158. package/dist/chunk-UB2XEZ7C.mjs.map +1 -0
  159. package/dist/chunk-UIKCTWKG.js +116 -0
  160. package/dist/chunk-UIKCTWKG.js.map +1 -0
  161. package/dist/chunk-UNOPDYA7.js +107 -0
  162. package/dist/chunk-UNOPDYA7.js.map +1 -0
  163. package/dist/chunk-V26K66NP.mjs +49 -0
  164. package/dist/chunk-V26K66NP.mjs.map +1 -0
  165. package/dist/chunk-W6YOBPL5.js +110 -0
  166. package/dist/chunk-W6YOBPL5.js.map +1 -0
  167. package/dist/chunk-X2DBGT7M.mjs +117 -0
  168. package/dist/chunk-X2DBGT7M.mjs.map +1 -0
  169. package/dist/chunk-YBOTLQ3G.mjs +99 -0
  170. package/dist/chunk-YBOTLQ3G.mjs.map +1 -0
  171. package/dist/chunk-Z3FAKG3E.mjs +125 -0
  172. package/dist/chunk-Z3FAKG3E.mjs.map +1 -0
  173. package/dist/chunk-Z4GRQHIG.mjs +177 -0
  174. package/dist/chunk-Z4GRQHIG.mjs.map +1 -0
  175. package/dist/chunk-ZRBVYPKN.js +169 -0
  176. package/dist/chunk-ZRBVYPKN.js.map +1 -0
  177. package/dist/chunk-ZRFSTYRL.mjs +157 -0
  178. package/dist/chunk-ZRFSTYRL.mjs.map +1 -0
  179. package/dist/chunk-ZXSSOEIM.js +197 -0
  180. package/dist/chunk-ZXSSOEIM.js.map +1 -0
  181. package/dist/components/AdvancedPickers.d.mts +77 -0
  182. package/dist/components/AdvancedPickers.d.ts +77 -0
  183. package/dist/components/AdvancedPickers.js +30 -0
  184. package/dist/components/AdvancedPickers.js.map +1 -0
  185. package/dist/components/AdvancedPickers.mjs +9 -0
  186. package/dist/components/AdvancedPickers.mjs.map +1 -0
  187. package/dist/components/AppShell.d.mts +55 -0
  188. package/dist/components/AppShell.d.ts +55 -0
  189. package/dist/components/AppShell.js +19 -0
  190. package/dist/components/AppShell.js.map +1 -0
  191. package/dist/components/AppShell.mjs +6 -0
  192. package/dist/components/AppShell.mjs.map +1 -0
  193. package/dist/components/Button.d.mts +16 -0
  194. package/dist/components/Button.d.ts +16 -0
  195. package/dist/components/Button.js +17 -0
  196. package/dist/components/Button.js.map +1 -0
  197. package/dist/components/Button.mjs +4 -0
  198. package/dist/components/Button.mjs.map +1 -0
  199. package/dist/components/Carousel.d.mts +17 -0
  200. package/dist/components/Carousel.d.ts +17 -0
  201. package/dist/components/Carousel.js +14 -0
  202. package/dist/components/Carousel.js.map +1 -0
  203. package/dist/components/Carousel.mjs +5 -0
  204. package/dist/components/Carousel.mjs.map +1 -0
  205. package/dist/components/Charts.d.mts +96 -0
  206. package/dist/components/Charts.d.ts +96 -0
  207. package/dist/components/Charts.js +29 -0
  208. package/dist/components/Charts.js.map +1 -0
  209. package/dist/components/Charts.mjs +4 -0
  210. package/dist/components/Charts.mjs.map +1 -0
  211. package/dist/components/Code.d.mts +18 -0
  212. package/dist/components/Code.d.ts +18 -0
  213. package/dist/components/Code.js +18 -0
  214. package/dist/components/Code.js.map +1 -0
  215. package/dist/components/Code.mjs +5 -0
  216. package/dist/components/Code.mjs.map +1 -0
  217. package/dist/components/Collapsible.d.mts +12 -0
  218. package/dist/components/Collapsible.d.ts +12 -0
  219. package/dist/components/Collapsible.js +21 -0
  220. package/dist/components/Collapsible.js.map +1 -0
  221. package/dist/components/Collapsible.mjs +4 -0
  222. package/dist/components/Collapsible.mjs.map +1 -0
  223. package/dist/components/Comments.d.mts +41 -0
  224. package/dist/components/Comments.d.ts +41 -0
  225. package/dist/components/Comments.js +25 -0
  226. package/dist/components/Comments.js.map +1 -0
  227. package/dist/components/Comments.mjs +8 -0
  228. package/dist/components/Comments.mjs.map +1 -0
  229. package/dist/components/Commerce.d.mts +159 -0
  230. package/dist/components/Commerce.d.ts +159 -0
  231. package/dist/components/Commerce.js +58 -0
  232. package/dist/components/Commerce.js.map +1 -0
  233. package/dist/components/Commerce.mjs +9 -0
  234. package/dist/components/Commerce.mjs.map +1 -0
  235. package/dist/components/ContextMenu.d.mts +22 -0
  236. package/dist/components/ContextMenu.d.ts +22 -0
  237. package/dist/components/ContextMenu.js +13 -0
  238. package/dist/components/ContextMenu.js.map +1 -0
  239. package/dist/components/ContextMenu.mjs +4 -0
  240. package/dist/components/ContextMenu.mjs.map +1 -0
  241. package/dist/components/DataTable.d.mts +121 -0
  242. package/dist/components/DataTable.d.ts +121 -0
  243. package/dist/components/DataTable.js +38 -0
  244. package/dist/components/DataTable.js.map +1 -0
  245. package/dist/components/DataTable.mjs +9 -0
  246. package/dist/components/DataTable.mjs.map +1 -0
  247. package/dist/components/Display.d.mts +56 -0
  248. package/dist/components/Display.d.ts +56 -0
  249. package/dist/components/Display.js +55 -0
  250. package/dist/components/Display.js.map +1 -0
  251. package/dist/components/Display.mjs +6 -0
  252. package/dist/components/Display.mjs.map +1 -0
  253. package/dist/components/Display2.d.mts +54 -0
  254. package/dist/components/Display2.d.ts +54 -0
  255. package/dist/components/Display2.js +26 -0
  256. package/dist/components/Display2.js.map +1 -0
  257. package/dist/components/Display2.mjs +5 -0
  258. package/dist/components/Display2.mjs.map +1 -0
  259. package/dist/components/Display3.d.mts +58 -0
  260. package/dist/components/Display3.d.ts +58 -0
  261. package/dist/components/Display3.js +36 -0
  262. package/dist/components/Display3.js.map +1 -0
  263. package/dist/components/Display3.mjs +7 -0
  264. package/dist/components/Display3.mjs.map +1 -0
  265. package/dist/components/Editing.d.mts +52 -0
  266. package/dist/components/Editing.d.ts +52 -0
  267. package/dist/components/Editing.js +33 -0
  268. package/dist/components/Editing.js.map +1 -0
  269. package/dist/components/Editing.mjs +8 -0
  270. package/dist/components/Editing.mjs.map +1 -0
  271. package/dist/components/Filters.d.mts +37 -0
  272. package/dist/components/Filters.d.ts +37 -0
  273. package/dist/components/Filters.js +28 -0
  274. package/dist/components/Filters.js.map +1 -0
  275. package/dist/components/Filters.mjs +7 -0
  276. package/dist/components/Filters.mjs.map +1 -0
  277. package/dist/components/Form.d.mts +55 -0
  278. package/dist/components/Form.d.ts +55 -0
  279. package/dist/components/Form.js +50 -0
  280. package/dist/components/Form.js.map +1 -0
  281. package/dist/components/Form.mjs +5 -0
  282. package/dist/components/Form.mjs.map +1 -0
  283. package/dist/components/Gallery.d.mts +28 -0
  284. package/dist/components/Gallery.d.ts +28 -0
  285. package/dist/components/Gallery.js +20 -0
  286. package/dist/components/Gallery.js.map +1 -0
  287. package/dist/components/Gallery.mjs +7 -0
  288. package/dist/components/Gallery.mjs.map +1 -0
  289. package/dist/components/HoverCard.d.mts +17 -0
  290. package/dist/components/HoverCard.d.ts +17 -0
  291. package/dist/components/HoverCard.js +13 -0
  292. package/dist/components/HoverCard.js.map +1 -0
  293. package/dist/components/HoverCard.mjs +4 -0
  294. package/dist/components/HoverCard.mjs.map +1 -0
  295. package/dist/components/Icons.d.mts +84 -0
  296. package/dist/components/Icons.d.ts +84 -0
  297. package/dist/components/Icons.js +272 -0
  298. package/dist/components/Icons.js.map +1 -0
  299. package/dist/components/Icons.mjs +3 -0
  300. package/dist/components/Icons.mjs.map +1 -0
  301. package/dist/components/InputOTP.d.mts +17 -0
  302. package/dist/components/InputOTP.d.ts +17 -0
  303. package/dist/components/InputOTP.js +13 -0
  304. package/dist/components/InputOTP.js.map +1 -0
  305. package/dist/components/InputOTP.mjs +4 -0
  306. package/dist/components/InputOTP.mjs.map +1 -0
  307. package/dist/components/Inputs.d.mts +45 -0
  308. package/dist/components/Inputs.d.ts +45 -0
  309. package/dist/components/Inputs.js +28 -0
  310. package/dist/components/Inputs.js.map +1 -0
  311. package/dist/components/Inputs.mjs +7 -0
  312. package/dist/components/Inputs.mjs.map +1 -0
  313. package/dist/components/InputsExtra.d.mts +98 -0
  314. package/dist/components/InputsExtra.d.ts +98 -0
  315. package/dist/components/InputsExtra.js +49 -0
  316. package/dist/components/InputsExtra.js.map +1 -0
  317. package/dist/components/InputsExtra.mjs +8 -0
  318. package/dist/components/InputsExtra.mjs.map +1 -0
  319. package/dist/components/Layout.d.mts +83 -0
  320. package/dist/components/Layout.d.ts +83 -0
  321. package/dist/components/Layout.js +78 -0
  322. package/dist/components/Layout.js.map +1 -0
  323. package/dist/components/Layout.mjs +5 -0
  324. package/dist/components/Layout.mjs.map +1 -0
  325. package/dist/components/Logo.d.mts +38 -0
  326. package/dist/components/Logo.d.ts +38 -0
  327. package/dist/components/Logo.js +14 -0
  328. package/dist/components/Logo.js.map +1 -0
  329. package/dist/components/Logo.mjs +5 -0
  330. package/dist/components/Logo.mjs.map +1 -0
  331. package/dist/components/Marketing.d.mts +46 -0
  332. package/dist/components/Marketing.d.ts +46 -0
  333. package/dist/components/Marketing.js +22 -0
  334. package/dist/components/Marketing.js.map +1 -0
  335. package/dist/components/Marketing.mjs +5 -0
  336. package/dist/components/Marketing.mjs.map +1 -0
  337. package/dist/components/Menubar.d.mts +24 -0
  338. package/dist/components/Menubar.d.ts +24 -0
  339. package/dist/components/Menubar.js +13 -0
  340. package/dist/components/Menubar.js.map +1 -0
  341. package/dist/components/Menubar.mjs +4 -0
  342. package/dist/components/Menubar.mjs.map +1 -0
  343. package/dist/components/NavigationMenu.d.mts +28 -0
  344. package/dist/components/NavigationMenu.d.ts +28 -0
  345. package/dist/components/NavigationMenu.js +14 -0
  346. package/dist/components/NavigationMenu.js.map +1 -0
  347. package/dist/components/NavigationMenu.mjs +5 -0
  348. package/dist/components/NavigationMenu.mjs.map +1 -0
  349. package/dist/components/Notifications.d.mts +25 -0
  350. package/dist/components/Notifications.d.ts +25 -0
  351. package/dist/components/Notifications.js +16 -0
  352. package/dist/components/Notifications.js.map +1 -0
  353. package/dist/components/Notifications.mjs +7 -0
  354. package/dist/components/Notifications.mjs.map +1 -0
  355. package/dist/components/Overlay.d.mts +20 -0
  356. package/dist/components/Overlay.d.ts +20 -0
  357. package/dist/components/Overlay.js +19 -0
  358. package/dist/components/Overlay.js.map +1 -0
  359. package/dist/components/Overlay.mjs +6 -0
  360. package/dist/components/Overlay.mjs.map +1 -0
  361. package/dist/components/Permissions.d.mts +23 -0
  362. package/dist/components/Permissions.d.ts +23 -0
  363. package/dist/components/Permissions.js +17 -0
  364. package/dist/components/Permissions.js.map +1 -0
  365. package/dist/components/Permissions.mjs +8 -0
  366. package/dist/components/Permissions.mjs.map +1 -0
  367. package/dist/components/Pickers.d.mts +54 -0
  368. package/dist/components/Pickers.d.ts +54 -0
  369. package/dist/components/Pickers.js +25 -0
  370. package/dist/components/Pickers.js.map +1 -0
  371. package/dist/components/Pickers.mjs +8 -0
  372. package/dist/components/Pickers.mjs.map +1 -0
  373. package/dist/components/Popover.d.mts +23 -0
  374. package/dist/components/Popover.d.ts +23 -0
  375. package/dist/components/Popover.js +13 -0
  376. package/dist/components/Popover.js.map +1 -0
  377. package/dist/components/Popover.mjs +4 -0
  378. package/dist/components/Popover.mjs.map +1 -0
  379. package/dist/components/Primitives.d.mts +18 -0
  380. package/dist/components/Primitives.d.ts +18 -0
  381. package/dist/components/Primitives.js +21 -0
  382. package/dist/components/Primitives.js.map +1 -0
  383. package/dist/components/Primitives.mjs +4 -0
  384. package/dist/components/Primitives.mjs.map +1 -0
  385. package/dist/components/Resizable.d.mts +27 -0
  386. package/dist/components/Resizable.d.ts +27 -0
  387. package/dist/components/Resizable.js +21 -0
  388. package/dist/components/Resizable.js.map +1 -0
  389. package/dist/components/Resizable.mjs +4 -0
  390. package/dist/components/Resizable.mjs.map +1 -0
  391. package/dist/components/Toast.d.mts +21 -0
  392. package/dist/components/Toast.d.ts +21 -0
  393. package/dist/components/Toast.js +19 -0
  394. package/dist/components/Toast.js.map +1 -0
  395. package/dist/components/Toast.mjs +6 -0
  396. package/dist/components/Toast.mjs.map +1 -0
  397. package/dist/components/Toggle.d.mts +42 -0
  398. package/dist/components/Toggle.d.ts +42 -0
  399. package/dist/components/Toggle.js +21 -0
  400. package/dist/components/Toggle.js.map +1 -0
  401. package/dist/components/Toggle.mjs +4 -0
  402. package/dist/components/Toggle.mjs.map +1 -0
  403. package/dist/fonts/DMSans-VariableFont_wght.woff2 +0 -0
  404. package/dist/fonts/OFL.txt +98 -0
  405. package/dist/fonts/Outfit-VariableFont_wght.woff2 +0 -0
  406. package/dist/fonts.css +1 -0
  407. package/dist/index.d.mts +43 -0
  408. package/dist/index.d.ts +43 -0
  409. package/dist/index.js +926 -0
  410. package/dist/index.js.map +1 -0
  411. package/dist/index.mjs +45 -0
  412. package/dist/index.mjs.map +1 -0
  413. package/dist/locale/index.d.mts +174 -0
  414. package/dist/locale/index.d.ts +174 -0
  415. package/dist/locale/index.js +26 -0
  416. package/dist/locale/index.js.map +1 -0
  417. package/dist/locale/index.mjs +5 -0
  418. package/dist/locale/index.mjs.map +1 -0
  419. package/dist/presets/elalba/defaults.d.mts +24 -0
  420. package/dist/presets/elalba/defaults.d.ts +24 -0
  421. package/dist/presets/elalba/defaults.js +13 -0
  422. package/dist/presets/elalba/defaults.js.map +1 -0
  423. package/dist/presets/elalba/defaults.mjs +11 -0
  424. package/dist/presets/elalba/defaults.mjs.map +1 -0
  425. package/dist/presets/elalba/logos/logo-horizontal-dark.png +0 -0
  426. package/dist/presets/elalba/logos/logo-horizontal-dark.svg +58 -0
  427. package/dist/presets/elalba/logos/logo-horizontal-light.png +0 -0
  428. package/dist/presets/elalba/logos/logo-horizontal-light.svg +68 -0
  429. package/dist/presets/elalba/logos/logo-vertical-dark.png +0 -0
  430. package/dist/presets/elalba/logos/logo-vertical-dark.svg +58 -0
  431. package/dist/presets/elalba/logos/logo-vertical-light.png +0 -0
  432. package/dist/presets/elalba/logos/logo-vertical-light.svg +68 -0
  433. package/dist/presets/elalba/logos/mark-dark.png +0 -0
  434. package/dist/presets/elalba/logos/mark-dark.svg +27 -0
  435. package/dist/presets/elalba/logos/mark-light.png +0 -0
  436. package/dist/presets/elalba/logos/mark-light.svg +27 -0
  437. package/dist/presets/elalba/logos/wordmark-dark.png +0 -0
  438. package/dist/presets/elalba/logos/wordmark-dark.svg +36 -0
  439. package/dist/presets/elalba/logos/wordmark-light.png +0 -0
  440. package/dist/presets/elalba/logos/wordmark-light.svg +36 -0
  441. package/dist/presets/elalba/styles.css +1 -0
  442. package/dist/styles.css +1 -0
  443. package/dist/tokens.css +1 -0
  444. package/dist/utils/cx.d.mts +3 -0
  445. package/dist/utils/cx.d.ts +3 -0
  446. package/dist/utils/cx.js +12 -0
  447. package/dist/utils/cx.js.map +1 -0
  448. package/dist/utils/cx.mjs +3 -0
  449. package/dist/utils/cx.mjs.map +1 -0
  450. package/dist/utils/dateFormat.d.mts +35 -0
  451. package/dist/utils/dateFormat.d.ts +35 -0
  452. package/dist/utils/dateFormat.js +29 -0
  453. package/dist/utils/dateFormat.js.map +1 -0
  454. package/dist/utils/dateFormat.mjs +4 -0
  455. package/dist/utils/dateFormat.mjs.map +1 -0
  456. package/package.json +94 -0
@@ -0,0 +1,84 @@
1
+ 'use strict';
2
+
3
+ var chunk3PXYCXDW_js = require('./chunk-3PXYCXDW.js');
4
+
5
+ // src/utils/dateFormat.ts
6
+ function detectFormatFromLocale(locale) {
7
+ try {
8
+ const parts = new Intl.DateTimeFormat(locale).formatToParts(new Date(2024, 0, 2));
9
+ const order = [];
10
+ for (const p of parts) {
11
+ if (p.type === "year") order.push("y");
12
+ else if (p.type === "month") order.push("m");
13
+ else if (p.type === "day") order.push("d");
14
+ }
15
+ const key = order.join("");
16
+ if (key === "ymd") return "iso";
17
+ if (key === "mdy") return "mdy";
18
+ return "dmy";
19
+ } catch {
20
+ return "dmy";
21
+ }
22
+ }
23
+ function resolveDateFormat(format) {
24
+ if (format === "auto") return detectFormatFromLocale(chunk3PXYCXDW_js.getBrand().locale);
25
+ return format;
26
+ }
27
+ var PLACEHOLDERS = {
28
+ iso: "aaaa-mm-dd",
29
+ dmy: "dd-mm-aaaa",
30
+ mdy: "mm-dd-aaaa"
31
+ };
32
+ function dateFormatPlaceholder(format) {
33
+ return PLACEHOLDERS[format];
34
+ }
35
+ function formatDate(d, format) {
36
+ const yyyy = d.getFullYear();
37
+ const mm = String(d.getMonth() + 1).padStart(2, "0");
38
+ const dd = String(d.getDate()).padStart(2, "0");
39
+ if (format === "iso") return `${yyyy}-${mm}-${dd}`;
40
+ if (format === "dmy") return `${dd}-${mm}-${yyyy}`;
41
+ return `${mm}-${dd}-${yyyy}`;
42
+ }
43
+ function parseDate(s, format) {
44
+ const trimmed = s.trim();
45
+ if (!trimmed) return null;
46
+ const iso = trimmed.match(/^(\d{4})-(\d{2})-(\d{2})$/);
47
+ if (iso) {
48
+ return safeDate(Number(iso[1]), Number(iso[2]), Number(iso[3]));
49
+ }
50
+ const m = trimmed.match(/^(\d{1,4})[\-\/.](\d{1,2})[\-\/.](\d{1,4})$/);
51
+ if (!m) return null;
52
+ let y, mo, d;
53
+ if (format === "iso") {
54
+ y = Number(m[1]);
55
+ mo = Number(m[2]);
56
+ d = Number(m[3]);
57
+ } else if (format === "dmy") {
58
+ d = Number(m[1]);
59
+ mo = Number(m[2]);
60
+ y = Number(m[3]);
61
+ } else {
62
+ mo = Number(m[1]);
63
+ d = Number(m[2]);
64
+ y = Number(m[3]);
65
+ }
66
+ if (y < 100) y += 2e3;
67
+ return safeDate(y, mo, d);
68
+ }
69
+ function safeDate(y, mo, d) {
70
+ if (mo < 1 || mo > 12 || d < 1 || d > 31) return null;
71
+ const dt = new Date(y, mo - 1, d);
72
+ if (isNaN(dt.getTime()) || dt.getFullYear() !== y || dt.getMonth() !== mo - 1 || dt.getDate() !== d) {
73
+ return null;
74
+ }
75
+ return dt;
76
+ }
77
+
78
+ exports.dateFormatPlaceholder = dateFormatPlaceholder;
79
+ exports.detectFormatFromLocale = detectFormatFromLocale;
80
+ exports.formatDate = formatDate;
81
+ exports.parseDate = parseDate;
82
+ exports.resolveDateFormat = resolveDateFormat;
83
+ //# sourceMappingURL=chunk-6LOJIU3C.js.map
84
+ //# sourceMappingURL=chunk-6LOJIU3C.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/dateFormat.ts"],"names":["getBrand"],"mappings":"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","file":"chunk-6LOJIU3C.js","sourcesContent":["import { getBrand } from '../brand';\n\n/**\n * Date display formats supported by the kit's date pickers.\n *\n * - `iso` → `2026-05-02` (ISO 8601, year-month-day)\n * - `dmy` → `02-05-2026` (day-month-year, common in es-CL, es-ES, en-GB, pt-BR)\n * - `mdy` → `05-02-2026` (month-day-year, en-US)\n * - `auto` → derived from `configureBrand().locale` via Intl.DateTimeFormat\n */\nexport type DateFormat = 'iso' | 'dmy' | 'mdy' | 'auto';\n\n/** A concrete (non-`auto`) format. */\nexport type ResolvedDateFormat = Exclude<DateFormat, 'auto'>;\n\n/**\n * Inspects the locale's date-part order using `Intl.DateTimeFormat.formatToParts`.\n * No hardcoded country lists — uses the runtime's CLDR data.\n */\nexport function detectFormatFromLocale(locale: string): ResolvedDateFormat {\n try {\n const parts = new Intl.DateTimeFormat(locale).formatToParts(new Date(2024, 0, 2));\n const order: string[] = [];\n for (const p of parts) {\n if (p.type === 'year') order.push('y');\n else if (p.type === 'month') order.push('m');\n else if (p.type === 'day') order.push('d');\n }\n const key = order.join('');\n if (key === 'ymd') return 'iso';\n if (key === 'mdy') return 'mdy';\n return 'dmy';\n } catch {\n return 'dmy';\n }\n}\n\n/** Resolves `'auto'` against the current `configureBrand().locale`. */\nexport function resolveDateFormat(format: DateFormat): ResolvedDateFormat {\n if (format === 'auto') return detectFormatFromLocale(getBrand().locale);\n return format;\n}\n\nconst PLACEHOLDERS: Record<ResolvedDateFormat, string> = {\n iso: 'aaaa-mm-dd',\n dmy: 'dd-mm-aaaa',\n mdy: 'mm-dd-aaaa',\n};\n\n/** Localized placeholder for the given resolved format. */\nexport function dateFormatPlaceholder(format: ResolvedDateFormat): string {\n return PLACEHOLDERS[format];\n}\n\n/** Format a Date as a string in the given resolved format. Always uses `-` as separator. */\nexport function formatDate(d: Date, format: ResolvedDateFormat): string {\n const yyyy = d.getFullYear();\n const mm = String(d.getMonth() + 1).padStart(2, '0');\n const dd = String(d.getDate()).padStart(2, '0');\n if (format === 'iso') return `${yyyy}-${mm}-${dd}`;\n if (format === 'dmy') return `${dd}-${mm}-${yyyy}`;\n return `${mm}-${dd}-${yyyy}`;\n}\n\n/**\n * Parse a user-typed date string. Tolerant of `-`, `/`, `.` separators.\n *\n * Always accepts ISO `aaaa-mm-dd` regardless of `format` (it's the canonical\n * wire format, used by APIs and `<input type=\"date\">`). Otherwise, interprets\n * the parts according to the provided format.\n *\n * Returns `null` for invalid dates (out of range, non-existent days like Feb 30,\n * unparseable strings).\n */\nexport function parseDate(s: string, format: ResolvedDateFormat): Date | null {\n const trimmed = s.trim();\n if (!trimmed) return null;\n\n // Always accept ISO as a fallback (wire format).\n const iso = trimmed.match(/^(\\d{4})-(\\d{2})-(\\d{2})$/);\n if (iso) {\n return safeDate(Number(iso[1]), Number(iso[2]), Number(iso[3]));\n }\n\n const m = trimmed.match(/^(\\d{1,4})[\\-\\/.](\\d{1,2})[\\-\\/.](\\d{1,4})$/);\n if (!m) return null;\n\n let y: number, mo: number, d: number;\n if (format === 'iso') {\n y = Number(m[1]); mo = Number(m[2]); d = Number(m[3]);\n } else if (format === 'dmy') {\n d = Number(m[1]); mo = Number(m[2]); y = Number(m[3]);\n } else {\n mo = Number(m[1]); d = Number(m[2]); y = Number(m[3]);\n }\n\n // 2-digit years: assume 2000s.\n if (y < 100) y += 2000;\n\n return safeDate(y, mo, d);\n}\n\nfunction safeDate(y: number, mo: number, d: number): Date | null {\n if (mo < 1 || mo > 12 || d < 1 || d > 31) return null;\n const dt = new Date(y, mo - 1, d);\n if (\n isNaN(dt.getTime()) ||\n dt.getFullYear() !== y ||\n dt.getMonth() !== mo - 1 ||\n dt.getDate() !== d\n ) {\n return null;\n }\n return dt;\n}\n"]}
@@ -0,0 +1,45 @@
1
+ import { cx } from './chunk-IEPCH3JB.mjs';
2
+ import * as React from 'react';
3
+ import { jsx } from 'react/jsx-runtime';
4
+
5
+ var AspectRatio = React.forwardRef(function AspectRatio2({ ratio = 16 / 9, style, className, children, ...rest }, ref) {
6
+ return /* @__PURE__ */ jsx(
7
+ "div",
8
+ {
9
+ ref,
10
+ className: cx("aspect-ratio", className),
11
+ style: { position: "relative", width: "100%", aspectRatio: String(ratio), ...style },
12
+ ...rest,
13
+ children
14
+ }
15
+ );
16
+ });
17
+ var Separator = React.forwardRef(function Separator2({ orientation = "horizontal", decorative = true, className, ...rest }, ref) {
18
+ const a11y = decorative ? { role: "none" } : { role: "separator", "aria-orientation": orientation };
19
+ return /* @__PURE__ */ jsx(
20
+ "div",
21
+ {
22
+ ref,
23
+ ...a11y,
24
+ className: cx("separator", `separator--${orientation}`, className),
25
+ ...rest
26
+ }
27
+ );
28
+ });
29
+ var ScrollArea = React.forwardRef(function ScrollArea2({ maxHeight, orientation = "vertical", className, style, children, ...rest }, ref) {
30
+ const overflow = orientation === "horizontal" ? { overflowX: "auto", overflowY: "hidden" } : orientation === "both" ? { overflow: "auto" } : { overflowY: "auto", overflowX: "hidden" };
31
+ return /* @__PURE__ */ jsx(
32
+ "div",
33
+ {
34
+ ref,
35
+ className: cx("scroll-area", `scroll-area--${orientation}`, className),
36
+ style: { ...overflow, maxHeight, ...style },
37
+ ...rest,
38
+ children
39
+ }
40
+ );
41
+ });
42
+
43
+ export { AspectRatio, ScrollArea, Separator };
44
+ //# sourceMappingURL=chunk-6MEOR4YO.mjs.map
45
+ //# sourceMappingURL=chunk-6MEOR4YO.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/Primitives.tsx"],"names":["AspectRatio","Separator","ScrollArea"],"mappings":";;;;AASO,IAAM,WAAA,GAAoB,KAAA,CAAA,UAAA,CAA6C,SAASA,YAAAA,CACrF,EAAE,KAAA,GAAQ,EAAA,GAAK,CAAA,EAAG,KAAA,EAAO,SAAA,EAAW,QAAA,EAAU,GAAG,IAAA,IACjD,GAAA,EACA;AACA,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,SAAA,EAAW,EAAA,CAAG,cAAA,EAAgB,SAAS,CAAA;AAAA,MACvC,KAAA,EAAO,EAAE,QAAA,EAAU,UAAA,EAAY,KAAA,EAAO,MAAA,EAAQ,WAAA,EAAa,MAAA,CAAO,KAAK,CAAA,EAAG,GAAG,KAAA,EAAM;AAAA,MAClF,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ,CAAC;AAQM,IAAM,SAAA,GAAkB,KAAA,CAAA,UAAA,CAA2C,SAASC,UAAAA,CACjF,EAAE,WAAA,GAAc,YAAA,EAAc,UAAA,GAAa,IAAA,EAAM,SAAA,EAAW,GAAG,IAAA,IAC/D,GAAA,EACA;AACA,EAAA,MAAM,IAAA,GAAO,UAAA,GAAa,EAAE,IAAA,EAAM,MAAA,KAAW,EAAE,IAAA,EAAM,WAAA,EAAa,kBAAA,EAAoB,WAAA,EAAY;AAClG,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACC,GAAG,IAAA;AAAA,MACJ,WAAW,EAAA,CAAG,WAAA,EAAa,CAAA,WAAA,EAAc,WAAW,IAAI,SAAS,CAAA;AAAA,MAChE,GAAG;AAAA;AAAA,GACN;AAEJ,CAAC;AAQM,IAAM,UAAA,GAAmB,KAAA,CAAA,UAAA,CAA4C,SAASC,WAAAA,CACnF,EAAE,SAAA,EAAW,WAAA,GAAc,UAAA,EAAY,SAAA,EAAW,KAAA,EAAO,QAAA,EAAU,GAAG,IAAA,IACtE,GAAA,EACA;AACA,EAAA,MAAM,WACJ,WAAA,KAAgB,YAAA,GACZ,EAAE,SAAA,EAAW,MAAA,EAAiB,WAAW,QAAA,EAAkB,GAC3D,gBAAgB,MAAA,GAChB,EAAE,UAAU,MAAA,EAAgB,GAC5B,EAAE,SAAA,EAAW,MAAA,EAAiB,WAAW,QAAA,EAAkB;AACjE,EAAA,uBACE,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,GAAA;AAAA,MACA,WAAW,EAAA,CAAG,aAAA,EAAe,CAAA,aAAA,EAAgB,WAAW,IAAI,SAAS,CAAA;AAAA,MACrE,OAAO,EAAE,GAAG,QAAA,EAAU,SAAA,EAAW,GAAG,KAAA,EAAM;AAAA,MACzC,GAAG,IAAA;AAAA,MAEH;AAAA;AAAA,GACH;AAEJ,CAAC","file":"chunk-6MEOR4YO.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { cx } from '../utils/cx';\n\n// ---------- AspectRatio ------------------------------------------------\nexport interface AspectRatioProps extends React.HTMLAttributes<HTMLDivElement> {\n ratio?: number;\n}\n\nexport const AspectRatio = React.forwardRef<HTMLDivElement, AspectRatioProps>(function AspectRatio(\n { ratio = 16 / 9, style, className, children, ...rest },\n ref\n) {\n return (\n <div\n ref={ref}\n className={cx('aspect-ratio', className)}\n style={{ position: 'relative', width: '100%', aspectRatio: String(ratio), ...style }}\n {...rest}\n >\n {children}\n </div>\n );\n});\n\n// ---------- Separator --------------------------------------------------\nexport interface SeparatorProps extends React.HTMLAttributes<HTMLDivElement> {\n orientation?: 'horizontal' | 'vertical';\n decorative?: boolean;\n}\n\nexport const Separator = React.forwardRef<HTMLDivElement, SeparatorProps>(function Separator(\n { orientation = 'horizontal', decorative = true, className, ...rest },\n ref\n) {\n const a11y = decorative ? { role: 'none' } : { role: 'separator', 'aria-orientation': orientation };\n return (\n <div\n ref={ref}\n {...a11y}\n className={cx('separator', `separator--${orientation}`, className)}\n {...rest}\n />\n );\n});\n\n// ---------- ScrollArea -------------------------------------------------\nexport interface ScrollAreaProps extends React.HTMLAttributes<HTMLDivElement> {\n maxHeight?: number | string;\n orientation?: 'vertical' | 'horizontal' | 'both';\n}\n\nexport const ScrollArea = React.forwardRef<HTMLDivElement, ScrollAreaProps>(function ScrollArea(\n { maxHeight, orientation = 'vertical', className, style, children, ...rest },\n ref\n) {\n const overflow =\n orientation === 'horizontal'\n ? { overflowX: 'auto' as const, overflowY: 'hidden' as const }\n : orientation === 'both'\n ? { overflow: 'auto' as const }\n : { overflowY: 'auto' as const, overflowX: 'hidden' as const };\n return (\n <div\n ref={ref}\n className={cx('scroll-area', `scroll-area--${orientation}`, className)}\n style={{ ...overflow, maxHeight, ...style }}\n {...rest}\n >\n {children}\n </div>\n );\n});\n"]}
@@ -0,0 +1,94 @@
1
+ import { format } from './chunk-KKOJI25C.mjs';
2
+ import { useLocale } from './chunk-ZRFSTYRL.mjs';
3
+ import { Bell } from './chunk-CIBJKJV3.mjs';
4
+ import { cx } from './chunk-IEPCH3JB.mjs';
5
+ import * as React from 'react';
6
+ import { jsxs, jsx } from 'react/jsx-runtime';
7
+
8
+ function NotificationCenter({
9
+ notifications,
10
+ onMarkAllRead,
11
+ onClearAll,
12
+ emptyMessage,
13
+ trigger,
14
+ className
15
+ }) {
16
+ const [open, setOpen] = React.useState(false);
17
+ const ref = React.useRef(null);
18
+ const t = useLocale();
19
+ const unread = notifications.filter((n) => !n.read).length;
20
+ const empty = emptyMessage ?? t["notifications.empty"];
21
+ React.useEffect(() => {
22
+ if (!open) return;
23
+ const onClick = (e) => {
24
+ if (ref.current && !ref.current.contains(e.target)) setOpen(false);
25
+ };
26
+ const onKey = (e) => {
27
+ if (e.key === "Escape") setOpen(false);
28
+ };
29
+ document.addEventListener("mousedown", onClick);
30
+ document.addEventListener("keydown", onKey);
31
+ return () => {
32
+ document.removeEventListener("mousedown", onClick);
33
+ document.removeEventListener("keydown", onKey);
34
+ };
35
+ }, [open]);
36
+ const triggerEl = trigger ? React.cloneElement(trigger, {
37
+ onClick: (e) => {
38
+ trigger.props.onClick?.(e);
39
+ setOpen((o) => !o);
40
+ },
41
+ "aria-haspopup": "dialog",
42
+ "aria-expanded": open
43
+ }) : /* @__PURE__ */ jsxs(
44
+ "button",
45
+ {
46
+ type: "button",
47
+ className: "notif__trigger",
48
+ "aria-label": `${t["notifications.button"]}${unread > 0 ? format(t["notifications.unreadSuffix"], { n: unread }) : ""}`,
49
+ "aria-haspopup": "dialog",
50
+ "aria-expanded": open,
51
+ onClick: () => setOpen((o) => !o),
52
+ children: [
53
+ /* @__PURE__ */ jsx(Bell, { size: 20 }),
54
+ unread > 0 && /* @__PURE__ */ jsx("span", { className: "notif__badge", "aria-hidden": "true", children: unread > 99 ? "99+" : unread })
55
+ ]
56
+ }
57
+ );
58
+ return /* @__PURE__ */ jsxs("div", { ref, className: cx("notif", className), children: [
59
+ triggerEl,
60
+ open && /* @__PURE__ */ jsxs("div", { className: "notif__panel", role: "dialog", "aria-label": t["notifications.panel"], children: [
61
+ /* @__PURE__ */ jsxs("div", { className: "notif__head", children: [
62
+ /* @__PURE__ */ jsx("span", { className: "notif__title", children: t["notifications.title"] }),
63
+ notifications.length > 0 && /* @__PURE__ */ jsxs("div", { className: "notif__head-actions", children: [
64
+ onMarkAllRead && unread > 0 && /* @__PURE__ */ jsx("button", { type: "button", className: "notif__action", onClick: onMarkAllRead, children: t["notifications.markAllRead"] }),
65
+ onClearAll && /* @__PURE__ */ jsx("button", { type: "button", className: "notif__action", onClick: onClearAll, children: t["notifications.clear"] })
66
+ ] })
67
+ ] }),
68
+ /* @__PURE__ */ jsx("div", { className: "notif__list", children: notifications.length === 0 ? /* @__PURE__ */ jsx("div", { className: "notif__empty", children: empty }) : notifications.map((n) => /* @__PURE__ */ jsxs(
69
+ "button",
70
+ {
71
+ type: "button",
72
+ className: cx("notif__item", !n.read && "is-unread"),
73
+ onClick: () => {
74
+ n.onClick?.();
75
+ setOpen(false);
76
+ },
77
+ children: [
78
+ /* @__PURE__ */ jsx("span", { className: cx("notif__dot", `notif__dot--${n.tone ?? "info"}`), "aria-hidden": "true" }),
79
+ /* @__PURE__ */ jsxs("div", { className: "notif__body", children: [
80
+ /* @__PURE__ */ jsx("div", { className: "notif__item-title", children: n.title }),
81
+ n.description && /* @__PURE__ */ jsx("div", { className: "notif__item-desc", children: n.description }),
82
+ n.timestamp && /* @__PURE__ */ jsx("div", { className: "notif__time", children: n.timestamp })
83
+ ] })
84
+ ]
85
+ },
86
+ n.id
87
+ )) })
88
+ ] })
89
+ ] });
90
+ }
91
+
92
+ export { NotificationCenter };
93
+ //# sourceMappingURL=chunk-6PEC4RRO.mjs.map
94
+ //# sourceMappingURL=chunk-6PEC4RRO.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/Notifications.tsx"],"names":[],"mappings":"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","file":"chunk-6PEC4RRO.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { cx } from '../utils/cx';\nimport { Bell } from './Icons';\nimport { useLocale } from '../locale/LocaleProvider';\nimport { format } from '../locale/messages';\n\nexport type NotificationTone = 'info' | 'success' | 'warning' | 'danger';\n\nexport interface NotificationItem {\n id: string;\n title: React.ReactNode;\n description?: React.ReactNode;\n tone?: NotificationTone;\n timestamp?: React.ReactNode;\n read?: boolean;\n onClick?: () => void;\n}\n\nexport interface NotificationCenterProps {\n notifications: NotificationItem[];\n onMarkAllRead?: () => void;\n onClearAll?: () => void;\n emptyMessage?: React.ReactNode;\n /** Custom trigger element. Si se pasa, reemplaza el botón con bell. */\n trigger?: React.ReactElement;\n className?: string;\n}\n\nexport function NotificationCenter({\n notifications, onMarkAllRead, onClearAll,\n emptyMessage,\n trigger, className,\n}: NotificationCenterProps) {\n const [open, setOpen] = React.useState(false);\n const ref = React.useRef<HTMLDivElement>(null);\n const t = useLocale();\n const unread = notifications.filter((n) => !n.read).length;\n const empty = emptyMessage ?? t['notifications.empty'];\n\n React.useEffect(() => {\n if (!open) return;\n const onClick = (e: MouseEvent) => {\n if (ref.current && !ref.current.contains(e.target as Node)) setOpen(false);\n };\n const onKey = (e: KeyboardEvent) => { if (e.key === 'Escape') setOpen(false); };\n document.addEventListener('mousedown', onClick);\n document.addEventListener('keydown', onKey);\n return () => {\n document.removeEventListener('mousedown', onClick);\n document.removeEventListener('keydown', onKey);\n };\n }, [open]);\n\n const triggerEl = trigger ? React.cloneElement(trigger, {\n onClick: (e: React.MouseEvent) => {\n trigger.props.onClick?.(e);\n setOpen((o) => !o);\n },\n 'aria-haspopup': 'dialog',\n 'aria-expanded': open,\n }) : (\n <button\n type=\"button\"\n className=\"notif__trigger\"\n aria-label={`${t['notifications.button']}${unread > 0 ? format(t['notifications.unreadSuffix'], { n: unread }) : ''}`}\n aria-haspopup=\"dialog\"\n aria-expanded={open}\n onClick={() => setOpen((o) => !o)}\n >\n <Bell size={20} />\n {unread > 0 && <span className=\"notif__badge\" aria-hidden=\"true\">{unread > 99 ? '99+' : unread}</span>}\n </button>\n );\n\n return (\n <div ref={ref} className={cx('notif', className)}>\n {triggerEl}\n {open && (\n <div className=\"notif__panel\" role=\"dialog\" aria-label={t['notifications.panel']}>\n <div className=\"notif__head\">\n <span className=\"notif__title\">{t['notifications.title']}</span>\n {notifications.length > 0 && (\n <div className=\"notif__head-actions\">\n {onMarkAllRead && unread > 0 && (\n <button type=\"button\" className=\"notif__action\" onClick={onMarkAllRead}>\n {t['notifications.markAllRead']}\n </button>\n )}\n {onClearAll && (\n <button type=\"button\" className=\"notif__action\" onClick={onClearAll}>\n {t['notifications.clear']}\n </button>\n )}\n </div>\n )}\n </div>\n <div className=\"notif__list\">\n {notifications.length === 0 ? (\n <div className=\"notif__empty\">{empty}</div>\n ) : (\n notifications.map((n) => (\n <button\n key={n.id}\n type=\"button\"\n className={cx('notif__item', !n.read && 'is-unread')}\n onClick={() => { n.onClick?.(); setOpen(false); }}\n >\n <span className={cx('notif__dot', `notif__dot--${n.tone ?? 'info'}`)} aria-hidden=\"true\" />\n <div className=\"notif__body\">\n <div className=\"notif__item-title\">{n.title}</div>\n {n.description && <div className=\"notif__item-desc\">{n.description}</div>}\n {n.timestamp && <div className=\"notif__time\">{n.timestamp}</div>}\n </div>\n </button>\n ))\n )}\n </div>\n </div>\n )}\n </div>\n );\n}\n"]}
@@ -0,0 +1,103 @@
1
+ import { cx } from './chunk-IEPCH3JB.mjs';
2
+ import * as React from 'react';
3
+ import { createPortal } from 'react-dom';
4
+ import { jsx, jsxs } from 'react/jsx-runtime';
5
+
6
+ function Popover({
7
+ open: controlledOpen,
8
+ defaultOpen = false,
9
+ onOpenChange,
10
+ trigger,
11
+ children,
12
+ placement = "bottom",
13
+ align = "center",
14
+ offset = 8,
15
+ closeOnOutsideClick = true,
16
+ closeOnEscape = true,
17
+ className,
18
+ contentClassName,
19
+ ariaLabel
20
+ }) {
21
+ const [internalOpen, setInternalOpen] = React.useState(defaultOpen);
22
+ const isControlled = controlledOpen !== void 0;
23
+ const open = isControlled ? controlledOpen : internalOpen;
24
+ const triggerRef = React.useRef(null);
25
+ const contentRef = React.useRef(null);
26
+ const [coords, setCoords] = React.useState(null);
27
+ const setOpen = (next) => {
28
+ if (!isControlled) setInternalOpen(next);
29
+ onOpenChange?.(next);
30
+ };
31
+ React.useEffect(() => {
32
+ if (!open || !triggerRef.current || !contentRef.current) return;
33
+ const t = triggerRef.current.getBoundingClientRect();
34
+ const c = contentRef.current.getBoundingClientRect();
35
+ let top = 0;
36
+ let left = 0;
37
+ if (placement === "bottom") {
38
+ top = t.bottom + offset;
39
+ left = align === "start" ? t.left : align === "end" ? t.right - c.width : t.left + (t.width - c.width) / 2;
40
+ } else if (placement === "top") {
41
+ top = t.top - c.height - offset;
42
+ left = align === "start" ? t.left : align === "end" ? t.right - c.width : t.left + (t.width - c.width) / 2;
43
+ } else if (placement === "right") {
44
+ left = t.right + offset;
45
+ top = align === "start" ? t.top : align === "end" ? t.bottom - c.height : t.top + (t.height - c.height) / 2;
46
+ } else {
47
+ left = t.left - c.width - offset;
48
+ top = align === "start" ? t.top : align === "end" ? t.bottom - c.height : t.top + (t.height - c.height) / 2;
49
+ }
50
+ const vw = window.innerWidth;
51
+ const vh = window.innerHeight;
52
+ left = Math.max(8, Math.min(left, vw - c.width - 8));
53
+ top = Math.max(8, Math.min(top, vh - c.height - 8));
54
+ setCoords({ top: top + window.scrollY, left: left + window.scrollX });
55
+ }, [open, placement, align, offset]);
56
+ React.useEffect(() => {
57
+ if (!open) return;
58
+ const onClick = (e) => {
59
+ if (!closeOnOutsideClick) return;
60
+ const target = e.target;
61
+ if (triggerRef.current?.contains(target) || contentRef.current?.contains(target)) return;
62
+ setOpen(false);
63
+ };
64
+ const onKey = (e) => {
65
+ if (closeOnEscape && e.key === "Escape") setOpen(false);
66
+ };
67
+ document.addEventListener("mousedown", onClick);
68
+ document.addEventListener("keydown", onKey);
69
+ return () => {
70
+ document.removeEventListener("mousedown", onClick);
71
+ document.removeEventListener("keydown", onKey);
72
+ };
73
+ }, [open, closeOnOutsideClick, closeOnEscape]);
74
+ const panel = open && /* @__PURE__ */ jsx(
75
+ "div",
76
+ {
77
+ ref: contentRef,
78
+ role: "dialog",
79
+ "aria-label": ariaLabel,
80
+ className: cx("popover__content", contentClassName),
81
+ style: coords ? { position: "absolute", top: coords.top, left: coords.left } : { position: "absolute", visibility: "hidden" },
82
+ children
83
+ }
84
+ );
85
+ return /* @__PURE__ */ jsxs("span", { className: cx("popover", className), children: [
86
+ /* @__PURE__ */ jsx(
87
+ "span",
88
+ {
89
+ ref: triggerRef,
90
+ className: "popover__trigger",
91
+ onClick: () => setOpen(!open),
92
+ "aria-haspopup": "dialog",
93
+ "aria-expanded": open,
94
+ children: trigger
95
+ }
96
+ ),
97
+ panel && typeof document !== "undefined" && createPortal(panel, document.body)
98
+ ] });
99
+ }
100
+
101
+ export { Popover };
102
+ //# sourceMappingURL=chunk-7AKN7FDA.mjs.map
103
+ //# sourceMappingURL=chunk-7AKN7FDA.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/Popover.tsx"],"names":[],"mappings":"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","file":"chunk-7AKN7FDA.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { createPortal } from 'react-dom';\nimport { cx } from '../utils/cx';\n\nexport type PopoverPlacement = 'top' | 'bottom' | 'left' | 'right';\nexport type PopoverAlign = 'start' | 'center' | 'end';\n\nexport interface PopoverProps {\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n trigger: React.ReactNode;\n children: React.ReactNode;\n placement?: PopoverPlacement;\n align?: PopoverAlign;\n offset?: number;\n closeOnOutsideClick?: boolean;\n closeOnEscape?: boolean;\n className?: string;\n contentClassName?: string;\n ariaLabel?: string;\n}\n\nexport function Popover({\n open: controlledOpen,\n defaultOpen = false,\n onOpenChange,\n trigger,\n children,\n placement = 'bottom',\n align = 'center',\n offset = 8,\n closeOnOutsideClick = true,\n closeOnEscape = true,\n className,\n contentClassName,\n ariaLabel,\n}: PopoverProps) {\n const [internalOpen, setInternalOpen] = React.useState(defaultOpen);\n const isControlled = controlledOpen !== undefined;\n const open = isControlled ? controlledOpen : internalOpen;\n\n const triggerRef = React.useRef<HTMLDivElement>(null);\n const contentRef = React.useRef<HTMLDivElement>(null);\n const [coords, setCoords] = React.useState<{ top: number; left: number } | null>(null);\n\n const setOpen = (next: boolean) => {\n if (!isControlled) setInternalOpen(next);\n onOpenChange?.(next);\n };\n\n React.useEffect(() => {\n if (!open || !triggerRef.current || !contentRef.current) return;\n const t = triggerRef.current.getBoundingClientRect();\n const c = contentRef.current.getBoundingClientRect();\n\n let top = 0;\n let left = 0;\n if (placement === 'bottom') {\n top = t.bottom + offset;\n left = align === 'start' ? t.left : align === 'end' ? t.right - c.width : t.left + (t.width - c.width) / 2;\n } else if (placement === 'top') {\n top = t.top - c.height - offset;\n left = align === 'start' ? t.left : align === 'end' ? t.right - c.width : t.left + (t.width - c.width) / 2;\n } else if (placement === 'right') {\n left = t.right + offset;\n top = align === 'start' ? t.top : align === 'end' ? t.bottom - c.height : t.top + (t.height - c.height) / 2;\n } else {\n left = t.left - c.width - offset;\n top = align === 'start' ? t.top : align === 'end' ? t.bottom - c.height : t.top + (t.height - c.height) / 2;\n }\n\n const vw = window.innerWidth;\n const vh = window.innerHeight;\n left = Math.max(8, Math.min(left, vw - c.width - 8));\n top = Math.max(8, Math.min(top, vh - c.height - 8));\n\n setCoords({ top: top + window.scrollY, left: left + window.scrollX });\n }, [open, placement, align, offset]);\n\n React.useEffect(() => {\n if (!open) return;\n const onClick = (e: MouseEvent) => {\n if (!closeOnOutsideClick) return;\n const target = e.target as Node;\n if (triggerRef.current?.contains(target) || contentRef.current?.contains(target)) return;\n setOpen(false);\n };\n const onKey = (e: KeyboardEvent) => {\n if (closeOnEscape && e.key === 'Escape') setOpen(false);\n };\n document.addEventListener('mousedown', onClick);\n document.addEventListener('keydown', onKey);\n return () => {\n document.removeEventListener('mousedown', onClick);\n document.removeEventListener('keydown', onKey);\n };\n }, [open, closeOnOutsideClick, closeOnEscape]);\n\n const panel = open && (\n <div\n ref={contentRef}\n role=\"dialog\"\n aria-label={ariaLabel}\n className={cx('popover__content', contentClassName)}\n style={coords ? { position: 'absolute', top: coords.top, left: coords.left } : { position: 'absolute', visibility: 'hidden' }}\n >\n {children}\n </div>\n );\n\n return (\n <span className={cx('popover', className)}>\n <span\n ref={triggerRef as any}\n className=\"popover__trigger\"\n onClick={() => setOpen(!open)}\n aria-haspopup=\"dialog\"\n aria-expanded={open}\n >\n {trigger}\n </span>\n {/* Portal to body so absolute coords (document-relative) match the\n positioning origin and overflow:hidden ancestors don't clip. */}\n {panel && typeof document !== 'undefined' && createPortal(panel, document.body)}\n </span>\n );\n}\n"]}