silver-ui 0.3.0 → 0.4.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 (713) hide show
  1. package/README.md +1 -1
  2. package/dist/chunk-2A3V6OR7.cjs +112 -0
  3. package/dist/chunk-2A3V6OR7.cjs.map +1 -0
  4. package/dist/{chunk-HLN3JQYD.js → chunk-2LABTS4P.js} +18 -58
  5. package/dist/chunk-2LABTS4P.js.map +1 -0
  6. package/dist/{chunk-GI5MVVIX.js → chunk-2N6FOSNM.js} +15 -14
  7. package/dist/chunk-2N6FOSNM.js.map +1 -0
  8. package/dist/chunk-2PSZAWLC.js +8 -0
  9. package/dist/chunk-2PSZAWLC.js.map +1 -0
  10. package/dist/{chunk-YGYA4BYN.js → chunk-2RKMG2TC.js} +19 -18
  11. package/dist/chunk-2RKMG2TC.js.map +1 -0
  12. package/dist/{chunk-5MDH6QZE.js → chunk-2XAA3CM5.js} +7 -10
  13. package/dist/chunk-2XAA3CM5.js.map +1 -0
  14. package/dist/{chunk-EMHLPPQZ.js → chunk-3CJC4QE6.js} +4 -4
  15. package/dist/chunk-3CJC4QE6.js.map +1 -0
  16. package/dist/{chunk-P3SMNZCT.js → chunk-3JPUXC5U.js} +3 -3
  17. package/dist/{chunk-P3SMNZCT.js.map → chunk-3JPUXC5U.js.map} +1 -1
  18. package/dist/{chunk-OJCJPYXE.js → chunk-3OIUA2NY.js} +9 -8
  19. package/dist/chunk-3OIUA2NY.js.map +1 -0
  20. package/dist/chunk-3ZV3EGGK.cjs +470 -0
  21. package/dist/chunk-3ZV3EGGK.cjs.map +1 -0
  22. package/dist/{chunk-BERQEJYB.js → chunk-4H7X5FGX.js} +7 -6
  23. package/dist/chunk-4H7X5FGX.js.map +1 -0
  24. package/dist/{chunk-EUN5TCB2.js → chunk-52WQDDWQ.js} +18 -20
  25. package/dist/chunk-52WQDDWQ.js.map +1 -0
  26. package/dist/{chunk-UMGW7WJI.cjs → chunk-5D2OR64D.cjs} +11 -9
  27. package/dist/chunk-5D2OR64D.cjs.map +1 -0
  28. package/dist/{chunk-YAIEA2YE.cjs → chunk-5PX76QOL.cjs} +3 -3
  29. package/dist/{chunk-YAIEA2YE.cjs.map → chunk-5PX76QOL.cjs.map} +1 -1
  30. package/dist/{chunk-HM7IEGQ2.cjs → chunk-5YS43PSQ.cjs} +7 -7
  31. package/dist/chunk-5YS43PSQ.cjs.map +1 -0
  32. package/dist/{chunk-AH4AMQEO.js → chunk-6ONAGCCZ.js} +262 -208
  33. package/dist/chunk-6ONAGCCZ.js.map +1 -0
  34. package/dist/{chunk-S54CKWKV.js → chunk-6ULCJ3XZ.js} +4 -4
  35. package/dist/{chunk-S54CKWKV.js.map → chunk-6ULCJ3XZ.js.map} +1 -1
  36. package/dist/{chunk-6XESVFC3.js → chunk-6XWXBXYE.js} +90 -75
  37. package/dist/chunk-6XWXBXYE.js.map +1 -0
  38. package/dist/{chunk-EXYBQVZT.js → chunk-7BSFKG7N.js} +3 -3
  39. package/dist/{chunk-EXYBQVZT.js.map → chunk-7BSFKG7N.js.map} +1 -1
  40. package/dist/{chunk-7GN6YTSS.cjs → chunk-7CCXHH6Y.cjs} +7 -7
  41. package/dist/chunk-7CCXHH6Y.cjs.map +1 -0
  42. package/dist/{chunk-3PDUOYAT.cjs → chunk-7U7JMRVF.cjs} +28 -30
  43. package/dist/chunk-7U7JMRVF.cjs.map +1 -0
  44. package/dist/chunk-AFI4V7LI.js +393 -0
  45. package/dist/chunk-AFI4V7LI.js.map +1 -0
  46. package/dist/{chunk-DSNJDFO3.cjs → chunk-AHVHLNHU.cjs} +18 -17
  47. package/dist/chunk-AHVHLNHU.cjs.map +1 -0
  48. package/dist/{chunk-35MFOORC.js → chunk-AJ6X62AI.js} +5 -5
  49. package/dist/{chunk-35MFOORC.js.map → chunk-AJ6X62AI.js.map} +1 -1
  50. package/dist/{chunk-OMHOVHPX.js → chunk-AP7BDTTF.js} +4 -4
  51. package/dist/{chunk-OMHOVHPX.js.map → chunk-AP7BDTTF.js.map} +1 -1
  52. package/dist/{chunk-4T62TLOD.cjs → chunk-AWDIKDX5.cjs} +10 -10
  53. package/dist/{chunk-4T62TLOD.cjs.map → chunk-AWDIKDX5.cjs.map} +1 -1
  54. package/dist/chunk-BCCPNGUV.js +162 -0
  55. package/dist/chunk-BCCPNGUV.js.map +1 -0
  56. package/dist/{chunk-PTJ5YZFY.cjs → chunk-BLRWA445.cjs} +242 -182
  57. package/dist/chunk-BLRWA445.cjs.map +1 -0
  58. package/dist/{chunk-67VLK263.js → chunk-BSAZRW6T.js} +13 -10
  59. package/dist/chunk-BSAZRW6T.js.map +1 -0
  60. package/dist/{chunk-I2X2Z7FA.cjs → chunk-BUESV4DR.cjs} +9 -9
  61. package/dist/{chunk-I2X2Z7FA.cjs.map → chunk-BUESV4DR.cjs.map} +1 -1
  62. package/dist/{chunk-UJODHP7E.cjs → chunk-BULJWVPU.cjs} +18 -17
  63. package/dist/chunk-BULJWVPU.cjs.map +1 -0
  64. package/dist/{chunk-PNYF6NS4.cjs → chunk-C6EYCIKJ.cjs} +9 -8
  65. package/dist/chunk-C6EYCIKJ.cjs.map +1 -0
  66. package/dist/{chunk-ZTQQ2O6O.cjs → chunk-C732WXKS.cjs} +36 -34
  67. package/dist/chunk-C732WXKS.cjs.map +1 -0
  68. package/dist/{chunk-GTPRZCNZ.js → chunk-CGYZ6QWY.js} +4 -4
  69. package/dist/{chunk-GTPRZCNZ.js.map → chunk-CGYZ6QWY.js.map} +1 -1
  70. package/dist/{chunk-X5ZQRMEM.cjs → chunk-CKTXDIH4.cjs} +39 -40
  71. package/dist/chunk-CKTXDIH4.cjs.map +1 -0
  72. package/dist/{chunk-PYW5UO2Z.js → chunk-D3LZQ5QS.js} +4 -4
  73. package/dist/chunk-D3LZQ5QS.js.map +1 -0
  74. package/dist/{chunk-WNGBWUWZ.cjs → chunk-DIRVAHOF.cjs} +6 -6
  75. package/dist/{chunk-WNGBWUWZ.cjs.map → chunk-DIRVAHOF.cjs.map} +1 -1
  76. package/dist/{chunk-K77D7H4V.cjs → chunk-DP7VC4FW.cjs} +7 -6
  77. package/dist/chunk-DP7VC4FW.cjs.map +1 -0
  78. package/dist/{chunk-4I6VIR44.cjs → chunk-DVGLYE3G.cjs} +16 -15
  79. package/dist/chunk-DVGLYE3G.cjs.map +1 -0
  80. package/dist/{chunk-ISYUZ5FS.js → chunk-DWUEPOYH.js} +31 -29
  81. package/dist/chunk-DWUEPOYH.js.map +1 -0
  82. package/dist/chunk-DXPQRAGI.js +110 -0
  83. package/dist/chunk-DXPQRAGI.js.map +1 -0
  84. package/dist/{chunk-P4A7GWQY.cjs → chunk-E2A3GJSN.cjs} +9 -8
  85. package/dist/chunk-E2A3GJSN.cjs.map +1 -0
  86. package/dist/{chunk-32G54PL3.cjs → chunk-EALKX3ST.cjs} +9 -8
  87. package/dist/chunk-EALKX3ST.cjs.map +1 -0
  88. package/dist/{chunk-ZW2ATXTL.js → chunk-EBDODJ5X.js} +8 -7
  89. package/dist/chunk-EBDODJ5X.js.map +1 -0
  90. package/dist/chunk-FB245S6T.cjs +395 -0
  91. package/dist/chunk-FB245S6T.cjs.map +1 -0
  92. package/dist/{chunk-RNB4BDEG.js → chunk-FDUO2HVX.js} +3 -3
  93. package/dist/{chunk-RNB4BDEG.js.map → chunk-FDUO2HVX.js.map} +1 -1
  94. package/dist/{chunk-JAHKLROD.cjs → chunk-FDZQPWFZ.cjs} +13 -12
  95. package/dist/chunk-FDZQPWFZ.cjs.map +1 -0
  96. package/dist/{chunk-KIGRE6NA.js → chunk-FMLIYHDP.js} +5 -5
  97. package/dist/{chunk-KIGRE6NA.js.map → chunk-FMLIYHDP.js.map} +1 -1
  98. package/dist/{chunk-4YQSKCVF.cjs → chunk-FNOUX5T2.cjs} +5 -5
  99. package/dist/{chunk-4YQSKCVF.cjs.map → chunk-FNOUX5T2.cjs.map} +1 -1
  100. package/dist/{chunk-LFRTNC7M.cjs → chunk-FNZOICR4.cjs} +7 -7
  101. package/dist/{chunk-LFRTNC7M.cjs.map → chunk-FNZOICR4.cjs.map} +1 -1
  102. package/dist/{chunk-4M2KCZMO.js → chunk-FP5E5BUM.js} +5 -4
  103. package/dist/chunk-FP5E5BUM.js.map +1 -0
  104. package/dist/{chunk-VSEKSDTK.js → chunk-G2U2W422.js} +8 -7
  105. package/dist/chunk-G2U2W422.js.map +1 -0
  106. package/dist/{chunk-MAL4D4LR.cjs → chunk-G2WW52GO.cjs} +14 -13
  107. package/dist/chunk-G2WW52GO.cjs.map +1 -0
  108. package/dist/{chunk-FQSOUCZS.cjs → chunk-G3KKLGZU.cjs} +9 -9
  109. package/dist/{chunk-FQSOUCZS.cjs.map → chunk-G3KKLGZU.cjs.map} +1 -1
  110. package/dist/{chunk-IKF6VHA4.cjs → chunk-GC5VUTUR.cjs} +4 -4
  111. package/dist/{chunk-IKF6VHA4.cjs.map → chunk-GC5VUTUR.cjs.map} +1 -1
  112. package/dist/{chunk-ITDQSF2O.cjs → chunk-GL7PSN7H.cjs} +17 -16
  113. package/dist/chunk-GL7PSN7H.cjs.map +1 -0
  114. package/dist/{chunk-WMXIUOOU.cjs → chunk-GYVWTH3U.cjs} +3 -3
  115. package/dist/{chunk-WMXIUOOU.cjs.map → chunk-GYVWTH3U.cjs.map} +1 -1
  116. package/dist/{chunk-ACQMLJ4I.cjs → chunk-H2CZ6IE5.cjs} +42 -39
  117. package/dist/chunk-H2CZ6IE5.cjs.map +1 -0
  118. package/dist/{chunk-CZNN2GOC.js → chunk-H7HQYBPH.js} +25 -26
  119. package/dist/chunk-H7HQYBPH.js.map +1 -0
  120. package/dist/{chunk-ZNUOFLCQ.js → chunk-HINS4GY6.js} +3 -3
  121. package/dist/chunk-HINS4GY6.js.map +1 -0
  122. package/dist/{chunk-PXTE3XRD.js → chunk-HNZWPIJE.js} +74 -68
  123. package/dist/chunk-HNZWPIJE.js.map +1 -0
  124. package/dist/{chunk-Y5SXQR52.cjs → chunk-IA5GII7N.cjs} +33 -22
  125. package/dist/chunk-IA5GII7N.cjs.map +1 -0
  126. package/dist/{chunk-EHCAF6D3.js → chunk-IAVZKGZS.js} +14 -3
  127. package/dist/chunk-IAVZKGZS.js.map +1 -0
  128. package/dist/{chunk-XM3AZXOA.js → chunk-ILEKDNP7.js} +6 -6
  129. package/dist/{chunk-XM3AZXOA.js.map → chunk-ILEKDNP7.js.map} +1 -1
  130. package/dist/{chunk-XSQOHNIF.js → chunk-J3DNWPXJ.js} +3 -3
  131. package/dist/{chunk-XSQOHNIF.js.map → chunk-J3DNWPXJ.js.map} +1 -1
  132. package/dist/{chunk-25FU5AVR.cjs → chunk-J4OEETYQ.cjs} +14 -13
  133. package/dist/chunk-J4OEETYQ.cjs.map +1 -0
  134. package/dist/{chunk-4Z62KDKI.js → chunk-J5IRFGUP.js} +25 -14
  135. package/dist/chunk-J5IRFGUP.js.map +1 -0
  136. package/dist/{chunk-2YC7SMVF.js → chunk-JDAJ2HJQ.js} +7 -6
  137. package/dist/chunk-JDAJ2HJQ.js.map +1 -0
  138. package/dist/{chunk-AGJ5SZCM.js → chunk-JIVYPJKO.js} +6 -6
  139. package/dist/{chunk-AGJ5SZCM.js.map → chunk-JIVYPJKO.js.map} +1 -1
  140. package/dist/{chunk-U2WVHZ24.cjs → chunk-JJ324PSZ.cjs} +6 -6
  141. package/dist/chunk-JJ324PSZ.cjs.map +1 -0
  142. package/dist/{chunk-WWB4NSEY.cjs → chunk-JSINCF2R.cjs} +10 -10
  143. package/dist/{chunk-WWB4NSEY.cjs.map → chunk-JSINCF2R.cjs.map} +1 -1
  144. package/dist/{chunk-BJD32VBQ.cjs → chunk-JTFNNEWR.cjs} +90 -75
  145. package/dist/chunk-JTFNNEWR.cjs.map +1 -0
  146. package/dist/{chunk-YAYINZT2.cjs → chunk-JYVYCU22.cjs} +3 -3
  147. package/dist/{chunk-YAYINZT2.cjs.map → chunk-JYVYCU22.cjs.map} +1 -1
  148. package/dist/chunk-K3XHXWBW.js +242 -0
  149. package/dist/chunk-K3XHXWBW.js.map +1 -0
  150. package/dist/{chunk-TRK2ZZFB.cjs → chunk-K4ZJNQTX.cjs} +6 -5
  151. package/dist/chunk-K4ZJNQTX.cjs.map +1 -0
  152. package/dist/{chunk-WA4VZ363.cjs → chunk-KDR5DCYL.cjs} +13 -12
  153. package/dist/chunk-KDR5DCYL.cjs.map +1 -0
  154. package/dist/{chunk-2D6SGEPH.cjs → chunk-KXIILLQD.cjs} +16 -11
  155. package/dist/chunk-KXIILLQD.cjs.map +1 -0
  156. package/dist/{chunk-ZNZ67KFM.js → chunk-L6VSBBPP.js} +9 -8
  157. package/dist/chunk-L6VSBBPP.js.map +1 -0
  158. package/dist/{chunk-YJJOKZN2.js → chunk-LNT2IFOA.js} +4 -4
  159. package/dist/{chunk-YJJOKZN2.js.map → chunk-LNT2IFOA.js.map} +1 -1
  160. package/dist/{chunk-IXJOPMJX.cjs → chunk-LO5NZY7N.cjs} +7 -6
  161. package/dist/chunk-LO5NZY7N.cjs.map +1 -0
  162. package/dist/{chunk-AADUJ6CN.js → chunk-LQIZSE3O.js} +212 -183
  163. package/dist/chunk-LQIZSE3O.js.map +1 -0
  164. package/dist/{chunk-OJKZS6HG.cjs → chunk-LUQVSNQL.cjs} +265 -211
  165. package/dist/chunk-LUQVSNQL.cjs.map +1 -0
  166. package/dist/{chunk-BYBVI7UN.js → chunk-LY6Z6A54.js} +10 -9
  167. package/dist/chunk-LY6Z6A54.js.map +1 -0
  168. package/dist/{chunk-JMNH45Q3.cjs → chunk-M26XECB2.cjs} +91 -97
  169. package/dist/chunk-M26XECB2.cjs.map +1 -0
  170. package/dist/chunk-M2MC3E27.cjs +220 -0
  171. package/dist/chunk-M2MC3E27.cjs.map +1 -0
  172. package/dist/chunk-MAYQGKKW.cjs +193 -0
  173. package/dist/chunk-MAYQGKKW.cjs.map +1 -0
  174. package/dist/{chunk-2IKWX66Q.js → chunk-MI5QU37D.js} +5 -5
  175. package/dist/{chunk-2IKWX66Q.js.map → chunk-MI5QU37D.js.map} +1 -1
  176. package/dist/{chunk-XVRQSTUF.js → chunk-N2TNBDQI.js} +4 -3
  177. package/dist/chunk-N2TNBDQI.js.map +1 -0
  178. package/dist/{chunk-H2SGYAUO.js → chunk-NFABMGNH.js} +56 -46
  179. package/dist/chunk-NFABMGNH.js.map +1 -0
  180. package/dist/{chunk-76FHSISK.cjs → chunk-NHXJVSZZ.cjs} +7 -10
  181. package/dist/chunk-NHXJVSZZ.cjs.map +1 -0
  182. package/dist/chunk-NI55JEYL.js +213 -0
  183. package/dist/chunk-NI55JEYL.js.map +1 -0
  184. package/dist/{chunk-BDPE6ZKX.cjs → chunk-O2WICOUK.cjs} +5 -5
  185. package/dist/{chunk-BDPE6ZKX.cjs.map → chunk-O2WICOUK.cjs.map} +1 -1
  186. package/dist/{chunk-ATDW2VII.cjs → chunk-OBWWRRL6.cjs} +66 -51
  187. package/dist/chunk-OBWWRRL6.cjs.map +1 -0
  188. package/dist/{chunk-3DW2N6UN.js → chunk-PIOMR4X2.js} +5 -5
  189. package/dist/{chunk-3DW2N6UN.js.map → chunk-PIOMR4X2.js.map} +1 -1
  190. package/dist/{chunk-7P3VY5JZ.js → chunk-PIZMCOKL.js} +9 -8
  191. package/dist/chunk-PIZMCOKL.js.map +1 -0
  192. package/dist/{chunk-W3QVSVL7.cjs → chunk-PQEFVHJZ.cjs} +12 -11
  193. package/dist/chunk-PQEFVHJZ.cjs.map +1 -0
  194. package/dist/chunk-QAO6QMNQ.cjs +10 -0
  195. package/dist/chunk-QAO6QMNQ.cjs.map +1 -0
  196. package/dist/{chunk-CFOGSQCG.cjs → chunk-QATCDVZ6.cjs} +14 -13
  197. package/dist/chunk-QATCDVZ6.cjs.map +1 -0
  198. package/dist/{chunk-YBPG5RPR.cjs → chunk-QOKEU3DC.cjs} +22 -62
  199. package/dist/chunk-QOKEU3DC.cjs.map +1 -0
  200. package/dist/{chunk-J2FCNWYM.js → chunk-QRFDPG34.js} +85 -91
  201. package/dist/chunk-QRFDPG34.js.map +1 -0
  202. package/dist/{chunk-UYXQBM2B.cjs → chunk-QVNDZZS6.cjs} +10 -10
  203. package/dist/{chunk-UYXQBM2B.cjs.map → chunk-QVNDZZS6.cjs.map} +1 -1
  204. package/dist/{chunk-AMG3S252.js → chunk-QY6OMQW6.js} +11 -10
  205. package/dist/chunk-QY6OMQW6.js.map +1 -0
  206. package/dist/{chunk-XIFLSMGW.js → chunk-R6CMJMIJ.js} +3 -3
  207. package/dist/{chunk-XIFLSMGW.js.map → chunk-R6CMJMIJ.js.map} +1 -1
  208. package/dist/{chunk-K6CQ45C2.js → chunk-RLOGQBFD.js} +10 -9
  209. package/dist/chunk-RLOGQBFD.js.map +1 -0
  210. package/dist/{chunk-5Q5TJUHI.js → chunk-S7INL5NI.js} +12 -7
  211. package/dist/chunk-S7INL5NI.js.map +1 -0
  212. package/dist/{chunk-VYFMYXU4.js → chunk-SBOXHIES.js} +234 -174
  213. package/dist/chunk-SBOXHIES.js.map +1 -0
  214. package/dist/{chunk-YXYD5HKL.cjs → chunk-SBS7U7CN.cjs} +6 -6
  215. package/dist/{chunk-YXYD5HKL.cjs.map → chunk-SBS7U7CN.cjs.map} +1 -1
  216. package/dist/chunk-SCGXGVNN.cjs +244 -0
  217. package/dist/chunk-SCGXGVNN.cjs.map +1 -0
  218. package/dist/{chunk-XQU4ECJY.js → chunk-SOCSUNIM.js} +19 -18
  219. package/dist/chunk-SOCSUNIM.js.map +1 -0
  220. package/dist/chunk-SR5VVJ5Y.cjs +164 -0
  221. package/dist/chunk-SR5VVJ5Y.cjs.map +1 -0
  222. package/dist/{chunk-SEAVOF6B.js → chunk-SSAYBCAD.js} +9 -7
  223. package/dist/chunk-SSAYBCAD.js.map +1 -0
  224. package/dist/{chunk-L6JT244G.cjs → chunk-SSOAZZNR.cjs} +4 -3
  225. package/dist/chunk-SSOAZZNR.cjs.map +1 -0
  226. package/dist/{chunk-24J3BUKL.js → chunk-SUH62Z64.js} +3 -3
  227. package/dist/{chunk-24J3BUKL.js.map → chunk-SUH62Z64.js.map} +1 -1
  228. package/dist/{chunk-3WMLV4VP.cjs → chunk-TBOQTPRO.cjs} +9 -9
  229. package/dist/chunk-TBOQTPRO.cjs.map +1 -0
  230. package/dist/chunk-TCTPR7YQ.js +191 -0
  231. package/dist/chunk-TCTPR7YQ.js.map +1 -0
  232. package/dist/{chunk-SFT5LCQP.cjs → chunk-TF7XVTSP.cjs} +61 -51
  233. package/dist/chunk-TF7XVTSP.cjs.map +1 -0
  234. package/dist/{chunk-PXVVTPRJ.js → chunk-TKTLWX2V.js} +11 -10
  235. package/dist/chunk-TKTLWX2V.js.map +1 -0
  236. package/dist/{chunk-ZXPKFGRB.cjs → chunk-TPB53MHV.cjs} +82 -76
  237. package/dist/chunk-TPB53MHV.cjs.map +1 -0
  238. package/dist/chunk-TQA3BI7M.cjs +216 -0
  239. package/dist/chunk-TQA3BI7M.cjs.map +1 -0
  240. package/dist/{chunk-MACIT6C6.js → chunk-U6NH54YD.js} +7 -6
  241. package/dist/chunk-U6NH54YD.js.map +1 -0
  242. package/dist/{chunk-NUTB2K4G.js → chunk-U7ALNPFJ.js} +3 -3
  243. package/dist/{chunk-NUTB2K4G.js.map → chunk-U7ALNPFJ.js.map} +1 -1
  244. package/dist/{chunk-S4GLMGFI.js → chunk-UKW2C5RN.js} +6 -5
  245. package/dist/chunk-UKW2C5RN.js.map +1 -0
  246. package/dist/chunk-UUVLEOSD.js +216 -0
  247. package/dist/chunk-UUVLEOSD.js.map +1 -0
  248. package/dist/{chunk-BA2VUDQS.js → chunk-VFGSNR35.js} +4 -4
  249. package/dist/{chunk-BA2VUDQS.js.map → chunk-VFGSNR35.js.map} +1 -1
  250. package/dist/{chunk-6ADWXOZ2.cjs → chunk-VGHNBMEJ.cjs} +6 -6
  251. package/dist/{chunk-6ADWXOZ2.cjs.map → chunk-VGHNBMEJ.cjs.map} +1 -1
  252. package/dist/{chunk-UR7RYJOU.cjs → chunk-VHKA25IV.cjs} +20 -17
  253. package/dist/chunk-VHKA25IV.cjs.map +1 -0
  254. package/dist/{chunk-E7UOFIBW.cjs → chunk-VK4O6W2K.cjs} +8 -7
  255. package/dist/chunk-VK4O6W2K.cjs.map +1 -0
  256. package/dist/{chunk-2VOB6LEI.js → chunk-VQ7U3ASC.js} +4 -4
  257. package/dist/{chunk-2VOB6LEI.js.map → chunk-VQ7U3ASC.js.map} +1 -1
  258. package/dist/{chunk-E4KM3RQ2.js → chunk-VUCMGGU5.js} +32 -17
  259. package/dist/chunk-VUCMGGU5.js.map +1 -0
  260. package/dist/{chunk-UY3MYNI6.js → chunk-W2Q4PQ6I.js} +6 -5
  261. package/dist/chunk-W2Q4PQ6I.js.map +1 -0
  262. package/dist/{chunk-RKMW3ZOK.js → chunk-W3C6QQF7.js} +5 -5
  263. package/dist/{chunk-RKMW3ZOK.js.map → chunk-W3C6QQF7.js.map} +1 -1
  264. package/dist/{chunk-GEGYC7CE.js → chunk-WBGFFP3G.js} +7 -7
  265. package/dist/chunk-WBGFFP3G.js.map +1 -0
  266. package/dist/{chunk-5BLNJVIA.js → chunk-WBQNPBXR.js} +10 -9
  267. package/dist/chunk-WBQNPBXR.js.map +1 -0
  268. package/dist/{chunk-ZH3GKYUZ.js → chunk-WY5BOT7O.js} +4 -4
  269. package/dist/{chunk-ZH3GKYUZ.js.map → chunk-WY5BOT7O.js.map} +1 -1
  270. package/dist/{chunk-PLXUM7U6.cjs → chunk-X574M2JB.cjs} +13 -13
  271. package/dist/{chunk-PLXUM7U6.cjs.map → chunk-X574M2JB.cjs.map} +1 -1
  272. package/dist/{chunk-ZNPTARIS.cjs → chunk-XLKXFJMU.cjs} +8 -8
  273. package/dist/{chunk-ZNPTARIS.cjs.map → chunk-XLKXFJMU.cjs.map} +1 -1
  274. package/dist/{chunk-W5G7ZDQ6.cjs → chunk-XLNRO3S6.cjs} +4 -4
  275. package/dist/{chunk-W5G7ZDQ6.cjs.map → chunk-XLNRO3S6.cjs.map} +1 -1
  276. package/dist/{chunk-A66NIFJE.cjs → chunk-XXBA3KSH.cjs} +5 -5
  277. package/dist/{chunk-A66NIFJE.cjs.map → chunk-XXBA3KSH.cjs.map} +1 -1
  278. package/dist/{chunk-PXIWITSS.js → chunk-YAWVGZRC.js} +6 -6
  279. package/dist/{chunk-PXIWITSS.js.map → chunk-YAWVGZRC.js.map} +1 -1
  280. package/dist/{chunk-BFWKL5MJ.cjs → chunk-YHBYVERE.cjs} +29 -28
  281. package/dist/chunk-YHBYVERE.cjs.map +1 -0
  282. package/dist/{chunk-CPOYENSZ.cjs → chunk-YO3MBGBP.cjs} +4 -4
  283. package/dist/{chunk-CPOYENSZ.cjs.map → chunk-YO3MBGBP.cjs.map} +1 -1
  284. package/dist/{chunk-MQQ4GSUG.cjs → chunk-YVHWOKR7.cjs} +33 -32
  285. package/dist/chunk-YVHWOKR7.cjs.map +1 -0
  286. package/dist/{chunk-C264Z2GQ.cjs → chunk-YWGYN6YV.cjs} +11 -10
  287. package/dist/chunk-YWGYN6YV.cjs.map +1 -0
  288. package/dist/{chunk-KFEXS6OK.cjs → chunk-YY6KJO5Z.cjs} +15 -14
  289. package/dist/chunk-YY6KJO5Z.cjs.map +1 -0
  290. package/dist/{chunk-IG4UJZ6B.js → chunk-YYNWZRXZ.js} +24 -21
  291. package/dist/chunk-YYNWZRXZ.js.map +1 -0
  292. package/dist/{chunk-5QPM5LUS.cjs → chunk-Z6RT3WPE.cjs} +15 -4
  293. package/dist/chunk-Z6RT3WPE.cjs.map +1 -0
  294. package/dist/{chunk-7FY26X2V.js → chunk-ZAX2UJBC.js} +8 -7
  295. package/dist/chunk-ZAX2UJBC.js.map +1 -0
  296. package/dist/{chunk-WATCCAQU.js → chunk-ZEA2VYX4.js} +5 -4
  297. package/dist/chunk-ZEA2VYX4.js.map +1 -0
  298. package/dist/{chunk-AXT4VA5N.cjs → chunk-ZFBQ4R7M.cjs} +11 -10
  299. package/dist/chunk-ZFBQ4R7M.cjs.map +1 -0
  300. package/dist/{chunk-AX6HC2YY.cjs → chunk-ZN7CULIL.cjs} +3 -3
  301. package/dist/{chunk-AX6HC2YY.cjs.map → chunk-ZN7CULIL.cjs.map} +1 -1
  302. package/dist/{chunk-OHKL4DOV.js → chunk-ZQUPAIBS.js} +8 -7
  303. package/dist/chunk-ZQUPAIBS.js.map +1 -0
  304. package/dist/{chunk-JVLE7PCJ.cjs → chunk-ZTWBG2XY.cjs} +8 -8
  305. package/dist/{chunk-JVLE7PCJ.cjs.map → chunk-ZTWBG2XY.cjs.map} +1 -1
  306. package/dist/components/Accordion/AccordionItem.recipe.d.ts +1 -1
  307. package/dist/components/Accordion/index.cjs +6 -7
  308. package/dist/components/Accordion/index.js +3 -4
  309. package/dist/components/Alert/Alert.d.ts.map +1 -1
  310. package/dist/components/Alert/Alert.recipe.d.ts +1 -1
  311. package/dist/components/Alert/index.cjs +13 -13
  312. package/dist/components/Alert/index.js +12 -12
  313. package/dist/components/AlertDialog/index.cjs +16 -16
  314. package/dist/components/AlertDialog/index.js +14 -14
  315. package/dist/components/AppShell/AppShell.d.ts.map +1 -1
  316. package/dist/components/AppShell/index.cjs +21 -21
  317. package/dist/components/AppShell/index.js +18 -18
  318. package/dist/components/AspectRatio/index.cjs +3 -3
  319. package/dist/components/AspectRatio/index.js +2 -2
  320. package/dist/components/AutocompleteInput/AutocompleteInput.d.ts +9 -2
  321. package/dist/components/AutocompleteInput/AutocompleteInput.d.ts.map +1 -1
  322. package/dist/components/AutocompleteInput/AutocompleteInput.recipe.d.ts +42 -0
  323. package/dist/components/AutocompleteInput/AutocompleteInput.recipe.d.ts.map +1 -0
  324. package/dist/components/AutocompleteInput/AutocompleteInputItem.d.ts +27 -4
  325. package/dist/components/AutocompleteInput/AutocompleteInputItem.d.ts.map +1 -1
  326. package/dist/components/AutocompleteInput/BaseAutocompleteInput.d.ts +25 -3
  327. package/dist/components/AutocompleteInput/BaseAutocompleteInput.d.ts.map +1 -1
  328. package/dist/components/AutocompleteInput/index.cjs +21 -21
  329. package/dist/components/AutocompleteInput/index.d.ts +1 -1
  330. package/dist/components/AutocompleteInput/index.d.ts.map +1 -1
  331. package/dist/components/AutocompleteInput/index.js +16 -16
  332. package/dist/components/AutocompleteInput/types.d.ts +42 -6
  333. package/dist/components/AutocompleteInput/types.d.ts.map +1 -1
  334. package/dist/components/Avatar/Avatar.d.ts.map +1 -1
  335. package/dist/components/Avatar/AvatarStatusDot.d.ts.map +1 -1
  336. package/dist/components/Avatar/index.cjs +7 -7
  337. package/dist/components/Avatar/index.js +4 -4
  338. package/dist/components/AvatarGroup/index.cjs +7 -7
  339. package/dist/components/AvatarGroup/index.js +5 -5
  340. package/dist/components/Badge/index.cjs +1 -1
  341. package/dist/components/Badge/index.js +1 -1
  342. package/dist/components/Blockquote/Blockquote.d.ts.map +1 -1
  343. package/dist/components/Blockquote/index.cjs +5 -5
  344. package/dist/components/Blockquote/index.js +4 -4
  345. package/dist/components/Breadcrumbs/BreadcrumbItem.d.ts.map +1 -1
  346. package/dist/components/Breadcrumbs/BreadcrumbItem.recipe.d.ts +22 -0
  347. package/dist/components/Breadcrumbs/BreadcrumbItem.recipe.d.ts.map +1 -0
  348. package/dist/components/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
  349. package/dist/components/Breadcrumbs/Breadcrumbs.recipe.d.ts +4 -0
  350. package/dist/components/Breadcrumbs/Breadcrumbs.recipe.d.ts.map +1 -0
  351. package/dist/components/Breadcrumbs/index.cjs +11 -10
  352. package/dist/components/Breadcrumbs/index.js +8 -7
  353. package/dist/components/Button/Button.d.ts.map +1 -1
  354. package/dist/components/Button/Button.recipe.d.ts +80 -62
  355. package/dist/components/Button/Button.recipe.d.ts.map +1 -1
  356. package/dist/components/Button/index.cjs +12 -12
  357. package/dist/components/Button/index.js +11 -11
  358. package/dist/components/ButtonGroup/index.cjs +1 -1
  359. package/dist/components/ButtonGroup/index.js +1 -1
  360. package/dist/components/Calendar/Calendar.d.ts.map +1 -1
  361. package/dist/components/Calendar/Calendar.recipe.d.ts +86 -0
  362. package/dist/components/Calendar/Calendar.recipe.d.ts.map +1 -0
  363. package/dist/components/Calendar/index.cjs +13 -13
  364. package/dist/components/Calendar/index.js +12 -12
  365. package/dist/components/Card/index.cjs +1 -1
  366. package/dist/components/Card/index.js +1 -1
  367. package/dist/components/Center/index.cjs +1 -1
  368. package/dist/components/Center/index.js +1 -1
  369. package/dist/components/CheckboxInput/CheckboxInput.d.ts.map +1 -1
  370. package/dist/components/CheckboxInput/CheckboxInput.recipe.d.ts +39 -0
  371. package/dist/components/CheckboxInput/CheckboxInput.recipe.d.ts.map +1 -0
  372. package/dist/components/CheckboxInput/index.cjs +13 -13
  373. package/dist/components/CheckboxInput/index.js +12 -12
  374. package/dist/components/CodeBlock/index.cjs +14 -14
  375. package/dist/components/CodeBlock/index.js +13 -13
  376. package/dist/components/ContextMenu/index.cjs +18 -18
  377. package/dist/components/ContextMenu/index.js +16 -16
  378. package/dist/components/DateInput/DateInput.d.ts +5 -1
  379. package/dist/components/DateInput/DateInput.d.ts.map +1 -1
  380. package/dist/components/DateInput/index.cjs +17 -17
  381. package/dist/components/DateInput/index.js +16 -16
  382. package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
  383. package/dist/components/DateRangeInput/index.cjs +17 -17
  384. package/dist/components/DateRangeInput/index.js +16 -16
  385. package/dist/components/DateTimeInput/DateTimeInput.d.ts.map +1 -1
  386. package/dist/components/DateTimeInput/index.cjs +19 -19
  387. package/dist/components/DateTimeInput/index.js +18 -18
  388. package/dist/components/Dialog/index.cjs +5 -6
  389. package/dist/components/Dialog/index.js +3 -4
  390. package/dist/components/Divider/Divider.d.ts.map +1 -1
  391. package/dist/components/Divider/index.cjs +5 -5
  392. package/dist/components/Divider/index.js +4 -4
  393. package/dist/components/Drawer/index.cjs +4 -4
  394. package/dist/components/Drawer/index.js +2 -2
  395. package/dist/components/DropdownMenu/DropdownMenu.d.ts.map +1 -1
  396. package/dist/components/DropdownMenu/DropdownMenuItem.d.ts.map +1 -1
  397. package/dist/components/DropdownMenu/DropdownMenuItem.recipe.d.ts +36 -0
  398. package/dist/components/DropdownMenu/DropdownMenuItem.recipe.d.ts.map +1 -0
  399. package/dist/components/DropdownMenu/index.cjs +19 -19
  400. package/dist/components/DropdownMenu/index.js +15 -15
  401. package/dist/components/EmptyState/EmptyState.d.ts.map +1 -1
  402. package/dist/components/EmptyState/EmptyState.recipe.d.ts +13 -4
  403. package/dist/components/EmptyState/EmptyState.recipe.d.ts.map +1 -1
  404. package/dist/components/EmptyState/index.cjs +8 -7
  405. package/dist/components/EmptyState/index.js +7 -6
  406. package/dist/components/Field/Field.d.ts.map +1 -1
  407. package/dist/components/Field/index.cjs +11 -11
  408. package/dist/components/Field/index.js +9 -9
  409. package/dist/components/FileInput/FileInput.d.ts.map +1 -1
  410. package/dist/components/FileInput/index.cjs +15 -15
  411. package/dist/components/FileInput/index.js +14 -14
  412. package/dist/components/HoverCard/index.cjs +5 -5
  413. package/dist/components/HoverCard/index.js +3 -3
  414. package/dist/components/HoverCard/useHoverCard.d.ts.map +1 -1
  415. package/dist/components/Icon/index.cjs +1 -1
  416. package/dist/components/Icon/index.js +1 -1
  417. package/dist/components/InputGroup/InputGroup.d.ts.map +1 -1
  418. package/dist/components/InputGroup/index.cjs +14 -14
  419. package/dist/components/InputGroup/index.js +10 -10
  420. package/dist/components/Item/Item.d.ts.map +1 -1
  421. package/dist/components/Item/index.cjs +9 -9
  422. package/dist/components/Item/index.js +8 -8
  423. package/dist/components/Kbd/index.cjs +4 -5
  424. package/dist/components/Kbd/index.js +3 -4
  425. package/dist/components/Layout/Layout.d.ts.map +1 -1
  426. package/dist/components/Layout/LayoutFooter.d.ts.map +1 -1
  427. package/dist/components/Layout/LayoutHeader.d.ts.map +1 -1
  428. package/dist/components/Layout/index.cjs +17 -17
  429. package/dist/components/Layout/index.js +12 -12
  430. package/dist/components/Lightbox/Lightbox.d.ts.map +1 -1
  431. package/dist/components/Lightbox/index.cjs +14 -14
  432. package/dist/components/Lightbox/index.js +12 -12
  433. package/dist/components/Link/index.cjs +9 -9
  434. package/dist/components/Link/index.js +6 -6
  435. package/dist/components/List/List.d.ts.map +1 -1
  436. package/dist/components/List/List.recipe.d.ts +42 -0
  437. package/dist/components/List/List.recipe.d.ts.map +1 -0
  438. package/dist/components/List/ListItem.d.ts.map +1 -1
  439. package/dist/components/List/index.cjs +12 -11
  440. package/dist/components/List/index.js +10 -9
  441. package/dist/components/MetadataList/index.cjs +7 -8
  442. package/dist/components/MetadataList/index.js +5 -6
  443. package/dist/components/MultiSelect/MultiSelect.d.ts.map +1 -1
  444. package/dist/components/MultiSelect/index.cjs +17 -17
  445. package/dist/components/MultiSelect/index.js +16 -16
  446. package/dist/components/NavIcon/index.cjs +3 -3
  447. package/dist/components/NavIcon/index.js +2 -2
  448. package/dist/components/NumberInput/NumberInput.d.ts.map +1 -1
  449. package/dist/components/NumberInput/index.cjs +16 -16
  450. package/dist/components/NumberInput/index.js +15 -15
  451. package/dist/components/Pagination/index.cjs +13 -13
  452. package/dist/components/Pagination/index.js +12 -12
  453. package/dist/components/PasswordInput/index.cjs +17 -17
  454. package/dist/components/PasswordInput/index.js +16 -16
  455. package/dist/components/Popover/Popover.d.ts.map +1 -1
  456. package/dist/components/Popover/index.cjs +14 -14
  457. package/dist/components/Popover/index.js +12 -12
  458. package/dist/components/Progress/Progress.d.ts.map +1 -1
  459. package/dist/components/Progress/Progress.recipe.d.ts +34 -16
  460. package/dist/components/Progress/Progress.recipe.d.ts.map +1 -1
  461. package/dist/components/Progress/index.cjs +5 -4
  462. package/dist/components/Progress/index.js +4 -3
  463. package/dist/components/RadioGroup/RadioGroup.d.ts.map +1 -1
  464. package/dist/components/RadioGroup/RadioGroupItem.d.ts.map +1 -1
  465. package/dist/components/RadioGroup/index.cjs +14 -14
  466. package/dist/components/RadioGroup/index.js +12 -12
  467. package/dist/components/Rating/index.cjs +5 -6
  468. package/dist/components/Rating/index.js +4 -5
  469. package/dist/components/Schedule/ListView.d.ts.map +1 -1
  470. package/dist/components/Schedule/MonthlyView.d.ts.map +1 -1
  471. package/dist/components/Schedule/TimeGridView.d.ts.map +1 -1
  472. package/dist/components/Schedule/index.cjs +27 -27
  473. package/dist/components/Schedule/index.js +16 -16
  474. package/dist/components/Schedule/shared.d.ts.map +1 -1
  475. package/dist/components/SearchFilterInput/SearchFilterInput.d.ts.map +1 -1
  476. package/dist/components/SearchFilterInput/index.cjs +36 -36
  477. package/dist/components/SearchFilterInput/index.js +28 -28
  478. package/dist/components/SegmentedControl/index.cjs +5 -5
  479. package/dist/components/SegmentedControl/index.js +3 -3
  480. package/dist/components/Select/Select.d.ts.map +1 -1
  481. package/dist/components/Select/Select.recipe.d.ts +25 -0
  482. package/dist/components/Select/Select.recipe.d.ts.map +1 -0
  483. package/dist/components/Select/SelectOption.d.ts.map +1 -1
  484. package/dist/components/Select/index.cjs +19 -19
  485. package/dist/components/Select/index.js +17 -17
  486. package/dist/components/SideNav/SideNav.d.ts.map +1 -1
  487. package/dist/components/SideNav/SideNavHeading.d.ts.map +1 -1
  488. package/dist/components/SideNav/SideNavItem.d.ts.map +1 -1
  489. package/dist/components/SideNav/SideNavSection.d.ts.map +1 -1
  490. package/dist/components/SideNav/index.cjs +20 -20
  491. package/dist/components/SideNav/index.js +14 -14
  492. package/dist/components/Skeleton/index.cjs +1 -1
  493. package/dist/components/Skeleton/index.js +1 -1
  494. package/dist/components/Slider/index.cjs +11 -11
  495. package/dist/components/Slider/index.js +10 -10
  496. package/dist/components/Spinner/index.cjs +7 -8
  497. package/dist/components/Spinner/index.js +6 -7
  498. package/dist/components/SplitButton/index.cjs +17 -17
  499. package/dist/components/SplitButton/index.js +16 -16
  500. package/dist/components/Stack/HStack.d.ts +1 -1
  501. package/dist/components/Stack/HStack.d.ts.map +1 -1
  502. package/dist/components/Stack/VStack.d.ts +1 -1
  503. package/dist/components/Stack/VStack.d.ts.map +1 -1
  504. package/dist/components/Stack/index.cjs +4 -4
  505. package/dist/components/Stack/index.d.ts +1 -1
  506. package/dist/components/Stack/index.d.ts.map +1 -1
  507. package/dist/components/Stack/index.js +2 -2
  508. package/dist/components/Stack/{Stack.d.ts → internal/Stack.d.ts} +13 -3
  509. package/dist/components/Stack/internal/Stack.d.ts.map +1 -0
  510. package/dist/components/Stack/{Stack.recipe.d.ts → internal/Stack.recipe.d.ts} +1 -1
  511. package/dist/components/Stack/internal/Stack.recipe.d.ts.map +1 -0
  512. package/dist/components/Stepper/Step.d.ts.map +1 -1
  513. package/dist/components/Stepper/index.cjs +9 -9
  514. package/dist/components/Stepper/index.js +6 -6
  515. package/dist/components/Switch/Switch.d.ts.map +1 -1
  516. package/dist/components/Switch/index.cjs +10 -10
  517. package/dist/components/Switch/index.js +9 -9
  518. package/dist/components/Table/BaseTable.d.ts.map +1 -1
  519. package/dist/components/Table/index.cjs +59 -59
  520. package/dist/components/Table/index.js +31 -31
  521. package/dist/components/Table/plugins/filtering/useTableFiltering.d.ts.map +1 -1
  522. package/dist/components/Tabs/Tab.d.ts.map +1 -1
  523. package/dist/components/Tabs/index.cjs +18 -18
  524. package/dist/components/Tabs/index.js +13 -13
  525. package/dist/components/Tag/Tag.d.ts +2 -2
  526. package/dist/components/Tag/Tag.d.ts.map +1 -1
  527. package/dist/components/Tag/Tag.recipe.d.ts +103 -68
  528. package/dist/components/Tag/Tag.recipe.d.ts.map +1 -1
  529. package/dist/components/Tag/index.cjs +9 -8
  530. package/dist/components/Tag/index.js +8 -7
  531. package/dist/components/TagsInput/TagsInput.d.ts +3 -1
  532. package/dist/components/TagsInput/TagsInput.d.ts.map +1 -1
  533. package/dist/components/TagsInput/index.cjs +18 -18
  534. package/dist/components/TagsInput/index.js +17 -17
  535. package/dist/components/Text/Heading.d.ts.map +1 -1
  536. package/dist/components/Text/Text.d.ts.map +1 -1
  537. package/dist/components/Text/index.cjs +6 -6
  538. package/dist/components/Text/index.js +4 -4
  539. package/dist/components/TextArea/TextArea.d.ts.map +1 -1
  540. package/dist/components/TextArea/index.cjs +12 -12
  541. package/dist/components/TextArea/index.js +11 -11
  542. package/dist/components/TextInput/TextInput.d.ts.map +1 -1
  543. package/dist/components/TextInput/index.cjs +16 -16
  544. package/dist/components/TextInput/index.js +15 -15
  545. package/dist/components/Thumbnail/Thumbnail.recipe.d.ts +1 -1
  546. package/dist/components/Thumbnail/index.cjs +13 -13
  547. package/dist/components/Thumbnail/index.js +12 -12
  548. package/dist/components/TimeInput/TimeInput.d.ts +10 -2
  549. package/dist/components/TimeInput/TimeInput.d.ts.map +1 -1
  550. package/dist/components/TimeInput/index.cjs +15 -15
  551. package/dist/components/TimeInput/index.js +14 -14
  552. package/dist/components/Toast/Toast.d.ts.map +1 -1
  553. package/dist/components/Toast/Toast.recipe.d.ts +39 -0
  554. package/dist/components/Toast/Toast.recipe.d.ts.map +1 -0
  555. package/dist/components/Toast/ToastViewport.d.ts.map +1 -1
  556. package/dist/components/Toast/index.cjs +15 -15
  557. package/dist/components/Toast/index.js +12 -12
  558. package/dist/components/ToggleButton/index.cjs +10 -11
  559. package/dist/components/ToggleButton/index.js +8 -9
  560. package/dist/components/Tooltip/index.cjs +5 -5
  561. package/dist/components/Tooltip/index.js +3 -3
  562. package/dist/components/Tooltip/useTooltip.d.ts.map +1 -1
  563. package/dist/components/TopNav/TopNav.d.ts.map +1 -1
  564. package/dist/components/TopNav/TopNavHeading.d.ts.map +1 -1
  565. package/dist/components/TopNav/index.cjs +20 -20
  566. package/dist/components/TopNav/index.js +14 -14
  567. package/dist/components/TreeView/TreeView.d.ts.map +1 -1
  568. package/dist/components/TreeView/TreeViewItem.d.ts.map +1 -1
  569. package/dist/components/TreeView/index.cjs +4 -3
  570. package/dist/components/TreeView/index.js +3 -2
  571. package/dist/index.cjs +248 -248
  572. package/dist/index.d.ts +1 -1
  573. package/dist/index.d.ts.map +1 -1
  574. package/dist/index.js +77 -77
  575. package/dist/internal/HoverLayerTrigger.d.ts.map +1 -1
  576. package/dist/internal/MobileNav/MobileNav.d.ts.map +1 -1
  577. package/dist/internal/OverflowList.d.ts.map +1 -1
  578. package/dist/internal/index.d.ts +1 -0
  579. package/dist/internal/index.d.ts.map +1 -1
  580. package/dist/internal/isReactNode.d.ts +3 -0
  581. package/dist/internal/isReactNode.d.ts.map +1 -0
  582. package/dist/internal/useLayer.d.ts.map +1 -1
  583. package/dist/internal/useSelectListbox.d.ts +2 -2
  584. package/dist/internal/useSelectListbox.d.ts.map +1 -1
  585. package/dist/styles.css +1 -1
  586. package/package.json +1 -1
  587. package/dist/chunk-25FU5AVR.cjs.map +0 -1
  588. package/dist/chunk-2D6SGEPH.cjs.map +0 -1
  589. package/dist/chunk-2TGDDZG6.cjs +0 -441
  590. package/dist/chunk-2TGDDZG6.cjs.map +0 -1
  591. package/dist/chunk-2YC7SMVF.js.map +0 -1
  592. package/dist/chunk-32G54PL3.cjs.map +0 -1
  593. package/dist/chunk-3PDUOYAT.cjs.map +0 -1
  594. package/dist/chunk-3WMLV4VP.cjs.map +0 -1
  595. package/dist/chunk-4I6VIR44.cjs.map +0 -1
  596. package/dist/chunk-4M2KCZMO.js.map +0 -1
  597. package/dist/chunk-4YESF35X.cjs +0 -211
  598. package/dist/chunk-4YESF35X.cjs.map +0 -1
  599. package/dist/chunk-4Z62KDKI.js.map +0 -1
  600. package/dist/chunk-5BLNJVIA.js.map +0 -1
  601. package/dist/chunk-5MDH6QZE.js.map +0 -1
  602. package/dist/chunk-5Q5TJUHI.js.map +0 -1
  603. package/dist/chunk-5QPM5LUS.cjs.map +0 -1
  604. package/dist/chunk-67VLK263.js.map +0 -1
  605. package/dist/chunk-6BK4LUK4.cjs +0 -17
  606. package/dist/chunk-6BK4LUK4.cjs.map +0 -1
  607. package/dist/chunk-6D3FA247.js +0 -126
  608. package/dist/chunk-6D3FA247.js.map +0 -1
  609. package/dist/chunk-6XESVFC3.js.map +0 -1
  610. package/dist/chunk-76FHSISK.cjs.map +0 -1
  611. package/dist/chunk-77RGTGRM.cjs +0 -128
  612. package/dist/chunk-77RGTGRM.cjs.map +0 -1
  613. package/dist/chunk-7FY26X2V.js.map +0 -1
  614. package/dist/chunk-7GN6YTSS.cjs.map +0 -1
  615. package/dist/chunk-7P3VY5JZ.js.map +0 -1
  616. package/dist/chunk-AADUJ6CN.js.map +0 -1
  617. package/dist/chunk-ACQMLJ4I.cjs.map +0 -1
  618. package/dist/chunk-AH4AMQEO.js.map +0 -1
  619. package/dist/chunk-AMG3S252.js.map +0 -1
  620. package/dist/chunk-ATDW2VII.cjs.map +0 -1
  621. package/dist/chunk-AXT4VA5N.cjs.map +0 -1
  622. package/dist/chunk-BERQEJYB.js.map +0 -1
  623. package/dist/chunk-BFWKL5MJ.cjs.map +0 -1
  624. package/dist/chunk-BJD32VBQ.cjs.map +0 -1
  625. package/dist/chunk-BYBVI7UN.js.map +0 -1
  626. package/dist/chunk-C264Z2GQ.cjs.map +0 -1
  627. package/dist/chunk-CFOGSQCG.cjs.map +0 -1
  628. package/dist/chunk-CZNN2GOC.js.map +0 -1
  629. package/dist/chunk-DSNJDFO3.cjs.map +0 -1
  630. package/dist/chunk-E2JZGYKU.cjs +0 -181
  631. package/dist/chunk-E2JZGYKU.cjs.map +0 -1
  632. package/dist/chunk-E4KM3RQ2.js.map +0 -1
  633. package/dist/chunk-E7UOFIBW.cjs.map +0 -1
  634. package/dist/chunk-EFO5NDBJ.js +0 -191
  635. package/dist/chunk-EFO5NDBJ.js.map +0 -1
  636. package/dist/chunk-EHCAF6D3.js.map +0 -1
  637. package/dist/chunk-EMHLPPQZ.js.map +0 -1
  638. package/dist/chunk-EUN5TCB2.js.map +0 -1
  639. package/dist/chunk-GEGYC7CE.js.map +0 -1
  640. package/dist/chunk-GI5MVVIX.js.map +0 -1
  641. package/dist/chunk-GUKZNXTB.js +0 -15
  642. package/dist/chunk-GUKZNXTB.js.map +0 -1
  643. package/dist/chunk-H2SGYAUO.js.map +0 -1
  644. package/dist/chunk-HLN3JQYD.js.map +0 -1
  645. package/dist/chunk-HM7IEGQ2.cjs.map +0 -1
  646. package/dist/chunk-IG4UJZ6B.js.map +0 -1
  647. package/dist/chunk-ISYUZ5FS.js.map +0 -1
  648. package/dist/chunk-ITDQSF2O.cjs.map +0 -1
  649. package/dist/chunk-IXJOPMJX.cjs.map +0 -1
  650. package/dist/chunk-J2FCNWYM.js.map +0 -1
  651. package/dist/chunk-JAHKLROD.cjs.map +0 -1
  652. package/dist/chunk-JMNH45Q3.cjs.map +0 -1
  653. package/dist/chunk-K6CQ45C2.js.map +0 -1
  654. package/dist/chunk-K77D7H4V.cjs.map +0 -1
  655. package/dist/chunk-KFEXS6OK.cjs.map +0 -1
  656. package/dist/chunk-L6JT244G.cjs.map +0 -1
  657. package/dist/chunk-L6WUK7O4.js +0 -207
  658. package/dist/chunk-L6WUK7O4.js.map +0 -1
  659. package/dist/chunk-LJLCGQRV.js +0 -99
  660. package/dist/chunk-LJLCGQRV.js.map +0 -1
  661. package/dist/chunk-MACIT6C6.js.map +0 -1
  662. package/dist/chunk-MAL4D4LR.cjs.map +0 -1
  663. package/dist/chunk-MMST4VXH.cjs +0 -392
  664. package/dist/chunk-MMST4VXH.cjs.map +0 -1
  665. package/dist/chunk-MQQ4GSUG.cjs.map +0 -1
  666. package/dist/chunk-OHKL4DOV.js.map +0 -1
  667. package/dist/chunk-OJCJPYXE.js.map +0 -1
  668. package/dist/chunk-OJKZS6HG.cjs.map +0 -1
  669. package/dist/chunk-P4A7GWQY.cjs.map +0 -1
  670. package/dist/chunk-P4TOIB2A.cjs +0 -101
  671. package/dist/chunk-P4TOIB2A.cjs.map +0 -1
  672. package/dist/chunk-PJXJOI73.js +0 -232
  673. package/dist/chunk-PJXJOI73.js.map +0 -1
  674. package/dist/chunk-PNYF6NS4.cjs.map +0 -1
  675. package/dist/chunk-PTJ5YZFY.cjs.map +0 -1
  676. package/dist/chunk-PXTE3XRD.js.map +0 -1
  677. package/dist/chunk-PXVVTPRJ.js.map +0 -1
  678. package/dist/chunk-PYW5UO2Z.js.map +0 -1
  679. package/dist/chunk-S4GLMGFI.js.map +0 -1
  680. package/dist/chunk-SEAVOF6B.js.map +0 -1
  681. package/dist/chunk-SFT5LCQP.cjs.map +0 -1
  682. package/dist/chunk-SSOHJEHS.js +0 -390
  683. package/dist/chunk-SSOHJEHS.js.map +0 -1
  684. package/dist/chunk-TO3ZPSYO.cjs +0 -234
  685. package/dist/chunk-TO3ZPSYO.cjs.map +0 -1
  686. package/dist/chunk-TRK2ZZFB.cjs.map +0 -1
  687. package/dist/chunk-U2WVHZ24.cjs.map +0 -1
  688. package/dist/chunk-UJODHP7E.cjs.map +0 -1
  689. package/dist/chunk-UMGW7WJI.cjs.map +0 -1
  690. package/dist/chunk-UR7RYJOU.cjs.map +0 -1
  691. package/dist/chunk-UX2Z7LRM.cjs +0 -194
  692. package/dist/chunk-UX2Z7LRM.cjs.map +0 -1
  693. package/dist/chunk-UY3MYNI6.js.map +0 -1
  694. package/dist/chunk-VSEKSDTK.js.map +0 -1
  695. package/dist/chunk-VYFMYXU4.js.map +0 -1
  696. package/dist/chunk-W3QVSVL7.cjs.map +0 -1
  697. package/dist/chunk-WA4VZ363.cjs.map +0 -1
  698. package/dist/chunk-WATCCAQU.js.map +0 -1
  699. package/dist/chunk-X5ZQRMEM.cjs.map +0 -1
  700. package/dist/chunk-XQU4ECJY.js.map +0 -1
  701. package/dist/chunk-XVRQSTUF.js.map +0 -1
  702. package/dist/chunk-Y5SXQR52.cjs.map +0 -1
  703. package/dist/chunk-YBPG5RPR.cjs.map +0 -1
  704. package/dist/chunk-YGYA4BYN.js.map +0 -1
  705. package/dist/chunk-ZC6GLBEL.js +0 -179
  706. package/dist/chunk-ZC6GLBEL.js.map +0 -1
  707. package/dist/chunk-ZNUOFLCQ.js.map +0 -1
  708. package/dist/chunk-ZNZ67KFM.js.map +0 -1
  709. package/dist/chunk-ZTQQ2O6O.cjs.map +0 -1
  710. package/dist/chunk-ZW2ATXTL.js.map +0 -1
  711. package/dist/chunk-ZXPKFGRB.cjs.map +0 -1
  712. package/dist/components/Stack/Stack.d.ts.map +0 -1
  713. package/dist/components/Stack/Stack.recipe.d.ts.map +0 -1
