silver-ui 0.1.1 → 0.2.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.
- package/README.md +38 -6
- package/dist/chunk-24J3BUKL.js +40 -0
- package/dist/chunk-24J3BUKL.js.map +1 -0
- package/dist/{chunk-WA4DRAQ7.js → chunk-2IKWX66Q.js} +8 -8
- package/dist/chunk-2IKWX66Q.js.map +1 -0
- package/dist/{chunk-FVIEYPDB.js → chunk-2K44WLBJ.js} +19 -17
- package/dist/chunk-2K44WLBJ.js.map +1 -0
- package/dist/{chunk-5G3BY75L.cjs → chunk-2P6D43V2.cjs} +6 -6
- package/dist/{chunk-5G3BY75L.cjs.map → chunk-2P6D43V2.cjs.map} +1 -1
- package/dist/{chunk-O5RVLBKN.cjs → chunk-2RIDPITG.cjs} +14 -15
- package/dist/chunk-2RIDPITG.cjs.map +1 -0
- package/dist/{chunk-PDXZDPOY.cjs → chunk-2VIJC4NW.cjs} +48 -47
- package/dist/chunk-2VIJC4NW.cjs.map +1 -0
- package/dist/{chunk-6BSEY2DF.js → chunk-2VOB6LEI.js} +5 -5
- package/dist/{chunk-6BSEY2DF.js.map → chunk-2VOB6LEI.js.map} +1 -1
- package/dist/{chunk-GUF4ZNPQ.js → chunk-35MFOORC.js} +6 -6
- package/dist/chunk-35MFOORC.js.map +1 -0
- package/dist/{chunk-RJXHAQCR.cjs → chunk-36QGPGT2.cjs} +25 -23
- package/dist/chunk-36QGPGT2.cjs.map +1 -0
- package/dist/chunk-3DFRJSNE.cjs +52 -0
- package/dist/chunk-3DFRJSNE.cjs.map +1 -0
- package/dist/chunk-3DZPRXMC.cjs +559 -0
- package/dist/chunk-3DZPRXMC.cjs.map +1 -0
- package/dist/{chunk-GI3NLBCW.cjs → chunk-3IDEWEDY.cjs} +22 -22
- package/dist/{chunk-GI3NLBCW.cjs.map → chunk-3IDEWEDY.cjs.map} +1 -1
- package/dist/{chunk-WIO3XITR.js → chunk-3JVD4AXC.js} +5 -5
- package/dist/{chunk-WIO3XITR.js.map → chunk-3JVD4AXC.js.map} +1 -1
- package/dist/chunk-3M23WX6K.js +106 -0
- package/dist/chunk-3M23WX6K.js.map +1 -0
- package/dist/{chunk-BSBEPQLM.cjs → chunk-3SLWOIT4.cjs} +4 -5
- package/dist/chunk-3SLWOIT4.cjs.map +1 -0
- package/dist/{chunk-Z2UFJIZU.cjs → chunk-3WMLV4VP.cjs} +20 -20
- package/dist/{chunk-Z2UFJIZU.cjs.map → chunk-3WMLV4VP.cjs.map} +1 -1
- package/dist/chunk-463O56TB.js +224 -0
- package/dist/chunk-463O56TB.js.map +1 -0
- package/dist/{chunk-SMF3YBH5.cjs → chunk-47FUQCAT.cjs} +70 -70
- package/dist/{chunk-SMF3YBH5.cjs.map → chunk-47FUQCAT.cjs.map} +1 -1
- package/dist/{chunk-YMC56K6R.cjs → chunk-4I6VIR44.cjs} +26 -29
- package/dist/chunk-4I6VIR44.cjs.map +1 -0
- package/dist/{chunk-YHR44PWO.js → chunk-4M2KCZMO.js} +5 -5
- package/dist/chunk-4M2KCZMO.js.map +1 -0
- package/dist/{chunk-PHFEQG4E.cjs → chunk-4TIAKZ4Q.cjs} +4 -5
- package/dist/chunk-4TIAKZ4Q.cjs.map +1 -0
- package/dist/{chunk-F7AUYO3H.cjs → chunk-4YESF35X.cjs} +18 -18
- package/dist/{chunk-F7AUYO3H.cjs.map → chunk-4YESF35X.cjs.map} +1 -1
- package/dist/{chunk-2ZGGJWJY.cjs → chunk-4YQSKCVF.cjs} +16 -16
- package/dist/{chunk-2ZGGJWJY.cjs.map → chunk-4YQSKCVF.cjs.map} +1 -1
- package/dist/{chunk-4A4EI26N.cjs → chunk-4YQTSHIB.cjs} +35 -35
- package/dist/{chunk-4A4EI26N.cjs.map → chunk-4YQTSHIB.cjs.map} +1 -1
- package/dist/{chunk-Z2STCD6I.js → chunk-5MDH6QZE.js} +4 -4
- package/dist/chunk-5MDH6QZE.js.map +1 -0
- package/dist/chunk-5QPM5LUS.cjs +46 -0
- package/dist/chunk-5QPM5LUS.cjs.map +1 -0
- package/dist/{chunk-YRXGCYT2.js → chunk-63RKQ237.js} +11 -13
- package/dist/chunk-63RKQ237.js.map +1 -0
- package/dist/chunk-6BK4LUK4.cjs +17 -0
- package/dist/chunk-6BK4LUK4.cjs.map +1 -0
- package/dist/chunk-6D3FA247.js +126 -0
- package/dist/chunk-6D3FA247.js.map +1 -0
- package/dist/{chunk-H6OY6FLC.js → chunk-6NY5DOFM.js} +16 -14
- package/dist/chunk-6NY5DOFM.js.map +1 -0
- package/dist/{chunk-RJQQ2UIQ.js → chunk-74ONIT6C.js} +5 -5
- package/dist/{chunk-RJQQ2UIQ.js.map → chunk-74ONIT6C.js.map} +1 -1
- package/dist/{chunk-CZJUKLFD.cjs → chunk-76FHSISK.cjs} +4 -5
- package/dist/chunk-76FHSISK.cjs.map +1 -0
- package/dist/chunk-77RGTGRM.cjs +128 -0
- package/dist/chunk-77RGTGRM.cjs.map +1 -0
- package/dist/{chunk-W6B55MNU.js → chunk-7DWASA3K.js} +4 -4
- package/dist/{chunk-W6B55MNU.js.map → chunk-7DWASA3K.js.map} +1 -1
- package/dist/{chunk-MKAOIB2O.cjs → chunk-7GN6YTSS.cjs} +14 -13
- package/dist/chunk-7GN6YTSS.cjs.map +1 -0
- package/dist/chunk-7MB2KK6X.js +50 -0
- package/dist/chunk-7MB2KK6X.js.map +1 -0
- package/dist/{chunk-KVREBGWA.js → chunk-7P3VY5JZ.js} +4 -7
- package/dist/chunk-7P3VY5JZ.js.map +1 -0
- package/dist/{chunk-4W7L63LH.js → chunk-7T3SWOY7.js} +4 -4
- package/dist/chunk-7T3SWOY7.js.map +1 -0
- package/dist/{chunk-BTBOTNOE.cjs → chunk-A66NIFJE.cjs} +18 -18
- package/dist/{chunk-BTBOTNOE.cjs.map → chunk-A66NIFJE.cjs.map} +1 -1
- package/dist/chunk-ABEOBHAM.cjs +416 -0
- package/dist/chunk-ABEOBHAM.cjs.map +1 -0
- package/dist/chunk-AJYVGSBW.cjs +56 -0
- package/dist/chunk-AJYVGSBW.cjs.map +1 -0
- package/dist/{chunk-EM2F6BZ2.js → chunk-AKTUU5ML.js} +9 -9
- package/dist/chunk-AKTUU5ML.js.map +1 -0
- package/dist/{chunk-CA6645TQ.js → chunk-AMG3S252.js} +5 -8
- package/dist/chunk-AMG3S252.js.map +1 -0
- package/dist/{chunk-HXT6A6GH.cjs → chunk-AX6HC2YY.cjs} +6 -7
- package/dist/chunk-AX6HC2YY.cjs.map +1 -0
- package/dist/{chunk-NOZ6U6ZJ.js → chunk-AXCE2HKG.js} +16 -13
- package/dist/chunk-AXCE2HKG.js.map +1 -0
- package/dist/{chunk-BCJ25X7C.js → chunk-BA2VUDQS.js} +114 -74
- package/dist/chunk-BA2VUDQS.js.map +1 -0
- package/dist/{chunk-WSAZHUB3.cjs → chunk-BDBHHJGN.cjs} +21 -20
- package/dist/chunk-BDBHHJGN.cjs.map +1 -0
- package/dist/{chunk-2UTRYTT3.cjs → chunk-BDPE6ZKX.cjs} +114 -74
- package/dist/chunk-BDPE6ZKX.cjs.map +1 -0
- package/dist/{chunk-CXBB2LN7.js → chunk-BKKLUIIU.js} +2 -2
- package/dist/chunk-BKKLUIIU.js.map +1 -0
- package/dist/{chunk-VL6IDFI2.js → chunk-BTL6GUMN.js} +4 -4
- package/dist/{chunk-VL6IDFI2.js.map → chunk-BTL6GUMN.js.map} +1 -1
- package/dist/{chunk-S5NFDKPL.js → chunk-BZ4XKKNH.js} +18 -17
- package/dist/chunk-BZ4XKKNH.js.map +1 -0
- package/dist/chunk-CBJ4APCT.js +556 -0
- package/dist/chunk-CBJ4APCT.js.map +1 -0
- package/dist/{chunk-E4TIWN4Z.cjs → chunk-CPOYENSZ.cjs} +41 -35
- package/dist/chunk-CPOYENSZ.cjs.map +1 -0
- package/dist/{chunk-NJDV3LDH.js → chunk-CPZWTWYQ.js} +12 -17
- package/dist/chunk-CPZWTWYQ.js.map +1 -0
- package/dist/{chunk-6NIFOTUZ.cjs → chunk-DH2ZFYKE.cjs} +47 -45
- package/dist/chunk-DH2ZFYKE.cjs.map +1 -0
- package/dist/{chunk-QRXMW7MQ.cjs → chunk-DP4KK2N4.cjs} +63 -69
- package/dist/chunk-DP4KK2N4.cjs.map +1 -0
- package/dist/{chunk-I25KF3UF.js → chunk-DZ3NHSJ4.js} +6 -6
- package/dist/{chunk-I25KF3UF.js.map → chunk-DZ3NHSJ4.js.map} +1 -1
- package/dist/{chunk-K574UTWP.cjs → chunk-E2JZGYKU.cjs} +14 -15
- package/dist/chunk-E2JZGYKU.cjs.map +1 -0
- package/dist/{chunk-C2CNRYZI.cjs → chunk-E7UOFIBW.cjs} +30 -30
- package/dist/{chunk-C2CNRYZI.cjs.map → chunk-E7UOFIBW.cjs.map} +1 -1
- package/dist/{chunk-HPZ7LLXK.js → chunk-EBCHOGKT.js} +11 -12
- package/dist/chunk-EBCHOGKT.js.map +1 -0
- package/dist/{chunk-DFF72N57.js → chunk-EFO5NDBJ.js} +4 -5
- package/dist/chunk-EFO5NDBJ.js.map +1 -0
- package/dist/chunk-EHCAF6D3.js +44 -0
- package/dist/chunk-EHCAF6D3.js.map +1 -0
- package/dist/{chunk-EB5EHX6I.js → chunk-EMHLPPQZ.js} +5 -4
- package/dist/chunk-EMHLPPQZ.js.map +1 -0
- package/dist/{chunk-IWSS5745.js → chunk-ESJND7B6.js} +18 -17
- package/dist/chunk-ESJND7B6.js.map +1 -0
- package/dist/{chunk-V5W7NZN5.js → chunk-EXYBQVZT.js} +3 -3
- package/dist/{chunk-V5W7NZN5.js.map → chunk-EXYBQVZT.js.map} +1 -1
- package/dist/chunk-FDSUILCM.cjs +202 -0
- package/dist/chunk-FDSUILCM.cjs.map +1 -0
- package/dist/{chunk-ELCRG7WZ.js → chunk-FHKB6MBQ.js} +15 -15
- package/dist/{chunk-ELCRG7WZ.js.map → chunk-FHKB6MBQ.js.map} +1 -1
- package/dist/{chunk-NAELQLZN.js → chunk-FMEIPGUP.js} +3 -3
- package/dist/{chunk-NAELQLZN.js.map → chunk-FMEIPGUP.js.map} +1 -1
- package/dist/{chunk-PLFKU46A.js → chunk-GEGYC7CE.js} +7 -7
- package/dist/{chunk-PLFKU46A.js.map → chunk-GEGYC7CE.js.map} +1 -1
- package/dist/{chunk-TPSOUQG7.cjs → chunk-GGZGVAEF.cjs} +29 -28
- package/dist/chunk-GGZGVAEF.cjs.map +1 -0
- package/dist/{chunk-PBZWX2RJ.js → chunk-GTPRZCNZ.js} +5 -5
- package/dist/{chunk-PBZWX2RJ.js.map → chunk-GTPRZCNZ.js.map} +1 -1
- package/dist/chunk-GUKZNXTB.js +15 -0
- package/dist/chunk-GUKZNXTB.js.map +1 -0
- package/dist/chunk-GYUWDJXS.cjs +282 -0
- package/dist/chunk-GYUWDJXS.cjs.map +1 -0
- package/dist/{chunk-OAUKYH6C.cjs → chunk-H7LOOHWU.cjs} +2 -2
- package/dist/chunk-H7LOOHWU.cjs.map +1 -0
- package/dist/{chunk-NSHWBZL4.cjs → chunk-HM7IEGQ2.cjs} +14 -13
- package/dist/chunk-HM7IEGQ2.cjs.map +1 -0
- package/dist/{chunk-UZNSGQT3.cjs → chunk-HMWV6KCW.cjs} +34 -40
- package/dist/chunk-HMWV6KCW.cjs.map +1 -0
- package/dist/{chunk-KXXTWWJZ.cjs → chunk-I45346RZ.cjs} +8 -10
- package/dist/chunk-I45346RZ.cjs.map +1 -0
- package/dist/{chunk-LBRKUZSQ.cjs → chunk-IKF6VHA4.cjs} +73 -114
- package/dist/chunk-IKF6VHA4.cjs.map +1 -0
- package/dist/{chunk-YLXM3CGV.js → chunk-IR4COTIR.js} +5 -5
- package/dist/{chunk-YLXM3CGV.js.map → chunk-IR4COTIR.js.map} +1 -1
- package/dist/{chunk-QFO5ZTZZ.js → chunk-IUUQXCDE.js} +8 -9
- package/dist/chunk-IUUQXCDE.js.map +1 -0
- package/dist/{chunk-WEEYUS7M.cjs → chunk-IXJOPMJX.cjs} +7 -7
- package/dist/chunk-IXJOPMJX.cjs.map +1 -0
- package/dist/{chunk-PZO5MZ46.js → chunk-J2FCNWYM.js} +7 -6
- package/dist/chunk-J2FCNWYM.js.map +1 -0
- package/dist/chunk-JEK5SVB5.cjs +226 -0
- package/dist/chunk-JEK5SVB5.cjs.map +1 -0
- package/dist/{chunk-ZVBVKZ4P.cjs → chunk-JKERY7QF.cjs} +27 -18
- package/dist/chunk-JKERY7QF.cjs.map +1 -0
- package/dist/{chunk-32XQJNKY.cjs → chunk-JMLJLDHO.cjs} +15 -15
- package/dist/{chunk-32XQJNKY.cjs.map → chunk-JMLJLDHO.cjs.map} +1 -1
- package/dist/{chunk-47BELFYO.cjs → chunk-JMNH45Q3.cjs} +17 -18
- package/dist/chunk-JMNH45Q3.cjs.map +1 -0
- package/dist/{chunk-JAX62FUE.cjs → chunk-JRBQKFVO.cjs} +14 -14
- package/dist/{chunk-JAX62FUE.cjs.map → chunk-JRBQKFVO.cjs.map} +1 -1
- package/dist/{chunk-6UVJUY7Z.cjs → chunk-JVLE7PCJ.cjs} +11 -12
- package/dist/chunk-JVLE7PCJ.cjs.map +1 -0
- package/dist/chunk-K6CQ45C2.js +115 -0
- package/dist/chunk-K6CQ45C2.js.map +1 -0
- package/dist/chunk-K77D7H4V.cjs +125 -0
- package/dist/chunk-K77D7H4V.cjs.map +1 -0
- package/dist/chunk-KFEXS6OK.cjs +118 -0
- package/dist/chunk-KFEXS6OK.cjs.map +1 -0
- package/dist/{chunk-KYDRDJRM.cjs → chunk-L6JT244G.cjs} +5 -5
- package/dist/{chunk-KYDRDJRM.cjs.map → chunk-L6JT244G.cjs.map} +1 -1
- package/dist/{chunk-3UUZY42Z.js → chunk-L6WUK7O4.js} +5 -5
- package/dist/{chunk-3UUZY42Z.js.map → chunk-L6WUK7O4.js.map} +1 -1
- package/dist/{chunk-OA4KIVLO.cjs → chunk-LFRTNC7M.cjs} +12 -13
- package/dist/chunk-LFRTNC7M.cjs.map +1 -0
- package/dist/{chunk-Y73472IA.js → chunk-LJLCGQRV.js} +6 -6
- package/dist/chunk-LJLCGQRV.js.map +1 -0
- package/dist/{chunk-JCYPM27J.js → chunk-MEBIRX2P.js} +7 -7
- package/dist/chunk-MEBIRX2P.js.map +1 -0
- package/dist/{chunk-YX7DI3O3.cjs → chunk-MMQIQILP.cjs} +30 -31
- package/dist/chunk-MMQIQILP.cjs.map +1 -0
- package/dist/{chunk-QRDRZNCS.cjs → chunk-MMST4VXH.cjs} +25 -26
- package/dist/chunk-MMST4VXH.cjs.map +1 -0
- package/dist/{chunk-LFZXGIR6.cjs → chunk-MNVBSOAQ.cjs} +48 -46
- package/dist/chunk-MNVBSOAQ.cjs.map +1 -0
- package/dist/{chunk-CR4NB42L.cjs → chunk-MX2F3HUI.cjs} +37 -39
- package/dist/chunk-MX2F3HUI.cjs.map +1 -0
- package/dist/{chunk-L3G7SHEP.cjs → chunk-NF63IRZR.cjs} +42 -42
- package/dist/{chunk-L3G7SHEP.cjs.map → chunk-NF63IRZR.cjs.map} +1 -1
- package/dist/chunk-NUTB2K4G.js +87 -0
- package/dist/chunk-NUTB2K4G.js.map +1 -0
- package/dist/{chunk-NPJXGQOF.cjs → chunk-O2ZMOBMA.cjs} +116 -117
- package/dist/chunk-O2ZMOBMA.cjs.map +1 -0
- package/dist/{chunk-NILB6Y4Z.cjs → chunk-O3T7Z6RH.cjs} +31 -145
- package/dist/chunk-O3T7Z6RH.cjs.map +1 -0
- package/dist/{chunk-2XCNB2O6.js → chunk-OBBPRWYD.js} +18 -15
- package/dist/chunk-OBBPRWYD.js.map +1 -0
- package/dist/{chunk-UHQRL4OA.js → chunk-OD4DHHZH.js} +25 -3
- package/dist/chunk-OD4DHHZH.js.map +1 -0
- package/dist/{chunk-PGKOWMP4.js → chunk-OHKL4DOV.js} +78 -69
- package/dist/chunk-OHKL4DOV.js.map +1 -0
- package/dist/{chunk-VVYUCQHP.js → chunk-OJ3KVNW2.js} +17 -23
- package/dist/chunk-OJ3KVNW2.js.map +1 -0
- package/dist/{chunk-CWUC4TOQ.js → chunk-OJCJPYXE.js} +122 -121
- package/dist/chunk-OJCJPYXE.js.map +1 -0
- package/dist/{chunk-MCOVG6W6.js → chunk-P3SMNZCT.js} +75 -115
- package/dist/chunk-P3SMNZCT.js.map +1 -0
- package/dist/{chunk-KXXRALHT.cjs → chunk-P4A7GWQY.cjs} +83 -75
- package/dist/chunk-P4A7GWQY.cjs.map +1 -0
- package/dist/{chunk-2PHHFBJ3.cjs → chunk-P4TOIB2A.cjs} +11 -12
- package/dist/chunk-P4TOIB2A.cjs.map +1 -0
- package/dist/{chunk-RCAA2CZJ.js → chunk-PJXJOI73.js} +13 -13
- package/dist/chunk-PJXJOI73.js.map +1 -0
- package/dist/{chunk-2FPZULX3.cjs → chunk-PNYF6NS4.cjs} +32 -35
- package/dist/chunk-PNYF6NS4.cjs.map +1 -0
- package/dist/chunk-POW2Z7TP.js +414 -0
- package/dist/chunk-POW2Z7TP.js.map +1 -0
- package/dist/{chunk-D6KXW75E.js → chunk-PTZAJW3J.js} +10 -15
- package/dist/chunk-PTZAJW3J.js.map +1 -0
- package/dist/{chunk-YT3UWEVY.js → chunk-PUVBNGCF.js} +27 -17
- package/dist/chunk-PUVBNGCF.js.map +1 -0
- package/dist/{chunk-DONU5ALC.cjs → chunk-PWL6TWVC.cjs} +31 -37
- package/dist/chunk-PWL6TWVC.cjs.map +1 -0
- package/dist/chunk-PXVVTPRJ.js +278 -0
- package/dist/chunk-PXVVTPRJ.js.map +1 -0
- package/dist/{chunk-ZC7H4S4T.cjs → chunk-PYPXJC35.cjs} +6 -7
- package/dist/chunk-PYPXJC35.cjs.map +1 -0
- package/dist/{chunk-GZ5SRSD4.js → chunk-PYW5UO2Z.js} +5 -4
- package/dist/chunk-PYW5UO2Z.js.map +1 -0
- package/dist/{chunk-2QK2NZN5.js → chunk-QADMIAYK.js} +8 -7
- package/dist/chunk-QADMIAYK.js.map +1 -0
- package/dist/chunk-QPYPPJEZ.js +53 -0
- package/dist/chunk-QPYPPJEZ.js.map +1 -0
- package/dist/{chunk-7EXVJWG5.js → chunk-RNB4BDEG.js} +41 -35
- package/dist/chunk-RNB4BDEG.js.map +1 -0
- package/dist/{chunk-VIJHDURK.js → chunk-RQ5BMSGU.js} +5 -5
- package/dist/chunk-RQ5BMSGU.js.map +1 -0
- package/dist/{chunk-VLIQPSPM.js → chunk-RRNT32KY.js} +18 -131
- package/dist/chunk-RRNT32KY.js.map +1 -0
- package/dist/{chunk-VT7VKCHL.cjs → chunk-RSG7N5QQ.cjs} +25 -27
- package/dist/chunk-RSG7N5QQ.cjs.map +1 -0
- package/dist/{chunk-AZDWQGAX.cjs → chunk-RU6JG3FS.cjs} +25 -2
- package/dist/chunk-RU6JG3FS.cjs.map +1 -0
- package/dist/{chunk-YQJJCYJP.js → chunk-S4GLMGFI.js} +6 -6
- package/dist/{chunk-YQJJCYJP.js.map → chunk-S4GLMGFI.js.map} +1 -1
- package/dist/chunk-S54CKWKV.js +107 -0
- package/dist/chunk-S54CKWKV.js.map +1 -0
- package/dist/{chunk-WIW2YR46.js → chunk-SA3LUT6E.js} +31 -14
- package/dist/chunk-SA3LUT6E.js.map +1 -0
- package/dist/{chunk-2FUG6NKO.js → chunk-SSOHJEHS.js} +9 -9
- package/dist/chunk-SSOHJEHS.js.map +1 -0
- package/dist/{chunk-3PSQDJQH.js → chunk-STSR3FAC.js} +17 -14
- package/dist/chunk-STSR3FAC.js.map +1 -0
- package/dist/chunk-SXIBQQ55.js +280 -0
- package/dist/chunk-SXIBQQ55.js.map +1 -0
- package/dist/{chunk-ZW4XKNDR.cjs → chunk-TH3H5UGK.cjs} +38 -21
- package/dist/chunk-TH3H5UGK.cjs.map +1 -0
- package/dist/{chunk-5EQN3YMQ.cjs → chunk-TO3ZPSYO.cjs} +35 -35
- package/dist/chunk-TO3ZPSYO.cjs.map +1 -0
- package/dist/{chunk-I7PJTLP2.cjs → chunk-TZQWZ7IL.cjs} +26 -26
- package/dist/{chunk-I7PJTLP2.cjs.map → chunk-TZQWZ7IL.cjs.map} +1 -1
- package/dist/{chunk-6SPQDYHC.cjs → chunk-U2WVHZ24.cjs} +11 -22
- package/dist/chunk-U2WVHZ24.cjs.map +1 -0
- package/dist/{chunk-U35V3GVC.js → chunk-U4GWNENK.js} +27 -21
- package/dist/chunk-U4GWNENK.js.map +1 -0
- package/dist/{chunk-GKG47NK6.cjs → chunk-U5ZCQI5O.cjs} +86 -88
- package/dist/chunk-U5ZCQI5O.cjs.map +1 -0
- package/dist/{chunk-UWG5UQFV.cjs → chunk-UC36KIEP.cjs} +27 -20
- package/dist/chunk-UC36KIEP.cjs.map +1 -0
- package/dist/chunk-UJODHP7E.cjs +280 -0
- package/dist/chunk-UJODHP7E.cjs.map +1 -0
- package/dist/{chunk-ZHFAFEI2.js → chunk-UQV5MOGR.js} +5 -6
- package/dist/chunk-UQV5MOGR.js.map +1 -0
- package/dist/{chunk-WIIDQ44X.cjs → chunk-UUIAGGFW.cjs} +27 -24
- package/dist/chunk-UUIAGGFW.cjs.map +1 -0
- package/dist/{chunk-YZUBJ2L2.cjs → chunk-UX2Z7LRM.cjs} +17 -18
- package/dist/chunk-UX2Z7LRM.cjs.map +1 -0
- package/dist/chunk-UY3MYNI6.js +123 -0
- package/dist/chunk-UY3MYNI6.js.map +1 -0
- package/dist/{chunk-T55MB2CA.js → chunk-UYKFE7KF.js} +4 -4
- package/dist/chunk-UYKFE7KF.js.map +1 -0
- package/dist/{chunk-DNVOWNQG.cjs → chunk-V7Q64Z3S.cjs} +11 -11
- package/dist/{chunk-DNVOWNQG.cjs.map → chunk-V7Q64Z3S.cjs.map} +1 -1
- package/dist/{chunk-XQMLA75S.js → chunk-VBL5SI5N.js} +18 -16
- package/dist/chunk-VBL5SI5N.js.map +1 -0
- package/dist/{chunk-NMHCRHRI.cjs → chunk-VQ7IRFRR.cjs} +29 -28
- package/dist/chunk-VQ7IRFRR.cjs.map +1 -0
- package/dist/chunk-VXBVSYPA.cjs +109 -0
- package/dist/chunk-VXBVSYPA.cjs.map +1 -0
- package/dist/{chunk-25OAUQRF.cjs → chunk-W3QVSVL7.cjs} +23 -22
- package/dist/chunk-W3QVSVL7.cjs.map +1 -0
- package/dist/chunk-W5G7ZDQ6.cjs +89 -0
- package/dist/chunk-W5G7ZDQ6.cjs.map +1 -0
- package/dist/chunk-WA4VZ363.cjs +259 -0
- package/dist/chunk-WA4VZ363.cjs.map +1 -0
- package/dist/{chunk-IT72TF72.js → chunk-WE2AXMPB.js} +13 -12
- package/dist/chunk-WE2AXMPB.js.map +1 -0
- package/dist/{chunk-2QM5XBX4.cjs → chunk-WMXIUOOU.cjs} +4 -4
- package/dist/{chunk-2QM5XBX4.cjs.map → chunk-WMXIUOOU.cjs.map} +1 -1
- package/dist/{chunk-3L3M7SJ3.js → chunk-WOIWI2UO.js} +3 -3
- package/dist/{chunk-3L3M7SJ3.js.map → chunk-WOIWI2UO.js.map} +1 -1
- package/dist/chunk-WVQDFCFQ.js +199 -0
- package/dist/chunk-WVQDFCFQ.js.map +1 -0
- package/dist/{chunk-WE3ECIRS.cjs → chunk-XHTKGOQV.cjs} +50 -47
- package/dist/chunk-XHTKGOQV.cjs.map +1 -0
- package/dist/chunk-XIFLSMGW.js +200 -0
- package/dist/chunk-XIFLSMGW.js.map +1 -0
- package/dist/{chunk-WBPIJ4D5.js → chunk-XSQOHNIF.js} +5 -5
- package/dist/chunk-XSQOHNIF.js.map +1 -0
- package/dist/{chunk-E7EO3YVJ.js → chunk-XVRQSTUF.js} +3 -3
- package/dist/{chunk-E7EO3YVJ.js.map → chunk-XVRQSTUF.js.map} +1 -1
- package/dist/chunk-YAIEA2YE.cjs +203 -0
- package/dist/chunk-YAIEA2YE.cjs.map +1 -0
- package/dist/chunk-YAYINZT2.cjs +42 -0
- package/dist/chunk-YAYINZT2.cjs.map +1 -0
- package/dist/{chunk-DJW7T3WJ.js → chunk-YUONTRNC.js} +11 -12
- package/dist/chunk-YUONTRNC.js.map +1 -0
- package/dist/chunk-YXYD5HKL.cjs +109 -0
- package/dist/chunk-YXYD5HKL.cjs.map +1 -0
- package/dist/{chunk-EETTQWW5.cjs → chunk-Z7ID5TC7.cjs} +25 -22
- package/dist/chunk-Z7ID5TC7.cjs.map +1 -0
- package/dist/{chunk-5OS5A27C.js → chunk-ZC6GLBEL.js} +6 -6
- package/dist/chunk-ZC6GLBEL.js.map +1 -0
- package/dist/{chunk-R2NQNVEV.js → chunk-ZJ2NV4SQ.js} +19 -21
- package/dist/chunk-ZJ2NV4SQ.js.map +1 -0
- package/dist/{chunk-OKKL652L.js → chunk-ZNUOFLCQ.js} +5 -15
- package/dist/chunk-ZNUOFLCQ.js.map +1 -0
- package/dist/{chunk-P5AZUUM2.cjs → chunk-ZP3UZDSV.cjs} +11 -11
- package/dist/chunk-ZP3UZDSV.cjs.map +1 -0
- package/dist/{chunk-HWCL6JFB.js → chunk-ZW2ATXTL.js} +10 -9
- package/dist/chunk-ZW2ATXTL.js.map +1 -0
- package/dist/components/Accordion/Accordion.d.ts.map +1 -1
- package/dist/components/Accordion/AccordionItem.d.ts.map +1 -1
- package/dist/components/Accordion/AccordionItem.recipe.d.ts +17 -0
- package/dist/components/Accordion/AccordionItem.recipe.d.ts.map +1 -0
- package/dist/components/Accordion/index.cjs +9 -7
- package/dist/components/Accordion/index.js +6 -4
- package/dist/components/Accordion/useCollapsible.d.ts.map +1 -1
- package/dist/components/Alert/Alert.d.ts +13 -4
- package/dist/components/Alert/Alert.d.ts.map +1 -1
- package/dist/components/Alert/Alert.recipe.d.ts +119 -25
- package/dist/components/Alert/Alert.recipe.d.ts.map +1 -1
- package/dist/components/Alert/index.cjs +15 -16
- package/dist/components/Alert/index.d.ts +0 -1
- package/dist/components/Alert/index.d.ts.map +1 -1
- package/dist/components/Alert/index.js +14 -11
- package/dist/components/AlertDialog/AlertDialog.d.ts +1 -1
- package/dist/components/AlertDialog/AlertDialog.d.ts.map +1 -1
- package/dist/components/AlertDialog/index.cjs +19 -16
- package/dist/components/AlertDialog/index.js +17 -14
- package/dist/components/AlertDialog/useAlertDialog.d.ts.map +1 -1
- package/dist/components/AppShell/AppShell.d.ts +2 -2
- package/dist/components/AppShell/AppShell.d.ts.map +1 -1
- package/dist/components/AppShell/index.cjs +24 -25
- package/dist/components/AppShell/index.d.ts +0 -1
- package/dist/components/AppShell/index.d.ts.map +1 -1
- package/dist/components/AppShell/index.js +21 -18
- package/dist/components/AspectRatio/index.cjs +4 -8
- package/dist/components/AspectRatio/index.d.ts +0 -1
- package/dist/components/AspectRatio/index.d.ts.map +1 -1
- package/dist/components/AspectRatio/index.js +3 -3
- package/dist/components/AutocompleteInput/AutocompleteInput.d.ts.map +1 -1
- package/dist/components/AutocompleteInput/index.cjs +24 -20
- package/dist/components/AutocompleteInput/index.js +20 -16
- package/dist/components/Avatar/Avatar.d.ts.map +1 -1
- package/dist/components/Avatar/Avatar.recipe.d.ts +11 -9
- package/dist/components/Avatar/Avatar.recipe.d.ts.map +1 -1
- package/dist/components/Avatar/AvatarStatusDot.d.ts.map +1 -1
- package/dist/components/Avatar/index.cjs +9 -11
- package/dist/components/Avatar/index.d.ts +0 -1
- package/dist/components/Avatar/index.d.ts.map +1 -1
- package/dist/components/Avatar/index.js +6 -4
- package/dist/components/AvatarGroup/index.cjs +9 -11
- package/dist/components/AvatarGroup/index.d.ts +0 -1
- package/dist/components/AvatarGroup/index.d.ts.map +1 -1
- package/dist/components/AvatarGroup/index.js +7 -5
- package/dist/components/Badge/Badge.d.ts +8 -2
- package/dist/components/Badge/Badge.d.ts.map +1 -1
- package/dist/components/Badge/index.cjs +5 -9
- package/dist/components/Badge/index.d.ts +0 -1
- package/dist/components/Badge/index.d.ts.map +1 -1
- package/dist/components/Badge/index.js +4 -4
- package/dist/components/Blockquote/Blockquote.d.ts.map +1 -1
- package/dist/components/Blockquote/Blockquote.recipe.d.ts +4 -0
- package/dist/components/Blockquote/Blockquote.recipe.d.ts.map +1 -0
- package/dist/components/Blockquote/index.cjs +15 -44
- package/dist/components/Blockquote/index.cjs.map +1 -1
- package/dist/components/Blockquote/index.d.ts +1 -0
- package/dist/components/Blockquote/index.d.ts.map +1 -1
- package/dist/components/Blockquote/index.js +6 -46
- package/dist/components/Blockquote/index.js.map +1 -1
- package/dist/components/Breadcrumbs/index.cjs +12 -11
- package/dist/components/Breadcrumbs/index.js +9 -8
- package/dist/components/Button/Button.d.ts.map +1 -1
- package/dist/components/Button/Button.recipe.d.ts +2 -2
- package/dist/components/Button/index.cjs +14 -15
- package/dist/components/Button/index.d.ts +0 -1
- package/dist/components/Button/index.d.ts.map +1 -1
- package/dist/components/Button/index.js +13 -10
- package/dist/components/ButtonGroup/index.cjs +4 -8
- package/dist/components/ButtonGroup/index.d.ts +0 -1
- package/dist/components/ButtonGroup/index.d.ts.map +1 -1
- package/dist/components/ButtonGroup/index.js +3 -3
- package/dist/components/Calendar/index.cjs +15 -12
- package/dist/components/Calendar/index.js +14 -11
- package/dist/components/Card/Card.d.ts +16 -4
- package/dist/components/Card/Card.d.ts.map +1 -1
- package/dist/components/Card/Card.recipe.d.ts +18 -0
- package/dist/components/Card/Card.recipe.d.ts.map +1 -1
- package/dist/components/Card/index.cjs +4 -8
- package/dist/components/Card/index.d.ts +1 -2
- package/dist/components/Card/index.d.ts.map +1 -1
- package/dist/components/Card/index.js +3 -3
- package/dist/components/Center/Center.recipe.d.ts +0 -1
- package/dist/components/Center/Center.recipe.d.ts.map +1 -1
- package/dist/components/Center/index.cjs +4 -8
- package/dist/components/Center/index.d.ts +0 -1
- package/dist/components/Center/index.d.ts.map +1 -1
- package/dist/components/Center/index.js +3 -3
- package/dist/components/CheckboxInput/CheckboxInput.d.ts.map +1 -1
- package/dist/components/CheckboxInput/index.cjs +16 -14
- package/dist/components/CheckboxInput/index.js +15 -13
- package/dist/components/CodeBlock/CodeBlock.d.ts +6 -4
- package/dist/components/CodeBlock/CodeBlock.d.ts.map +1 -1
- package/dist/components/CodeBlock/CodeBlock.recipe.d.ts +87 -0
- package/dist/components/CodeBlock/CodeBlock.recipe.d.ts.map +1 -0
- package/dist/components/CodeBlock/index.cjs +17 -12
- package/dist/components/CodeBlock/index.d.ts +1 -0
- package/dist/components/CodeBlock/index.d.ts.map +1 -1
- package/dist/components/CodeBlock/index.js +16 -11
- package/dist/components/ContextMenu/index.cjs +20 -17
- package/dist/components/ContextMenu/index.js +18 -15
- package/dist/components/DateInput/DateInput.d.ts +1 -1
- package/dist/components/DateInput/DateInput.d.ts.map +1 -1
- package/dist/components/DateInput/index.cjs +21 -17
- package/dist/components/DateInput/index.js +20 -16
- package/dist/components/DateRangeInput/DateRangeInput.d.ts +1 -1
- package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
- package/dist/components/DateRangeInput/index.cjs +21 -17
- package/dist/components/DateRangeInput/index.js +20 -16
- package/dist/components/DateTimeInput/DateTimeInput.d.ts.map +1 -1
- package/dist/components/DateTimeInput/index.cjs +23 -19
- package/dist/components/DateTimeInput/index.js +22 -18
- package/dist/components/Dialog/Dialog.d.ts +7 -2
- package/dist/components/Dialog/Dialog.d.ts.map +1 -1
- package/dist/components/Dialog/Dialog.recipe.d.ts +13 -10
- package/dist/components/Dialog/Dialog.recipe.d.ts.map +1 -1
- package/dist/components/Dialog/DialogContext.d.ts +6 -0
- package/dist/components/Dialog/DialogContext.d.ts.map +1 -1
- package/dist/components/Dialog/index.cjs +10 -12
- package/dist/components/Dialog/index.d.ts +0 -1
- package/dist/components/Dialog/index.d.ts.map +1 -1
- package/dist/components/Dialog/index.js +6 -4
- package/dist/components/Divider/Divider.d.ts +11 -1
- package/dist/components/Divider/Divider.d.ts.map +1 -1
- package/dist/components/Divider/Divider.recipe.d.ts +35 -10
- package/dist/components/Divider/Divider.recipe.d.ts.map +1 -1
- package/dist/components/Divider/index.cjs +6 -8
- package/dist/components/Divider/index.d.ts +0 -1
- package/dist/components/Divider/index.d.ts.map +1 -1
- package/dist/components/Divider/index.js +5 -3
- package/dist/components/Drawer/index.cjs +13 -197
- package/dist/components/Drawer/index.cjs.map +1 -1
- package/dist/components/Drawer/index.js +4 -198
- package/dist/components/Drawer/index.js.map +1 -1
- package/dist/components/DropdownMenu/DropdownMenuItem.d.ts.map +1 -1
- package/dist/components/DropdownMenu/index.cjs +21 -18
- package/dist/components/DropdownMenu/index.js +17 -14
- package/dist/components/EmptyState/index.cjs +8 -11
- package/dist/components/EmptyState/index.d.ts +0 -1
- package/dist/components/EmptyState/index.d.ts.map +1 -1
- package/dist/components/EmptyState/index.js +7 -6
- package/dist/components/Field/Field.d.ts +22 -10
- package/dist/components/Field/Field.d.ts.map +1 -1
- package/dist/components/Field/Field.recipe.d.ts +33 -24
- package/dist/components/Field/Field.recipe.d.ts.map +1 -1
- package/dist/components/Field/index.cjs +14 -24
- package/dist/components/Field/index.d.ts +1 -3
- package/dist/components/Field/index.d.ts.map +1 -1
- package/dist/components/Field/index.js +11 -9
- package/dist/components/Field/inputStyles.d.ts +0 -1
- package/dist/components/Field/inputStyles.d.ts.map +1 -1
- package/dist/components/FileInput/FileInput.d.ts.map +1 -1
- package/dist/components/FileInput/index.cjs +20 -13
- package/dist/components/FileInput/index.js +19 -12
- package/dist/components/HoverCard/index.cjs +6 -5
- package/dist/components/HoverCard/index.js +4 -3
- package/dist/components/Icon/index.cjs +4 -8
- package/dist/components/Icon/index.d.ts +0 -1
- package/dist/components/Icon/index.d.ts.map +1 -1
- package/dist/components/Icon/index.js +3 -3
- package/dist/components/InputGroup/InputGroup.d.ts.map +1 -1
- package/dist/components/InputGroup/index.cjs +16 -14
- package/dist/components/InputGroup/index.js +12 -10
- package/dist/components/Item/Item.d.ts.map +1 -1
- package/dist/components/Item/index.cjs +11 -10
- package/dist/components/Item/index.js +10 -9
- package/dist/components/Kbd/Kbd.d.ts.map +1 -1
- package/dist/components/Kbd/Kbd.recipe.d.ts +28 -13
- package/dist/components/Kbd/Kbd.recipe.d.ts.map +1 -1
- package/dist/components/Kbd/index.cjs +6 -4
- package/dist/components/Kbd/index.d.ts +1 -0
- package/dist/components/Kbd/index.d.ts.map +1 -1
- package/dist/components/Kbd/index.js +5 -3
- package/dist/components/Layout/Layout.d.ts +3 -2
- package/dist/components/Layout/Layout.d.ts.map +1 -1
- package/dist/components/Layout/LayoutContent.d.ts +2 -2
- package/dist/components/Layout/LayoutContent.d.ts.map +1 -1
- package/dist/components/Layout/LayoutFooter.d.ts +2 -2
- package/dist/components/Layout/LayoutFooter.d.ts.map +1 -1
- package/dist/components/Layout/LayoutHeader.d.ts +2 -2
- package/dist/components/Layout/LayoutHeader.d.ts.map +1 -1
- package/dist/components/Layout/LayoutPanel.d.ts +2 -2
- package/dist/components/Layout/LayoutPanel.d.ts.map +1 -1
- package/dist/components/Layout/index.cjs +20 -21
- package/dist/components/Layout/index.d.ts +1 -2
- package/dist/components/Layout/index.d.ts.map +1 -1
- package/dist/components/Layout/index.js +15 -12
- package/dist/components/Layout/types.d.ts +1 -1
- package/dist/components/Layout/types.d.ts.map +1 -1
- package/dist/components/Lightbox/index.cjs +16 -13
- package/dist/components/Lightbox/index.js +14 -11
- package/dist/components/Link/index.cjs +11 -14
- package/dist/components/Link/index.d.ts +0 -1
- package/dist/components/Link/index.d.ts.map +1 -1
- package/dist/components/Link/index.js +8 -7
- package/dist/components/List/ListItem.d.ts.map +1 -1
- package/dist/components/List/index.cjs +13 -12
- package/dist/components/List/index.js +11 -10
- package/dist/components/MetadataList/index.cjs +10 -9
- package/dist/components/MetadataList/index.js +8 -7
- package/dist/components/MultiSelect/MultiSelect.d.ts.map +1 -1
- package/dist/components/MultiSelect/index.cjs +22 -18
- package/dist/components/MultiSelect/index.js +21 -17
- package/dist/components/NavIcon/index.cjs +8 -36
- package/dist/components/NavIcon/index.cjs.map +1 -1
- package/dist/components/NavIcon/index.js +3 -38
- package/dist/components/NavIcon/index.js.map +1 -1
- package/dist/components/NumberInput/NumberInput.d.ts.map +1 -1
- package/dist/components/NumberInput/index.cjs +21 -14
- package/dist/components/NumberInput/index.js +20 -13
- package/dist/components/Pagination/index.cjs +15 -12
- package/dist/components/Pagination/index.js +14 -11
- package/dist/components/PasswordInput/PasswordInput.d.ts +1 -1
- package/dist/components/PasswordInput/PasswordInput.d.ts.map +1 -1
- package/dist/components/PasswordInput/index.cjs +25 -54
- package/dist/components/PasswordInput/index.cjs.map +1 -1
- package/dist/components/PasswordInput/index.js +20 -56
- package/dist/components/PasswordInput/index.js.map +1 -1
- package/dist/components/Popover/Popover.d.ts +1 -1
- package/dist/components/Popover/Popover.d.ts.map +1 -1
- package/dist/components/Popover/index.cjs +16 -13
- package/dist/components/Popover/index.js +14 -11
- package/dist/components/Progress/index.cjs +5 -9
- package/dist/components/Progress/index.d.ts +0 -1
- package/dist/components/Progress/index.d.ts.map +1 -1
- package/dist/components/Progress/index.js +4 -4
- package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -1
- package/dist/components/RadioGroup/RadioGroup.recipe.d.ts +90 -0
- package/dist/components/RadioGroup/RadioGroup.recipe.d.ts.map +1 -0
- package/dist/components/RadioGroup/RadioGroupContext.d.ts +1 -1
- package/dist/components/RadioGroup/RadioGroupContext.d.ts.map +1 -1
- package/dist/components/RadioGroup/RadioGroupItem.d.ts.map +1 -1
- package/dist/components/RadioGroup/index.cjs +17 -15
- package/dist/components/RadioGroup/index.d.ts +1 -0
- package/dist/components/RadioGroup/index.d.ts.map +1 -1
- package/dist/components/RadioGroup/index.js +15 -13
- package/dist/components/Rating/Rating.d.ts.map +1 -1
- package/dist/components/Rating/Rating.recipe.d.ts +23 -0
- package/dist/components/Rating/Rating.recipe.d.ts.map +1 -0
- package/dist/components/Rating/index.cjs +17 -179
- package/dist/components/Rating/index.cjs.map +1 -1
- package/dist/components/Rating/index.d.ts +1 -0
- package/dist/components/Rating/index.d.ts.map +1 -1
- package/dist/components/Rating/index.js +8 -181
- package/dist/components/Rating/index.js.map +1 -1
- package/dist/components/Schedule/MonthlyView.d.ts.map +1 -1
- package/dist/components/Schedule/index.cjs +30 -27
- package/dist/components/Schedule/index.js +19 -16
- package/dist/components/SearchFilterInput/index.cjs +40 -36
- package/dist/components/SearchFilterInput/index.js +32 -28
- package/dist/components/SegmentedControl/SegmentedControl.d.ts +6 -1
- package/dist/components/SegmentedControl/SegmentedControl.d.ts.map +1 -1
- package/dist/components/SegmentedControl/index.cjs +7 -7
- package/dist/components/SegmentedControl/index.js +5 -5
- package/dist/components/Select/Select.d.ts.map +1 -1
- package/dist/components/Select/index.cjs +23 -19
- package/dist/components/Select/index.js +21 -17
- package/dist/components/SideNav/SideNav.recipe.d.ts.map +1 -1
- package/dist/components/SideNav/SideNavItem.d.ts.map +1 -1
- package/dist/components/SideNav/index.cjs +22 -23
- package/dist/components/SideNav/index.d.ts +0 -1
- package/dist/components/SideNav/index.d.ts.map +1 -1
- package/dist/components/SideNav/index.js +16 -13
- package/dist/components/Skeleton/Skeleton.d.ts.map +1 -1
- package/dist/components/Skeleton/Skeleton.recipe.d.ts +28 -0
- package/dist/components/Skeleton/Skeleton.recipe.d.ts.map +1 -0
- package/dist/components/Skeleton/index.cjs +8 -3
- package/dist/components/Skeleton/index.d.ts +1 -0
- package/dist/components/Skeleton/index.d.ts.map +1 -1
- package/dist/components/Skeleton/index.js +3 -2
- package/dist/components/Slider/Slider.d.ts.map +1 -1
- package/dist/components/Slider/Slider.recipe.d.ts +99 -0
- package/dist/components/Slider/Slider.recipe.d.ts.map +1 -0
- package/dist/components/Slider/index.cjs +17 -11
- package/dist/components/Slider/index.d.ts +1 -0
- package/dist/components/Slider/index.d.ts.map +1 -1
- package/dist/components/Slider/index.js +12 -10
- package/dist/components/Spinner/Spinner.d.ts +6 -6
- package/dist/components/Spinner/Spinner.d.ts.map +1 -1
- package/dist/components/Spinner/Spinner.recipe.d.ts +25 -12
- package/dist/components/Spinner/Spinner.recipe.d.ts.map +1 -1
- package/dist/components/Spinner/index.cjs +9 -11
- package/dist/components/Spinner/index.d.ts +0 -1
- package/dist/components/Spinner/index.d.ts.map +1 -1
- package/dist/components/Spinner/index.js +8 -6
- package/dist/components/Stack/Stack.d.ts +2 -2
- package/dist/components/Stack/Stack.d.ts.map +1 -1
- package/dist/components/Stack/index.cjs +5 -9
- package/dist/components/Stack/index.d.ts +0 -1
- package/dist/components/Stack/index.d.ts.map +1 -1
- package/dist/components/Stack/index.js +3 -3
- package/dist/components/Stepper/index.cjs +11 -10
- package/dist/components/Stepper/index.js +8 -7
- package/dist/components/Switch/Switch.d.ts.map +1 -1
- package/dist/components/Switch/Switch.recipe.d.ts +60 -0
- package/dist/components/Switch/Switch.recipe.d.ts.map +1 -0
- package/dist/components/Switch/index.cjs +13 -11
- package/dist/components/Switch/index.js +12 -10
- package/dist/components/Table/TableCell.d.ts.map +1 -1
- package/dist/components/Table/TableHeaderCell.d.ts.map +1 -1
- package/dist/components/Table/index.cjs +64 -60
- package/dist/components/Table/index.js +36 -32
- package/dist/components/Tabs/Tabs.d.ts +5 -0
- package/dist/components/Tabs/Tabs.d.ts.map +1 -1
- package/dist/components/Tabs/index.cjs +20 -17
- package/dist/components/Tabs/index.js +15 -12
- package/dist/components/Tag/index.cjs +10 -13
- package/dist/components/Tag/index.d.ts +0 -1
- package/dist/components/Tag/index.d.ts.map +1 -1
- package/dist/components/Tag/index.js +9 -8
- package/dist/components/TagsInput/TagsInput.d.ts.map +1 -1
- package/dist/components/TagsInput/index.cjs +22 -18
- package/dist/components/TagsInput/index.js +21 -17
- package/dist/components/Text/index.cjs +8 -15
- package/dist/components/Text/index.d.ts +0 -1
- package/dist/components/Text/index.d.ts.map +1 -1
- package/dist/components/Text/index.js +6 -5
- package/dist/components/TextArea/TextArea.d.ts.map +1 -1
- package/dist/components/TextArea/index.cjs +16 -13
- package/dist/components/TextArea/index.js +15 -12
- package/dist/components/TextInput/TextInput.d.ts.map +1 -1
- package/dist/components/TextInput/index.cjs +21 -14
- package/dist/components/TextInput/index.js +20 -13
- package/dist/components/Thumbnail/Thumbnail.d.ts.map +1 -1
- package/dist/components/Thumbnail/Thumbnail.recipe.d.ts +36 -0
- package/dist/components/Thumbnail/Thumbnail.recipe.d.ts.map +1 -0
- package/dist/components/Thumbnail/index.cjs +16 -13
- package/dist/components/Thumbnail/index.d.ts +1 -0
- package/dist/components/Thumbnail/index.d.ts.map +1 -1
- package/dist/components/Thumbnail/index.js +15 -12
- package/dist/components/TimeInput/TimeInput.d.ts.map +1 -1
- package/dist/components/TimeInput/index.cjs +20 -13
- package/dist/components/TimeInput/index.js +19 -12
- package/dist/components/Toast/index.cjs +17 -14
- package/dist/components/Toast/index.js +14 -11
- package/dist/components/ToggleButton/ToggleButton.d.ts.map +1 -1
- package/dist/components/ToggleButton/index.cjs +13 -14
- package/dist/components/ToggleButton/index.js +11 -12
- package/dist/components/Tooltip/index.cjs +6 -5
- package/dist/components/Tooltip/index.js +4 -3
- package/dist/components/TopNav/TopNav.recipe.d.ts.map +1 -1
- package/dist/components/TopNav/index.cjs +22 -23
- package/dist/components/TopNav/index.d.ts +0 -1
- package/dist/components/TopNav/index.d.ts.map +1 -1
- package/dist/components/TopNav/index.js +16 -13
- package/dist/components/TreeView/TreeViewItem.d.ts.map +1 -1
- package/dist/components/TreeView/index.cjs +5 -5
- package/dist/components/TreeView/index.js +4 -4
- package/dist/index.cjs +584 -332
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +27 -22
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +384 -77
- package/dist/index.js.map +1 -1
- package/dist/internal/MobileNav/MobileNav.d.ts.map +1 -1
- package/dist/internal/spacingTokens.d.ts +8 -0
- package/dist/internal/spacingTokens.d.ts.map +1 -0
- package/dist/styles.css +1 -1
- package/dist/themes/presets.d.ts +48 -0
- package/dist/themes/presets.d.ts.map +1 -0
- package/package.json +12 -2
- package/dist/chunk-25OAUQRF.cjs.map +0 -1
- package/dist/chunk-2FPZULX3.cjs.map +0 -1
- package/dist/chunk-2FUG6NKO.js.map +0 -1
- package/dist/chunk-2PHHFBJ3.cjs.map +0 -1
- package/dist/chunk-2QK2NZN5.js.map +0 -1
- package/dist/chunk-2UTRYTT3.cjs.map +0 -1
- package/dist/chunk-2WP6NYYY.cjs +0 -113
- package/dist/chunk-2WP6NYYY.cjs.map +0 -1
- package/dist/chunk-2XCNB2O6.js.map +0 -1
- package/dist/chunk-3DE4GOZU.js +0 -207
- package/dist/chunk-3DE4GOZU.js.map +0 -1
- package/dist/chunk-3PSQDJQH.js.map +0 -1
- package/dist/chunk-47BELFYO.cjs.map +0 -1
- package/dist/chunk-4W7L63LH.js.map +0 -1
- package/dist/chunk-4XRVXUJQ.cjs +0 -242
- package/dist/chunk-4XRVXUJQ.cjs.map +0 -1
- package/dist/chunk-5EQN3YMQ.cjs.map +0 -1
- package/dist/chunk-5OS5A27C.js.map +0 -1
- package/dist/chunk-6NIFOTUZ.cjs.map +0 -1
- package/dist/chunk-6SPQDYHC.cjs.map +0 -1
- package/dist/chunk-6UVJUY7Z.cjs.map +0 -1
- package/dist/chunk-7EXVJWG5.js.map +0 -1
- package/dist/chunk-AFT635BR.cjs +0 -308
- package/dist/chunk-AFT635BR.cjs.map +0 -1
- package/dist/chunk-AZDWQGAX.cjs.map +0 -1
- package/dist/chunk-BCJ25X7C.js.map +0 -1
- package/dist/chunk-BSBEPQLM.cjs.map +0 -1
- package/dist/chunk-CA6645TQ.js.map +0 -1
- package/dist/chunk-CR4NB42L.cjs.map +0 -1
- package/dist/chunk-CVH6X6ND.js +0 -125
- package/dist/chunk-CVH6X6ND.js.map +0 -1
- package/dist/chunk-CWUC4TOQ.js.map +0 -1
- package/dist/chunk-CXBB2LN7.js.map +0 -1
- package/dist/chunk-CZJUKLFD.cjs.map +0 -1
- package/dist/chunk-D6KXW75E.js.map +0 -1
- package/dist/chunk-DFF72N57.js.map +0 -1
- package/dist/chunk-DHUK3GNK.cjs +0 -258
- package/dist/chunk-DHUK3GNK.cjs.map +0 -1
- package/dist/chunk-DJW7T3WJ.js.map +0 -1
- package/dist/chunk-DONU5ALC.cjs.map +0 -1
- package/dist/chunk-E4TIWN4Z.cjs.map +0 -1
- package/dist/chunk-EB5EHX6I.js.map +0 -1
- package/dist/chunk-EBUSMPS6.js +0 -306
- package/dist/chunk-EBUSMPS6.js.map +0 -1
- package/dist/chunk-EETTQWW5.cjs.map +0 -1
- package/dist/chunk-EHBV6ZMM.js +0 -239
- package/dist/chunk-EHBV6ZMM.js.map +0 -1
- package/dist/chunk-EM2F6BZ2.js.map +0 -1
- package/dist/chunk-FVIEYPDB.js.map +0 -1
- package/dist/chunk-G44NDBPN.cjs +0 -62
- package/dist/chunk-G44NDBPN.cjs.map +0 -1
- package/dist/chunk-GKG47NK6.cjs.map +0 -1
- package/dist/chunk-GUF4ZNPQ.js.map +0 -1
- package/dist/chunk-GZ5SRSD4.js.map +0 -1
- package/dist/chunk-H6OY6FLC.js.map +0 -1
- package/dist/chunk-HPZ7LLXK.js.map +0 -1
- package/dist/chunk-HWCL6JFB.js.map +0 -1
- package/dist/chunk-HXT6A6GH.cjs.map +0 -1
- package/dist/chunk-I6IGTQLG.cjs +0 -251
- package/dist/chunk-I6IGTQLG.cjs.map +0 -1
- package/dist/chunk-IT72TF72.js.map +0 -1
- package/dist/chunk-IWSS5745.js.map +0 -1
- package/dist/chunk-JCYPM27J.js.map +0 -1
- package/dist/chunk-K574UTWP.cjs.map +0 -1
- package/dist/chunk-KVREBGWA.js.map +0 -1
- package/dist/chunk-KXXRALHT.cjs.map +0 -1
- package/dist/chunk-KXXTWWJZ.cjs.map +0 -1
- package/dist/chunk-LBRKUZSQ.cjs.map +0 -1
- package/dist/chunk-LFZXGIR6.cjs.map +0 -1
- package/dist/chunk-MCOVG6W6.js.map +0 -1
- package/dist/chunk-MKAOIB2O.cjs.map +0 -1
- package/dist/chunk-NGWNIMMX.js +0 -247
- package/dist/chunk-NGWNIMMX.js.map +0 -1
- package/dist/chunk-NILB6Y4Z.cjs.map +0 -1
- package/dist/chunk-NJDV3LDH.js.map +0 -1
- package/dist/chunk-NMHCRHRI.cjs.map +0 -1
- package/dist/chunk-NOZ6U6ZJ.js.map +0 -1
- package/dist/chunk-NPJXGQOF.cjs.map +0 -1
- package/dist/chunk-NSHWBZL4.cjs.map +0 -1
- package/dist/chunk-O5RVLBKN.cjs.map +0 -1
- package/dist/chunk-OA4KIVLO.cjs.map +0 -1
- package/dist/chunk-OAUKYH6C.cjs.map +0 -1
- package/dist/chunk-OKKL652L.js.map +0 -1
- package/dist/chunk-OZNNBPMP.cjs +0 -288
- package/dist/chunk-OZNNBPMP.cjs.map +0 -1
- package/dist/chunk-P5AZUUM2.cjs.map +0 -1
- package/dist/chunk-PDXZDPOY.cjs.map +0 -1
- package/dist/chunk-PGKOWMP4.js.map +0 -1
- package/dist/chunk-PHFEQG4E.cjs.map +0 -1
- package/dist/chunk-PZO5MZ46.js.map +0 -1
- package/dist/chunk-QFO5ZTZZ.js.map +0 -1
- package/dist/chunk-QRDRZNCS.cjs.map +0 -1
- package/dist/chunk-QRXMW7MQ.cjs.map +0 -1
- package/dist/chunk-QXI446BK.cjs +0 -209
- package/dist/chunk-QXI446BK.cjs.map +0 -1
- package/dist/chunk-R2NQNVEV.js.map +0 -1
- package/dist/chunk-RCAA2CZJ.js.map +0 -1
- package/dist/chunk-RGPL6EDK.js +0 -110
- package/dist/chunk-RGPL6EDK.js.map +0 -1
- package/dist/chunk-RJXHAQCR.cjs.map +0 -1
- package/dist/chunk-RLQYXUDO.js +0 -59
- package/dist/chunk-RLQYXUDO.js.map +0 -1
- package/dist/chunk-S5NFDKPL.js.map +0 -1
- package/dist/chunk-T55MB2CA.js.map +0 -1
- package/dist/chunk-TPSOUQG7.cjs.map +0 -1
- package/dist/chunk-U35V3GVC.js.map +0 -1
- package/dist/chunk-UHQRL4OA.js.map +0 -1
- package/dist/chunk-UWG5UQFV.cjs.map +0 -1
- package/dist/chunk-UZNSGQT3.cjs.map +0 -1
- package/dist/chunk-VIJHDURK.js.map +0 -1
- package/dist/chunk-VLIQPSPM.js.map +0 -1
- package/dist/chunk-VT7VKCHL.cjs.map +0 -1
- package/dist/chunk-VTQRXV32.js +0 -565
- package/dist/chunk-VTQRXV32.js.map +0 -1
- package/dist/chunk-VVYUCQHP.js.map +0 -1
- package/dist/chunk-WA4DRAQ7.js.map +0 -1
- package/dist/chunk-WBPIJ4D5.js.map +0 -1
- package/dist/chunk-WE3ECIRS.cjs.map +0 -1
- package/dist/chunk-WEEYUS7M.cjs.map +0 -1
- package/dist/chunk-WIIDQ44X.cjs.map +0 -1
- package/dist/chunk-WIW2YR46.js.map +0 -1
- package/dist/chunk-WM66IPV4.cjs +0 -567
- package/dist/chunk-WM66IPV4.cjs.map +0 -1
- package/dist/chunk-WSAZHUB3.cjs.map +0 -1
- package/dist/chunk-XQMLA75S.js.map +0 -1
- package/dist/chunk-Y73472IA.js.map +0 -1
- package/dist/chunk-YHR44PWO.js.map +0 -1
- package/dist/chunk-YMC56K6R.cjs.map +0 -1
- package/dist/chunk-YOFCBZAX.js +0 -286
- package/dist/chunk-YOFCBZAX.js.map +0 -1
- package/dist/chunk-YOWRLFMF.cjs +0 -128
- package/dist/chunk-YOWRLFMF.cjs.map +0 -1
- package/dist/chunk-YRXGCYT2.js.map +0 -1
- package/dist/chunk-YT3UWEVY.js.map +0 -1
- package/dist/chunk-YX7DI3O3.cjs.map +0 -1
- package/dist/chunk-YZUBJ2L2.cjs.map +0 -1
- package/dist/chunk-Z2STCD6I.js.map +0 -1
- package/dist/chunk-ZC7H4S4T.cjs.map +0 -1
- package/dist/chunk-ZHFAFEI2.js.map +0 -1
- package/dist/chunk-ZVBVKZ4P.cjs.map +0 -1
- package/dist/chunk-ZW4XKNDR.cjs.map +0 -1
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { sva } from './chunk-EHCAF6D3.js';
|
|
2
|
+
import { Icon } from './chunk-7T3SWOY7.js';
|
|
2
3
|
import { cx } from './chunk-PPNETWIP.js';
|
|
3
|
-
import { css } from './chunk-
|
|
4
|
-
import { createContext, useState, useMemo, useCallback, useId, use } from 'react';
|
|
4
|
+
import { css } from './chunk-OD4DHHZH.js';
|
|
5
|
+
import { createContext, useState, useRef, useMemo, useCallback, useId, use } from 'react';
|
|
5
6
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
6
7
|
import { ChevronDown } from 'lucide-react';
|
|
7
8
|
|
|
@@ -39,6 +40,22 @@ function Accordion({
|
|
|
39
40
|
const [internalValue, setInternalValue] = useState(
|
|
40
41
|
() => normalizeToSet(defaultValue)
|
|
41
42
|
);
|
|
43
|
+
const prevControlledArrayRef = useRef(
|
|
44
|
+
void 0
|
|
45
|
+
);
|
|
46
|
+
const hasWarnedUnstableValueRef = useRef(false);
|
|
47
|
+
if (process.env.NODE_ENV !== "production") {
|
|
48
|
+
if (Array.isArray(controlledValue)) {
|
|
49
|
+
const prev = prevControlledArrayRef.current;
|
|
50
|
+
if (!hasWarnedUnstableValueRef.current && prev !== void 0 && prev !== controlledValue && prev.length === controlledValue.length && prev.every((item, i) => item === controlledValue[i])) {
|
|
51
|
+
hasWarnedUnstableValueRef.current = true;
|
|
52
|
+
console.warn(
|
|
53
|
+
"Accordion: the `value` array changed identity between renders but contains the same items. Memoize it (e.g. with `useMemo`) to avoid unnecessary re-renders of the accordion items."
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
prevControlledArrayRef.current = controlledValue;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
42
59
|
const openValues = useMemo(
|
|
43
60
|
() => isControlled ? normalizeToSet(controlledValue) : internalValue,
|
|
44
61
|
[isControlled, controlledValue, internalValue]
|
|
@@ -94,6 +111,82 @@ function Accordion({
|
|
|
94
111
|
) });
|
|
95
112
|
}
|
|
96
113
|
Accordion.displayName = "Accordion";
|
|
114
|
+
|
|
115
|
+
// src/components/Accordion/AccordionItem.recipe.ts
|
|
116
|
+
var accordionItemRecipe = sva({
|
|
117
|
+
slots: ["root", "trigger", "chevron", "panel", "panelInner"],
|
|
118
|
+
base: {
|
|
119
|
+
root: {
|
|
120
|
+
w: "100%"
|
|
121
|
+
},
|
|
122
|
+
trigger: {
|
|
123
|
+
display: "flex",
|
|
124
|
+
alignItems: "center",
|
|
125
|
+
justifyContent: "space-between",
|
|
126
|
+
w: "100%",
|
|
127
|
+
cursor: "pointer",
|
|
128
|
+
fontFamily: "body",
|
|
129
|
+
fontSize: "lg",
|
|
130
|
+
fontWeight: "semibold",
|
|
131
|
+
color: "fg",
|
|
132
|
+
textAlign: "start",
|
|
133
|
+
py: 0,
|
|
134
|
+
_disabled: {
|
|
135
|
+
opacity: 0.5,
|
|
136
|
+
cursor: "not-allowed"
|
|
137
|
+
},
|
|
138
|
+
_focusVisible: {
|
|
139
|
+
outlineWidth: "focus",
|
|
140
|
+
outlineStyle: "solid",
|
|
141
|
+
outlineColor: "primary",
|
|
142
|
+
outlineOffset: "focusOffset",
|
|
143
|
+
borderRadius: "sm"
|
|
144
|
+
}
|
|
145
|
+
},
|
|
146
|
+
chevron: {
|
|
147
|
+
display: "inline-flex",
|
|
148
|
+
alignItems: "center",
|
|
149
|
+
justifyContent: "center",
|
|
150
|
+
flexShrink: 0,
|
|
151
|
+
transitionProperty: "transform",
|
|
152
|
+
transitionDuration: "fast",
|
|
153
|
+
transitionTimingFunction: "default",
|
|
154
|
+
color: "fg.muted"
|
|
155
|
+
},
|
|
156
|
+
panel: {
|
|
157
|
+
display: "grid",
|
|
158
|
+
gridTemplateRows: "1fr",
|
|
159
|
+
// `visibility` is transitioned alongside the rows so the content stays
|
|
160
|
+
// readable while collapsing, then becomes `hidden` (removing it from the
|
|
161
|
+
// a11y tree and tab order) once closed. The inline `visibility` style in
|
|
162
|
+
// the component drives the open/closed value.
|
|
163
|
+
transitionProperty: "grid-template-rows, visibility",
|
|
164
|
+
transitionDuration: "normal",
|
|
165
|
+
transitionTimingFunction: "default",
|
|
166
|
+
"@media (prefers-reduced-motion: reduce)": {
|
|
167
|
+
transitionDuration: "0.01s"
|
|
168
|
+
}
|
|
169
|
+
},
|
|
170
|
+
panelInner: {
|
|
171
|
+
overflow: "hidden",
|
|
172
|
+
minH: 0,
|
|
173
|
+
pt: "1"
|
|
174
|
+
}
|
|
175
|
+
},
|
|
176
|
+
variants: {
|
|
177
|
+
isOpen: {
|
|
178
|
+
true: {
|
|
179
|
+
chevron: { transform: "rotate(180deg)" }
|
|
180
|
+
},
|
|
181
|
+
false: {
|
|
182
|
+
panel: { gridTemplateRows: "0fr" }
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
},
|
|
186
|
+
defaultVariants: {
|
|
187
|
+
isOpen: false
|
|
188
|
+
}
|
|
189
|
+
});
|
|
97
190
|
function useCollapsible(options) {
|
|
98
191
|
const { config, value } = options;
|
|
99
192
|
const group = use(AccordionContext);
|
|
@@ -125,67 +218,22 @@ function useCollapsible(options) {
|
|
|
125
218
|
} else {
|
|
126
219
|
isOpen = internalIsOpen;
|
|
127
220
|
}
|
|
128
|
-
const
|
|
129
|
-
|
|
221
|
+
const configIsOpen = config?.isOpen;
|
|
222
|
+
const onOpenChange = config?.onOpenChange;
|
|
223
|
+
const toggle = useCallback(() => {
|
|
224
|
+
if (group != null && value != null) {
|
|
130
225
|
group.toggle(value);
|
|
131
|
-
} else if (
|
|
226
|
+
} else if (group != null) {
|
|
132
227
|
return;
|
|
133
|
-
} else if (
|
|
134
|
-
|
|
228
|
+
} else if (configIsOpen !== void 0) {
|
|
229
|
+
onOpenChange?.(!configIsOpen);
|
|
135
230
|
} else {
|
|
136
231
|
setInternalIsOpen((prev) => !prev);
|
|
137
|
-
|
|
232
|
+
onOpenChange?.(!isOpen);
|
|
138
233
|
}
|
|
139
|
-
};
|
|
234
|
+
}, [group, value, configIsOpen, onOpenChange, isOpen]);
|
|
140
235
|
return { isOpen, toggle };
|
|
141
236
|
}
|
|
142
|
-
var styles2 = {
|
|
143
|
-
root: css({
|
|
144
|
-
w: "100%"
|
|
145
|
-
}),
|
|
146
|
-
trigger: css({
|
|
147
|
-
all: "unset",
|
|
148
|
-
boxSizing: "border-box",
|
|
149
|
-
display: "flex",
|
|
150
|
-
alignItems: "center",
|
|
151
|
-
justifyContent: "space-between",
|
|
152
|
-
w: "100%",
|
|
153
|
-
cursor: "pointer",
|
|
154
|
-
fontFamily: "body",
|
|
155
|
-
fontSize: "lg",
|
|
156
|
-
fontWeight: "semibold",
|
|
157
|
-
color: "fg",
|
|
158
|
-
textAlign: "start",
|
|
159
|
-
py: 0,
|
|
160
|
-
_disabled: {
|
|
161
|
-
opacity: 0.5,
|
|
162
|
-
cursor: "not-allowed"
|
|
163
|
-
},
|
|
164
|
-
_focusVisible: {
|
|
165
|
-
outlineWidth: "focus",
|
|
166
|
-
outlineStyle: "solid",
|
|
167
|
-
outlineColor: "primary",
|
|
168
|
-
outlineOffset: "focusOffset",
|
|
169
|
-
borderRadius: "sm"
|
|
170
|
-
}
|
|
171
|
-
}),
|
|
172
|
-
chevron: css({
|
|
173
|
-
display: "inline-flex",
|
|
174
|
-
alignItems: "center",
|
|
175
|
-
justifyContent: "center",
|
|
176
|
-
flexShrink: 0,
|
|
177
|
-
transitionProperty: "transform",
|
|
178
|
-
transitionDuration: "fast",
|
|
179
|
-
transitionTimingFunction: "default",
|
|
180
|
-
color: "fg.muted"
|
|
181
|
-
}),
|
|
182
|
-
chevronOpen: css({
|
|
183
|
-
transform: "rotate(180deg)"
|
|
184
|
-
}),
|
|
185
|
-
content: css({
|
|
186
|
-
pt: "1"
|
|
187
|
-
})
|
|
188
|
-
};
|
|
189
237
|
function AccordionItem({
|
|
190
238
|
trigger,
|
|
191
239
|
children,
|
|
@@ -207,10 +255,11 @@ function AccordionItem({
|
|
|
207
255
|
const id = useId();
|
|
208
256
|
const triggerId = `${id}-trigger`;
|
|
209
257
|
const panelId = `${id}-panel`;
|
|
258
|
+
const classes = accordionItemRecipe({ isOpen });
|
|
210
259
|
return /* @__PURE__ */ jsxs(
|
|
211
260
|
"div",
|
|
212
261
|
{
|
|
213
|
-
className: cx(
|
|
262
|
+
className: cx(classes.root, className),
|
|
214
263
|
"data-testid": dataTestId,
|
|
215
264
|
ref,
|
|
216
265
|
style,
|
|
@@ -220,23 +269,14 @@ function AccordionItem({
|
|
|
220
269
|
{
|
|
221
270
|
"aria-controls": panelId,
|
|
222
271
|
"aria-expanded": isOpen,
|
|
223
|
-
className:
|
|
272
|
+
className: classes.trigger,
|
|
224
273
|
disabled: isDisabled,
|
|
225
274
|
id: triggerId,
|
|
226
275
|
onClick: toggle,
|
|
227
276
|
type: "button",
|
|
228
277
|
children: [
|
|
229
278
|
trigger,
|
|
230
|
-
/* @__PURE__ */ jsx(
|
|
231
|
-
"span",
|
|
232
|
-
{
|
|
233
|
-
className: cx(
|
|
234
|
-
styles2.chevron,
|
|
235
|
-
isOpen ? styles2.chevronOpen : void 0
|
|
236
|
-
),
|
|
237
|
-
children: /* @__PURE__ */ jsx(Icon, { icon: ChevronDown, size: "md" })
|
|
238
|
-
}
|
|
239
|
-
)
|
|
279
|
+
/* @__PURE__ */ jsx("span", { className: classes.chevron, children: /* @__PURE__ */ jsx(Icon, { icon: ChevronDown, size: "md" }) })
|
|
240
280
|
]
|
|
241
281
|
}
|
|
242
282
|
),
|
|
@@ -244,11 +284,11 @@ function AccordionItem({
|
|
|
244
284
|
"div",
|
|
245
285
|
{
|
|
246
286
|
"aria-labelledby": triggerId,
|
|
247
|
-
className:
|
|
248
|
-
hidden: !isOpen || void 0,
|
|
287
|
+
className: classes.panel,
|
|
249
288
|
id: panelId,
|
|
250
289
|
role: "region",
|
|
251
|
-
|
|
290
|
+
style: { visibility: isOpen ? void 0 : "hidden" },
|
|
291
|
+
children: /* @__PURE__ */ jsx("div", { className: classes.panelInner, children })
|
|
252
292
|
}
|
|
253
293
|
)
|
|
254
294
|
]
|
|
@@ -277,5 +317,5 @@ function Collapsible({
|
|
|
277
317
|
Collapsible.displayName = "Collapsible";
|
|
278
318
|
|
|
279
319
|
export { Accordion, AccordionItem, Collapsible };
|
|
280
|
-
//# sourceMappingURL=chunk-
|
|
281
|
-
//# sourceMappingURL=chunk-
|
|
320
|
+
//# sourceMappingURL=chunk-BA2VUDQS.js.map
|
|
321
|
+
//# sourceMappingURL=chunk-BA2VUDQS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/Accordion/AccordionContext.tsx","../src/components/Accordion/Accordion.tsx","../src/components/Accordion/AccordionItem.recipe.ts","../src/components/Accordion/useCollapsible.ts","../src/components/Accordion/AccordionItem.tsx","../src/components/Accordion/Collapsible.tsx"],"names":["useState","useCallback","jsx"],"mappings":"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","file":"chunk-BA2VUDQS.js","sourcesContent":["import {createContext} from 'react';\n\nexport interface AccordionContextValue {\n getIsOpen: (value: string) => boolean;\n toggle: (value: string) => void;\n}\n\nexport const AccordionContext = createContext<AccordionContextValue | null>(\n null,\n);\nAccordionContext.displayName = 'AccordionContext';\n","import {\n useCallback,\n useMemo,\n useRef,\n useState,\n type CSSProperties,\n type ReactNode,\n type Ref,\n} from 'react';\nimport {css} from 'styled-system/css';\nimport {cx} from '../../internal/cx';\nimport {AccordionContext, type AccordionContextValue} from './AccordionContext';\n\n/**\n * A container that coordinates multiple `AccordionItem` children so that\n * one (`type=\"single\"`) or several (`type=\"multiple\"`) can be open at a\n * time. For a standalone disclosure widget, use `Collapsible` instead.\n */\ninterface AccordionBaseProps {\n /**\n * Accessible label for the accordion group. Provide either `aria-label`\n * or `aria-labelledby`, not both.\n */\n 'aria-label'?: string;\n /**\n * ID of an element that labels the accordion group. Provide either\n * `aria-label` or `aria-labelledby`, not both.\n */\n 'aria-labelledby'?: string;\n /**\n * One or more `AccordionItem` elements.\n */\n children: ReactNode;\n /**\n * Additional CSS class names applied to the root element.\n */\n className?: string;\n /**\n * Test ID applied to the root element.\n */\n 'data-testid'?: string;\n /**\n * Ref forwarded to the root element.\n */\n ref?: Ref<HTMLDivElement>;\n /**\n * Inline styles applied to the root element.\n */\n style?: CSSProperties;\n}\n\nexport type AccordionProps =\n | (AccordionBaseProps & {\n /**\n * Item value that is open on initial render, or `null` for all\n * closed. Ignored when `value` is provided.\n */\n defaultValue?: string | null;\n /**\n * Called when the open item changes. Receives the item value string,\n * or `null` when all items are closed.\n */\n onChange?: (value: string | null) => void;\n /**\n * Only one item can be open at a time. This is the default.\n */\n type?: 'single';\n /**\n * Controls which item is open externally. Pass `null` to close all\n * items. When set, the component becomes controlled and `onChange`\n * should be provided.\n */\n value?: string | null;\n })\n | (AccordionBaseProps & {\n /**\n * Item values that are open on initial render. Ignored when `value` is\n * provided.\n */\n defaultValue?: string[];\n /**\n * Called when the set of open items changes. Receives an array of\n * open item values.\n */\n onChange?: (value: string[]) => void;\n /**\n * Multiple items can be open simultaneously.\n */\n type: 'multiple';\n /**\n * Controls which items are open externally. When set, the component\n * becomes controlled and `onChange` should be provided. Memoize array\n * values to avoid unnecessary re-renders.\n */\n value?: string[];\n });\n\nfunction normalizeToSet(\n value: string | string[] | null | undefined,\n): ReadonlySet<string> {\n if (value == null) {\n return new Set();\n }\n return new Set(Array.isArray(value) ? value : [value]);\n}\n\nconst styles = {\n root: css({\n display: 'flex',\n flexDirection: 'column',\n gap: '3',\n }),\n};\n\nexport function Accordion({\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n type = 'single',\n defaultValue,\n value: controlledValue,\n onChange,\n children,\n className,\n 'data-testid': dataTestId,\n ref,\n style,\n}: AccordionProps): React.JSX.Element {\n const isControlled = controlledValue !== undefined;\n const [internalValue, setInternalValue] = useState<ReadonlySet<string>>(() =>\n normalizeToSet(defaultValue),\n );\n\n // Dev-only: warn when a controlled `value` array is recreated each render\n // with the same contents, which defeats the `openValues` memo and forces\n // unnecessary re-renders. These refs are read/written during render purely\n // for the diagnostic — they never affect render output — and the whole\n // block is inert in production.\n /* eslint-disable @eslint-react/refs -- diagnostic-only ref use, does not affect render output */\n const prevControlledArrayRef = useRef<ReadonlyArray<string> | undefined>(\n undefined,\n );\n const hasWarnedUnstableValueRef = useRef(false);\n if (process.env.NODE_ENV !== 'production') {\n if (Array.isArray(controlledValue)) {\n const prev = prevControlledArrayRef.current;\n if (\n !hasWarnedUnstableValueRef.current &&\n prev !== undefined &&\n prev !== controlledValue &&\n prev.length === controlledValue.length &&\n prev.every((item, i) => item === controlledValue[i])\n ) {\n hasWarnedUnstableValueRef.current = true;\n console.warn(\n 'Accordion: the `value` array changed identity between renders but ' +\n 'contains the same items. Memoize it (e.g. with `useMemo`) to ' +\n 'avoid unnecessary re-renders of the accordion items.',\n );\n }\n prevControlledArrayRef.current = controlledValue;\n }\n }\n /* eslint-enable @eslint-react/refs */\n\n const openValues = useMemo(\n () => (isControlled ? normalizeToSet(controlledValue) : internalValue),\n [isControlled, controlledValue, internalValue],\n );\n\n const getIsOpen = useCallback(\n (itemValue: string) => openValues.has(itemValue),\n [openValues],\n );\n\n const toggle = useCallback(\n (itemValue: string) => {\n let nextValues: ReadonlySet<string>;\n\n if (type === 'single') {\n nextValues = openValues.has(itemValue)\n ? new Set()\n : new Set([itemValue]);\n } else {\n const next = new Set(openValues);\n if (next.has(itemValue)) {\n next.delete(itemValue);\n } else {\n next.add(itemValue);\n }\n nextValues = next;\n }\n\n if (!isControlled) {\n setInternalValue(nextValues);\n }\n\n if (onChange) {\n const arr = [...nextValues];\n if (type === 'single') {\n (onChange as (value: string | null) => void)(arr[0] ?? null);\n } else {\n (onChange as (value: string[]) => void)(arr);\n }\n }\n },\n [type, openValues, isControlled, onChange],\n );\n\n const contextValue = useMemo<AccordionContextValue>(\n () => ({getIsOpen, toggle}),\n [getIsOpen, toggle],\n );\n\n return (\n <AccordionContext value={contextValue}>\n <div\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledby}\n className={cx(styles.root, className)}\n data-testid={dataTestId}\n ref={ref}\n role=\"group\"\n style={style}>\n {children}\n </div>\n </AccordionContext>\n );\n}\n\nAccordion.displayName = 'Accordion';\n","import {sva, type RecipeVariantProps} from 'styled-system/css';\n\nexport const accordionItemRecipe = sva({\n slots: ['root', 'trigger', 'chevron', 'panel', 'panelInner'],\n base: {\n root: {\n w: '100%',\n },\n trigger: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n w: '100%',\n cursor: 'pointer',\n fontFamily: 'body',\n fontSize: 'lg',\n fontWeight: 'semibold',\n color: 'fg',\n textAlign: 'start',\n py: 0,\n _disabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n _focusVisible: {\n outlineWidth: 'focus',\n outlineStyle: 'solid',\n outlineColor: 'primary',\n outlineOffset: 'focusOffset',\n borderRadius: 'sm',\n },\n },\n chevron: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n transitionProperty: 'transform',\n transitionDuration: 'fast',\n transitionTimingFunction: 'default',\n color: 'fg.muted',\n },\n panel: {\n display: 'grid',\n gridTemplateRows: '1fr',\n // `visibility` is transitioned alongside the rows so the content stays\n // readable while collapsing, then becomes `hidden` (removing it from the\n // a11y tree and tab order) once closed. The inline `visibility` style in\n // the component drives the open/closed value.\n transitionProperty: 'grid-template-rows, visibility',\n transitionDuration: 'normal',\n transitionTimingFunction: 'default',\n '@media (prefers-reduced-motion: reduce)': {\n transitionDuration: '0.01s',\n },\n },\n panelInner: {\n overflow: 'hidden',\n minH: 0,\n pt: '1',\n },\n },\n variants: {\n isOpen: {\n true: {\n chevron: {transform: 'rotate(180deg)'},\n },\n false: {\n panel: {gridTemplateRows: '0fr'},\n },\n },\n },\n defaultVariants: {\n isOpen: false,\n },\n});\n\nexport type AccordionItemVariants = RecipeVariantProps<\n typeof accordionItemRecipe\n>;\n","import {use, useCallback, useState} from 'react';\nimport {AccordionContext} from './AccordionContext';\n\nexport interface CollapsibleConfig {\n isDefaultOpen?: boolean;\n isOpen?: boolean;\n onOpenChange?: (isOpen: boolean) => void;\n}\n\nexport interface UseCollapsibleOptions {\n config?: CollapsibleConfig;\n value?: string;\n}\n\nexport interface UseCollapsibleReturn {\n isOpen: boolean;\n toggle: () => void;\n}\n\nexport function useCollapsible(\n options: UseCollapsibleOptions,\n): UseCollapsibleReturn {\n const {config, value} = options;\n\n const group = use(AccordionContext);\n const isMissingGroupValue = group != null && value == null;\n const isControlledByGroup = group != null && value != null;\n\n if (process.env.NODE_ENV !== 'production') {\n if (isMissingGroupValue) {\n throw new Error(\n 'AccordionItem: `value` prop is required when used inside an Accordion.',\n );\n }\n }\n\n const [internalIsOpen, setInternalIsOpen] = useState(() => {\n if (isControlledByGroup) {\n return true;\n }\n if (config?.isOpen !== undefined) {\n return config.isOpen;\n }\n return config?.isDefaultOpen ?? true;\n });\n\n let isOpen: boolean;\n if (isControlledByGroup) {\n isOpen = group.getIsOpen(value);\n } else if (isMissingGroupValue) {\n isOpen = false;\n } else if (config?.isOpen !== undefined) {\n isOpen = config.isOpen;\n } else {\n isOpen = internalIsOpen;\n }\n\n const configIsOpen = config?.isOpen;\n const onOpenChange = config?.onOpenChange;\n\n // Depend on the primitive config fields rather than the `config` object so\n // the toggle keeps a stable identity across renders (callers commonly build\n // a fresh `config` object each render). Re-checking `group`/`value` inside\n // the callback also gives TypeScript the non-null narrowing it needs.\n const toggle = useCallback(() => {\n if (group != null && value != null) {\n group.toggle(value);\n } else if (group != null) {\n // Inside a group but missing a `value` prop: nothing to toggle.\n return;\n } else if (configIsOpen !== undefined) {\n onOpenChange?.(!configIsOpen);\n } else {\n setInternalIsOpen(prev => !prev);\n onOpenChange?.(!isOpen);\n }\n }, [group, value, configIsOpen, onOpenChange, isOpen]);\n\n return {isOpen, toggle};\n}\n","import {ChevronDown} from 'lucide-react';\nimport {useId, type CSSProperties, type ReactNode, type Ref} from 'react';\nimport {cx} from '../../internal/cx';\nimport {Icon} from '../Icon';\nimport {accordionItemRecipe} from './AccordionItem.recipe';\nimport {useCollapsible} from './useCollapsible';\n\n/**\n * A single expandable section within an `Accordion`, or a standalone\n * collapsible panel when used outside of an `Accordion` context. Prefer\n * the `Collapsible` wrapper for standalone usage.\n */\nexport interface AccordionItemProps {\n /**\n * Content revealed when the item is open.\n */\n children?: ReactNode;\n /**\n * Additional CSS class names applied to the root element.\n */\n className?: string;\n /**\n * Test ID applied to the root element.\n */\n 'data-testid'?: string;\n /**\n * Whether the item is open on initial render. Ignored when `isOpen` is\n * provided or the item is inside an `Accordion`. Defaults to `true`.\n */\n isDefaultOpen?: boolean;\n /**\n * Whether the trigger is disabled. Prevents toggling and applies disabled\n * styling.\n */\n isDisabled?: boolean;\n /**\n * Controls the open state externally. When set, the component becomes\n * controlled and `onOpenChange` should be provided. Ignored when the\n * item is inside an `Accordion`.\n */\n isOpen?: boolean;\n /**\n * Called when the open state changes from user interaction.\n */\n onOpenChange?: (isOpen: boolean) => void;\n /**\n * Ref forwarded to the root element.\n */\n ref?: Ref<HTMLDivElement>;\n /**\n * Inline styles applied to the root element.\n */\n style?: CSSProperties;\n /**\n * Content rendered as the clickable trigger. Must be phrasing content\n * (text, `<span>`, `<strong>`, icons, etc.) since it is placed inside a\n * `<button>` element.\n */\n trigger: ReactNode;\n /**\n * Unique identifier used by a parent `Accordion` to track which items\n * are open. Required when used inside an `Accordion`, ignored otherwise.\n */\n value?: string;\n}\n\nexport function AccordionItem({\n trigger,\n children,\n isDefaultOpen,\n isDisabled = false,\n isOpen: controlledIsOpen,\n onOpenChange,\n value,\n ref,\n className,\n 'data-testid': dataTestId,\n style,\n}: AccordionItemProps): React.JSX.Element {\n const collapsibleConfig =\n controlledIsOpen !== undefined\n ? {isOpen: controlledIsOpen, onOpenChange}\n : {isDefaultOpen: isDefaultOpen ?? true, onOpenChange};\n\n const {isOpen, toggle} = useCollapsible({\n config: collapsibleConfig,\n value,\n });\n\n const id = useId();\n const triggerId = `${id}-trigger`;\n const panelId = `${id}-panel`;\n\n const classes = accordionItemRecipe({isOpen});\n\n return (\n <div\n className={cx(classes.root, className)}\n data-testid={dataTestId}\n ref={ref}\n style={style}>\n <button\n aria-controls={panelId}\n aria-expanded={isOpen}\n className={classes.trigger}\n disabled={isDisabled}\n id={triggerId}\n onClick={toggle}\n type=\"button\">\n {trigger}\n <span className={classes.chevron}>\n <Icon icon={ChevronDown} size=\"md\" />\n </span>\n </button>\n <div\n aria-labelledby={triggerId}\n className={classes.panel}\n id={panelId}\n role=\"region\"\n style={{visibility: isOpen ? undefined : 'hidden'}}>\n <div className={classes.panelInner}>{children}</div>\n </div>\n </div>\n );\n}\n\nAccordionItem.displayName = 'AccordionItem';\n","import type {CSSProperties, ReactNode, Ref} from 'react';\nimport {AccordionItem} from './AccordionItem';\n\n/**\n * A standalone disclosure widget that toggles the visibility of a content\n * panel. Use `Collapsible` for individual expand/collapse sections. For\n * coordinated groups where only one (or a subset) can be open at a time,\n * use `Accordion` with `AccordionItem` instead.\n */\nexport interface CollapsibleProps {\n /**\n * Content revealed when the collapsible is open.\n */\n children?: ReactNode;\n /**\n * Additional CSS class names applied to the root element.\n */\n className?: string;\n /**\n * Test ID applied to the root element.\n */\n 'data-testid'?: string;\n /**\n * Whether the collapsible is open on initial render. Ignored when `isOpen`\n * is provided. Defaults to `true`.\n */\n isDefaultOpen?: boolean;\n /**\n * Whether the trigger is disabled. Prevents toggling and applies disabled\n * styling.\n */\n isDisabled?: boolean;\n /**\n * Controls the open state externally. When set, the component becomes\n * controlled and `onOpenChange` should be provided to handle toggling.\n */\n isOpen?: boolean;\n /**\n * Called when the open state changes, either from a user click on the\n * trigger or from a keyboard interaction.\n */\n onOpenChange?: (isOpen: boolean) => void;\n /**\n * Ref forwarded to the root element.\n */\n ref?: Ref<HTMLDivElement>;\n /**\n * Inline styles applied to the root element.\n */\n style?: CSSProperties;\n /**\n * Content rendered as the clickable trigger that toggles the panel. Must be\n * phrasing content (text, `<span>`, `<strong>`, icons, etc.) since it is\n * placed inside a `<button>` element.\n */\n trigger: ReactNode;\n}\n\nexport function Collapsible({\n className,\n 'data-testid': dataTestId,\n ref,\n style,\n ...props\n}: CollapsibleProps): React.JSX.Element {\n return (\n <AccordionItem\n {...props}\n className={className}\n data-testid={dataTestId}\n ref={ref}\n style={style}\n />\n );\n}\n\nCollapsible.displayName = 'Collapsible';\n"]}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var chunkR37R7DEV_cjs = require('./chunk-R37R7DEV.cjs');
|
|
4
|
-
var
|
|
5
|
-
var
|
|
6
|
-
var
|
|
7
|
-
var
|
|
4
|
+
var chunkO3T7Z6RH_cjs = require('./chunk-O3T7Z6RH.cjs');
|
|
5
|
+
var chunkJMNH45Q3_cjs = require('./chunk-JMNH45Q3.cjs');
|
|
6
|
+
var chunkU2WVHZ24_cjs = require('./chunk-U2WVHZ24.cjs');
|
|
7
|
+
var chunk6BK4LUK4_cjs = require('./chunk-6BK4LUK4.cjs');
|
|
8
|
+
var chunkRU6JG3FS_cjs = require('./chunk-RU6JG3FS.cjs');
|
|
8
9
|
var react = require('react');
|
|
9
10
|
var lucideReact = require('lucide-react');
|
|
10
11
|
var jsxRuntime = require('react/jsx-runtime');
|
|
@@ -69,7 +70,7 @@ function useFocusTrap({
|
|
|
69
70
|
return { containerRef, focusFirst };
|
|
70
71
|
}
|
|
71
72
|
var styles = {
|
|
72
|
-
surface:
|
|
73
|
+
surface: chunkRU6JG3FS_cjs.css({
|
|
73
74
|
position: "relative",
|
|
74
75
|
bg: "bg",
|
|
75
76
|
borderRadius: "md",
|
|
@@ -78,7 +79,7 @@ var styles = {
|
|
|
78
79
|
borderStyle: "solid",
|
|
79
80
|
borderColor: "border"
|
|
80
81
|
}),
|
|
81
|
-
closeButtonWrapper:
|
|
82
|
+
closeButtonWrapper: chunkRU6JG3FS_cjs.css({
|
|
82
83
|
position: "absolute",
|
|
83
84
|
w: "1px",
|
|
84
85
|
h: "1px",
|
|
@@ -98,7 +99,7 @@ function usePopover({
|
|
|
98
99
|
role = "dialog"
|
|
99
100
|
} = {}) {
|
|
100
101
|
const skipAutoFocusRef = react.useRef(false);
|
|
101
|
-
const layer =
|
|
102
|
+
const layer = chunkU2WVHZ24_cjs.useLayer({ hasLightDismiss, onShow, onHide });
|
|
102
103
|
const { containerRef: contentRef, focusFirst } = useFocusTrap({
|
|
103
104
|
isActive: layer.isOpen,
|
|
104
105
|
onEscape: layer.hide
|
|
@@ -139,7 +140,7 @@ function usePopover({
|
|
|
139
140
|
children: [
|
|
140
141
|
children,
|
|
141
142
|
hasCloseButton ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.closeButtonWrapper, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
142
|
-
|
|
143
|
+
chunkO3T7Z6RH_cjs.Button,
|
|
143
144
|
{
|
|
144
145
|
icon: lucideReact.X,
|
|
145
146
|
isIconOnly: true,
|
|
@@ -205,15 +206,15 @@ function usePopover({
|
|
|
205
206
|
}
|
|
206
207
|
var BUTTON_SELECTOR = 'button, [role="button"]';
|
|
207
208
|
var styles2 = {
|
|
208
|
-
anchor:
|
|
209
|
+
anchor: chunkRU6JG3FS_cjs.css({
|
|
209
210
|
display: "inline-flex"
|
|
210
211
|
}),
|
|
211
|
-
content:
|
|
212
|
+
content: chunkRU6JG3FS_cjs.css({}),
|
|
212
213
|
gap: {
|
|
213
|
-
above:
|
|
214
|
-
below:
|
|
215
|
-
start:
|
|
216
|
-
end:
|
|
214
|
+
above: chunkRU6JG3FS_cjs.css({ mb: "1" }),
|
|
215
|
+
below: chunkRU6JG3FS_cjs.css({ mt: "1" }),
|
|
216
|
+
start: chunkRU6JG3FS_cjs.css({ mr: "1" }),
|
|
217
|
+
end: chunkRU6JG3FS_cjs.css({ ml: "1" })
|
|
217
218
|
}
|
|
218
219
|
};
|
|
219
220
|
function findTriggerButton(element) {
|
|
@@ -309,7 +310,7 @@ function Popover({
|
|
|
309
310
|
},
|
|
310
311
|
[handleTriggerClick, handleTriggerKeyDown, popover.triggerProps]
|
|
311
312
|
);
|
|
312
|
-
|
|
313
|
+
chunkU2WVHZ24_cjs.useIsomorphicLayoutEffect(() => {
|
|
313
314
|
const anchor = anchorRef?.current ?? wrapperRef.current;
|
|
314
315
|
if (anchor == null) {
|
|
315
316
|
return;
|
|
@@ -327,7 +328,7 @@ function Popover({
|
|
|
327
328
|
detach();
|
|
328
329
|
};
|
|
329
330
|
}, [anchorRef, attachTrigger, isEnabled, popover]);
|
|
330
|
-
|
|
331
|
+
chunkU2WVHZ24_cjs.useIsomorphicLayoutEffect(() => {
|
|
331
332
|
if (!isControlled) {
|
|
332
333
|
return;
|
|
333
334
|
}
|
|
@@ -338,12 +339,12 @@ function Popover({
|
|
|
338
339
|
}
|
|
339
340
|
}, [isControlled, isOpen, popover]);
|
|
340
341
|
const widthStyle = width == null ? void 0 : { width: typeof width === "number" ? `${width}px` : width };
|
|
341
|
-
const paddingStyle = padding != null && padding !==
|
|
342
|
+
const paddingStyle = padding != null && padding !== 0 ? { padding: chunkJMNH45Q3_cjs.token(`spacing.${padding}`) } : void 0;
|
|
342
343
|
const popoverContent = popover.render(
|
|
343
344
|
/* @__PURE__ */ jsxRuntime.jsx(
|
|
344
345
|
"div",
|
|
345
346
|
{
|
|
346
|
-
className:
|
|
347
|
+
className: chunk6BK4LUK4_cjs.cx(styles2.content, className),
|
|
347
348
|
"data-testid": dataTestId,
|
|
348
349
|
ref,
|
|
349
350
|
style: { ...paddingStyle, ...widthStyle, ...style },
|
|
@@ -369,5 +370,5 @@ Popover.displayName = "Popover";
|
|
|
369
370
|
|
|
370
371
|
exports.Popover = Popover;
|
|
371
372
|
exports.usePopover = usePopover;
|
|
372
|
-
//# sourceMappingURL=chunk-
|
|
373
|
-
//# sourceMappingURL=chunk-
|
|
373
|
+
//# sourceMappingURL=chunk-BDBHHJGN.cjs.map
|
|
374
|
+
//# sourceMappingURL=chunk-BDBHHJGN.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/internal/useFocusTrap.ts","../src/components/Popover/usePopover.tsx","../src/components/Popover/Popover.tsx"],"names":["useRef","useCallback","useEffect","css","useLayer","jsxs","jsx","Button","X","useMemo","styles","nowMonotonicMilliseconds","useIsomorphicLayoutEffect","token","cx","Fragment"],"mappings":"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","file":"chunk-BDBHHJGN.cjs","sourcesContent":["import {useCallback, useEffect, useRef} from 'react';\n\nconst FOCUSABLE_SELECTOR =\n 'button:not([disabled]), [href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex=\"-1\"]):not([disabled])';\n\nexport interface UseFocusTrapOptions {\n isActive: boolean;\n onEscape?: () => void;\n}\n\nexport interface UseFocusTrapReturn<T extends HTMLElement = HTMLElement> {\n containerRef: React.RefObject<T | null>;\n focusFirst: () => void;\n}\n\nfunction getFocusableElements(container: HTMLElement): HTMLElement[] {\n return Array.from(\n container.querySelectorAll<HTMLElement>(FOCUSABLE_SELECTOR),\n );\n}\n\nfunction focusFirstDescendant(container: HTMLElement): void {\n getFocusableElements(container)[0]?.focus();\n}\n\nfunction focusLastDescendant(container: HTMLElement): void {\n const elements = getFocusableElements(container);\n elements.at(-1)?.focus();\n}\n\nexport function useFocusTrap<T extends HTMLElement = HTMLElement>({\n isActive,\n onEscape,\n}: UseFocusTrapOptions): UseFocusTrapReturn<T> {\n const containerRef = useRef<T>(null);\n\n const focusFirst = useCallback(() => {\n if (containerRef.current != null) {\n focusFirstDescendant(containerRef.current);\n }\n }, []);\n\n useEffect(() => {\n if (!isActive) {\n return;\n }\n\n const handleKeyDown = (event: KeyboardEvent) => {\n const container = containerRef.current;\n if (container == null) {\n return;\n }\n\n if (event.key === 'Escape') {\n event.preventDefault();\n onEscape?.();\n return;\n }\n\n if (event.key !== 'Tab') {\n return;\n }\n\n const focusable = getFocusableElements(container);\n if (focusable.length === 0) {\n return;\n }\n\n const first = focusable[0];\n const last = focusable.at(-1);\n if (event.shiftKey && document.activeElement === first) {\n event.preventDefault();\n focusLastDescendant(container);\n } else if (!event.shiftKey && document.activeElement === last) {\n event.preventDefault();\n focusFirstDescendant(container);\n }\n };\n\n document.addEventListener('keydown', handleKeyDown);\n return () => document.removeEventListener('keydown', handleKeyDown);\n }, [isActive, onEscape]);\n\n return {containerRef, focusFirst};\n}\n","import {X} from 'lucide-react';\nimport {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n type ReactNode,\n type RefCallback,\n} from 'react';\nimport {css} from 'styled-system/css';\nimport {useFocusTrap} from '../../internal/useFocusTrap';\nimport {useLayer, type ContextRenderProps} from '../../internal/useLayer';\nimport {Button} from '../Button';\n\nexport type {LayerAlignment, LayerPlacement} from '../../internal/useLayer';\n\nexport interface UsePopoverOptions {\n closeButtonLabel?: string;\n hasAutoFocus?: boolean;\n hasCloseButton?: boolean;\n hasLightDismiss?: boolean;\n hasSurface?: boolean;\n label?: string;\n onHide?: () => void;\n onShow?: () => void;\n role?: 'dialog' | 'menu';\n}\n\nexport interface UsePopoverReturn {\n anchorId: string;\n contentRef: React.RefObject<HTMLDivElement | null>;\n hide: () => void;\n id: string;\n isOpen: boolean;\n render: (children: ReactNode, props?: ContextRenderProps) => ReactNode;\n show: (options?: {isAutoFocusSkipped?: boolean}) => void;\n toggle: () => void;\n triggerProps: {\n 'aria-controls': string;\n 'aria-expanded': boolean;\n 'aria-haspopup': 'dialog' | 'menu';\n };\n triggerRef: RefCallback<HTMLElement>;\n}\n\nconst styles = {\n surface: css({\n position: 'relative',\n bg: 'bg',\n borderRadius: 'md',\n boxShadow: 'lg',\n borderWidth: 'default',\n borderStyle: 'solid',\n borderColor: 'border',\n }),\n closeButtonWrapper: css({\n position: 'absolute',\n w: '1px',\n h: '1px',\n overflow: 'hidden',\n clipPath: 'inset(50%)',\n }),\n} as const;\n\nexport function usePopover({\n onShow,\n onHide,\n hasLightDismiss = true,\n hasAutoFocus = true,\n hasSurface = true,\n hasCloseButton = true,\n closeButtonLabel = 'Close popover',\n label,\n role = 'dialog',\n}: UsePopoverOptions = {}): UsePopoverReturn {\n const skipAutoFocusRef = useRef(false);\n const layer = useLayer({hasLightDismiss, onShow, onHide});\n const {containerRef: contentRef, focusFirst} = useFocusTrap<HTMLDivElement>({\n isActive: layer.isOpen,\n onEscape: layer.hide,\n });\n\n useEffect(() => {\n if (!layer.isOpen) {\n skipAutoFocusRef.current = false;\n return;\n }\n\n if (hasAutoFocus && !skipAutoFocusRef.current) {\n requestAnimationFrame(() => focusFirst());\n }\n }, [focusFirst, hasAutoFocus, layer.isOpen]);\n\n const show = useCallback(\n (options?: {isAutoFocusSkipped?: boolean}) => {\n skipAutoFocusRef.current = options?.isAutoFocusSkipped ?? false;\n layer.show();\n },\n [layer],\n );\n\n const toggle = useCallback(() => {\n if (layer.isOpen) {\n layer.hide();\n return;\n }\n\n show();\n }, [layer, show]);\n\n const render = useCallback(\n (children: ReactNode, props?: ContextRenderProps): ReactNode => {\n return layer.render(\n <div\n aria-label={label}\n className={hasSurface ? styles.surface : undefined}\n ref={contentRef}\n role={role}>\n {children}\n {hasCloseButton ? (\n <div className={styles.closeButtonWrapper}>\n <Button\n icon={X}\n isIconOnly\n label={closeButtonLabel}\n onClick={layer.hide}\n size=\"sm\"\n variant=\"ghost\"\n />\n </div>\n ) : null}\n </div>,\n {\n ...props,\n className: props?.className,\n },\n );\n },\n [\n closeButtonLabel,\n contentRef,\n hasCloseButton,\n hasSurface,\n label,\n layer,\n role,\n ],\n );\n\n const triggerProps = useMemo(\n () => ({\n 'aria-controls': layer.id,\n 'aria-expanded': layer.isOpen,\n 'aria-haspopup': role,\n }),\n [layer.id, layer.isOpen, role],\n );\n\n return useMemo(\n () => ({\n anchorId: layer.anchorId,\n contentRef,\n hide: layer.hide,\n id: layer.id,\n isOpen: layer.isOpen,\n render,\n show,\n toggle,\n triggerProps,\n triggerRef: layer.ref,\n }),\n [\n contentRef,\n layer.anchorId,\n layer.hide,\n layer.id,\n layer.isOpen,\n layer.ref,\n render,\n show,\n toggle,\n triggerProps,\n ],\n );\n}\n","import {\n useCallback,\n useRef,\n type CSSProperties,\n type ReactNode,\n type Ref,\n type RefObject,\n} from 'react';\nimport {css, cx} from 'styled-system/css';\nimport {token} from 'styled-system/tokens';\nimport type {SpacingToken} from '../../internal/spacingTokens';\nimport {nowMonotonicMilliseconds} from '../../internal/time';\nimport {useIsomorphicLayoutEffect} from '../../internal/useIsomorphicLayoutEffect';\nimport type {LayerAlignment, LayerPlacement} from '../../internal/useLayer';\nimport {usePopover} from './usePopover';\n\nexport interface PopoverProps {\n /**\n * Alignment along the placement axis.\n * @default 'start'\n */\n alignment?: LayerAlignment;\n /**\n * External trigger element. When provided without children, Popover attaches\n * click and ARIA behavior directly to this element.\n */\n anchorRef?: RefObject<HTMLElement | null>;\n /**\n * Trigger content. Must contain a `<button>` or `[role=\"button\"]`.\n */\n children?: ReactNode;\n /**\n * Additional CSS class names applied to the popover content.\n */\n className?: string;\n /**\n * Label for the hidden close button.\n * @default 'Close popover'\n */\n closeButtonLabel?: string;\n /**\n * Content displayed inside the popover dialog.\n */\n content: ReactNode;\n /**\n * Test ID applied to the popover content.\n */\n 'data-testid'?: string;\n /**\n * Whether to focus the first focusable item after opening.\n * @default true\n */\n hasAutoFocus?: boolean;\n /**\n * Whether to include a keyboard-accessible close button.\n * @default true\n */\n hasCloseButton?: boolean;\n /**\n * Whether clicking outside closes the popover.\n * @default true\n */\n hasLightDismiss?: boolean;\n /**\n * Whether trigger interactions open the popover.\n * @default true\n */\n isEnabled?: boolean;\n /**\n * Controlled open state.\n */\n isOpen?: boolean;\n /**\n * Accessible label for the popover dialog.\n */\n label?: string;\n /**\n * Callback fired when open state changes.\n */\n onOpenChange?: (isOpen: boolean) => void;\n /**\n * Inner padding of the popover content.\n * @default 0\n */\n padding?: SpacingToken;\n /**\n * Position relative to the trigger.\n * @default 'below'\n */\n placement?: LayerPlacement;\n /**\n * Ref forwarded to the popover content element.\n */\n ref?: Ref<HTMLDivElement>;\n /**\n * ARIA role for the floating content.\n * @default 'dialog'\n */\n role?: 'dialog' | 'menu';\n /**\n * Inline styles applied to the popover content.\n */\n style?: CSSProperties;\n /**\n * Width of the popover content.\n */\n width?: number | string;\n}\n\nconst BUTTON_SELECTOR = 'button, [role=\"button\"]';\n\nconst styles = {\n anchor: css({\n display: 'inline-flex',\n }),\n content: css({}),\n gap: {\n above: css({mb: '1'}),\n below: css({mt: '1'}),\n start: css({mr: '1'}),\n end: css({ml: '1'}),\n },\n} as const;\n\nfunction findTriggerButton(element: HTMLElement): HTMLElement | null {\n if (element.matches(BUTTON_SELECTOR)) {\n return element;\n }\n\n return element.querySelector<HTMLElement>(BUTTON_SELECTOR);\n}\n\n/**\n * A click-triggered floating dialog anchored to a trigger element.\n */\nexport function Popover({\n anchorRef,\n children,\n content,\n placement = 'below',\n alignment = 'start',\n isOpen,\n onOpenChange,\n isEnabled = true,\n width,\n label,\n hasCloseButton,\n hasLightDismiss,\n closeButtonLabel,\n padding,\n ref,\n hasAutoFocus,\n className,\n style,\n role,\n 'data-testid': dataTestId,\n}: PopoverProps): React.JSX.Element {\n const wrapperRef = useRef<HTMLDivElement>(null);\n const isControlled = isOpen !== undefined;\n const lastHideTimeRef = useRef(0);\n\n const popover = usePopover({\n closeButtonLabel,\n hasAutoFocus,\n hasCloseButton,\n hasLightDismiss,\n label,\n onHide: () => {\n lastHideTimeRef.current = nowMonotonicMilliseconds();\n onOpenChange?.(false);\n },\n onShow: () => onOpenChange?.(true),\n role,\n });\n\n const handleTriggerClick = useCallback(() => {\n if (!isEnabled) {\n return;\n }\n\n if (nowMonotonicMilliseconds() - lastHideTimeRef.current < 50) {\n return;\n }\n\n popover.toggle();\n }, [isEnabled, popover]);\n\n const handleTriggerKeyDown = useCallback(\n (event: KeyboardEvent) => {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n handleTriggerClick();\n }\n },\n [handleTriggerClick],\n );\n\n const attachTrigger = useCallback(\n (button: HTMLElement) => {\n button.setAttribute(\n 'aria-haspopup',\n popover.triggerProps['aria-haspopup'],\n );\n button.setAttribute(\n 'aria-expanded',\n String(popover.triggerProps['aria-expanded']),\n );\n button.setAttribute(\n 'aria-controls',\n popover.triggerProps['aria-controls'],\n );\n button.addEventListener('click', handleTriggerClick);\n\n const needsKeyDown =\n button.tagName !== 'BUTTON' && button.getAttribute('role') === 'button';\n if (needsKeyDown) {\n button.addEventListener('keydown', handleTriggerKeyDown);\n }\n\n return () => {\n button.removeAttribute('aria-haspopup');\n button.removeAttribute('aria-expanded');\n button.removeAttribute('aria-controls');\n button.removeEventListener('click', handleTriggerClick);\n if (needsKeyDown) {\n button.removeEventListener('keydown', handleTriggerKeyDown);\n }\n };\n },\n [handleTriggerClick, handleTriggerKeyDown, popover.triggerProps],\n );\n\n useIsomorphicLayoutEffect(() => {\n const anchor = anchorRef?.current ?? wrapperRef.current;\n if (anchor == null) {\n return;\n }\n\n popover.triggerRef(anchor);\n const trigger = findTriggerButton(anchor);\n if (trigger == null || !isEnabled) {\n return () => {\n popover.triggerRef(null);\n };\n }\n\n const detach = attachTrigger(trigger);\n return () => {\n popover.triggerRef(null);\n detach();\n };\n }, [anchorRef, attachTrigger, isEnabled, popover]);\n\n useIsomorphicLayoutEffect(() => {\n if (!isControlled) {\n return;\n }\n\n if (isOpen === true && !popover.isOpen) {\n popover.show();\n } else if (isOpen === false && popover.isOpen) {\n popover.hide();\n }\n }, [isControlled, isOpen, popover]);\n\n const widthStyle =\n width == null\n ? undefined\n : {width: typeof width === 'number' ? `${width}px` : width};\n\n const paddingStyle =\n padding != null && padding !== 0\n ? {padding: token(`spacing.${padding}`)}\n : undefined;\n\n const popoverContent = popover.render(\n <div\n className={cx(styles.content, className)}\n data-testid={dataTestId}\n ref={ref}\n style={{...paddingStyle, ...widthStyle, ...style}}>\n {content}\n </div>,\n {\n placement,\n alignment,\n className: styles.gap[placement],\n style: {minWidth: 'anchor-size(width)'},\n },\n );\n\n if (anchorRef != null && children == null) {\n return <>{popoverContent}</>;\n }\n\n return (\n <>\n <div className={styles.anchor} ref={wrapperRef}>\n {children}\n </div>\n {popoverContent}\n </>\n );\n}\n\nPopover.displayName = 'Popover';\n"]}
|