@@ -1,12 +1,13 @@
1
- import { TopNavMobileContentContext, TopNavRenderContext } from './chunk-YGYA4BYN.js';
2
- import { SideNavRenderContext } from './chunk-XQU4ECJY.js';
3
- import { AppShellMobileContext, MobileNavToggle } from './chunk-SEAVOF6B.js';
4
- import { Layout, LayoutPanel, LayoutContent } from './chunk-GI5MVVIX.js';
1
+ import { TopNavMobileContentContext, TopNavRenderContext } from './chunk-2RKMG2TC.js';
2
+ import { SideNavRenderContext } from './chunk-SOCSUNIM.js';
3
+ import { AppShellMobileContext, MobileNavToggle } from './chunk-SSAYBCAD.js';
4
+ import { Layout, LayoutPanel, LayoutContent } from './chunk-2N6FOSNM.js';
5
5
  import { mergeRefs } from './chunk-SGLIDI6R.js';
6
+ import { isReactNode } from './chunk-2PSZAWLC.js';
6
7
  import { cva } from './chunk-FMEIPGUP.js';
7
- import { cx } from './chunk-PPNETWIP.js';
8
8
  import { css } from './chunk-OD4DHHZH.js';
9
- import { useId, useState, useCallback, useRef, useEffect, useMemo, useSyncExternalStore } from 'react';
9
+ import { cx } from './chunk-PPNETWIP.js';
10
+ import { useId, useState, useRef, useEffect, useMemo, useCallback, useSyncExternalStore } from 'react';
10
11
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
11
12
 
12
13
  // src/internal/sharedResizeObserver.ts
@@ -224,13 +225,10 @@ function AppShell({
224
225
  const breakpointQuery = mobileBreakpoint === "none" ? "(max-width: 0px)" : `(max-width: ${BREAKPOINT_VALUES[mobileBreakpoint]}px)`;
225
226
  const isBelowBreakpoint = useMediaQuery(breakpointQuery);
226
227
  const [isMobileNavOpen, setIsMobileNavOpen] = useState(false);
227
- const setMobileNavOpen = useCallback((isOpen) => {
228
- setIsMobileNavOpen(isOpen);
229
- }, []);
230
- const { ref: topNavPresenceRef, hasContent: hasTopNavContent } = useSlotPresence(topNav != null);
231
- const { ref: sideNavPresenceRef, hasContent: hasSideNavContent } = useSlotPresence(sideNav != null);
232
- const hasTopNav = topNav != null;
233
- const hasSideNav = sideNav != null;
228
+ const { ref: topNavPresenceRef, hasContent: hasTopNavContent } = useSlotPresence(isReactNode(topNav));
229
+ const { ref: sideNavPresenceRef, hasContent: hasSideNavContent } = useSlotPresence(isReactNode(sideNav));
230
+ const hasTopNav = isReactNode(topNav);
231
+ const hasSideNav = isReactNode(sideNav);
234
232
  const hasNavContent = hasTopNavContent || hasSideNavContent;
235
233
  const mobileNavEnabled = !isMobileNavDisabled && hasNavContent;
236
234
  const showSideNavInline = hasSideNav && !isBelowBreakpoint;
@@ -256,25 +254,25 @@ function AppShell({
256
254
  }, [isAuto]);
257
255
  const mobileContextValue = useMemo(
258
256
  () => ({
259
- closeMobileNav: () => setMobileNavOpen(false),
257
+ closeMobileNav: () => setIsMobileNavOpen(false),
260
258
  hasAutoToggle: true,
261
259
  isMobile: isBelowBreakpoint,
262
260
  isMobileNavEnabled: mobileNavEnabled,
263
261
  isMobileNavOpen,
264
- openMobileNav: () => mobileNavEnabled && setMobileNavOpen(true),
262
+ openMobileNav: () => mobileNavEnabled && setIsMobileNavOpen(true),
265
263
  toggleMobileNav: () => {
266
264
  if (mobileNavEnabled) {
267
265
  setIsMobileNavOpen((prev) => !prev);
268
266
  }
269
267
  }
270
268
  }),
271
- [isBelowBreakpoint, isMobileNavOpen, mobileNavEnabled, setMobileNavOpen]
269
+ [isBelowBreakpoint, isMobileNavOpen, mobileNavEnabled]
272
270
  );
273
271
  const mobileContentValue = hasSideNavContent ? /* @__PURE__ */ jsx(SideNavRenderContext, { value: "drawer-content", children: /* @__PURE__ */ jsx("div", { className: styles.slotContents, ref: sideNavPresenceRef, children: sideNav }) }) : null;
274
272
  const drawerMobileContentValue = hasSideNavContent ? /* @__PURE__ */ jsx(SideNavRenderContext, { value: "drawer-content", children: sideNav }) : null;
275
273
  const topNavContent = hasTopNav && isBelowBreakpoint && !isMobileNavDisabled ? /* @__PURE__ */ jsx(TopNavMobileContentContext, { value: mobileContentValue, children: /* @__PURE__ */ jsx(TopNavRenderContext, { value: "mobile-bar", children: /* @__PURE__ */ jsx("div", { className: styles.slotContents, ref: topNavPresenceRef, children: topNav }) }) }) : topNav;
276
- const headerContent = hasTopNav || banner != null ? /* @__PURE__ */ jsx("div", { className: cx(isAuto && styles.headerSticky), ref: headerRef, children: /* @__PURE__ */ jsxs("header", { style: { flexShrink: 0 }, children: [
277
- banner != null ? /* @__PURE__ */ jsx("div", { className: styles.banner, children: banner }) : null,
274
+ const headerContent = hasTopNav || isReactNode(banner) ? /* @__PURE__ */ jsx("div", { className: cx(isAuto && styles.headerSticky), ref: headerRef, children: /* @__PURE__ */ jsxs("header", { style: { flexShrink: 0 }, children: [
275
+ isReactNode(banner) ? /* @__PURE__ */ jsx("div", { className: styles.banner, children: banner }) : null,
278
276
  hasTopNav ? /* @__PURE__ */ jsx("div", { className: styles.slotContents, ref: topNavPresenceRef, children: topNavContent }) : null
279
277
  ] }) }) : void 0;
280
278
  const autoMobileTopBar = !isMobileNavDisabled && isBelowBreakpoint && !hasTopNavContent && hasSideNav ? /* @__PURE__ */ jsx("header", { style: { flexShrink: 0 }, children: /* @__PURE__ */ jsxs(
@@ -351,5 +349,5 @@ function AppShell({
351
349
  AppShell.displayName = "AppShell";
352
350
 
353
351
  export { AppShell };
354
- //# sourceMappingURL=chunk-EUN5TCB2.js.map
355
- //# sourceMappingURL=chunk-EUN5TCB2.js.map
352
+ //# sourceMappingURL=chunk-52WQDDWQ.js.map
353
+ //# sourceMappingURL=chunk-52WQDDWQ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/internal/sharedResizeObserver.ts","../src/internal/useMediaQuery.ts","../src/components/AppShell/AppShell.recipe.ts","../src/components/AppShell/useSlotPresence.tsx","../src/components/AppShell/AppShell.tsx"],"names":["useCallback","observer","useState","useRef","useEffect"],"mappings":"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","file":"chunk-52WQDDWQ.js","sourcesContent":["type ResizeCallback = (entry: ResizeObserverEntry) => void;\n\nlet observer: ResizeObserver | null = null;\nconst callbacks = new Map<Element, ResizeCallback>();\n\nfunction getObserver(): ResizeObserver {\n observer ??= new ResizeObserver(entries => {\n for (const entry of entries) {\n callbacks.get(entry.target)?.(entry);\n }\n });\n\n return observer;\n}\n\nexport function observeResize(\n element: Element,\n callback: ResizeCallback,\n): void {\n callbacks.set(element, callback);\n getObserver().observe(element);\n}\n\nexport function unobserveResize(element: Element): void {\n callbacks.delete(element);\n\n if (observer == null) {\n return;\n }\n\n observer.unobserve(element);\n\n if (callbacks.size === 0) {\n observer.disconnect();\n observer = null;\n }\n}\n","import {useCallback, useSyncExternalStore} from 'react';\n\nfunction getServerSnapshot(): boolean {\n return false;\n}\n\n/**\n * Subscribe to a browser media query using React's external-store API.\n */\nexport function useMediaQuery(query: string): boolean {\n const subscribe = useCallback(\n (onStoreChange: () => void) => {\n const mediaQueryList = window.matchMedia(query);\n mediaQueryList.addEventListener('change', onStoreChange);\n return () => mediaQueryList.removeEventListener('change', onStoreChange);\n },\n [query],\n );\n\n const getSnapshot = useCallback(() => {\n return window.matchMedia(query).matches;\n }, [query]);\n\n return useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);\n}\n","import {cva, type RecipeVariantProps} from 'styled-system/css';\n\nexport const appShellRecipe = cva({\n base: {\n display: 'flex',\n flexDirection: 'column',\n position: 'relative',\n },\n variants: {\n height: {\n fill: {\n h: '100dvh',\n },\n auto: {\n minH: '100dvh',\n },\n },\n variant: {\n default: {\n bg: 'bg.subtle',\n },\n section: {\n bg: 'bg',\n },\n },\n },\n defaultVariants: {\n height: 'fill',\n variant: 'default',\n },\n});\n\nexport type AppShellVariants = RecipeVariantProps<typeof appShellRecipe>;\n","import {useCallback, useEffect, useRef, useState} from 'react';\n\nfunction hasChildContent(element: HTMLElement): boolean {\n for (const node of element.childNodes) {\n if (node.nodeType === Node.ELEMENT_NODE) {\n return true;\n }\n\n if (node.nodeType === Node.TEXT_NODE && node.textContent?.trim() !== '') {\n return true;\n }\n }\n\n return false;\n}\n\nexport function useSlotPresence(initialValue = false): {\n hasContent: boolean;\n ref: (node: HTMLDivElement | null) => void;\n} {\n const [hasContent, setHasContent] = useState(initialValue);\n const observerRef = useRef<MutationObserver | null>(null);\n\n const ref = useCallback((node: HTMLDivElement | null) => {\n observerRef.current?.disconnect();\n observerRef.current = null;\n\n if (node == null) {\n setHasContent(false);\n return;\n }\n\n setHasContent(hasChildContent(node));\n\n const observer = new MutationObserver(() => {\n setHasContent(hasChildContent(node));\n });\n observer.observe(node, {childList: true});\n observerRef.current = observer;\n }, []);\n\n useEffect(() => {\n return () => observerRef.current?.disconnect();\n }, []);\n\n return {hasContent, ref};\n}\n","import type {CSSProperties, ReactNode, Ref} from 'react';\nimport {useEffect, useId, useMemo, useRef, useState} from 'react';\nimport {css} from 'styled-system/css';\nimport {MobileNavToggle} from '../../internal/MobileNav';\nimport {cx} from '../../internal/cx';\nimport isReactNode from '../../internal/isReactNode';\nimport {mergeRefs} from '../../internal/mergeRefs';\nimport {\n observeResize,\n unobserveResize,\n} from '../../internal/sharedResizeObserver';\nimport type {SpacingToken} from '../../internal/spacingTokens';\nimport {useMediaQuery} from '../../internal/useMediaQuery';\nimport {Layout, LayoutContent, LayoutPanel} from '../Layout';\nimport {SideNavRenderContext} from '../SideNav';\nimport {TopNavMobileContentContext, TopNavRenderContext} from '../TopNav';\nimport {appShellRecipe} from './AppShell.recipe';\nimport {\n AppShellMobileContext,\n type AppShellMobileContextValue,\n} from './AppShellMobileContext';\nimport {useSlotPresence} from './useSlotPresence';\n\nexport type AppShellBreakpoint = 'sm' | 'md' | 'lg' | 'none';\nexport type AppShellVariant = 'default' | 'section';\nexport type AppShellHeight = 'fill' | 'auto';\n\n/**\n * Application-level layout shell with top navigation, side navigation,\n * banner, skip-to-content support, and responsive mobile navigation.\n */\nexport interface AppShellProps {\n /**\n * System-wide content rendered above the top navigation.\n */\n banner?: ReactNode;\n /**\n * Main content rendered inside the shell's `<main>` landmark.\n */\n children: ReactNode;\n /**\n * Additional CSS class names applied to the root element.\n */\n className?: string;\n /**\n * Padding applied to the main content area. Default is `0`.\n */\n contentPadding?: SpacingToken;\n /**\n * Test ID applied to the root element.\n */\n 'data-testid'?: string;\n /**\n * Height behavior. `fill` keeps scrolling inside the shell; `auto` lets the\n * page grow with content.\n */\n height?: AppShellHeight;\n /**\n * Disable generated mobile navigation.\n */\n isMobileNavDisabled?: boolean;\n /**\n * Breakpoint below which mobile navigation is used.\n * @default 'md'\n */\n mobileBreakpoint?: AppShellBreakpoint;\n /**\n * Ref forwarded to the root element.\n */\n ref?: Ref<HTMLDivElement>;\n /**\n * Side navigation slot, typically a SideNav.\n */\n sideNav?: ReactNode;\n /**\n * Inline styles applied to the root element.\n */\n style?: CSSProperties;\n /**\n * Top navigation slot, typically a TopNav.\n */\n topNav?: ReactNode;\n /**\n * Background and divider style for the shell.\n */\n variant?: AppShellVariant;\n}\n\nconst BREAKPOINT_VALUES: Record<AppShellBreakpoint, number> = {\n sm: 640,\n md: 768,\n lg: 1024,\n none: 0,\n};\n\nconst styles = {\n skipLink: css({\n position: 'absolute',\n top: 0,\n insetInlineStart: 0,\n w: '1px',\n h: '1px',\n p: 0,\n m: '-1px',\n overflow: 'hidden',\n clipPath: 'inset(50%)',\n whiteSpace: 'nowrap',\n borderWidth: 0,\n zIndex: 9999,\n bg: 'bg',\n color: 'primary',\n textDecoration: 'none',\n fontWeight: 'semibold',\n _focus: {\n position: 'fixed',\n top: '2',\n insetInlineStart: '2',\n w: 'auto',\n h: 'auto',\n p: '2',\n m: 0,\n overflow: 'visible',\n clipPath: 'none',\n whiteSpace: 'normal',\n outlineWidth: 'focus',\n outlineStyle: 'solid',\n outlineColor: 'primary',\n outlineOffset: 'focusOffset',\n },\n }),\n headerSticky: css({\n position: 'sticky',\n top: 0,\n zIndex: 1,\n }),\n banner: css({\n flexShrink: 0,\n }),\n autoMobileTopBar: css({\n display: 'flex',\n alignItems: 'center',\n h: '12',\n px: '2',\n }),\n sideNavSticky: css({\n flexShrink: 0,\n overflow: 'clip',\n position: 'sticky',\n top: 'var(--appshell-header-height, 0px)',\n h: 'calc(100dvh - var(--appshell-header-height, 0px))',\n display: 'flex',\n flexDirection: 'column',\n }),\n elevatedWrapper: css({\n position: 'relative',\n display: 'flex',\n flex: 1,\n minH: 0,\n h: '100%',\n }),\n elevatedBackdrop: css({\n position: 'absolute',\n inset: 0,\n bg: 'bg',\n borderStartStartRadius: '2xl',\n pointerEvents: 'none',\n }),\n contentSurface: css({\n bg: 'bg',\n }),\n contentTransparent: css({\n bg: 'transparent',\n isolation: 'isolate',\n }),\n slotContents: css({\n display: 'contents',\n }),\n};\n\ntype AppShellRootStyle = CSSProperties & {\n '--appshell-header-height'?: string;\n};\n\n/**\n * Application-level layout shell with top navigation, side navigation,\n * banner, skip-to-content support, and responsive mobile navigation.\n */\nexport function AppShell({\n banner,\n children,\n className,\n contentPadding,\n 'data-testid': dataTestId,\n height = 'fill',\n isMobileNavDisabled = false,\n mobileBreakpoint = 'md',\n ref,\n sideNav,\n style,\n topNav,\n variant = 'default',\n}: AppShellProps): React.JSX.Element {\n const mainContentId = useId();\n const breakpointQuery =\n mobileBreakpoint === 'none'\n ? '(max-width: 0px)'\n : `(max-width: ${BREAKPOINT_VALUES[mobileBreakpoint]}px)`;\n const isBelowBreakpoint = useMediaQuery(breakpointQuery);\n const [isMobileNavOpen, setIsMobileNavOpen] = useState(false);\n const {ref: topNavPresenceRef, hasContent: hasTopNavContent} =\n useSlotPresence(isReactNode(topNav));\n const {ref: sideNavPresenceRef, hasContent: hasSideNavContent} =\n useSlotPresence(isReactNode(sideNav));\n const hasTopNav = isReactNode(topNav);\n const hasSideNav = isReactNode(sideNav);\n const hasNavContent = hasTopNavContent || hasSideNavContent;\n const mobileNavEnabled = !isMobileNavDisabled && hasNavContent;\n const showSideNavInline = hasSideNav && !isBelowBreakpoint;\n const isAuto = height === 'auto';\n const isFill = height === 'fill';\n const navHasDividers = variant === 'section';\n const headerRef = useRef<HTMLDivElement>(null);\n const shellRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n if (!isAuto || headerRef.current == null || shellRef.current == null) {\n return;\n }\n\n const headerElement = headerRef.current;\n const shellElement = shellRef.current;\n const updateHeight = () => {\n shellElement.style.setProperty(\n '--appshell-header-height',\n `${headerElement.getBoundingClientRect().height}px`,\n );\n };\n\n observeResize(headerElement, updateHeight);\n return () => unobserveResize(headerElement);\n }, [isAuto]);\n\n const mobileContextValue = useMemo<AppShellMobileContextValue>(\n () => ({\n closeMobileNav: () => setIsMobileNavOpen(false),\n hasAutoToggle: true,\n isMobile: isBelowBreakpoint,\n isMobileNavEnabled: mobileNavEnabled,\n isMobileNavOpen,\n openMobileNav: () => mobileNavEnabled && setIsMobileNavOpen(true),\n toggleMobileNav: () => {\n if (mobileNavEnabled) {\n setIsMobileNavOpen(prev => !prev);\n }\n },\n }),\n [isBelowBreakpoint, isMobileNavOpen, mobileNavEnabled],\n );\n\n /* eslint-disable @eslint-react/no-unstable-context-value -- sideNav ReactNode prop prevents stable memoization */\n const mobileContentValue = hasSideNavContent ? (\n <SideNavRenderContext value=\"drawer-content\">\n <div className={styles.slotContents} ref={sideNavPresenceRef}>\n {sideNav}\n </div>\n </SideNavRenderContext>\n ) : null;\n const drawerMobileContentValue = hasSideNavContent ? (\n <SideNavRenderContext value=\"drawer-content\">\n {sideNav}\n </SideNavRenderContext>\n ) : null;\n /* eslint-enable @eslint-react/no-unstable-context-value */\n const topNavContent =\n hasTopNav && isBelowBreakpoint && !isMobileNavDisabled ? (\n <TopNavMobileContentContext value={mobileContentValue}>\n <TopNavRenderContext value=\"mobile-bar\">\n <div className={styles.slotContents} ref={topNavPresenceRef}>\n {topNav}\n </div>\n </TopNavRenderContext>\n </TopNavMobileContentContext>\n ) : (\n topNav\n );\n const headerContent =\n hasTopNav || isReactNode(banner) ? (\n <div className={cx(isAuto && styles.headerSticky)} ref={headerRef}>\n <header style={{flexShrink: 0}}>\n {isReactNode(banner) ? (\n <div className={styles.banner}>{banner}</div>\n ) : null}\n {hasTopNav ? (\n <div className={styles.slotContents} ref={topNavPresenceRef}>\n {topNavContent}\n </div>\n ) : null}\n </header>\n </div>\n ) : undefined;\n const autoMobileTopBar =\n !isMobileNavDisabled &&\n isBelowBreakpoint &&\n !hasTopNavContent &&\n hasSideNav ? (\n <header style={{flexShrink: 0}}>\n <div\n aria-label=\"Mobile navigation\"\n className={styles.autoMobileTopBar}\n role=\"navigation\">\n <SideNavRenderContext value=\"topbar\">\n <div className={styles.slotContents} ref={sideNavPresenceRef}>\n {sideNav}\n </div>\n </SideNavRenderContext>\n <MobileNavToggle />\n </div>\n </header>\n ) : undefined;\n const sideNavPanel = showSideNavInline ? (\n <LayoutPanel isScrollable={isFill} padding={0}>\n <div className={styles.slotContents} ref={sideNavPresenceRef}>\n {sideNav}\n </div>\n </LayoutPanel>\n ) : undefined;\n const sideNavContent =\n sideNavPanel != null && isAuto ? (\n <div className={styles.sideNavSticky}>{sideNavPanel}</div>\n ) : (\n sideNavPanel\n );\n const contentClassName =\n variant === 'default' && hasTopNavContent && showSideNavInline\n ? styles.contentTransparent\n : variant === 'default'\n ? styles.contentSurface\n : undefined;\n const mainInner = (\n <LayoutContent\n as=\"main\"\n className={contentClassName}\n id={mainContentId}\n isScrollable={isFill}\n padding={contentPadding ?? 0}>\n {children}\n </LayoutContent>\n );\n const shouldElevateWithCorner =\n variant === 'default' && hasTopNavContent && showSideNavInline;\n const mainContent = shouldElevateWithCorner ? (\n <div className={styles.elevatedWrapper}>\n <div className={styles.elevatedBackdrop} />\n {mainInner}\n </div>\n ) : (\n mainInner\n );\n const rootStyle: AppShellRootStyle = {...style};\n\n return (\n <AppShellMobileContext value={mobileContextValue}>\n <div\n className={cx(appShellRecipe({height, variant}), className)}\n data-testid={dataTestId}\n ref={mergeRefs(ref, shellRef)}\n style={rootStyle}>\n <a\n className={styles.skipLink}\n data-testid=\"skip-to-content\"\n href={`#${mainContentId}`}>\n Skip to content\n </a>\n <Layout\n content={mainContent}\n hasDividers={navHasDividers}\n header={\n <>\n {headerContent}\n {autoMobileTopBar}\n </>\n }\n height={height}\n padding={0}\n start={sideNavContent}\n />\n {isBelowBreakpoint && !isMobileNavDisabled ? (\n <>\n {hasSideNav && !hasTopNavContent ? (\n <SideNavRenderContext value=\"drawer\">\n {sideNav}\n </SideNavRenderContext>\n ) : null}\n {hasTopNav && hasTopNavContent ? (\n <TopNavMobileContentContext value={drawerMobileContentValue}>\n <TopNavRenderContext value=\"drawer\">\n {topNav}\n </TopNavRenderContext>\n </TopNavMobileContentContext>\n ) : null}\n </>\n ) : null}\n </div>\n </AppShellMobileContext>\n );\n}\n\nAppShell.displayName = 'AppShell';\n"]}
@@ -1,10 +1,10 @@
1
1
  'use strict';
2
2
 
3
- var chunkYBPG5RPR_cjs = require('./chunk-YBPG5RPR.cjs');
3
+ var chunkQOKEU3DC_cjs = require('./chunk-QOKEU3DC.cjs');
4
4
  var chunk6SHL7FYO_cjs = require('./chunk-6SHL7FYO.cjs');
5
5
  var chunkJRBQKFVO_cjs = require('./chunk-JRBQKFVO.cjs');
6
- var chunkSPDVNY2Z_cjs = require('./chunk-SPDVNY2Z.cjs');
7
6
  var chunkRU6JG3FS_cjs = require('./chunk-RU6JG3FS.cjs');
7
+ var chunkSPDVNY2Z_cjs = require('./chunk-SPDVNY2Z.cjs');
8
8
  var react = require('react');
9
9
  var lucideReact = require('lucide-react');
10
10
  var jsxRuntime = require('react/jsx-runtime');
@@ -82,12 +82,14 @@ var styles = {
82
82
  drawerStart: chunkRU6JG3FS_cjs.css({
83
83
  insetInlineStart: 0,
84
84
  borderInlineEndWidth: "default",
85
- transform: "translateX(-100%)"
85
+ transform: "translateX(-100%)",
86
+ _rtl: { transform: "translateX(100%)" }
86
87
  }),
87
88
  drawerEnd: chunkRU6JG3FS_cjs.css({
88
89
  insetInlineEnd: 0,
89
90
  borderInlineStartWidth: "default",
90
- transform: "translateX(100%)"
91
+ transform: "translateX(100%)",
92
+ _rtl: { transform: "translateX(-100%)" }
91
93
  }),
92
94
  drawerOpen: chunkRU6JG3FS_cjs.css({
93
95
  transform: "translateX(0)"
@@ -197,7 +199,7 @@ function MobileNav({
197
199
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.header, children: [
198
200
  header ?? /* @__PURE__ */ jsxRuntime.jsx("span", {}),
199
201
  /* @__PURE__ */ jsxRuntime.jsx(
200
- chunkYBPG5RPR_cjs.Button,
202
+ chunkQOKEU3DC_cjs.Button,
201
203
  {
202
204
  icon: lucideReact.X,
203
205
  isIconOnly: true,
@@ -227,10 +229,10 @@ function MobileNavToggle({
227
229
  return null;
228
230
  }
229
231
  return /* @__PURE__ */ jsxRuntime.jsx(
230
- chunkYBPG5RPR_cjs.Button,
232
+ chunkQOKEU3DC_cjs.Button,
231
233
  {
232
234
  className,
233
- "data-testid": dataTestId ?? "mobile-nav-toggle",
235
+ "data-testid": dataTestId,
234
236
  icon: lucideReact.Menu,
235
237
  isIconOnly: true,
236
238
  label,
@@ -247,5 +249,5 @@ exports.AppShellMobileContext = AppShellMobileContext;
247
249
  exports.MobileNav = MobileNav;
248
250
  exports.MobileNavToggle = MobileNavToggle;
249
251
  exports.useAppShellMobile = useAppShellMobile;
250
- //# sourceMappingURL=chunk-UMGW7WJI.cjs.map
251
- //# sourceMappingURL=chunk-UMGW7WJI.cjs.map
252
+ //# sourceMappingURL=chunk-5D2OR64D.cjs.map
253
+ //# sourceMappingURL=chunk-5D2OR64D.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/AppShell/AppShellMobileContext.tsx","../src/internal/MobileNav/MobileNav.recipe.ts","../src/internal/MobileNav/MobileNav.tsx","../src/internal/MobileNav/MobileNavToggle.tsx"],"names":["createContext","use","cva","css","useCallback","useRef","useEffect","jsx","cx","mergeRefs","jsxs","Button","X","Menu"],"mappings":"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","file":"chunk-5D2OR64D.cjs","sourcesContent":["import {createContext, use} from 'react';\n\nexport interface AppShellMobileContextValue {\n closeMobileNav: () => void;\n hasAutoToggle: boolean;\n isMobile: boolean;\n isMobileNavEnabled: boolean;\n isMobileNavOpen: boolean;\n openMobileNav: () => void;\n toggleMobileNav: () => void;\n}\n\nconst defaultValue: AppShellMobileContextValue = {\n closeMobileNav: () => {},\n hasAutoToggle: true,\n isMobile: false,\n isMobileNavEnabled: false,\n isMobileNavOpen: false,\n openMobileNav: () => {},\n toggleMobileNav: () => {},\n};\n\nexport const AppShellMobileContext =\n createContext<AppShellMobileContextValue>(defaultValue);\nAppShellMobileContext.displayName = 'AppShellMobileContext';\n\nexport function useAppShellMobile(): AppShellMobileContextValue {\n return use(AppShellMobileContext);\n}\n","import {cva, type RecipeVariantProps} from 'styled-system/css';\n\nexport const mobileNavRecipe = cva({\n base: {\n position: 'fixed',\n inset: 0,\n m: 0,\n p: 0,\n borderWidth: 0,\n maxW: 'none',\n maxH: 'none',\n w: '100vw',\n h: '100dvh',\n bg: 'transparent',\n overflow: 'hidden',\n display: 'none',\n '&::backdrop': {\n bg: 'overlay.scrim',\n backdropFilter: 'blur(2px)',\n },\n },\n variants: {\n isOpen: {\n true: {\n display: 'flex',\n },\n false: {},\n },\n },\n defaultVariants: {\n isOpen: false,\n },\n});\n\nexport type MobileNavVariants = RecipeVariantProps<typeof mobileNavRecipe>;\n","import {X} from 'lucide-react';\nimport type {CSSProperties, ReactNode, Ref} from 'react';\nimport {useCallback, useEffect, useRef} from 'react';\nimport {css} from 'styled-system/css';\nimport {useAppShellMobile} from '../../components/AppShell/AppShellMobileContext';\nimport {Button} from '../../components/Button';\nimport {cx} from '../cx';\nimport {mergeRefs} from '../mergeRefs';\nimport {mobileNavRecipe} from './MobileNav.recipe';\n\nexport type MobileNavSide = 'start' | 'end';\n\n/**\n * Slide-out drawer for mobile navigation.\n */\nexport interface MobileNavProps {\n /**\n * Drawer body content.\n */\n children: ReactNode;\n /**\n * Additional CSS class names applied to the dialog element.\n */\n className?: string;\n /**\n * Test ID applied to the dialog element.\n */\n 'data-testid'?: string;\n /**\n * Content rendered in the drawer header bar.\n */\n header?: ReactNode;\n /**\n * Whether the drawer is open.\n */\n isOpen?: boolean;\n /**\n * Accessible label for the dialog.\n */\n label?: string;\n /**\n * Called when the drawer requests an open-state change.\n */\n onOpenChange?: (isOpen: boolean) => void;\n /**\n * Ref forwarded to the dialog element.\n */\n ref?: Ref<HTMLDialogElement>;\n /**\n * Which edge of the viewport the drawer slides from.\n * @default 'end'\n */\n side?: MobileNavSide;\n /**\n * Maximum drawer width.\n * @default 320\n */\n size?: number | string;\n /**\n * Inline styles applied to the dialog element.\n */\n style?: CSSProperties;\n}\n\nfunction formatSize(value: number | string): string {\n return typeof value === 'number' ? `${value}px` : value;\n}\n\nconst CLOSE_BUTTON_SELECTOR = '[aria-label=\"Close navigation\"]';\n\nconst styles = {\n drawer: css({\n position: 'absolute',\n insetBlock: 0,\n display: 'flex',\n flexDirection: 'column',\n bg: 'bg',\n borderColor: 'border',\n overflow: 'hidden',\n transitionProperty: 'transform',\n transitionDuration: 'fast',\n transitionTimingFunction: 'default',\n '@media (prefers-reduced-motion: reduce)': {\n transitionDuration: '0.01s',\n },\n }),\n drawerStart: css({\n insetInlineStart: 0,\n borderInlineEndWidth: 'default',\n transform: 'translateX(-100%)',\n _rtl: {transform: 'translateX(100%)'},\n }),\n drawerEnd: css({\n insetInlineEnd: 0,\n borderInlineStartWidth: 'default',\n transform: 'translateX(100%)',\n _rtl: {transform: 'translateX(-100%)'},\n }),\n drawerOpen: css({\n transform: 'translateX(0)',\n }),\n header: css({\n h: '12',\n px: '2',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n borderBlockEndWidth: 'default',\n borderBlockEndStyle: 'solid',\n borderBlockEndColor: 'border',\n flexShrink: 0,\n }),\n body: css({\n flex: 1,\n overflowY: 'auto',\n overflowX: 'hidden',\n p: '2',\n }),\n};\n\nexport function MobileNav({\n children,\n className,\n 'data-testid': dataTestId,\n header,\n isOpen: isOpenFromProps,\n label,\n onOpenChange: onOpenChangeFromProps,\n ref,\n side = 'end',\n size = 320,\n style,\n}: MobileNavProps): React.JSX.Element {\n const appShellMobile = useAppShellMobile();\n const isOpen = isOpenFromProps ?? appShellMobile.isMobileNavOpen;\n const {openMobileNav, closeMobileNav} = appShellMobile;\n const onOpenChange = useCallback(\n (isNextOpen: boolean) => {\n if (onOpenChangeFromProps != null) {\n onOpenChangeFromProps(isNextOpen);\n } else if (isNextOpen) {\n openMobileNav();\n } else {\n closeMobileNav();\n }\n },\n [openMobileNav, closeMobileNav, onOpenChangeFromProps],\n );\n const dialogRef = useRef<HTMLDialogElement>(null);\n\n useEffect(() => {\n const dialog = dialogRef.current;\n\n if (dialog == null) {\n return;\n }\n\n if (isOpen && !dialog.open) {\n dialog.showModal();\n\n const firstFocusable = dialog.querySelector<HTMLElement>(\n `a[href], button:not(${CLOSE_BUTTON_SELECTOR}):not([disabled])`,\n );\n if (firstFocusable != null) {\n firstFocusable.focus();\n }\n } else if (!isOpen && dialog.open) {\n dialog.close();\n }\n }, [isOpen]);\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n\n const previousOverflow = document.body.style.overflow;\n document.body.style.overflow = 'hidden';\n return () => {\n document.body.style.overflow = previousOverflow;\n };\n }, [isOpen]);\n\n const formattedSize = formatSize(size);\n\n return (\n <dialog\n aria-label={label ?? (typeof header === 'string' ? header : 'Navigation')}\n className={cx(mobileNavRecipe({isOpen}), className)}\n data-testid={dataTestId}\n onCancel={event => {\n event.preventDefault();\n onOpenChange(false);\n }}\n onClick={event => {\n if (event.target === event.currentTarget) {\n onOpenChange(false);\n }\n }}\n ref={mergeRefs(ref, dialogRef)}\n style={style}>\n <div\n className={cx(\n styles.drawer,\n side === 'start' ? styles.drawerStart : styles.drawerEnd,\n isOpen && styles.drawerOpen,\n )}\n style={{maxWidth: formattedSize, width: '100vw'}}>\n <div className={styles.header}>\n {header ?? <span />}\n <Button\n icon={X}\n isIconOnly\n label=\"Close navigation\"\n onClick={() => onOpenChange(false)}\n variant=\"ghost\"\n />\n </div>\n <div className={styles.body}>{children}</div>\n </div>\n </dialog>\n );\n}\n\nMobileNav.displayName = 'MobileNav';\n","import {Menu} from 'lucide-react';\nimport type {CSSProperties, Ref} from 'react';\nimport {useAppShellMobile} from '../../components/AppShell/AppShellMobileContext';\nimport {Button} from '../../components/Button';\n\n/**\n * Props for {@link MobileNavToggle}.\n */\nexport interface MobileNavToggleProps {\n /**\n * Additional CSS class names applied to the toggle button.\n */\n className?: string;\n /**\n * Test ID applied to the toggle button.\n */\n 'data-testid'?: string;\n /**\n * Accessible label for the toggle button.\n * @default 'Open navigation'\n */\n label?: string;\n /**\n * Ref forwarded to the toggle button.\n */\n ref?: Ref<HTMLElement>;\n /**\n * Inline styles applied to the toggle button.\n */\n style?: CSSProperties;\n}\n\n/**\n * Hamburger-style button that toggles the mobile navigation drawer.\n * Renders nothing when the viewport is above the mobile breakpoint or\n * mobile navigation is disabled.\n */\nexport function MobileNavToggle({\n className,\n 'data-testid': dataTestId,\n label = 'Open navigation',\n ref,\n style,\n}: MobileNavToggleProps): React.JSX.Element | null {\n const {isMobile, isMobileNavEnabled, toggleMobileNav} = useAppShellMobile();\n\n if (!isMobile || !isMobileNavEnabled) {\n return null;\n }\n\n return (\n <Button\n className={className}\n data-testid={dataTestId}\n icon={Menu}\n isIconOnly\n label={label}\n onClick={toggleMobileNav}\n ref={ref}\n style={style}\n variant=\"ghost\"\n />\n );\n}\n\nMobileNavToggle.displayName = 'MobileNavToggle';\n"]}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
3
  var chunk6SHL7FYO_cjs = require('./chunk-6SHL7FYO.cjs');
4
- var chunkSPDVNY2Z_cjs = require('./chunk-SPDVNY2Z.cjs');
5
4
  var chunkRU6JG3FS_cjs = require('./chunk-RU6JG3FS.cjs');
5
+ var chunkSPDVNY2Z_cjs = require('./chunk-SPDVNY2Z.cjs');
6
6
  var react = require('react');
7
7
  var jsxRuntime = require('react/jsx-runtime');
8
8
 
@@ -199,5 +199,5 @@ function useDrawer(defaultOptions) {
199
199
 
200
200
  exports.Drawer = Drawer;
201
201
  exports.useDrawer = useDrawer;
202
- //# sourceMappingURL=chunk-YAIEA2YE.cjs.map
203
- //# sourceMappingURL=chunk-YAIEA2YE.cjs.map
202
+ //# sourceMappingURL=chunk-5PX76QOL.cjs.map
203
+ //# sourceMappingURL=chunk-5PX76QOL.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/Drawer/Drawer.tsx","../src/components/Drawer/useDrawer.tsx"],"names":["css","useRef","useEffect","jsx","cx","mergeRefs","useState","useCallback","useMemo"],"mappings":"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","file":"chunk-YAIEA2YE.cjs","sourcesContent":["import type {CSSProperties, ReactNode, Ref} from 'react';\nimport {useEffect, useRef} from 'react';\nimport {css} from 'styled-system/css';\nimport {cx} from '../../internal/cx';\nimport {mergeRefs} from '../../internal/mergeRefs';\n\nexport type DrawerPlacement = 'start' | 'end' | 'top' | 'bottom';\n\nexport interface DrawerProps {\n /**\n * Drawer body content.\n */\n children: ReactNode;\n /**\n * Additional CSS class names applied to the drawer.\n */\n className?: string;\n /**\n * Test ID applied to the drawer.\n */\n 'data-testid'?: string;\n /**\n * Whether the drawer is open.\n */\n isOpen: boolean;\n /**\n * Accessible label for the drawer.\n */\n label: string;\n /**\n * Called when the drawer requests an open-state change.\n */\n onOpenChange: (isOpen: boolean) => void;\n /**\n * Edge of the viewport the drawer slides in from.\n * @default 'end'\n */\n placement?: DrawerPlacement;\n /**\n * Ref forwarded to the drawer element.\n */\n ref?: Ref<HTMLElement>;\n /**\n * Width (start/end) or height (top/bottom) of the drawer.\n */\n size?: number | string;\n /**\n * Inline styles applied to the drawer.\n */\n style?: CSSProperties;\n}\n\nfunction formatSize(value: number | string): string {\n return typeof value === 'number' ? `${value}px` : value;\n}\n\nconst styles = {\n root: css({\n position: 'fixed',\n p: 0,\n borderWidth: 0,\n bg: 'bg',\n color: 'fg',\n boxShadow: 'xl',\n flexDirection: 'column',\n overscrollBehavior: 'contain',\n _backdrop: {\n bg: 'overlay.scrim',\n backdropFilter: 'blur(2px)',\n },\n _focusVisible: {\n outline: 'none',\n },\n }),\n open: css({\n display: 'flex',\n }),\n start: css({\n inset: 0,\n marginInlineEnd: 'auto',\n h: '100dvh',\n maxH: '100dvh',\n borderRadius: 0,\n borderInlineEndWidth: 'default',\n borderInlineEndStyle: 'solid',\n borderInlineEndColor: 'border',\n }),\n end: css({\n inset: 0,\n marginInlineStart: 'auto',\n h: '100dvh',\n maxH: '100dvh',\n borderRadius: 0,\n borderInlineStartWidth: 'default',\n borderInlineStartStyle: 'solid',\n borderInlineStartColor: 'border',\n }),\n top: css({\n inset: 0,\n mb: 'auto',\n w: '100dvw',\n maxW: '100dvw',\n borderRadius: 0,\n borderBlockEndWidth: 'default',\n borderBlockEndStyle: 'solid',\n borderBlockEndColor: 'border',\n }),\n bottom: css({\n inset: 0,\n mt: 'auto',\n w: '100dvw',\n maxW: '100dvw',\n borderRadius: 0,\n borderBlockStartWidth: 'default',\n borderBlockStartStyle: 'solid',\n borderBlockStartColor: 'border',\n }),\n inner: css({\n display: 'flex',\n flexDirection: 'column',\n flex: '1 1 auto',\n minH: 0,\n overflow: 'hidden',\n }),\n} as const;\n\nconst DEFAULT_SIZES: Record<DrawerPlacement, number | string> = {\n start: 320,\n end: 320,\n top: '40vh',\n bottom: '40vh',\n};\n\nfunction getSizeStyle(\n placement: DrawerPlacement,\n size: number | string,\n): CSSProperties {\n const formatted = formatSize(size);\n if (placement === 'start' || placement === 'end') {\n return {width: formatted, maxWidth: '100dvw'};\n }\n return {height: formatted, maxHeight: '100dvh'};\n}\n\n/**\n * A slide-in panel anchored to an edge of the viewport.\n */\nexport function Drawer({\n isOpen,\n label,\n onOpenChange,\n placement = 'end',\n size,\n children,\n className,\n 'data-testid': dataTestId,\n style,\n ref,\n}: DrawerProps): React.JSX.Element {\n const dialogRef = useRef<HTMLDialogElement>(null);\n const triggerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n const dialog = dialogRef.current;\n if (dialog == null) {\n return;\n }\n\n if (isOpen) {\n triggerRef.current = document.activeElement as HTMLElement | null;\n if (!dialog.open) {\n dialog.showModal();\n }\n dialog\n .querySelector<HTMLElement>('[data-autofocus=\"true\"], [autofocus]')\n ?.focus();\n } else if (dialog.open) {\n dialog.close();\n triggerRef.current?.focus();\n triggerRef.current = null;\n }\n }, [isOpen]);\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n const previousOverflow = document.body.style.overflow;\n document.body.style.overflow = 'hidden';\n return () => {\n document.body.style.overflow = previousOverflow;\n };\n }, [isOpen]);\n\n const effectiveSize = size ?? DEFAULT_SIZES[placement];\n const sizeStyle = getSizeStyle(placement, effectiveSize);\n\n return (\n // eslint-disable-next-line jsx-a11y-x/click-events-have-key-events, jsx-a11y-x/no-noninteractive-element-interactions -- native dialog backdrop clicks close the drawer\n <dialog\n aria-label={label}\n aria-modal=\"true\"\n className={cx(\n styles.root,\n isOpen ? styles.open : undefined,\n styles[placement],\n className,\n )}\n data-testid={dataTestId}\n onCancel={event => {\n event.preventDefault();\n onOpenChange(false);\n }}\n onClick={event => {\n if (event.target === event.currentTarget) {\n onOpenChange(false);\n }\n }}\n ref={mergeRefs(ref as Ref<HTMLDialogElement>, dialogRef)}\n style={{...sizeStyle, ...style}}>\n <div className={styles.inner}>{children}</div>\n </dialog>\n );\n}\n\nDrawer.displayName = 'Drawer';\n","import {useCallback, useMemo, useState, type ReactNode} from 'react';\nimport {Drawer, type DrawerProps} from './Drawer';\n\nexport type DrawerOptions = Partial<\n Omit<DrawerProps, 'children' | 'isOpen' | 'onOpenChange'>\n>;\n\nexport interface UseDrawerReturn {\n element: ReactNode;\n hide: () => void;\n isOpen: boolean;\n show: (content: ReactNode, options?: DrawerOptions) => void;\n}\n\nexport function useDrawer(defaultOptions?: DrawerOptions): UseDrawerReturn {\n const [isOpen, setIsOpen] = useState(false);\n const [content, setContent] = useState<ReactNode>(null);\n const [options, setOptions] = useState<DrawerOptions | undefined>(\n defaultOptions,\n );\n\n const show = useCallback(\n (nextContent: ReactNode, nextOptions?: DrawerOptions) => {\n setContent(nextContent);\n setOptions(previous => ({...previous, ...nextOptions}));\n setIsOpen(true);\n },\n [],\n );\n\n const hide = useCallback(() => setIsOpen(false), []);\n\n const element = useMemo(\n () => (\n <Drawer\n {...(defaultOptions ?? {})}\n {...(options ?? {})}\n isOpen={isOpen}\n label={options?.label ?? defaultOptions?.label ?? 'Drawer'}\n onOpenChange={setIsOpen}>\n {content}\n </Drawer>\n ),\n [content, defaultOptions, isOpen, options],\n );\n\n return {element, hide, isOpen, show};\n}\n"]}
1
+ {"version":3,"sources":["../src/components/Drawer/Drawer.tsx","../src/components/Drawer/useDrawer.tsx"],"names":["css","useRef","useEffect","jsx","cx","mergeRefs","useState","useCallback","useMemo"],"mappings":";;;;;;;;AAoDA,SAAS,WAAW,KAAA,EAAgC;AAClD,EAAA,OAAO,OAAO,KAAA,KAAU,QAAA,GAAW,CAAA,EAAG,KAAK,CAAA,EAAA,CAAA,GAAO,KAAA;AACpD;AAEA,IAAM,MAAA,GAAS;AAAA,EACb,MAAMA,qBAAA,CAAI;AAAA,IACR,QAAA,EAAU,OAAA;AAAA,IACV,CAAA,EAAG,CAAA;AAAA,IACH,WAAA,EAAa,CAAA;AAAA,IACb,EAAA,EAAI,IAAA;AAAA,IACJ,KAAA,EAAO,IAAA;AAAA,IACP,SAAA,EAAW,IAAA;AAAA,IACX,aAAA,EAAe,QAAA;AAAA,IACf,kBAAA,EAAoB,SAAA;AAAA,IACpB,SAAA,EAAW;AAAA,MACT,EAAA,EAAI,eAAA;AAAA,MACJ,cAAA,EAAgB;AAAA,KAClB;AAAA,IACA,aAAA,EAAe;AAAA,MACb,OAAA,EAAS;AAAA;AACX,GACD,CAAA;AAAA,EACD,MAAMA,qBAAA,CAAI;AAAA,IACR,OAAA,EAAS;AAAA,GACV,CAAA;AAAA,EACD,OAAOA,qBAAA,CAAI;AAAA,IACT,KAAA,EAAO,CAAA;AAAA,IACP,eAAA,EAAiB,MAAA;AAAA,IACjB,CAAA,EAAG,QAAA;AAAA,IACH,IAAA,EAAM,QAAA;AAAA,IACN,YAAA,EAAc,CAAA;AAAA,IACd,oBAAA,EAAsB,SAAA;AAAA,IACtB,oBAAA,EAAsB,OAAA;AAAA,IACtB,oBAAA,EAAsB;AAAA,GACvB,CAAA;AAAA,EACD,KAAKA,qBAAA,CAAI;AAAA,IACP,KAAA,EAAO,CAAA;AAAA,IACP,iBAAA,EAAmB,MAAA;AAAA,IACnB,CAAA,EAAG,QAAA;AAAA,IACH,IAAA,EAAM,QAAA;AAAA,IACN,YAAA,EAAc,CAAA;AAAA,IACd,sBAAA,EAAwB,SAAA;AAAA,IACxB,sBAAA,EAAwB,OAAA;AAAA,IACxB,sBAAA,EAAwB;AAAA,GACzB,CAAA;AAAA,EACD,KAAKA,qBAAA,CAAI;AAAA,IACP,KAAA,EAAO,CAAA;AAAA,IACP,EAAA,EAAI,MAAA;AAAA,IACJ,CAAA,EAAG,QAAA;AAAA,IACH,IAAA,EAAM,QAAA;AAAA,IACN,YAAA,EAAc,CAAA;AAAA,IACd,mBAAA,EAAqB,SAAA;AAAA,IACrB,mBAAA,EAAqB,OAAA;AAAA,IACrB,mBAAA,EAAqB;AAAA,GACtB,CAAA;AAAA,EACD,QAAQA,qBAAA,CAAI;AAAA,IACV,KAAA,EAAO,CAAA;AAAA,IACP,EAAA,EAAI,MAAA;AAAA,IACJ,CAAA,EAAG,QAAA;AAAA,IACH,IAAA,EAAM,QAAA;AAAA,IACN,YAAA,EAAc,CAAA;AAAA,IACd,qBAAA,EAAuB,SAAA;AAAA,IACvB,qBAAA,EAAuB,OAAA;AAAA,IACvB,qBAAA,EAAuB;AAAA,GACxB,CAAA;AAAA,EACD,OAAOA,qBAAA,CAAI;AAAA,IACT,OAAA,EAAS,MAAA;AAAA,IACT,aAAA,EAAe,QAAA;AAAA,IACf,IAAA,EAAM,UAAA;AAAA,IACN,IAAA,EAAM,CAAA;AAAA,IACN,QAAA,EAAU;AAAA,GACX;AACH,CAAA;AAEA,IAAM,aAAA,GAA0D;AAAA,EAC9D,KAAA,EAAO,GAAA;AAAA,EACP,GAAA,EAAK,GAAA;AAAA,EACL,GAAA,EAAK,MAAA;AAAA,EACL,MAAA,EAAQ;AACV,CAAA;AAEA,SAAS,YAAA,CACP,WACA,IAAA,EACe;AACf,EAAA,MAAM,SAAA,GAAY,WAAW,IAAI,CAAA;AACjC,EAAA,IAAI,SAAA,KAAc,OAAA,IAAW,SAAA,KAAc,KAAA,EAAO;AAChD,IAAA,OAAO,EAAC,KAAA,EAAO,SAAA,EAAW,QAAA,EAAU,QAAA,EAAQ;AAAA,EAC9C;AACA,EAAA,OAAO,EAAC,MAAA,EAAQ,SAAA,EAAW,SAAA,EAAW,QAAA,EAAQ;AAChD;AAKO,SAAS,MAAA,CAAO;AAAA,EACrB,MAAA;AAAA,EACA,KAAA;AAAA,EACA,YAAA;AAAA,EACA,SAAA,GAAY,KAAA;AAAA,EACZ,IAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,aAAA,EAAe,UAAA;AAAA,EACf,KAAA;AAAA,EACA;AACF,CAAA,EAAmC;AACjC,EAAA,MAAM,SAAA,GAAYC,aAA0B,IAAI,CAAA;AAChD,EAAA,MAAM,UAAA,GAAaA,aAA2B,IAAI,CAAA;AAElD,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,MAAM,SAAS,SAAA,CAAU,OAAA;AACzB,IAAA,IAAI,UAAU,IAAA,EAAM;AAClB,MAAA;AAAA,IACF;AAEA,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,UAAA,CAAW,UAAU,QAAA,CAAS,aAAA;AAC9B,MAAA,IAAI,CAAC,OAAO,IAAA,EAAM;AAChB,QAAA,MAAA,CAAO,SAAA,EAAU;AAAA,MACnB;AACA,MAAA,MAAA,CACG,aAAA,CAA2B,sCAAsC,CAAA,EAChE,KAAA,EAAM;AAAA,IACZ,CAAA,MAAA,IAAW,OAAO,IAAA,EAAM;AACtB,MAAA,MAAA,CAAO,KAAA,EAAM;AACb,MAAA,UAAA,CAAW,SAAS,KAAA,EAAM;AAC1B,MAAA,UAAA,CAAW,OAAA,GAAU,IAAA;AAAA,IACvB;AAAA,EACF,CAAA,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,EAAAA,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA;AAAA,IACF;AACA,IAAA,MAAM,gBAAA,GAAmB,QAAA,CAAS,IAAA,CAAK,KAAA,CAAM,QAAA;AAC7C,IAAA,QAAA,CAAS,IAAA,CAAK,MAAM,QAAA,GAAW,QAAA;AAC/B,IAAA,OAAO,MAAM;AACX,MAAA,QAAA,CAAS,IAAA,CAAK,MAAM,QAAA,GAAW,gBAAA;AAAA,IACjC,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,MAAM,CAAC,CAAA;AAEX,EAAA,MAAM,aAAA,GAAgB,IAAA,IAAQ,aAAA,CAAc,SAAS,CAAA;AACrD,EAAA,MAAM,SAAA,GAAY,YAAA,CAAa,SAAA,EAAW,aAAa,CAAA;AAEvD,EAAA;AAAA;AAAA,oBAEEC,cAAA;AAAA,MAAC,QAAA;AAAA,MAAA;AAAA,QACC,YAAA,EAAY,KAAA;AAAA,QACZ,YAAA,EAAW,MAAA;AAAA,QACX,SAAA,EAAWC,oBAAA;AAAA,UACT,MAAA,CAAO,IAAA;AAAA,UACP,MAAA,GAAS,OAAO,IAAA,GAAO,MAAA;AAAA,UACvB,OAAO,SAAS,CAAA;AAAA,UAChB;AAAA,SACF;AAAA,QACA,aAAA,EAAa,UAAA;AAAA,QACb,UAAU,CAAA,KAAA,KAAS;AACjB,UAAA,KAAA,CAAM,cAAA,EAAe;AACrB,UAAA,YAAA,CAAa,KAAK,CAAA;AAAA,QACpB,CAAA;AAAA,QACA,SAAS,CAAA,KAAA,KAAS;AAChB,UAAA,IAAI,KAAA,CAAM,MAAA,KAAW,KAAA,CAAM,aAAA,EAAe;AACxC,YAAA,YAAA,CAAa,KAAK,CAAA;AAAA,UACpB;AAAA,QACF,CAAA;AAAA,QACA,GAAA,EAAKC,2BAAA,CAAU,GAAA,EAA+B,SAAS,CAAA;AAAA,QACvD,KAAA,EAAO,EAAC,GAAG,SAAA,EAAW,GAAG,KAAA,EAAK;AAAA,QAC9B,QAAA,kBAAAF,cAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAW,MAAA,CAAO,OAAQ,QAAA,EAAS;AAAA;AAAA;AAC1C;AAEJ;AAEA,MAAA,CAAO,WAAA,GAAc,QAAA;ACnNd,SAAS,UAAU,cAAA,EAAiD;AACzE,EAAA,MAAM,CAAC,MAAA,EAAQ,SAAS,CAAA,GAAIG,eAAS,KAAK,CAAA;AAC1C,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAIA,eAAoB,IAAI,CAAA;AACtD,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAIA,cAAA;AAAA,IAC5B;AAAA,GACF;AAEA,EAAA,MAAM,IAAA,GAAOC,iBAAA;AAAA,IACX,CAAC,aAAwB,WAAA,KAAgC;AACvD,MAAA,UAAA,CAAW,WAAW,CAAA;AACtB,MAAA,UAAA,CAAW,eAAa,EAAC,GAAG,QAAA,EAAU,GAAG,aAAW,CAAE,CAAA;AACtD,MAAA,SAAA,CAAU,IAAI,CAAA;AAAA,IAChB,CAAA;AAAA,IACA;AAAC,GACH;AAEA,EAAA,MAAM,OAAOA,iBAAA,CAAY,MAAM,UAAU,KAAK,CAAA,EAAG,EAAE,CAAA;AAEnD,EAAA,MAAM,OAAA,GAAUC,aAAA;AAAA,IACd,sBACEL,cAAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACE,GAAI,kBAAkB,EAAC;AAAA,QACvB,GAAI,WAAW,EAAC;AAAA,QACjB,MAAA;AAAA,QACA,KAAA,EAAO,OAAA,EAAS,KAAA,IAAS,cAAA,EAAgB,KAAA,IAAS,QAAA;AAAA,QAClD,YAAA,EAAc,SAAA;AAAA,QACb,QAAA,EAAA;AAAA;AAAA,KACH;AAAA,IAEF,CAAC,OAAA,EAAS,cAAA,EAAgB,MAAA,EAAQ,OAAO;AAAA,GAC3C;AAEA,EAAA,OAAO,EAAC,OAAA,EAAS,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAI;AACrC","file":"chunk-5PX76QOL.cjs","sourcesContent":["import type {CSSProperties, ReactNode, Ref} from 'react';\nimport {useEffect, useRef} from 'react';\nimport {css} from 'styled-system/css';\nimport {cx} from '../../internal/cx';\nimport {mergeRefs} from '../../internal/mergeRefs';\n\nexport type DrawerPlacement = 'start' | 'end' | 'top' | 'bottom';\n\nexport interface DrawerProps {\n /**\n * Drawer body content.\n */\n children: ReactNode;\n /**\n * Additional CSS class names applied to the drawer.\n */\n className?: string;\n /**\n * Test ID applied to the drawer.\n */\n 'data-testid'?: string;\n /**\n * Whether the drawer is open.\n */\n isOpen: boolean;\n /**\n * Accessible label for the drawer.\n */\n label: string;\n /**\n * Called when the drawer requests an open-state change.\n */\n onOpenChange: (isOpen: boolean) => void;\n /**\n * Edge of the viewport the drawer slides in from.\n * @default 'end'\n */\n placement?: DrawerPlacement;\n /**\n * Ref forwarded to the drawer element.\n */\n ref?: Ref<HTMLElement>;\n /**\n * Width (start/end) or height (top/bottom) of the drawer.\n */\n size?: number | string;\n /**\n * Inline styles applied to the drawer.\n */\n style?: CSSProperties;\n}\n\nfunction formatSize(value: number | string): string {\n return typeof value === 'number' ? `${value}px` : value;\n}\n\nconst styles = {\n root: css({\n position: 'fixed',\n p: 0,\n borderWidth: 0,\n bg: 'bg',\n color: 'fg',\n boxShadow: 'xl',\n flexDirection: 'column',\n overscrollBehavior: 'contain',\n _backdrop: {\n bg: 'overlay.scrim',\n backdropFilter: 'blur(2px)',\n },\n _focusVisible: {\n outline: 'none',\n },\n }),\n open: css({\n display: 'flex',\n }),\n start: css({\n inset: 0,\n marginInlineEnd: 'auto',\n h: '100dvh',\n maxH: '100dvh',\n borderRadius: 0,\n borderInlineEndWidth: 'default',\n borderInlineEndStyle: 'solid',\n borderInlineEndColor: 'border',\n }),\n end: css({\n inset: 0,\n marginInlineStart: 'auto',\n h: '100dvh',\n maxH: '100dvh',\n borderRadius: 0,\n borderInlineStartWidth: 'default',\n borderInlineStartStyle: 'solid',\n borderInlineStartColor: 'border',\n }),\n top: css({\n inset: 0,\n mb: 'auto',\n w: '100dvw',\n maxW: '100dvw',\n borderRadius: 0,\n borderBlockEndWidth: 'default',\n borderBlockEndStyle: 'solid',\n borderBlockEndColor: 'border',\n }),\n bottom: css({\n inset: 0,\n mt: 'auto',\n w: '100dvw',\n maxW: '100dvw',\n borderRadius: 0,\n borderBlockStartWidth: 'default',\n borderBlockStartStyle: 'solid',\n borderBlockStartColor: 'border',\n }),\n inner: css({\n display: 'flex',\n flexDirection: 'column',\n flex: '1 1 auto',\n minH: 0,\n overflow: 'hidden',\n }),\n} as const;\n\nconst DEFAULT_SIZES: Record<DrawerPlacement, number | string> = {\n start: 320,\n end: 320,\n top: '40vh',\n bottom: '40vh',\n};\n\nfunction getSizeStyle(\n placement: DrawerPlacement,\n size: number | string,\n): CSSProperties {\n const formatted = formatSize(size);\n if (placement === 'start' || placement === 'end') {\n return {width: formatted, maxWidth: '100dvw'};\n }\n return {height: formatted, maxHeight: '100dvh'};\n}\n\n/**\n * A slide-in panel anchored to an edge of the viewport.\n */\nexport function Drawer({\n isOpen,\n label,\n onOpenChange,\n placement = 'end',\n size,\n children,\n className,\n 'data-testid': dataTestId,\n style,\n ref,\n}: DrawerProps): React.JSX.Element {\n const dialogRef = useRef<HTMLDialogElement>(null);\n const triggerRef = useRef<HTMLElement | null>(null);\n\n useEffect(() => {\n const dialog = dialogRef.current;\n if (dialog == null) {\n return;\n }\n\n if (isOpen) {\n triggerRef.current = document.activeElement as HTMLElement | null;\n if (!dialog.open) {\n dialog.showModal();\n }\n dialog\n .querySelector<HTMLElement>('[data-autofocus=\"true\"], [autofocus]')\n ?.focus();\n } else if (dialog.open) {\n dialog.close();\n triggerRef.current?.focus();\n triggerRef.current = null;\n }\n }, [isOpen]);\n\n useEffect(() => {\n if (!isOpen) {\n return;\n }\n const previousOverflow = document.body.style.overflow;\n document.body.style.overflow = 'hidden';\n return () => {\n document.body.style.overflow = previousOverflow;\n };\n }, [isOpen]);\n\n const effectiveSize = size ?? DEFAULT_SIZES[placement];\n const sizeStyle = getSizeStyle(placement, effectiveSize);\n\n return (\n // eslint-disable-next-line jsx-a11y-x/click-events-have-key-events, jsx-a11y-x/no-noninteractive-element-interactions -- native dialog backdrop clicks close the drawer\n <dialog\n aria-label={label}\n aria-modal=\"true\"\n className={cx(\n styles.root,\n isOpen ? styles.open : undefined,\n styles[placement],\n className,\n )}\n data-testid={dataTestId}\n onCancel={event => {\n event.preventDefault();\n onOpenChange(false);\n }}\n onClick={event => {\n if (event.target === event.currentTarget) {\n onOpenChange(false);\n }\n }}\n ref={mergeRefs(ref as Ref<HTMLDialogElement>, dialogRef)}\n style={{...sizeStyle, ...style}}>\n <div className={styles.inner}>{children}</div>\n </dialog>\n );\n}\n\nDrawer.displayName = 'Drawer';\n","import {useCallback, useMemo, useState, type ReactNode} from 'react';\nimport {Drawer, type DrawerProps} from './Drawer';\n\nexport type DrawerOptions = Partial<\n Omit<DrawerProps, 'children' | 'isOpen' | 'onOpenChange'>\n>;\n\nexport interface UseDrawerReturn {\n element: ReactNode;\n hide: () => void;\n isOpen: boolean;\n show: (content: ReactNode, options?: DrawerOptions) => void;\n}\n\nexport function useDrawer(defaultOptions?: DrawerOptions): UseDrawerReturn {\n const [isOpen, setIsOpen] = useState(false);\n const [content, setContent] = useState<ReactNode>(null);\n const [options, setOptions] = useState<DrawerOptions | undefined>(\n defaultOptions,\n );\n\n const show = useCallback(\n (nextContent: ReactNode, nextOptions?: DrawerOptions) => {\n setContent(nextContent);\n setOptions(previous => ({...previous, ...nextOptions}));\n setIsOpen(true);\n },\n [],\n );\n\n const hide = useCallback(() => setIsOpen(false), []);\n\n const element = useMemo(\n () => (\n <Drawer\n {...(defaultOptions ?? {})}\n {...(options ?? {})}\n isOpen={isOpen}\n label={options?.label ?? defaultOptions?.label ?? 'Drawer'}\n onOpenChange={setIsOpen}>\n {content}\n </Drawer>\n ),\n [content, defaultOptions, isOpen, options],\n );\n\n return {element, hide, isOpen, show};\n}\n"]}
@@ -1,8 +1,8 @@
1
1
  'use strict';
2
2
 
3
- var chunkU2WVHZ24_cjs = require('./chunk-U2WVHZ24.cjs');
4
- var chunk6BK4LUK4_cjs = require('./chunk-6BK4LUK4.cjs');
3
+ var chunkJJ324PSZ_cjs = require('./chunk-JJ324PSZ.cjs');
5
4
  var chunkRU6JG3FS_cjs = require('./chunk-RU6JG3FS.cjs');
5
+ var chunkSPDVNY2Z_cjs = require('./chunk-SPDVNY2Z.cjs');
6
6
  var react = require('react');
7
7
  var jsxRuntime = require('react/jsx-runtime');
8
8
 
@@ -37,7 +37,7 @@ function useHoverCard({
37
37
  } = {}) {
38
38
  const isHoveringContentRef = react.useRef(false);
39
39
  const isEscapeDismissingRef = react.useRef(false);
40
- const hoverLayer = chunkU2WVHZ24_cjs.useHoverLayer({
40
+ const hoverLayer = chunkJJ324PSZ_cjs.useHoverLayer({
41
41
  delay,
42
42
  focusTrigger,
43
43
  hideDelay,
@@ -107,7 +107,7 @@ function useHoverCard({
107
107
  {
108
108
  placement: renderPlacement,
109
109
  alignment: props?.alignment ?? alignment,
110
- className: chunk6BK4LUK4_cjs.cx(
110
+ className: chunkSPDVNY2Z_cjs.cx(
111
111
  styles.container,
112
112
  styles.margin[renderPlacement],
113
113
  props?.className
@@ -175,7 +175,7 @@ function HoverCard({
175
175
  placement
176
176
  });
177
177
  return /* @__PURE__ */ jsxRuntime.jsx(
178
- chunkU2WVHZ24_cjs.HoverLayerTrigger,
178
+ chunkJJ324PSZ_cjs.HoverLayerTrigger,
179
179
  {
180
180
  className,
181
181
  "data-testid": dataTestId,
@@ -194,5 +194,5 @@ HoverCard.displayName = "HoverCard";
194
194
 
195
195
  exports.HoverCard = HoverCard;
196
196
  exports.useHoverCard = useHoverCard;
197
- //# sourceMappingURL=chunk-HM7IEGQ2.cjs.map
198
- //# sourceMappingURL=chunk-HM7IEGQ2.cjs.map
197
+ //# sourceMappingURL=chunk-5YS43PSQ.cjs.map
198
+ //# sourceMappingURL=chunk-5YS43PSQ.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/HoverCard/useHoverCard.tsx","../src/components/HoverCard/HoverCard.tsx"],"names":["css","useRef","useHoverLayer","useCallback","jsx","cx","useMemo","HoverLayerTrigger"],"mappings":"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","file":"chunk-5YS43PSQ.cjs","sourcesContent":["import {\n useCallback,\n useMemo,\n useRef,\n type FocusEvent as ReactFocusEvent,\n type ReactNode,\n type RefCallback,\n} from 'react';\nimport {css} from 'styled-system/css';\nimport {cx} from '../../internal/cx';\nimport {\n useHoverLayer,\n type HoverLayerFocusTrigger,\n} from '../../internal/useHoverLayer';\nimport type {\n ContextRenderProps,\n LayerAlignment,\n LayerPlacement,\n} from '../../internal/useLayer';\n\nexport type HoverCardFocusTrigger = HoverLayerFocusTrigger;\n\nexport interface UseHoverCardOptions {\n alignment?: LayerAlignment;\n delay?: number;\n focusTrigger?: HoverCardFocusTrigger;\n hideDelay?: number;\n isEnabled?: boolean;\n onHide?: () => void;\n onShow?: () => void;\n placement?: LayerPlacement;\n}\n\nexport interface UseHoverCardReturn {\n anchorId: string;\n describedBy: string;\n hide: () => void;\n interactionRef: RefCallback<HTMLElement>;\n positionRef: RefCallback<HTMLElement>;\n ref: RefCallback<HTMLElement>;\n renderHoverCard: (\n children: ReactNode,\n props?: ContextRenderProps,\n ) => ReactNode;\n show: () => void;\n}\n\nconst styles = {\n container: css({\n bg: 'bg',\n borderRadius: 'md',\n boxShadow: 'lg',\n borderWidth: 'default',\n borderStyle: 'solid',\n borderColor: 'border',\n }),\n content: css({\n p: '3',\n }),\n margin: {\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\nexport function useHoverCard({\n placement = 'above',\n alignment = 'center',\n delay = 300,\n hideDelay = 200,\n focusTrigger = 'auto',\n isEnabled = true,\n onShow,\n onHide,\n}: UseHoverCardOptions = {}): UseHoverCardReturn {\n const isHoveringContentRef = useRef(false);\n const isEscapeDismissingRef = useRef(false);\n\n const hoverLayer = useHoverLayer({\n delay,\n focusTrigger,\n hideDelay,\n isEnabled,\n onFocusIn: () => {\n if (isEscapeDismissingRef.current) {\n isEscapeDismissingRef.current = false;\n return false;\n }\n\n return true;\n },\n onFocusOut: event => {\n const relatedTarget = event.relatedTarget as HTMLElement | null;\n const popoverElement = document.getElementById(hoverLayer.describedBy);\n\n return !popoverElement?.contains(relatedTarget);\n },\n onHide,\n onShow,\n onTriggerEscape: event => {\n event.stopPropagation();\n hoverLayer.clearTimeouts();\n hoverLayer.hide();\n },\n shouldHide: () => !isHoveringContentRef.current,\n });\n\n const {clearTimeouts, interactionRef, layer, ref, scheduleHide, triggerRef} =\n hoverLayer;\n\n const handleContentBlur = useCallback(\n (event: ReactFocusEvent<HTMLElement>) => {\n const relatedTarget = event.relatedTarget as HTMLElement | null;\n if (\n event.currentTarget.contains(relatedTarget) ||\n triggerRef.current?.contains(relatedTarget)\n ) {\n return;\n }\n\n scheduleHide();\n },\n [scheduleHide, triggerRef],\n );\n\n const renderHoverCard = useCallback(\n (children: ReactNode, props?: ContextRenderProps): ReactNode => {\n const renderPlacement = props?.placement ?? placement;\n\n return layer.render(\n // eslint-disable-next-line jsx-a11y-x/no-static-element-interactions\n <div\n className={styles.content}\n onBlur={handleContentBlur}\n onKeyDown={event => {\n if (event.key === 'Escape') {\n event.stopPropagation();\n isEscapeDismissingRef.current = true;\n clearTimeouts();\n hoverLayer.hide();\n triggerRef.current?.focus();\n }\n }}\n onMouseEnter={() => {\n isHoveringContentRef.current = true;\n clearTimeouts();\n }}\n onMouseLeave={() => {\n isHoveringContentRef.current = false;\n scheduleHide();\n }}>\n {children}\n </div>,\n {\n placement: renderPlacement,\n alignment: props?.alignment ?? alignment,\n className: cx(\n styles.container,\n styles.margin[renderPlacement],\n props?.className,\n ),\n role: props?.role,\n style: props?.style,\n },\n );\n },\n [\n alignment,\n clearTimeouts,\n handleContentBlur,\n hoverLayer,\n layer,\n placement,\n scheduleHide,\n triggerRef,\n ],\n );\n\n return useMemo(\n () => ({\n anchorId: layer.anchorId,\n describedBy: layer.id,\n hide: hoverLayer.hide,\n interactionRef,\n positionRef: layer.ref,\n ref,\n renderHoverCard,\n show: hoverLayer.show,\n }),\n [\n hoverLayer.hide,\n hoverLayer.show,\n interactionRef,\n layer.anchorId,\n layer.id,\n layer.ref,\n ref,\n renderHoverCard,\n ],\n );\n}\n","import type {CSSProperties, ReactNode, Ref} from 'react';\nimport {HoverLayerTrigger} from '../../internal/HoverLayerTrigger';\nimport type {LayerAlignment, LayerPlacement} from '../../internal/useLayer';\nimport {useHoverCard, type HoverCardFocusTrigger} from './useHoverCard';\n\nexport type {HoverCardFocusTrigger} from './useHoverCard';\n\nexport interface HoverCardProps {\n /**\n * Alignment along the placement axis.\n * @default 'center'\n */\n alignment?: LayerAlignment;\n /**\n * Trigger content.\n */\n children: ReactNode;\n /**\n * Additional class names applied to the trigger wrapper for text triggers.\n */\n className?: string;\n /**\n * Content shown in the floating hover card.\n */\n content: ReactNode;\n /**\n * Test ID applied to the trigger wrapper for text triggers.\n */\n 'data-testid'?: string;\n /**\n * Delay before opening on hover, in milliseconds.\n * @default 300\n */\n delay?: number;\n /**\n * Controls focus-trigger behavior.\n * @default 'auto'\n */\n focusTrigger?: HoverCardFocusTrigger;\n /**\n * Whether to visually underline text triggers.\n * @default 'auto'\n */\n hasHoverIndication?: 'auto' | boolean;\n /**\n * Delay before closing after hover/focus leaves, in milliseconds.\n * @default 200\n */\n hideDelay?: number;\n /**\n * Whether hover/focus interactions are enabled.\n * @default true\n */\n isEnabled?: boolean;\n /**\n * Position relative to the trigger.\n * @default 'above'\n */\n placement?: LayerPlacement;\n /**\n * Ref forwarded to the text trigger wrapper.\n */\n ref?: Ref<HTMLSpanElement>;\n /**\n * Inline styles applied to the text trigger wrapper.\n */\n style?: CSSProperties;\n}\n\n/**\n * A floating card that appears on hover or focus of a trigger element.\n */\nexport function HoverCard({\n children,\n content,\n placement = 'above',\n alignment = 'center',\n delay = 300,\n hideDelay = 200,\n focusTrigger = 'auto',\n isEnabled = true,\n hasHoverIndication = 'auto',\n className,\n style,\n ref,\n 'data-testid': dataTestId,\n}: HoverCardProps): React.JSX.Element {\n const hoverCard = useHoverCard({\n alignment,\n delay,\n focusTrigger,\n hideDelay,\n isEnabled,\n placement,\n });\n\n return (\n <HoverLayerTrigger\n className={className}\n data-testid={dataTestId}\n describedBy={hoverCard.describedBy}\n hasHoverIndication={hasHoverIndication}\n layer={hoverCard.renderHoverCard(content)}\n shouldForwardNonTextWrapperProps={false}\n style={style}\n triggerRef={hoverCard.ref}\n wrapperRef={ref}>\n {children}\n </HoverLayerTrigger>\n );\n}\n\nHoverCard.displayName = 'HoverCard';\n"]}