react-grab 0.1.33 → 0.1.34

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 (450) hide show
  1. package/README.md +22 -22
  2. package/dist/copy-content-BVdIJS-d.d.cts +218 -0
  3. package/dist/copy-content-CZBjwiz6.d.ts +218 -0
  4. package/dist/core/index.cjs +1 -1
  5. package/dist/core/index.d.cts +2 -2
  6. package/dist/core/index.d.ts +2 -2
  7. package/dist/core/index.js +1 -1
  8. package/dist/core--Ufj16_R.js +22 -0
  9. package/dist/core--g1aIj2P.cjs +16 -0
  10. package/dist/core-58frx10s.js +21 -0
  11. package/dist/core-6WHLinaP.cjs +22 -0
  12. package/dist/core-8hT_aem6.cjs +16 -0
  13. package/dist/core-B04T5GVi.js +23 -0
  14. package/dist/core-B0VVBCnw.cjs +16 -0
  15. package/dist/core-B2Fb14V5.cjs +21 -0
  16. package/dist/core-B2KP8L5M.js +22 -0
  17. package/dist/core-B2doJOtN.cjs +16 -0
  18. package/dist/core-B3ei2CmJ.cjs +16 -0
  19. package/dist/core-B4UZXEzF.cjs +16 -0
  20. package/dist/core-B4fokp5c.js +23 -0
  21. package/dist/core-B4mcQjIW.cjs +16 -0
  22. package/dist/core-B4op93Jm.js +16 -0
  23. package/dist/core-B61jKle0.js +22 -0
  24. package/dist/core-B7-ZXWFD.js +21 -0
  25. package/dist/core-B8-HrDOV.js +23 -0
  26. package/dist/core-B8Qoj_Uu.js +16 -0
  27. package/dist/core-BAybPvu0.js +16 -0
  28. package/dist/core-BCoxaMuv.js +22 -0
  29. package/dist/core-BFUbt-Lr.cjs +16 -0
  30. package/dist/core-BFs0o0ry.cjs +16 -0
  31. package/dist/core-BFtyedBy.cjs +21 -0
  32. package/dist/core-BK3dbxMw.cjs +16 -0
  33. package/dist/core-BS6dlci7.js +16 -0
  34. package/dist/core-BSJSAr9t.cjs +23 -0
  35. package/dist/core-BShyP6v6.cjs +23 -0
  36. package/dist/core-BVCK03rH.cjs +16 -0
  37. package/dist/core-BZ-oKEob.cjs +16 -0
  38. package/dist/core-B_AsSPHz.js +23 -0
  39. package/dist/core-Bfp2AINN.cjs +23 -0
  40. package/dist/core-BhZjFvho.js +16 -0
  41. package/dist/core-BhfWpuzf.cjs +16 -0
  42. package/dist/core-BiXQdZjv.cjs +21 -0
  43. package/dist/core-BkCAY-6t.cjs +23 -0
  44. package/dist/core-BkHiZtUw.cjs +16 -0
  45. package/dist/core-BlCRSmTs.cjs +22 -0
  46. package/dist/core-BmWjaBiL.js +16 -0
  47. package/dist/core-BmlPgqbf.js +21 -0
  48. package/dist/core-Bmsc35N2.js +16 -0
  49. package/dist/core-BqGFVds-.cjs +16 -0
  50. package/dist/core-BqlaX0mO.js +16 -0
  51. package/dist/core-Br3-SZtp.cjs +16 -0
  52. package/dist/core-BrTobpFq.js +16 -0
  53. package/dist/core-BrWkCelW.cjs +16 -0
  54. package/dist/core-BtBnSqSp.js +16 -0
  55. package/dist/core-By8r6FNh.js +16 -0
  56. package/dist/core-C-ix7khG.js +22 -0
  57. package/dist/core-C3t1u5we.cjs +16 -0
  58. package/dist/core-C8EAzl4C.cjs +22 -0
  59. package/dist/core-C8gbQjmB.cjs +16 -0
  60. package/dist/core-C9W8Rk56.cjs +21 -0
  61. package/dist/core-CB43TUtW.cjs +22 -0
  62. package/dist/core-CJE2rmiu.js +16 -0
  63. package/dist/core-CMKd1SgC.cjs +16 -0
  64. package/dist/core-CNozueCf.js +16 -0
  65. package/dist/core-CQmdTUA-.js +16 -0
  66. package/dist/core-CSrz73MQ.js +23 -0
  67. package/dist/core-Cc09jN7g.cjs +16 -0
  68. package/dist/core-CcRJXtp4.cjs +16 -0
  69. package/dist/core-CcfWW8Yl.js +16 -0
  70. package/dist/core-CdoXsvsW.js +16 -0
  71. package/dist/core-CeEIf9A2.js +16 -0
  72. package/dist/core-CjcWLnZy.cjs +23 -0
  73. package/dist/core-CjqP4v2-.cjs +23 -0
  74. package/dist/core-CkD3vLFE.cjs +23 -0
  75. package/dist/core-CkiTaENw.cjs +16 -0
  76. package/dist/core-CnAMxMzZ.js +16 -0
  77. package/dist/core-CpZmNWbD.js +21 -0
  78. package/dist/core-CvgdmQ4p.js +22 -0
  79. package/dist/core-CxsODFDQ.cjs +16 -0
  80. package/dist/core-Cy4XMOO0.js +23 -0
  81. package/dist/core-Cz9O7gHH.cjs +16 -0
  82. package/dist/core-D0ky-6qT.cjs +22 -0
  83. package/dist/core-D9-l5I-_.cjs +16 -0
  84. package/dist/core-DEwKIq5J.cjs +16 -0
  85. package/dist/core-DFfTC69x.cjs +16 -0
  86. package/dist/core-DILYG446.js +16 -0
  87. package/dist/core-DKn94t_L.js +16 -0
  88. package/dist/core-DM-_GEhu.js +16 -0
  89. package/dist/core-DO-NwFws.js +16 -0
  90. package/dist/core-DODQNUmx.js +23 -0
  91. package/dist/core-DOPBacgQ.js +16 -0
  92. package/dist/core-DOb5ZaB5.js +16 -0
  93. package/dist/core-DOr6dvSK.cjs +23 -0
  94. package/dist/core-DR0Ro3q8.cjs +16 -0
  95. package/dist/core-DTcMkp10.cjs +16 -0
  96. package/dist/core-DTsROgB4.cjs +23 -0
  97. package/dist/core-DXQG3Wk9.js +23 -0
  98. package/dist/core-DXglqx_w.cjs +22 -0
  99. package/dist/core-DZ9x860t.cjs +16 -0
  100. package/dist/core-DZEKGXRR.js +22 -0
  101. package/dist/core-DZZ5G9na.js +16 -0
  102. package/dist/core-DbA9kq9x.js +21 -0
  103. package/dist/core-DfZtR6Kt.cjs +16 -0
  104. package/dist/core-Dgp8uIuC.js +4569 -0
  105. package/dist/core-DiEmqghi.js +16 -0
  106. package/dist/core-DlRuOC3A.cjs +23 -0
  107. package/dist/core-DnGsYklN.js +16 -0
  108. package/dist/core-DpoYsdkP.js +16 -0
  109. package/dist/core-DujSA1aI.cjs +16 -0
  110. package/dist/core-DxiziFMu.cjs +16 -0
  111. package/dist/core-Dy9ynhXB.js +16 -0
  112. package/dist/core-EHhBxHJ_.js +21 -0
  113. package/dist/core-G6p5b8ak.js +16 -0
  114. package/dist/core-H-_PbkBe.js +16 -0
  115. package/dist/core-JXJ0gE1j.cjs +22 -0
  116. package/dist/core-KoODoP9-.cjs +16 -0
  117. package/dist/core-LXhhDWv1.cjs +16 -0
  118. package/dist/core-QYSP7a25.cjs +16 -0
  119. package/dist/core-RWZw5had.js +23 -0
  120. package/dist/core-SZQqhCwV.js +23 -0
  121. package/dist/core-UpW6Z6Mk.cjs +21 -0
  122. package/dist/core-VscwhGe-.js +16 -0
  123. package/dist/core-WK1KkWG3.js +16 -0
  124. package/dist/core-X5YFIG5j.js +16 -0
  125. package/dist/core-XFT_Fkcw.js +16 -0
  126. package/dist/core-YQNuPG-3.cjs +16 -0
  127. package/dist/core-aViTfdTA.js +16 -0
  128. package/dist/core-b9fESdKU.cjs +16 -0
  129. package/dist/core-bUZ42VWj.cjs +4460 -0
  130. package/dist/core-eHkZbc2W.cjs +16 -0
  131. package/dist/core-gdUwD7JK.js +16 -0
  132. package/dist/core-jYKdSVlJ.cjs +21 -0
  133. package/dist/core-l8_Z4q-L.js +16 -0
  134. package/dist/core-q3XmQbpc.js +16 -0
  135. package/dist/core-rJjaR48p.js +16 -0
  136. package/dist/core-umpo-qTC.cjs +16 -0
  137. package/dist/core-vVsOKocN.js +16 -0
  138. package/dist/core-wQfD_pOM.cjs +23 -0
  139. package/dist/extract-element-css-0f3q-q7b.js +10 -0
  140. package/dist/extract-element-css-6J5DTdGN.cjs +336 -0
  141. package/dist/extract-element-css-B0mG017l.cjs +10 -0
  142. package/dist/extract-element-css-B1yr8Mpm.cjs +10 -0
  143. package/dist/extract-element-css-B3-IjvrV.js +10 -0
  144. package/dist/extract-element-css-BD8JAeoQ.cjs +10 -0
  145. package/dist/extract-element-css-BDBThjvO.cjs +10 -0
  146. package/dist/extract-element-css-BDF8Dsxi.cjs +10 -0
  147. package/dist/extract-element-css-BH2TCwmX.js +10 -0
  148. package/dist/extract-element-css-BIhJpEw3.js +10 -0
  149. package/dist/extract-element-css-BJ5IWmx6.cjs +10 -0
  150. package/dist/extract-element-css-BK5crNDH.js +10 -0
  151. package/dist/extract-element-css-BKago1jD.cjs +10 -0
  152. package/dist/extract-element-css-BOm7HBmq.cjs +10 -0
  153. package/dist/extract-element-css-BSpO2ilP.cjs +10 -0
  154. package/dist/extract-element-css-BUcxktuZ.js +10 -0
  155. package/dist/extract-element-css-BWBXnTPc.js +10 -0
  156. package/dist/extract-element-css-BctgCnqi.cjs +10 -0
  157. package/dist/extract-element-css-BlVzutos.js +10 -0
  158. package/dist/extract-element-css-BmiTc_Mk.js +10 -0
  159. package/dist/extract-element-css-BpXvHRvz.js +10 -0
  160. package/dist/extract-element-css-BvgbpVrI.js +10 -0
  161. package/dist/extract-element-css-C1tUbLOr.js +10 -0
  162. package/dist/extract-element-css-C2PYWNnN.cjs +10 -0
  163. package/dist/extract-element-css-C3RsAz33.js +10 -0
  164. package/dist/extract-element-css-C9TJ3qu4.cjs +10 -0
  165. package/dist/extract-element-css-CAyHke4c.js +10 -0
  166. package/dist/extract-element-css-CBMVWErt.cjs +10 -0
  167. package/dist/extract-element-css-CMVYWMgY.js +10 -0
  168. package/dist/extract-element-css-CUcY2ELh.cjs +10 -0
  169. package/dist/extract-element-css-CWZuIQQk.cjs +10 -0
  170. package/dist/extract-element-css-C_F87DWh.js +10 -0
  171. package/dist/extract-element-css-CcOv00u_.js +10 -0
  172. package/dist/extract-element-css-ClUN8rFQ.js +319 -0
  173. package/dist/extract-element-css-CllNZlHg.cjs +10 -0
  174. package/dist/extract-element-css-Cp3VzwsP.cjs +10 -0
  175. package/dist/extract-element-css-CuxQoy6m.cjs +10 -0
  176. package/dist/extract-element-css-CwaJovy6.js +10 -0
  177. package/dist/extract-element-css-D-ERlFXC.cjs +10 -0
  178. package/dist/extract-element-css-D1aWSxyg.js +10 -0
  179. package/dist/extract-element-css-D5rZpeek.js +10 -0
  180. package/dist/extract-element-css-DE-GktJ-.cjs +10 -0
  181. package/dist/extract-element-css-DGaQuxEj.js +10 -0
  182. package/dist/extract-element-css-DGf1_gmY.cjs +10 -0
  183. package/dist/extract-element-css-DHByDPFC.cjs +10 -0
  184. package/dist/extract-element-css-DMYDBqW4.js +10 -0
  185. package/dist/extract-element-css-DQhNHcHg.cjs +10 -0
  186. package/dist/extract-element-css-DRI296aF.js +10 -0
  187. package/dist/extract-element-css-DTyWMO7X.js +10 -0
  188. package/dist/extract-element-css-D_AtWyYd.cjs +10 -0
  189. package/dist/extract-element-css-DajcFN4D.cjs +10 -0
  190. package/dist/extract-element-css-DbsQg6dD.js +10 -0
  191. package/dist/extract-element-css-DeiBTDrG.js +10 -0
  192. package/dist/extract-element-css-Dg3hSOh_.cjs +10 -0
  193. package/dist/extract-element-css-Do-5VPcW.js +10 -0
  194. package/dist/extract-element-css-DoROI1Lu.js +10 -0
  195. package/dist/extract-element-css-DtPOE8Qf.js +10 -0
  196. package/dist/extract-element-css-DyHXp0kV.js +10 -0
  197. package/dist/extract-element-css-HQfFXyjl.cjs +10 -0
  198. package/dist/extract-element-css-JN4bPqiH.cjs +10 -0
  199. package/dist/extract-element-css-JmWO6AFd.cjs +10 -0
  200. package/dist/extract-element-css-KqQpDZ3u.js +10 -0
  201. package/dist/extract-element-css-LWV4qZnB.js +10 -0
  202. package/dist/extract-element-css-VQDyterf.cjs +10 -0
  203. package/dist/extract-element-css-X8oGGyC9.js +10 -0
  204. package/dist/extract-element-css-_52JSItY.cjs +10 -0
  205. package/dist/extract-element-css-_9FOk1X7.js +10 -0
  206. package/dist/extract-element-css-kWe0BrvE.cjs +10 -0
  207. package/dist/extract-element-css-xgQzkNfU.cjs +10 -0
  208. package/dist/extract-element-css-zpC79GoB.cjs +10 -0
  209. package/dist/freeze-updates-44ijEDa3.cjs +52 -0
  210. package/dist/freeze-updates-B-KM0P-S.js +55 -0
  211. package/dist/freeze-updates-B3BTWdin.js +52 -0
  212. package/dist/freeze-updates-B46IFLUc.js +52 -0
  213. package/dist/freeze-updates-B4Dd2NgX.cjs +55 -0
  214. package/dist/freeze-updates-B4sixfxL.cjs +55 -0
  215. package/dist/freeze-updates-B8XVmCbU.cjs +52 -0
  216. package/dist/freeze-updates-B9KiLr4J.js +53 -0
  217. package/dist/freeze-updates-BBXKN548.cjs +52 -0
  218. package/dist/freeze-updates-BCJY18RM.js +52 -0
  219. package/dist/freeze-updates-BFqQ7DfD.cjs +53 -0
  220. package/dist/freeze-updates-BIu5xw5I.cjs +55 -0
  221. package/dist/freeze-updates-BZyoCSfS.js +53 -0
  222. package/dist/freeze-updates-BgSzy4TP.cjs +52 -0
  223. package/dist/freeze-updates-Bh5uFj9M.cjs +53 -0
  224. package/dist/freeze-updates-Bl_wpv3s.js +53 -0
  225. package/dist/freeze-updates-BlxJUz-r.js +55 -0
  226. package/dist/freeze-updates-BzlaSiwx.js +53 -0
  227. package/dist/freeze-updates-C-n3vnIe.cjs +53 -0
  228. package/dist/freeze-updates-C19JTP7M.js +55 -0
  229. package/dist/freeze-updates-C2oMSGYa.js +55 -0
  230. package/dist/freeze-updates-C5e9EmRj.js +55 -0
  231. package/dist/freeze-updates-CAD_rBn-.cjs +52 -0
  232. package/dist/freeze-updates-CK3vDjxD.js +55 -0
  233. package/dist/freeze-updates-CPL37KUf.cjs +3145 -0
  234. package/dist/freeze-updates-CUfAvadN.js +52 -0
  235. package/dist/freeze-updates-CYI91QSS.js +52 -0
  236. package/dist/freeze-updates-CYLr9HLu.cjs +52 -0
  237. package/dist/freeze-updates-CcGZPbDa.cjs +53 -0
  238. package/dist/freeze-updates-CobOgm67.cjs +55 -0
  239. package/dist/freeze-updates-CqgugC0v.cjs +55 -0
  240. package/dist/freeze-updates-CvoDbgCn.cjs +55 -0
  241. package/dist/freeze-updates-CzNFqLh4.js +55 -0
  242. package/dist/freeze-updates-D-wqPzkS.cjs +53 -0
  243. package/dist/freeze-updates-D2K4dx91.js +55 -0
  244. package/dist/freeze-updates-DDJeC30f.cjs +55 -0
  245. package/dist/freeze-updates-DGd0kTS0.cjs +55 -0
  246. package/dist/freeze-updates-DHwYYvlF.js +52 -0
  247. package/dist/freeze-updates-DI2WrF4x.cjs +53 -0
  248. package/dist/freeze-updates-DISihwcW.cjs +55 -0
  249. package/dist/freeze-updates-DIXfS3oc.js +55 -0
  250. package/dist/freeze-updates-DJ_kd3MS.cjs +52 -0
  251. package/dist/freeze-updates-DQa7cAMD.js +52 -0
  252. package/dist/freeze-updates-DUhtP6Qh.cjs +53 -0
  253. package/dist/freeze-updates-DUrm6t8c.js +52 -0
  254. package/dist/freeze-updates-DVQXyNiy.js +52 -0
  255. package/dist/freeze-updates-DYnenNAx.js +53 -0
  256. package/dist/freeze-updates-D_k5kTsT.js +55 -0
  257. package/dist/freeze-updates-Daef1yLv.js +53 -0
  258. package/dist/freeze-updates-Dh6MIxrS.cjs +52 -0
  259. package/dist/freeze-updates-Diu7g9r6.cjs +52 -0
  260. package/dist/freeze-updates-DjDBr_oh.js +53 -0
  261. package/dist/freeze-updates-DkS4-mx9.cjs +52 -0
  262. package/dist/freeze-updates-DoeDby5W.js +52 -0
  263. package/dist/freeze-updates-Dp5H7855.js +53 -0
  264. package/dist/freeze-updates-DuFU4W3a.cjs +52 -0
  265. package/dist/freeze-updates-F_aGQXqR.js +55 -0
  266. package/dist/freeze-updates-HHHOlV6s.js +52 -0
  267. package/dist/freeze-updates-Iz-KAPxe.js +2755 -0
  268. package/dist/freeze-updates-JRtE2hMi.js +53 -0
  269. package/dist/freeze-updates-QRM0VlPw.cjs +52 -0
  270. package/dist/freeze-updates-RwvSZOO_.cjs +55 -0
  271. package/dist/freeze-updates-Tr7M7QVD.cjs +55 -0
  272. package/dist/freeze-updates-WLO3XKoj.cjs +53 -0
  273. package/dist/freeze-updates-YrXN1_2z.js +52 -0
  274. package/dist/freeze-updates-bnVMmz_x.cjs +53 -0
  275. package/dist/freeze-updates-dlxsMPrr.cjs +55 -0
  276. package/dist/freeze-updates-z2Ak9jr6.js +55 -0
  277. package/dist/index-5bXwDEQz.d.ts +446 -0
  278. package/dist/index-AOuLP5ui.d.cts +203 -0
  279. package/dist/index-B3INoNjJ.d.ts +461 -0
  280. package/dist/index-Beii_ZY2.d.ts +203 -0
  281. package/dist/index-BvBIePAo.d.cts +446 -0
  282. package/dist/index-C188F1-K.d.ts +460 -0
  283. package/dist/index-Cmlk2psk.d.cts +460 -0
  284. package/dist/index-CpD0mJy2.d.cts +461 -0
  285. package/dist/index-D4VTvmm1.d.cts +203 -0
  286. package/dist/index-DASKclJI.d.ts +203 -0
  287. package/dist/index-DZaWv0Sy.d.ts +461 -0
  288. package/dist/index-DxRpK6Tz.d.cts +461 -0
  289. package/dist/index-HrbjUEIv.d.ts +461 -0
  290. package/dist/index-iOOBO4Tu.d.cts +461 -0
  291. package/dist/index.cjs +1 -1
  292. package/dist/index.d.cts +2 -2
  293. package/dist/index.d.ts +2 -2
  294. package/dist/index.global.js +25 -19
  295. package/dist/index.iife.js +25 -19
  296. package/dist/index.js +1 -1
  297. package/dist/primitives.cjs +1 -1
  298. package/dist/primitives.d.cts +13 -2
  299. package/dist/primitives.d.ts +13 -2
  300. package/dist/primitives.js +1 -1
  301. package/dist/renderer-03E_Z-oG.cjs +9 -0
  302. package/dist/renderer-2FkGa8yQ.cjs +9 -0
  303. package/dist/renderer-2qf4XT0a.cjs +9 -0
  304. package/dist/renderer-4WLOXegj.js +9 -0
  305. package/dist/renderer-5OkvqZ27.cjs +9 -0
  306. package/dist/renderer-70hOclWm.js +9 -0
  307. package/dist/renderer-7PW4LWCI.js +9 -0
  308. package/dist/renderer-88pIB89V.cjs +9 -0
  309. package/dist/renderer-9QsCcfWA.cjs +9 -0
  310. package/dist/renderer-B0DLjOcW.js +9 -0
  311. package/dist/renderer-B28zz1-T.cjs +9 -0
  312. package/dist/renderer-B2kpCtoY.cjs +9 -0
  313. package/dist/renderer-BB0mKzDq.cjs +9 -0
  314. package/dist/renderer-BNYQfBKy.cjs +9 -0
  315. package/dist/renderer-BQCd2ezw.js +9 -0
  316. package/dist/renderer-BRyXuhLV.js +9 -0
  317. package/dist/renderer-BSjQmsCr.js +9 -0
  318. package/dist/renderer-BT6S4lrE.js +9 -0
  319. package/dist/renderer-BWb6GNsI.js +9 -0
  320. package/dist/renderer-Bc_LPRgB.js +9 -0
  321. package/dist/renderer-Bi3BGqK6.js +9 -0
  322. package/dist/renderer-Bo9Hj0Nz.cjs +9 -0
  323. package/dist/renderer-BrHbCsT-.cjs +9 -0
  324. package/dist/renderer-BrrTBbU_.cjs +9 -0
  325. package/dist/renderer-BtD4lYaA.cjs +9 -0
  326. package/dist/renderer-BwW5L228.cjs +9 -0
  327. package/dist/renderer-Bzq6OP1Q.cjs +9 -0
  328. package/dist/renderer-C60Irhis.cjs +9 -0
  329. package/dist/renderer-C667p9Ts.js +9 -0
  330. package/dist/renderer-CGDYcfpq.js +9 -0
  331. package/dist/renderer-CJs3DW7F.js +9 -0
  332. package/dist/renderer-CRtXJ6gz.js +9 -0
  333. package/dist/renderer-CSGre_uQ.js +9 -0
  334. package/dist/renderer-CU622nBs.cjs +9 -0
  335. package/dist/renderer-CZU0dUK9.js +9 -0
  336. package/dist/renderer-C_8ChDyN.js +9 -0
  337. package/dist/renderer-CaWdbJaJ.js +9 -0
  338. package/dist/renderer-CbIWDh9l.js +9 -0
  339. package/dist/renderer-Cbq6Rx1G.cjs +9 -0
  340. package/dist/renderer-CeCJd7_M.cjs +9 -0
  341. package/dist/renderer-ChrLxxjc.cjs +9 -0
  342. package/dist/renderer-CrOSekQx.cjs +9 -0
  343. package/dist/renderer-CrbJ1q93.cjs +9 -0
  344. package/dist/renderer-CwxBLDdk.js +9 -0
  345. package/dist/renderer-D2P_eRJ3.js +9 -0
  346. package/dist/renderer-D6bxtXXz.cjs +9 -0
  347. package/dist/renderer-D6oIEAce.cjs +9 -0
  348. package/dist/renderer-D6qViFpF.js +9 -0
  349. package/dist/renderer-D8fyDtUL.cjs +9 -0
  350. package/dist/renderer-DGXjcXzg.js +9 -0
  351. package/dist/renderer-DIQRqnHu.cjs +9 -0
  352. package/dist/renderer-DL6fAUQn.js +9 -0
  353. package/dist/renderer-DNQ9_mCu.js +3887 -0
  354. package/dist/renderer-DNWIs1VC.js +9 -0
  355. package/dist/renderer-DSjEGpz-.js +9 -0
  356. package/dist/renderer-DT7LZQtO.cjs +9 -0
  357. package/dist/renderer-DXeyOozP.js +9 -0
  358. package/dist/renderer-DdIChCSD.cjs +9 -0
  359. package/dist/renderer-DeWbPCuO.cjs +9 -0
  360. package/dist/renderer-Dlno_pdb.js +9 -0
  361. package/dist/renderer-DnYy5FOZ.js +9 -0
  362. package/dist/renderer-Dq7B2igO.js +9 -0
  363. package/dist/renderer-DtkrTfo1.cjs +9 -0
  364. package/dist/renderer-IibG__VV.js +9 -0
  365. package/dist/renderer-JmnYl4I6.js +9 -0
  366. package/dist/renderer-LNHnA-cT.cjs +3887 -0
  367. package/dist/renderer-Q0qVTIQc.js +9 -0
  368. package/dist/renderer-QW3s3A0S.cjs +9 -0
  369. package/dist/renderer-QpKM_dpy.js +9 -0
  370. package/dist/renderer-XmhoGb9V.cjs +9 -0
  371. package/dist/renderer-YUdjQ8nt.cjs +9 -0
  372. package/dist/renderer-_81FJC2J.js +9 -0
  373. package/dist/renderer-aqAvQN6V.cjs +9 -0
  374. package/dist/renderer-bnYZTPia.cjs +9 -0
  375. package/dist/renderer-kJC7KhNe.cjs +9 -0
  376. package/dist/renderer-nXRFY18V.js +9 -0
  377. package/dist/renderer-s5lBiYLe.js +9 -0
  378. package/dist/renderer-y9QnqihM.cjs +9 -0
  379. package/dist/state-7SBySxTA.cjs +9 -0
  380. package/dist/state-8yi9xrye.js +9 -0
  381. package/dist/state-9r5nglSb.js +9 -0
  382. package/dist/state-B0T1D-ks.cjs +9 -0
  383. package/dist/state-BA6QsS82.js +9 -0
  384. package/dist/state-BGtrXdJj.js +9 -0
  385. package/dist/state-BJlvi-2E.cjs +9 -0
  386. package/dist/state-BN964xZ5.js +9 -0
  387. package/dist/state-BO1NAkWD.js +9 -0
  388. package/dist/state-BO3AE8Fe.js +9 -0
  389. package/dist/state-BV9PmYfz.js +9 -0
  390. package/dist/state-BYF5b0D5.js +9 -0
  391. package/dist/state-Baa6Ci7k.js +9 -0
  392. package/dist/state-Bd2gljHi.js +9 -0
  393. package/dist/state-Bd6VTjeM.js +9 -0
  394. package/dist/state-BeBXGZmh.cjs +9 -0
  395. package/dist/state-BfN8pmY2.js +9 -0
  396. package/dist/state-Bpf5_85U.js +9 -0
  397. package/dist/state-BsfONYv7.cjs +9 -0
  398. package/dist/state-C-rvuJYD.cjs +9 -0
  399. package/dist/state-C0Ow0XmM.js +9 -0
  400. package/dist/state-C5Bj0Buz.js +9 -0
  401. package/dist/state-C6EfW8-M.js +9 -0
  402. package/dist/state-C6rrzEh-.cjs +9 -0
  403. package/dist/state-CEnDdOqw.cjs +9 -0
  404. package/dist/state-CGmKE82n.js +9 -0
  405. package/dist/state-CI0P3gEI.js +9 -0
  406. package/dist/state-CI2DgSGN.cjs +9 -0
  407. package/dist/state-CJLktzcx.cjs +9 -0
  408. package/dist/state-CNep2ElU.cjs +9 -0
  409. package/dist/state-CSGI31dx.js +9 -0
  410. package/dist/state-CUcDVMOr.js +1696 -0
  411. package/dist/state-CVzxiIHS.cjs +9 -0
  412. package/dist/state-C_MfICQQ.cjs +9 -0
  413. package/dist/state-CepA6OBG.cjs +9 -0
  414. package/dist/state-CfDNgfQC.cjs +9 -0
  415. package/dist/state-CfWNsT73.cjs +9 -0
  416. package/dist/state-Cl-Qsozk.cjs +9 -0
  417. package/dist/state-Cm5Lwn2E.js +9 -0
  418. package/dist/state-CvjZor_U.cjs +9 -0
  419. package/dist/state-CyD129tM.cjs +9 -0
  420. package/dist/state-CyUr2qMd.js +9 -0
  421. package/dist/state-D-fLHGyJ.js +9 -0
  422. package/dist/state-D0E4SXeX.js +9 -0
  423. package/dist/state-D2TlmfBW.cjs +9 -0
  424. package/dist/state-D6btATEI.js +9 -0
  425. package/dist/state-D9ZV8boi.cjs +9 -0
  426. package/dist/state-DCtMfI4R.cjs +9 -0
  427. package/dist/state-DGLq4GOX.js +9 -0
  428. package/dist/state-DJqo4o5A.js +9 -0
  429. package/dist/state-DMYmMd2O.cjs +9 -0
  430. package/dist/state-DUXEd2RT.cjs +9 -0
  431. package/dist/state-DZl9i9YY.js +9 -0
  432. package/dist/state-DcBwFGAn.js +9 -0
  433. package/dist/state-Dd1plgdI.cjs +9 -0
  434. package/dist/state-Dgh4g_LN.cjs +1293 -0
  435. package/dist/state-DiSiK2-w.cjs +9 -0
  436. package/dist/state-Dr92AOzO.js +9 -0
  437. package/dist/state-Dt428m3l.cjs +9 -0
  438. package/dist/state-DzPMjkFn.js +9 -0
  439. package/dist/state-LIGdfh87.cjs +9 -0
  440. package/dist/state-MC-BcccL.js +9 -0
  441. package/dist/state-P55CkQ4f.cjs +9 -0
  442. package/dist/state-Tb5KTyit.cjs +9 -0
  443. package/dist/state-_frBwcTV.cjs +9 -0
  444. package/dist/state-eM6WYht4.js +9 -0
  445. package/dist/state-nEfTr66e.cjs +9 -0
  446. package/dist/state-tAT5fWsb.cjs +9 -0
  447. package/dist/state-xjSIX0_u.js +9 -0
  448. package/dist/state-ze3D7XUZ.cjs +9 -0
  449. package/dist/styles.css +2 -2
  450. package/package.json +9 -8
@@ -0,0 +1,2755 @@
1
+ /**
2
+ * @license MIT
3
+ *
4
+ * Copyright (c) 2025 Aiden Bai
5
+ *
6
+ * This source code is licensed under the MIT license found in the
7
+ * LICENSE file in the root directory of this source tree.
8
+ */
9
+ //#region src/utils/supports-display-p3.ts
10
+ let cachedResult = null;
11
+ const supportsDisplayP3 = () => {
12
+ if (cachedResult !== null) return cachedResult;
13
+ try {
14
+ cachedResult = window.matchMedia("(color-gamut: p3)").matches;
15
+ } catch {
16
+ cachedResult = false;
17
+ }
18
+ return cachedResult;
19
+ };
20
+
21
+ //#endregion
22
+ //#region src/utils/overlay-color.ts
23
+ const isWideGamut = supportsDisplayP3();
24
+ const SRGB_COMPONENTS = "210, 57, 192";
25
+ const P3_COMPONENTS = "0.84 0.19 0.78";
26
+ const overlayColor = (alpha) => isWideGamut ? `color(display-p3 ${P3_COMPONENTS} / ${alpha})` : `rgba(${SRGB_COMPONENTS}, ${alpha})`;
27
+
28
+ //#endregion
29
+ //#region src/constants.ts
30
+ const VERSION = "[DEV]";
31
+ const OFFSCREEN_POSITION = -1e3;
32
+ const SELECTION_LERP_FACTOR = .95;
33
+ const FEEDBACK_DURATION_MS = 1500;
34
+ const SYMBOLICATION_TIMEOUT_MS = 5e3;
35
+ const MAX_SELECTOR_COMBINATIONS = 1e4;
36
+ const Z_INDEX_OVERLAY = 2147483647;
37
+ const Z_INDEX_OVERLAY_CANVAS = 2147483645;
38
+ const DRAG_LERP_FACTOR = .7;
39
+ const BASELINE_FRAME_DURATION_MS = 1e3 / 60;
40
+ const LERP_CONVERGENCE_THRESHOLD_PX = .5;
41
+ const OPACITY_CONVERGENCE_THRESHOLD = .01;
42
+ const OVERLAY_BORDER_COLOR_DRAG = overlayColor(.4);
43
+ const OVERLAY_FILL_COLOR_DRAG = overlayColor(.05);
44
+ const OVERLAY_BORDER_COLOR_DEFAULT = overlayColor(.5);
45
+ const OVERLAY_FILL_COLOR_DEFAULT = overlayColor(.08);
46
+ const FROZEN_GLOW_COLOR = overlayColor(.15);
47
+ const ARROW_MAX_LABEL_WIDTH_RATIO = .2;
48
+ const PREVIEW_PRIORITY_ATTRS = [
49
+ "id",
50
+ "class",
51
+ "aria-label",
52
+ "data-testid",
53
+ "role",
54
+ "name",
55
+ "title"
56
+ ];
57
+ const MODIFIER_KEYS = [
58
+ "Meta",
59
+ "Control",
60
+ "Shift",
61
+ "Alt"
62
+ ];
63
+ const ARROW_KEYS = new Set([
64
+ "ArrowUp",
65
+ "ArrowDown",
66
+ "ArrowLeft",
67
+ "ArrowRight"
68
+ ]);
69
+ const FROZEN_ELEMENT_ATTRIBUTE = "data-react-grab-frozen";
70
+ const USER_IGNORE_ATTRIBUTE = "data-react-grab-ignore";
71
+ const VIEWPORT_COVERAGE_THRESHOLD = .9;
72
+ const OVERLAY_Z_INDEX_THRESHOLD = 1e3;
73
+ const DEV_TOOLS_OVERLAY_Z_INDEX_THRESHOLD = 2147483600;
74
+ const TOOLBAR_DEFAULT_POSITION_RATIO = .5;
75
+ const DEFAULT_ACTION_ID = "comment";
76
+ const DRAG_SELECTION_COVERAGE_THRESHOLD = .75;
77
+ const ZOOM_DETECTION_THRESHOLD = .01;
78
+ const MOUNT_ROOT_RECHECK_DELAY_MS = 1e3;
79
+ const MAX_SESSION_STORAGE_SIZE_BYTES = 2 * 1024 * 1024;
80
+ const DROPDOWN_OFFSCREEN_POSITION = {
81
+ left: -9999,
82
+ top: -9999
83
+ };
84
+ const DROPDOWN_EDGE_TRANSFORM_ORIGIN = {
85
+ left: "left center",
86
+ right: "right center",
87
+ top: "center top",
88
+ bottom: "center bottom"
89
+ };
90
+ const NEXTJS_REVALIDATION_DELAY_MS = 1e3;
91
+ const SELECTION_LABEL_OFFSCREEN_PX = -9999;
92
+ const RELEVANT_CSS_PROPERTIES = new Set([
93
+ "display",
94
+ "position",
95
+ "top",
96
+ "right",
97
+ "bottom",
98
+ "left",
99
+ "z-index",
100
+ "overflow",
101
+ "overflow-x",
102
+ "overflow-y",
103
+ "width",
104
+ "height",
105
+ "min-width",
106
+ "min-height",
107
+ "max-width",
108
+ "max-height",
109
+ "margin-top",
110
+ "margin-right",
111
+ "margin-bottom",
112
+ "margin-left",
113
+ "padding-top",
114
+ "padding-right",
115
+ "padding-bottom",
116
+ "padding-left",
117
+ "flex-direction",
118
+ "flex-wrap",
119
+ "justify-content",
120
+ "align-items",
121
+ "align-self",
122
+ "align-content",
123
+ "flex-grow",
124
+ "flex-shrink",
125
+ "flex-basis",
126
+ "order",
127
+ "gap",
128
+ "row-gap",
129
+ "column-gap",
130
+ "grid-template-columns",
131
+ "grid-template-rows",
132
+ "grid-template-areas",
133
+ "font-family",
134
+ "font-size",
135
+ "font-weight",
136
+ "font-style",
137
+ "line-height",
138
+ "letter-spacing",
139
+ "text-align",
140
+ "text-decoration-line",
141
+ "text-decoration-style",
142
+ "text-transform",
143
+ "text-overflow",
144
+ "text-shadow",
145
+ "white-space",
146
+ "word-break",
147
+ "overflow-wrap",
148
+ "vertical-align",
149
+ "color",
150
+ "background-color",
151
+ "background-image",
152
+ "background-position",
153
+ "background-size",
154
+ "background-repeat",
155
+ "border-top-width",
156
+ "border-right-width",
157
+ "border-bottom-width",
158
+ "border-left-width",
159
+ "border-top-style",
160
+ "border-right-style",
161
+ "border-bottom-style",
162
+ "border-left-style",
163
+ "border-top-color",
164
+ "border-right-color",
165
+ "border-bottom-color",
166
+ "border-left-color",
167
+ "border-top-left-radius",
168
+ "border-top-right-radius",
169
+ "border-bottom-left-radius",
170
+ "border-bottom-right-radius",
171
+ "box-shadow",
172
+ "opacity",
173
+ "transform",
174
+ "filter",
175
+ "backdrop-filter",
176
+ "object-fit",
177
+ "object-position"
178
+ ]);
179
+
180
+ //#endregion
181
+ //#region src/utils/get-tag-name.ts
182
+ const getTagName = (element) => (element.tagName || "").toLowerCase();
183
+
184
+ //#endregion
185
+ //#region src/utils/detect-csp-nonce.ts
186
+ let cachedNonce;
187
+ const detectCspNonce = () => {
188
+ if (cachedNonce !== void 0) return cachedNonce;
189
+ const existingElement = document.querySelector("script[nonce], style[nonce]");
190
+ const nonce = existingElement?.nonce || existingElement?.getAttribute("nonce") || null;
191
+ if (nonce) cachedNonce = nonce;
192
+ return nonce;
193
+ };
194
+
195
+ //#endregion
196
+ //#region src/utils/hide-from-third-parties.ts
197
+ const THIRD_PARTY_PRIVACY_ATTRIBUTES = [
198
+ ["data-rr-block", ""],
199
+ ["data-rr-ignore", ""],
200
+ ["data-rr-mask", ""],
201
+ ["data-sentry-block", ""],
202
+ ["data-sentry-ignore", ""],
203
+ ["data-sentry-mask", ""],
204
+ ["data-dd-privacy", "hidden"],
205
+ ["data-fs-exclude", ""],
206
+ ["data-lr-exclude", ""],
207
+ ["data-hj-suppress", ""],
208
+ ["data-recording-disable", ""],
209
+ ["data-clarity-mask", "true"],
210
+ ["data-heap-redact-text", ""]
211
+ ];
212
+ const hideFromThirdParties = (element) => {
213
+ for (const [attributeName, attributeValue] of THIRD_PARTY_PRIVACY_ATTRIBUTES) element.setAttribute(attributeName, attributeValue);
214
+ element.setAttribute("data-testid", "react-grab-overlay");
215
+ element.classList.add("ph-no-capture");
216
+ };
217
+
218
+ //#endregion
219
+ //#region src/utils/native-raf.ts
220
+ const isClientSide = typeof window !== "undefined";
221
+ const noopAnimationFrame = (_callback) => 0;
222
+ const noopCancelFrame = (_id) => {};
223
+ const nativeRequestAnimationFrame = isClientSide ? (Object.getOwnPropertyDescriptor(Window.prototype, "requestAnimationFrame")?.value ?? window.requestAnimationFrame).bind(window) : noopAnimationFrame;
224
+ const nativeCancelAnimationFrame = isClientSide ? (Object.getOwnPropertyDescriptor(Window.prototype, "cancelAnimationFrame")?.value ?? window.cancelAnimationFrame).bind(window) : noopCancelFrame;
225
+ const waitUntilNextFrame = () => isClientSide ? new Promise((resolve) => nativeRequestAnimationFrame(() => resolve())) : Promise.resolve();
226
+
227
+ //#endregion
228
+ //#region ../../node_modules/.pnpm/bippy@0.5.39_react@19.2.6/node_modules/bippy/dist/rdt-hook.js
229
+ /**
230
+ * @license bippy
231
+ *
232
+ * Copyright (c) Aiden Bai
233
+ *
234
+ * This source code is licensed under the MIT license found in the
235
+ * LICENSE file in the root directory of this source tree.
236
+ */
237
+ const e = `0.5.39`, t = `bippy-${e}`, n = Object.defineProperty, r = Object.prototype.hasOwnProperty, i$1 = () => {}, a$1 = (e) => {
238
+ try {
239
+ Function.prototype.toString.call(e).indexOf(`^_^`) > -1 && setTimeout(() => {
240
+ throw Error(`React is running in production mode, but dead code elimination has not been applied. Read how to correctly configure React for production: https://reactjs.org/link/perf-use-production-build`);
241
+ });
242
+ } catch {}
243
+ }, o$1 = (e = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__) => !!(e && `getFiberRoots` in e);
244
+ let s$1 = !1, c$1;
245
+ const l$1 = (e = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__) => s$1 ? !0 : (e && typeof e.inject == `function` && (c$1 = e.inject.toString()), !!c$1?.includes(`(injected)`)), u$1 = /* @__PURE__ */ new Set(), d$2 = /* @__PURE__ */ new Set(), f$2 = (e) => {
246
+ let r = /* @__PURE__ */ new Map(), o = 0, s = {
247
+ _instrumentationIsActive: !1,
248
+ _instrumentationSource: t,
249
+ checkDCE: a$1,
250
+ hasUnsupportedRendererAttached: !1,
251
+ inject(e) {
252
+ let t = ++o;
253
+ return r.set(t, e), d$2.add(e), s._instrumentationIsActive || (s._instrumentationIsActive = !0, u$1.forEach((e) => e())), t;
254
+ },
255
+ on: i$1,
256
+ onCommitFiberRoot: i$1,
257
+ onCommitFiberUnmount: i$1,
258
+ onPostCommitFiberRoot: i$1,
259
+ renderers: r,
260
+ supportsFiber: !0,
261
+ supportsFlight: !0
262
+ };
263
+ try {
264
+ n(globalThis, `__REACT_DEVTOOLS_GLOBAL_HOOK__`, {
265
+ configurable: !0,
266
+ enumerable: !0,
267
+ get() {
268
+ return s;
269
+ },
270
+ set(t) {
271
+ if (t && typeof t == `object`) {
272
+ let n = s.renderers;
273
+ s = t, n.size > 0 && (n.forEach((e, n) => {
274
+ d$2.add(e), t.renderers.set(n, e);
275
+ }), p$2(e));
276
+ }
277
+ }
278
+ });
279
+ let t = window.hasOwnProperty, r = !1;
280
+ n(window, `hasOwnProperty`, {
281
+ configurable: !0,
282
+ value: function(...e) {
283
+ try {
284
+ if (!r && e[0] === `__REACT_DEVTOOLS_GLOBAL_HOOK__`) return globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__ = void 0, r = !0, -0;
285
+ } catch {}
286
+ return t.apply(this, e);
287
+ },
288
+ writable: !0
289
+ });
290
+ } catch {
291
+ p$2(e);
292
+ }
293
+ return s;
294
+ }, p$2 = (e) => {
295
+ e && u$1.add(e);
296
+ try {
297
+ let n = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
298
+ if (!n) return;
299
+ if (!n._instrumentationSource) {
300
+ n.checkDCE = a$1, n.supportsFiber = !0, n.supportsFlight = !0, n.hasUnsupportedRendererAttached = !1, n._instrumentationSource = t, n._instrumentationIsActive = !1;
301
+ let e = o$1(n);
302
+ if (e || (n.on = i$1), n.renderers.size) {
303
+ n._instrumentationIsActive = !0, u$1.forEach((e) => e());
304
+ return;
305
+ }
306
+ let r = n.inject, c = l$1(n);
307
+ c && !e && (s$1 = !0, n.inject({ scheduleRefresh() {} }) && (n._instrumentationIsActive = !0)), n.inject = (e) => {
308
+ let t = r(e);
309
+ return d$2.add(e), c && n.renderers.set(t, e), n._instrumentationIsActive = !0, u$1.forEach((e) => e()), t;
310
+ };
311
+ }
312
+ (n.renderers.size || n._instrumentationIsActive || l$1()) && e?.();
313
+ } catch {}
314
+ }, m$2 = () => r.call(globalThis, `__REACT_DEVTOOLS_GLOBAL_HOOK__`), h$2 = (e) => m$2() ? (p$2(e), globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__) : f$2(e), g$2 = () => !!(typeof window < `u` && (window.document?.createElement || window.navigator?.product === `ReactNative`)), _$2 = () => {
315
+ try {
316
+ g$2() && h$2();
317
+ } catch {}
318
+ };
319
+
320
+ //#endregion
321
+ //#region ../../node_modules/.pnpm/bippy@0.5.39_react@19.2.6/node_modules/bippy/dist/core.js
322
+ /**
323
+ * @license bippy
324
+ *
325
+ * Copyright (c) Aiden Bai
326
+ *
327
+ * This source code is licensed under the MIT license found in the
328
+ * LICENSE file in the root directory of this source tree.
329
+ */
330
+ const d$1 = 0, ee$1 = 1, te$1 = 3, ne$1 = 5, re$1 = 6, ie$1 = 7, f$1 = 9, p$1 = 11, m$1 = 13, h$1 = 14, g$1 = 15, ae$1 = 16, oe$1 = 18, se$1 = 19, ce$1 = 22, le$1 = 23, ue$1 = 26, de$1 = 27, fe$1 = 28, pe$1 = 30, _$1 = 60111, me$1 = `Symbol(react.element)`, he$1 = `Symbol(react.transitional.element)`, v$1 = `Symbol(react.concurrent_mode)`, y$1 = `Symbol(react.async_mode)`, b$1 = 13366, ge$1 = (e) => typeof e == `object` && !!e && `$$typeof` in e && [`Symbol(react.element)`, `Symbol(react.transitional.element)`].includes(String(e.$$typeof)), _e$1 = (e) => typeof e == `object` && !!e && `tag` in e && `stateNode` in e && `return` in e && `child` in e && `sibling` in e && `flags` in e, x$1 = (e) => {
331
+ switch (e.tag) {
332
+ case 5:
333
+ case 26:
334
+ case 27: return !0;
335
+ default: return typeof e.type == `string`;
336
+ }
337
+ }, ve$1 = (e) => {
338
+ switch (e.tag) {
339
+ case 1:
340
+ case 11:
341
+ case 0:
342
+ case 14:
343
+ case 15: return !0;
344
+ default: return !1;
345
+ }
346
+ }, ye$1 = (e) => !e || typeof e != `object` ? !1 : `pendingProps` in e && !(`containerInfo` in e), be$1 = (e, t) => e === t || e.alternate === t || t.alternate === e, xe$1 = (e, t) => {
347
+ try {
348
+ let n = e.dependencies, r = e.alternate?.dependencies;
349
+ if (!n || !r || typeof n != `object` || !(`firstContext` in n) || typeof r != `object` || !(`firstContext` in r)) return !1;
350
+ let i = n.firstContext, a = r.firstContext;
351
+ for (; i && typeof i == `object` && `memoizedValue` in i || a && typeof a == `object` && `memoizedValue` in a;) {
352
+ if (t(i, a) === !0) return !0;
353
+ i = i?.next, a = a?.next;
354
+ }
355
+ } catch {}
356
+ return !1;
357
+ }, S$1 = (e, t) => {
358
+ try {
359
+ let n = e.memoizedState, r = e.alternate?.memoizedState;
360
+ for (; n || r;) {
361
+ if (t(n, r) === !0) return !0;
362
+ n = n?.next, r = r?.next;
363
+ }
364
+ } catch {}
365
+ return !1;
366
+ }, C$1 = (e, t) => {
367
+ try {
368
+ let n = e.memoizedProps, r = e.alternate?.memoizedProps || {}, i = new Set([...Object.keys(n), ...Object.keys(r)]);
369
+ for (let e of i) {
370
+ let i = r?.[e], a = n?.[e];
371
+ if (t(e, a, i) === !0) return !0;
372
+ }
373
+ } catch {}
374
+ return !1;
375
+ }, w$1 = (e) => {
376
+ let t = e.memoizedProps, n = e.alternate?.memoizedProps || {}, r = e.flags ?? e.effectTag ?? 0;
377
+ switch (e.tag) {
378
+ case 1:
379
+ case 9:
380
+ case 11:
381
+ case 0:
382
+ case 14:
383
+ case 15: return (r & 1) == 1;
384
+ default: return e.alternate ? n !== t || e.alternate.memoizedState !== e.memoizedState || e.alternate.ref !== e.ref : !0;
385
+ }
386
+ }, T$1 = (e) => !!(e.flags & (b$1 | 8) || e.subtreeFlags & (b$1 | 8)), E$1 = (e) => {
387
+ let t = [], n = [e];
388
+ for (; n.length;) {
389
+ let e = n.pop();
390
+ e && (x$1(e) && T$1(e) && w$1(e) && t.push(e), e.child && n.push(e.child), e.sibling && n.push(e.sibling));
391
+ }
392
+ return t;
393
+ }, D$1 = (e) => {
394
+ let t = [], n = e;
395
+ for (; n.return;) t.push(n), n = n.return;
396
+ return t;
397
+ }, O$1 = (e) => {
398
+ switch (e.tag) {
399
+ case 18: return !0;
400
+ case 7:
401
+ case 6:
402
+ case 23:
403
+ case 22: return !0;
404
+ case 3: return !1;
405
+ default: {
406
+ let t = typeof e.type == `object` && e.type !== null ? e.type.$$typeof : e.type;
407
+ switch (typeof t == `symbol` ? t.toString() : t) {
408
+ case _$1:
409
+ case v$1:
410
+ case y$1: return !0;
411
+ default: return !1;
412
+ }
413
+ }
414
+ }
415
+ }, k$1 = (e, t = !1) => {
416
+ let n = j$1(e, x$1, t);
417
+ return n ||= j$1(e, x$1, !t), n;
418
+ }, A$1 = (e) => {
419
+ let t = [], n = [];
420
+ for (x$1(e) ? t.push(e) : e.child && n.push(e.child); n.length;) {
421
+ let e = n.pop();
422
+ if (!e) break;
423
+ x$1(e) ? t.push(e) : e.child && n.push(e.child), e.sibling && n.push(e.sibling);
424
+ }
425
+ return t;
426
+ };
427
+ function j$1(e, t, n = !1) {
428
+ if (!e) return null;
429
+ let r = t(e);
430
+ if (r instanceof Promise) return (async () => {
431
+ if (await r === !0) return e;
432
+ let i = n ? e.return : e.child;
433
+ for (; i;) {
434
+ let e = await N$1(i, t, n);
435
+ if (e) return e;
436
+ i = n ? null : i.sibling;
437
+ }
438
+ return null;
439
+ })();
440
+ if (r === !0) return e;
441
+ let i = n ? e.return : e.child;
442
+ for (; i;) {
443
+ let e = M$1(i, t, n);
444
+ if (e) return e;
445
+ i = n ? null : i.sibling;
446
+ }
447
+ return null;
448
+ }
449
+ const M$1 = (e, t, n = !1) => {
450
+ if (!e) return null;
451
+ if (t(e) === !0) return e;
452
+ let r = n ? e.return : e.child;
453
+ for (; r;) {
454
+ let e = M$1(r, t, n);
455
+ if (e) return e;
456
+ r = n ? null : r.sibling;
457
+ }
458
+ return null;
459
+ }, N$1 = async (e, t, n = !1) => {
460
+ if (!e) return null;
461
+ if (await t(e) === !0) return e;
462
+ let r = n ? e.return : e.child;
463
+ for (; r;) {
464
+ let e = await N$1(r, t, n);
465
+ if (e) return e;
466
+ r = n ? null : r.sibling;
467
+ }
468
+ return null;
469
+ }, Se$1 = (e) => {
470
+ let t = e?.actualDuration ?? 0, n = t, r = e?.child ?? null;
471
+ for (; t > 0 && r != null;) n -= r.actualDuration ?? 0, r = r.sibling;
472
+ return {
473
+ selfTime: n,
474
+ totalTime: t
475
+ };
476
+ }, Ce$1 = (e) => !!e.updateQueue?.memoCache, P$1 = (e) => {
477
+ let t = e;
478
+ return typeof t == `function` ? t : typeof t == `object` && t ? P$1(t.type || t.render) : null;
479
+ }, we$1 = (e) => {
480
+ let t = e;
481
+ if (typeof t == `string`) return t;
482
+ if (typeof t != `function` && !(typeof t == `object` && t)) return null;
483
+ let n = t.displayName || t.name || null;
484
+ if (n) return n;
485
+ let r = P$1(t);
486
+ return r && (r.displayName || r.name) || null;
487
+ }, F$1 = (e) => {
488
+ try {
489
+ if (typeof e.version == `string` && e.bundleType > 0) return `development`;
490
+ } catch {}
491
+ return `production`;
492
+ }, Te$1 = () => {
493
+ let e = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
494
+ return !!e?._instrumentationIsActive || o$1(e) || l$1(e);
495
+ }, Ee$1 = (e) => {
496
+ let t = e.alternate;
497
+ if (!t) return e;
498
+ if (t.actualStartTime && e.actualStartTime) return t.actualStartTime > e.actualStartTime ? t : e;
499
+ for (let t of $) {
500
+ let n = j$1(t.current, (t) => {
501
+ if (t === e) return !0;
502
+ });
503
+ if (n) return n;
504
+ }
505
+ return e;
506
+ };
507
+ let G$1 = null, K$1 = null, q$1 = null;
508
+ const J$1 = () => {
509
+ if (!m$2()) return null;
510
+ let e = h$2();
511
+ if (!e?.renderers) return null;
512
+ if (G$1 || K$1 || q$1) return {
513
+ overrideContext: q$1,
514
+ overrideHookState: K$1,
515
+ overrideProps: G$1
516
+ };
517
+ for (let [, t] of Array.from(e.renderers)) try {
518
+ if (K$1) {
519
+ let e = K$1;
520
+ K$1 = (n, r, i, a) => {
521
+ let o = n.memoizedState;
522
+ for (let e = 0; e < Number(r) && o?.next; e++) o = o.next;
523
+ if (o?.queue) {
524
+ let e = o.queue;
525
+ if (Y$1(e) && `dispatch` in e) {
526
+ let t = e.dispatch;
527
+ t(a);
528
+ return;
529
+ }
530
+ }
531
+ e(n, r, i, a), t.overrideHookState?.(n, r, i, a);
532
+ };
533
+ } else t.overrideHookState && (K$1 = t.overrideHookState);
534
+ if (G$1) {
535
+ let e = G$1;
536
+ G$1 = (n, r, i) => {
537
+ e(n, r, i), t.overrideProps?.(n, r, i);
538
+ };
539
+ } else t.overrideProps && (G$1 = t.overrideProps);
540
+ q$1 = (e, t, n, r) => {
541
+ let i = e;
542
+ for (; i;) {
543
+ let e = i.type;
544
+ if (e === t || e?.Provider === t) {
545
+ G$1 && (G$1(i, [`value`, ...n], r), i.alternate && G$1(i.alternate, [`value`, ...n], r));
546
+ break;
547
+ }
548
+ i = i.return;
549
+ }
550
+ };
551
+ } catch {}
552
+ }, Y$1 = (e) => Object.prototype.toString.call(e) === `[object Object]` && (Object.getPrototypeOf(e) === Object.prototype || Object.getPrototypeOf(e) === null), X$1 = (e, t = []) => {
553
+ if (!Y$1(e)) return [{
554
+ path: t,
555
+ value: e
556
+ }];
557
+ let n = [];
558
+ for (let r in e) {
559
+ let i = e[r], a = t.concat(r);
560
+ Y$1(i) ? n.push(...X$1(i, a)) : n.push({
561
+ path: a,
562
+ value: i
563
+ });
564
+ }
565
+ return n;
566
+ }, ke$1 = (e, t) => {
567
+ J$1();
568
+ let n = X$1(t);
569
+ for (let { path: t, value: r } of n) try {
570
+ G$1?.(e, t, r);
571
+ } catch {}
572
+ }, Ae$1 = (e, t, n) => {
573
+ J$1();
574
+ let r = String(t);
575
+ if (Y$1(n)) {
576
+ let t = X$1(n);
577
+ for (let { path: n, value: i } of t) try {
578
+ K$1?.(e, r, n, i);
579
+ } catch {}
580
+ } else try {
581
+ K$1?.(e, r, [], n);
582
+ } catch {}
583
+ }, je$1 = (e, t, n) => {
584
+ if (J$1(), Y$1(n)) {
585
+ let r = X$1(n);
586
+ for (let { path: n, value: i } of r) try {
587
+ q$1?.(e, t, n, i);
588
+ } catch {}
589
+ } else try {
590
+ q$1?.(e, t, [], n);
591
+ } catch {}
592
+ }, Me$1 = (e) => {
593
+ let t$1 = h$2(e.onActive);
594
+ t$1._instrumentationSource = e.name ?? t;
595
+ let n = t$1.onCommitFiberRoot;
596
+ if (e.onCommitFiberRoot) {
597
+ let r = (t, i, a) => {
598
+ n !== r && (n?.(t, i, a), e.onCommitFiberRoot?.(t, i, a));
599
+ };
600
+ t$1.onCommitFiberRoot = r;
601
+ }
602
+ let r = t$1.onCommitFiberUnmount;
603
+ if (e.onCommitFiberUnmount) {
604
+ let n = (i, a) => {
605
+ t$1.onCommitFiberUnmount === n && (r?.(i, a), e.onCommitFiberUnmount?.(i, a));
606
+ };
607
+ t$1.onCommitFiberUnmount = n;
608
+ }
609
+ let i = t$1.onPostCommitFiberRoot;
610
+ if (e.onPostCommitFiberRoot) {
611
+ let n = (r, a) => {
612
+ t$1.onPostCommitFiberRoot === n && (i?.(r, a), e.onPostCommitFiberRoot?.(r, a));
613
+ };
614
+ t$1.onPostCommitFiberRoot = n;
615
+ }
616
+ return t$1;
617
+ }, Z$1 = (e) => {
618
+ let t = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
619
+ if (t?.renderers) for (let n of t.renderers.values()) try {
620
+ let t = n.findFiberByHostInstance?.(e);
621
+ if (t) return t;
622
+ } catch {}
623
+ if (typeof e == `object` && e) {
624
+ if (`_reactRootContainer` in e) return e._reactRootContainer?._internalRoot?.current?.child;
625
+ for (let t in e) if (t.startsWith(`__reactContainer$`) || t.startsWith(`__reactInternalInstance$`) || t.startsWith(`__reactFiber`)) return e[t] || null;
626
+ }
627
+ return null;
628
+ }, Q$1 = Error(), $ = /* @__PURE__ */ new Set(), Ne$1 = (e, n = {}) => {
629
+ let i = e.onActive, a = m$2(), o = o$1(), l = l$1(), u, d = !n.isProduction;
630
+ return e.onActive = () => {
631
+ clearTimeout(u);
632
+ let t = !0;
633
+ try {
634
+ let e = h$2();
635
+ for (let r of e.renderers.values()) {
636
+ let [e] = r.version.split(`.`);
637
+ Number(e) < (n.minReactMajorVersion ?? 17) && (t = !1), F$1(r) === `development` ? d = !0 : n.dangerouslyRunInProduction || (t = !1);
638
+ }
639
+ } catch (e) {
640
+ n.onError?.(e);
641
+ }
642
+ if (!t) {
643
+ e.onCommitFiberRoot = void 0, e.onCommitFiberUnmount = void 0, e.onPostCommitFiberRoot = void 0, e.onActive = void 0;
644
+ return;
645
+ }
646
+ i?.();
647
+ try {
648
+ let t = e.onCommitFiberRoot;
649
+ t && (e.onCommitFiberRoot = (e, r, i) => {
650
+ $.has(r) || $.add(r);
651
+ try {
652
+ t(e, r, i);
653
+ } catch (e) {
654
+ n.onError?.(e);
655
+ }
656
+ });
657
+ let r = e.onCommitFiberUnmount;
658
+ r && (e.onCommitFiberUnmount = (e, t) => {
659
+ try {
660
+ r(e, t);
661
+ } catch (e) {
662
+ n.onError?.(e);
663
+ }
664
+ });
665
+ let i = e.onPostCommitFiberRoot;
666
+ i && (e.onPostCommitFiberRoot = (e, t) => {
667
+ try {
668
+ i(e, t);
669
+ } catch (e) {
670
+ n.onError?.(e);
671
+ }
672
+ });
673
+ } catch (e) {
674
+ n.onError?.(e);
675
+ }
676
+ }, !a && !o && !l && (u = setTimeout(() => {
677
+ d && n.onError?.(Q$1), stop();
678
+ }, n.installCheckTimeout ?? 100)), e;
679
+ };
680
+
681
+ //#endregion
682
+ //#region ../../node_modules/.pnpm/bippy@0.5.39_react@19.2.6/node_modules/bippy/dist/source.js
683
+ /**
684
+ * @license bippy
685
+ *
686
+ * Copyright (c) Aiden Bai
687
+ *
688
+ * This source code is licensed under the MIT license found in the
689
+ * LICENSE file in the root directory of this source tree.
690
+ */
691
+ const i = /^[a-zA-Z][a-zA-Z\d+\-.]*:/, a = [
692
+ `rsc://`,
693
+ `file:///`,
694
+ `webpack-internal://`,
695
+ `webpack://`,
696
+ `node:`,
697
+ `turbopack://`,
698
+ `metro://`,
699
+ `/app-pages-browser/`,
700
+ `/(app-pages-browser)/`
701
+ ], o = [
702
+ `<anonymous>`,
703
+ `eval`,
704
+ ``
705
+ ], s = /\.(jsx|tsx|ts|js)$/, c = /(\.min|bundle|chunk|vendor|vendors|runtime|polyfill|polyfills)\.(js|mjs|cjs)$|(chunk|bundle|vendor|vendors|runtime|polyfill|polyfills|framework|app|main|index)[-_.][A-Za-z0-9_-]{4,}\.(js|mjs|cjs)$|[\da-f]{8,}\.(js|mjs|cjs)$|[-_.][\da-f]{20,}\.(js|mjs|cjs)$|\/dist\/|\/build\/|\/.next\/|\/out\/|\/node_modules\/|\.webpack\.|\.vite\.|\.turbopack\./i, l = /^\?[\w~.-]+(?:=[^&#]*)?(?:&[\w~.-]+(?:=[^&#]*)?)*$/, u = /(^|@)\S+:\d+/, d = /^\s*at .*(\S+:\d+|\(native\))/m, f = /^(eval@)?(\[native code\])?$/, p = (e) => {
706
+ if (e && typeof e == `object`) {
707
+ let t = e.stacktrace;
708
+ return typeof t == `string` ? t : null;
709
+ }
710
+ return null;
711
+ }, m = (e, t) => {
712
+ if (t?.includeInElement !== !1) {
713
+ let n = e.split(`
714
+ `), r = [];
715
+ for (let e of n) if (/^\s*at\s+/.test(e)) {
716
+ let t = _(e, void 0)[0];
717
+ t && r.push(t);
718
+ } else if (/^\s*in\s+/.test(e)) {
719
+ let t = e.replace(/^\s*in\s+/, ``).replace(/\s*\(at .*\)$/, ``);
720
+ r.push({
721
+ functionName: t,
722
+ source: e
723
+ });
724
+ } else if (e.match(u)) {
725
+ let t = v(e, void 0)[0];
726
+ t && r.push(t);
727
+ }
728
+ return g(r, t);
729
+ }
730
+ return e.match(d) ? _(e, t) : v(e, t);
731
+ }, h = (e) => {
732
+ if (!e.includes(`:`)) return [
733
+ e,
734
+ void 0,
735
+ void 0
736
+ ];
737
+ let t = e.startsWith(`(`) && /:\d+\)$/.test(e) ? e.slice(1, -1) : e, n = /(.+?)(?::(\d+))?(?::(\d+))?$/.exec(t);
738
+ return n ? [
739
+ n[1],
740
+ n[2] || void 0,
741
+ n[3] || void 0
742
+ ] : [
743
+ t,
744
+ void 0,
745
+ void 0
746
+ ];
747
+ }, g = (e, t) => t && t.slice != null ? Array.isArray(t.slice) ? e.slice(t.slice[0], t.slice[1]) : e.slice(0, t.slice) : e, ee = (e, t) => _(e.stack, t), _ = (e, t) => g(e.split(`
748
+ `).filter((e) => !!e.match(d)), t).map((e) => {
749
+ let t = e;
750
+ t.includes(`(eval `) && (t = t.replace(/eval code/g, `eval`).replace(/(\(eval at [^()]*)|(,.*$)/g, ``));
751
+ let n = t.replace(/^\s+/, ``).replace(/\(eval code/g, `(`).replace(/^.*?\s+/, ``), r = n.match(/ (\(.+\)$)/);
752
+ n = r ? n.replace(r[0], ``) : n;
753
+ let i = h(r ? r[1] : n);
754
+ return {
755
+ functionName: r && n || void 0,
756
+ fileName: [`eval`, `<anonymous>`].includes(i[0]) ? void 0 : i[0],
757
+ lineNumber: i[1] ? +i[1] : void 0,
758
+ columnNumber: i[2] ? +i[2] : void 0,
759
+ source: t
760
+ };
761
+ }), te = (e, t) => v(e.stack, t), v = (e, t) => g(e.split(`
762
+ `).filter((e) => !e.match(f)), t).map((e) => {
763
+ let t = e;
764
+ if (t.includes(` > eval`) && (t = t.replace(/ line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g, `:$1`)), !t.includes(`@`) && !t.includes(`:`)) return { functionName: t };
765
+ {
766
+ let e = /(([^\n\r"\u2028\u2029]*".[^\n\r"\u2028\u2029]*"[^\n\r@\u2028\u2029]*(?:@[^\n\r"\u2028\u2029]*"[^\n\r@\u2028\u2029]*)*(?:[\n\r\u2028\u2029][^@]*)?)?[^@]*)@/, n = t.match(e), r = n && n[1] ? n[1] : void 0, i = h(t.replace(e, ``));
767
+ return {
768
+ functionName: r,
769
+ fileName: i[0],
770
+ lineNumber: i[1] ? +i[1] : void 0,
771
+ columnNumber: i[2] ? +i[2] : void 0,
772
+ source: t
773
+ };
774
+ }
775
+ }), ne = (e, t) => {
776
+ let n = p(e);
777
+ return !n || e.message.includes(`
778
+ `) && e.message.split(`
779
+ `).length > n.split(`
780
+ `).length ? y(e, t) : e.stack ? re(e, t) : b(e, t);
781
+ }, y = (e, t) => {
782
+ let n = /Line (\d+).*script (?:in )?(\S+)/i, r = e.message.split(`
783
+ `), i = [];
784
+ for (let e = 2, t = r.length; e < t; e += 2) {
785
+ let t = n.exec(r[e]);
786
+ t && i.push({
787
+ fileName: t[2],
788
+ lineNumber: +t[1],
789
+ source: r[e]
790
+ });
791
+ }
792
+ return g(i, t);
793
+ }, b = (e, t) => {
794
+ let n = /Line (\d+).*script (?:in )?(\S+)(?:: In function (\S+))?$/i, r = (p(e) || ``).split(`
795
+ `), i = [];
796
+ for (let e = 0, t = r.length; e < t; e += 2) {
797
+ let t = n.exec(r[e]);
798
+ t && i.push({
799
+ functionName: t[3] || void 0,
800
+ fileName: t[2],
801
+ lineNumber: t[1] ? +t[1] : void 0,
802
+ source: r[e]
803
+ });
804
+ }
805
+ return g(i, t);
806
+ }, re = (e, t) => g(e.stack.split(`
807
+ `).filter((e) => !!e.match(u) && !e.match(/^Error created at/)), t).map((e) => {
808
+ let t = e.split(`@`), n = h(t.pop()), r = t.shift() || ``, i = r.replace(/<anonymous function(: (\w+))?>/, `$2`).replace(/\([^)]*\)/g, ``) || void 0, a;
809
+ return r.match(/\(([^)]*)\)/) && (a = r.replace(/^[^(]+\(([^)]*)\)$/, `$1`)), {
810
+ functionName: i,
811
+ args: a === void 0 || a === `[arguments not available]` ? void 0 : a.split(`,`),
812
+ fileName: n[0],
813
+ lineNumber: n[1] ? +n[1] : void 0,
814
+ columnNumber: n[2] ? +n[2] : void 0,
815
+ source: e
816
+ };
817
+ });
818
+ var ie = 44, ae = `ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/`, oe = new Uint8Array(64), se = new Uint8Array(128);
819
+ for (let e = 0; e < ae.length; e++) {
820
+ let t = ae.charCodeAt(e);
821
+ oe[e] = t, se[t] = e;
822
+ }
823
+ function x(e, t) {
824
+ let n = 0, r = 0, i = 0;
825
+ do
826
+ i = se[e.next()], n |= (i & 31) << r, r += 5;
827
+ while (i & 32);
828
+ let a = n & 1;
829
+ return n >>>= 1, a && (n = -2147483648 | -n), t + n;
830
+ }
831
+ function ce(e, t) {
832
+ return e.pos >= t ? !1 : e.peek() !== ie;
833
+ }
834
+ var le = class {
835
+ constructor(e) {
836
+ this.pos = 0, this.buffer = e;
837
+ }
838
+ next() {
839
+ return this.buffer.charCodeAt(this.pos++);
840
+ }
841
+ peek() {
842
+ return this.buffer.charCodeAt(this.pos);
843
+ }
844
+ indexOf(e) {
845
+ let { buffer: t, pos: n } = this, r = t.indexOf(e, n);
846
+ return r === -1 ? t.length : r;
847
+ }
848
+ };
849
+ function ue(e) {
850
+ let { length: t } = e, n = new le(e), r = [], i = 0, a = 0, o = 0, s = 0, c = 0;
851
+ do {
852
+ let e = n.indexOf(`;`), t = [], l = !0, u = 0;
853
+ for (i = 0; n.pos < e;) {
854
+ let r;
855
+ i = x(n, i), i < u && (l = !1), u = i, ce(n, e) ? (a = x(n, a), o = x(n, o), s = x(n, s), ce(n, e) ? (c = x(n, c), r = [
856
+ i,
857
+ a,
858
+ o,
859
+ s,
860
+ c
861
+ ]) : r = [
862
+ i,
863
+ a,
864
+ o,
865
+ s
866
+ ]) : r = [i], t.push(r), n.pos++;
867
+ }
868
+ l || de(t), r.push(t), n.pos = e + 1;
869
+ } while (n.pos <= t);
870
+ return r;
871
+ }
872
+ function de(e) {
873
+ e.sort(fe);
874
+ }
875
+ function fe(e, t) {
876
+ return e[0] - t[0];
877
+ }
878
+ const pe = /^[a-zA-Z][a-zA-Z\d+\-.]*:/, me = /^data:application\/json[^,]+base64,/, he = /(?:\/\/[@#][ \t]+sourceMappingURL=([^\s'"]+?)[ \t]*$)|(?:\/\*[@#][ \t]+sourceMappingURL=([^*]+?)[ \t]*(?:\*\/)[ \t]*$)/, S = typeof WeakRef < `u`, C = /* @__PURE__ */ new Map(), w = /* @__PURE__ */ new Map(), ge = (e) => S && e instanceof WeakRef, _e = (e, t, n, r) => {
879
+ if (n < 0 || n >= e.length) return null;
880
+ let i = e[n];
881
+ if (!i || i.length === 0) return null;
882
+ let a = null;
883
+ for (let e of i) if (e[0] <= r) a = e;
884
+ else break;
885
+ if (!a || a.length < 4) return null;
886
+ let [, o, s, c] = a;
887
+ if (o === void 0 || s === void 0 || c === void 0) return null;
888
+ let l = t[o];
889
+ return l ? {
890
+ columnNumber: c,
891
+ fileName: l,
892
+ lineNumber: s + 1
893
+ } : null;
894
+ }, T = (e, t, n) => {
895
+ if (e.sections) {
896
+ let r = null;
897
+ for (let i of e.sections) if (t > i.offset.line || t === i.offset.line && n >= i.offset.column) r = i;
898
+ else break;
899
+ if (!r) return null;
900
+ let i = t - r.offset.line, a = t === r.offset.line ? n - r.offset.column : n;
901
+ return _e(r.map.mappings, r.map.sources, i, a);
902
+ }
903
+ return _e(e.mappings, e.sources, t - 1, n);
904
+ }, ve = (e, t) => {
905
+ let n = t.split(`
906
+ `), r;
907
+ for (let e = n.length - 1; e >= 0 && !r; e--) {
908
+ let t = n[e].match(he);
909
+ t && (r = t[1] || t[2]);
910
+ }
911
+ if (!r) return null;
912
+ let i = pe.test(r);
913
+ if (!(me.test(r) || i || r.startsWith(`/`))) {
914
+ let t = e.split(`/`);
915
+ t[t.length - 1] = r, r = t.join(`/`);
916
+ }
917
+ return r;
918
+ }, ye = (e) => ({
919
+ file: e.file,
920
+ mappings: ue(e.mappings),
921
+ names: e.names,
922
+ sourceRoot: e.sourceRoot,
923
+ sources: e.sources,
924
+ sourcesContent: e.sourcesContent,
925
+ version: 3
926
+ }), be = (e) => {
927
+ let t = e.sections.map(({ map: e, offset: t }) => ({
928
+ map: {
929
+ ...e,
930
+ mappings: ue(e.mappings)
931
+ },
932
+ offset: t
933
+ })), n = /* @__PURE__ */ new Set();
934
+ for (let e of t) for (let t of e.map.sources) n.add(t);
935
+ return {
936
+ file: e.file,
937
+ mappings: [],
938
+ names: [],
939
+ sections: t,
940
+ sourceRoot: void 0,
941
+ sources: Array.from(n),
942
+ sourcesContent: void 0,
943
+ version: 3
944
+ };
945
+ }, E = (e) => {
946
+ if (!e) return !1;
947
+ let t = e.trim();
948
+ if (!t) return !1;
949
+ let n = t.match(pe);
950
+ if (!n) return !0;
951
+ let r = n[0].toLowerCase();
952
+ return r === `http:` || r === `https:`;
953
+ }, D = async (e, t = fetch) => {
954
+ if (!E(e)) return null;
955
+ let n;
956
+ try {
957
+ let r = await t(e);
958
+ if (!r.ok) return null;
959
+ n = await r.text();
960
+ } catch {
961
+ return null;
962
+ }
963
+ if (!n) return null;
964
+ let r = ve(e, n);
965
+ if (!r || !E(r)) return null;
966
+ try {
967
+ let e = await t(r);
968
+ if (!e.ok) return null;
969
+ let n = await e.json();
970
+ return `sections` in n ? be(n) : ye(n);
971
+ } catch {
972
+ return null;
973
+ }
974
+ }, O = async (e, t = !0, n) => {
975
+ if (t && C.has(e)) {
976
+ let t = C.get(e);
977
+ if (t == null) return null;
978
+ if (ge(t)) {
979
+ let n = t.deref();
980
+ if (n) return n;
981
+ C.delete(e);
982
+ } else return t;
983
+ }
984
+ if (t && w.has(e)) return w.get(e);
985
+ let r = D(e, n);
986
+ t && w.set(e, r);
987
+ let i = await r;
988
+ return t && w.delete(e), t && (i === null ? C.set(e, null) : C.set(e, S ? new WeakRef(i) : i)), i;
989
+ }, xe = async (e, t = !0, n) => await Promise.all(e.map(async (e) => {
990
+ if (!e.fileName) return e;
991
+ let r = await O(e.fileName, t, n);
992
+ if (!r || typeof e.lineNumber != `number` || typeof e.columnNumber != `number`) return e;
993
+ let i = T(r, e.lineNumber, e.columnNumber);
994
+ return i ? {
995
+ ...e,
996
+ source: i.fileName && e.source ? e.source.replace(e.fileName, i.fileName) : e.source,
997
+ fileName: i.fileName,
998
+ lineNumber: i.lineNumber,
999
+ columnNumber: i.columnNumber,
1000
+ isSymbolicated: !0
1001
+ } : e;
1002
+ })), Se = (e) => e._debugStack instanceof Error && typeof e._debugStack?.stack == `string`, Ce = () => {
1003
+ let n = h$2();
1004
+ for (let t of [...Array.from(d$2), ...Array.from(n.renderers.values())]) {
1005
+ let e = t.currentDispatcherRef;
1006
+ if (e && typeof e == `object`) return `H` in e ? e.H : e.current;
1007
+ }
1008
+ return null;
1009
+ }, k = (t) => {
1010
+ for (let n of d$2) {
1011
+ let e = n.currentDispatcherRef;
1012
+ e && typeof e == `object` && (`H` in e ? e.H = t : e.current = t);
1013
+ }
1014
+ }, A = (e) => `\n in ${e}`, j = (e, t) => {
1015
+ let n = A(e);
1016
+ return t && (n += ` (at ${t})`), n;
1017
+ };
1018
+ let M = !1;
1019
+ const N = (e, t) => {
1020
+ if (!e || M) return ``;
1021
+ let r = Error.prepareStackTrace;
1022
+ Error.prepareStackTrace = void 0, M = !0;
1023
+ let i = Ce();
1024
+ k(null);
1025
+ let a = console.error, o = console.warn;
1026
+ console.error = () => {}, console.warn = () => {};
1027
+ try {
1028
+ let r = { DetermineComponentFrameRoot() {
1029
+ let n;
1030
+ try {
1031
+ if (t) {
1032
+ let t = function() {
1033
+ throw Error();
1034
+ };
1035
+ if (Object.defineProperty(t.prototype, `props`, { set: function() {
1036
+ throw Error();
1037
+ } }), typeof Reflect == `object` && Reflect.construct) {
1038
+ try {
1039
+ Reflect.construct(t, []);
1040
+ } catch (e) {
1041
+ n = e;
1042
+ }
1043
+ Reflect.construct(e, [], t);
1044
+ } else {
1045
+ try {
1046
+ t.call();
1047
+ } catch (e) {
1048
+ n = e;
1049
+ }
1050
+ e.call(t.prototype);
1051
+ }
1052
+ } else {
1053
+ try {
1054
+ throw Error();
1055
+ } catch (e) {
1056
+ n = e;
1057
+ }
1058
+ let t = e();
1059
+ t && typeof t.catch == `function` && t.catch(() => {});
1060
+ }
1061
+ } catch (e) {
1062
+ if (e instanceof Error && n instanceof Error && typeof e.stack == `string`) return [e.stack, n.stack];
1063
+ }
1064
+ return [null, null];
1065
+ } };
1066
+ r.DetermineComponentFrameRoot.displayName = `DetermineComponentFrameRoot`, Object.getOwnPropertyDescriptor(r.DetermineComponentFrameRoot, `name`)?.configurable && Object.defineProperty(r.DetermineComponentFrameRoot, `name`, { value: `DetermineComponentFrameRoot` });
1067
+ let [i, a] = r.DetermineComponentFrameRoot();
1068
+ if (i && a) {
1069
+ let t = i.split(`
1070
+ `), r = a.split(`
1071
+ `), o = 0, s = 0;
1072
+ for (; o < t.length && !t[o].includes(`DetermineComponentFrameRoot`);) o++;
1073
+ for (; s < r.length && !r[s].includes(`DetermineComponentFrameRoot`);) s++;
1074
+ if (o === t.length || s === r.length) for (o = t.length - 1, s = r.length - 1; o >= 1 && s >= 0 && t[o] !== r[s];) s--;
1075
+ for (; o >= 1 && s >= 0; o--, s--) if (t[o] !== r[s]) {
1076
+ if (o !== 1 || s !== 1) do
1077
+ if (o--, s--, s < 0 || t[o] !== r[s]) {
1078
+ let r = `\n${t[o].replace(` at new `, ` at `)}`, i = we$1(e);
1079
+ return i && r.includes(`<anonymous>`) && (r = r.replace(`<anonymous>`, i)), r;
1080
+ }
1081
+ while (o >= 1 && s >= 0);
1082
+ break;
1083
+ }
1084
+ }
1085
+ } finally {
1086
+ M = !1, Error.prepareStackTrace = r, k(i), console.error = a, console.warn = o;
1087
+ }
1088
+ let s = e ? we$1(e) : ``;
1089
+ return s ? A(s) : ``;
1090
+ }, P = (e, t) => {
1091
+ let n = e.tag, r = ``;
1092
+ switch (n) {
1093
+ case 28:
1094
+ r = A(`Activity`);
1095
+ break;
1096
+ case 1:
1097
+ r = N(e.type, !0);
1098
+ break;
1099
+ case 11:
1100
+ r = N(e.type.render, !1);
1101
+ break;
1102
+ case 0:
1103
+ case 15:
1104
+ r = N(e.type, !1);
1105
+ break;
1106
+ case 5:
1107
+ case 26:
1108
+ case 27:
1109
+ r = A(e.type);
1110
+ break;
1111
+ case 16:
1112
+ r = A(`Lazy`);
1113
+ break;
1114
+ case 13:
1115
+ r = e.child !== t && t !== null ? A(`Suspense Fallback`) : A(`Suspense`);
1116
+ break;
1117
+ case 19:
1118
+ r = A(`SuspenseList`);
1119
+ break;
1120
+ case 30:
1121
+ r = A(`ViewTransition`);
1122
+ break;
1123
+ default: return ``;
1124
+ }
1125
+ return r;
1126
+ }, F = (e) => {
1127
+ try {
1128
+ let t = ``, n = e, r = null;
1129
+ do {
1130
+ t += P(n, r);
1131
+ let e = n._debugInfo;
1132
+ if (e && Array.isArray(e)) for (let n = e.length - 1; n >= 0; n--) {
1133
+ let r = e[n];
1134
+ typeof r.name == `string` && (t += j(r.name, r.env));
1135
+ }
1136
+ r = n, n = n.return;
1137
+ } while (n);
1138
+ return t;
1139
+ } catch (e) {
1140
+ return e instanceof Error ? `\nError generating stack: ${e.message}\n${e.stack}` : ``;
1141
+ }
1142
+ }, I = (e) => {
1143
+ let t = Error.prepareStackTrace;
1144
+ Error.prepareStackTrace = void 0;
1145
+ let n = e;
1146
+ if (!n) return ``;
1147
+ Error.prepareStackTrace = t, n.startsWith(`Error: react-stack-top-frame
1148
+ `) && (n = n.slice(29));
1149
+ let r = n.indexOf(`
1150
+ `);
1151
+ if (r !== -1 && (n = n.slice(r + 1)), r = Math.max(n.indexOf(`react_stack_bottom_frame`), n.indexOf(`react-stack-bottom-frame`)), r !== -1 && (r = n.lastIndexOf(`
1152
+ `, r)), r !== -1) n = n.slice(0, r);
1153
+ else return ``;
1154
+ return n;
1155
+ }, we = (e) => !!(e.fileName?.startsWith(`rsc://`) && e.functionName), Te = (e, t) => e.fileName === t.fileName && e.lineNumber === t.lineNumber && e.columnNumber === t.columnNumber, Ee = (e) => {
1156
+ let t = /* @__PURE__ */ new Map();
1157
+ for (let n of e) for (let e of n.stackFrames) {
1158
+ if (!we(e)) continue;
1159
+ let n = e.functionName, r = t.get(n) ?? [];
1160
+ r.some((t) => Te(t, e)) || (r.push(e), t.set(n, r));
1161
+ }
1162
+ return t;
1163
+ }, De = (e, t, n) => {
1164
+ if (!e.functionName) return {
1165
+ ...e,
1166
+ isServer: !0
1167
+ };
1168
+ let r = t.get(e.functionName);
1169
+ if (!r || r.length === 0) return {
1170
+ ...e,
1171
+ isServer: !0
1172
+ };
1173
+ let i = n.get(e.functionName) ?? 0, a = r[i % r.length];
1174
+ return n.set(e.functionName, i + 1), {
1175
+ ...e,
1176
+ isServer: !0,
1177
+ fileName: a.fileName,
1178
+ lineNumber: a.lineNumber,
1179
+ columnNumber: a.columnNumber,
1180
+ source: e.source?.replace(`(at Server)`, `(${a.fileName}:${a.lineNumber}:${a.columnNumber})`)
1181
+ };
1182
+ }, Oe = (e) => {
1183
+ let t = [];
1184
+ return j$1(e, (e) => {
1185
+ if (!Se(e)) return;
1186
+ let r = typeof e.type == `string` ? e.type : we$1(e.type) || `<anonymous>`;
1187
+ t.push({
1188
+ componentName: r,
1189
+ stackFrames: m(I(e._debugStack?.stack))
1190
+ });
1191
+ }, !0), t;
1192
+ }, L = async (e, t = !0, n) => {
1193
+ let r = Oe(e), i = m(F(e)), a = Ee(r), o = /* @__PURE__ */ new Map();
1194
+ return xe(i.map((e) => e.source?.includes(`(at Server)`) ?? !1 ? De(e, a, o) : e).filter((e, t, n) => {
1195
+ if (t === 0) return !0;
1196
+ let r = n[t - 1];
1197
+ return e.functionName !== r.functionName;
1198
+ }), t, n);
1199
+ }, R = (e) => {
1200
+ let t = e._debugSource;
1201
+ return t ? typeof t == `object` && !!t && `fileName` in t && typeof t.fileName == `string` && `lineNumber` in t && typeof t.lineNumber == `number` : !1;
1202
+ }, ke = async (e, t = !0, n) => {
1203
+ if (R(e)) return e._debugSource || null;
1204
+ let r = await L(e, t, n);
1205
+ for (let e of r) if (e.fileName) return {
1206
+ fileName: e.fileName,
1207
+ lineNumber: e.lineNumber,
1208
+ columnNumber: e.columnNumber,
1209
+ functionName: e.functionName
1210
+ };
1211
+ return null;
1212
+ }, z = (e) => e.split(`/`).filter(Boolean).length, Ae = (e) => e.split(`/`).filter(Boolean)[0] ?? null, je = (e) => {
1213
+ let t = e.indexOf(`/`, 1);
1214
+ if (t === -1 || z(e.slice(0, t)) !== 1) return e;
1215
+ let n = e.slice(t);
1216
+ if (!s.test(n) || z(n) < 2) return e;
1217
+ let r = Ae(n);
1218
+ return !r || r.startsWith(`@`) || r.length > 4 ? e : n;
1219
+ }, Me = (e) => {
1220
+ if (!e || o.some((t) => t === e)) return ``;
1221
+ let t = e, n = t.startsWith(`http://`) || t.startsWith(`https://`);
1222
+ if (n) try {
1223
+ t = new URL(t).pathname;
1224
+ } catch {}
1225
+ if (n && (t = je(t)), t.startsWith(`about://React/`)) {
1226
+ let e = t.slice(14), n = e.indexOf(`/`), r = e.indexOf(`:`);
1227
+ t = n !== -1 && (r === -1 || n < r) ? e.slice(n + 1) : e;
1228
+ }
1229
+ let r = !0;
1230
+ for (; r;) {
1231
+ r = !1;
1232
+ for (let e of a) if (t.startsWith(e)) {
1233
+ t = t.slice(e.length), e === `file:///` && (t = `/${t.replace(/^\/+/, ``)}`), r = !0;
1234
+ break;
1235
+ }
1236
+ }
1237
+ if (i.test(t)) {
1238
+ let e = t.match(i);
1239
+ e && (t = t.slice(e[0].length));
1240
+ }
1241
+ if (t.startsWith(`//`)) {
1242
+ let e = t.indexOf(`/`, 2);
1243
+ t = e === -1 ? `` : t.slice(e);
1244
+ }
1245
+ let s = t.indexOf(`?`);
1246
+ if (s !== -1) {
1247
+ let e = t.slice(s);
1248
+ l.test(e) && (t = t.slice(0, s));
1249
+ }
1250
+ return t;
1251
+ }, Ne = (e) => {
1252
+ let t = Me(e);
1253
+ return !(!t || !s.test(t) || c.test(t));
1254
+ }, Pe = (e, t) => {
1255
+ let n = e.split(`
1256
+ `), r = t - 1;
1257
+ if (r < 0 || r >= n.length) return null;
1258
+ let i = Math.max(0, r - 5), a = Math.min(n.length, r + 5), o = n.slice(i, a).join(`
1259
+ `), s = /(?:^|export\s+)(?:const|let|var)\s+(\w+)\s*=/m, c = /(?:^|export\s+)function\s+(\w+)/m, l = /(?:^|export\s+)class\s+(\w+)/m, u = o.match(s);
1260
+ if (u?.[1]) return u[1];
1261
+ let d = o.match(c);
1262
+ if (d?.[1]) return d[1];
1263
+ let f = o.match(l);
1264
+ return f?.[1] ? f[1] : null;
1265
+ }, Fe = async (e, t = !0, r) => {
1266
+ let i = (await L(e, t, r)).filter((e) => e.fileName)[0];
1267
+ if (!i?.fileName) return we$1(e.type);
1268
+ let a = await O(i.fileName, t, r);
1269
+ if (!a) return we$1(e.type);
1270
+ let o = null;
1271
+ if (typeof i.lineNumber == `number` && typeof i.columnNumber == `number` && (o = T(a, i.lineNumber, i.columnNumber)), !o?.fileName || !o.lineNumber || !a.sourcesContent) return we$1(e.type);
1272
+ let s = a.sources.indexOf(o.fileName);
1273
+ if (s === -1 || !a.sourcesContent[s]) return we$1(e.type);
1274
+ let c = a.sourcesContent[s];
1275
+ return Pe(c, o.lineNumber) || we$1(e.type);
1276
+ }, Ie = Symbol.for(`react.context`), Le = Symbol.for(`react.memo_cache_sentinel`);
1277
+ let B = [], V = null, H = null, U = null, W = null, G = 0, K = null;
1278
+ const q = Error("Suspense Exception: This is not a real error! It's an implementation detail of `use` to interrupt the current render."), J = (e) => m(e.stack || ``, { includeInElement: !1 }), Y = () => {
1279
+ let e = U;
1280
+ return e !== null && (U = e.next), e;
1281
+ }, X = (e) => {
1282
+ if (H === null) return e._currentValue;
1283
+ if (W === null) throw Error(`Context reads do not line up with context dependencies.`);
1284
+ if (Object.prototype.hasOwnProperty.call(W, `memoizedValue`)) {
1285
+ let e = W.memoizedValue;
1286
+ return W = W.next, e;
1287
+ }
1288
+ return e._currentValue;
1289
+ }, Re = () => {
1290
+ let n = h$2(), r = [...d$2, ...n.renderers.values()];
1291
+ for (let e of r) {
1292
+ let t = e.currentDispatcherRef;
1293
+ if (t && typeof t == `object`) return t;
1294
+ }
1295
+ return null;
1296
+ }, ze = (e) => `H` in e ? e.H : e.current, Be = (e, t) => {
1297
+ `H` in e ? e.H = t : e.current = t;
1298
+ }, Z = (e, t, n, r = null) => {
1299
+ B.push({
1300
+ displayName: r,
1301
+ primitive: e,
1302
+ stackError: Error(),
1303
+ value: t,
1304
+ dispatcherHookName: n
1305
+ });
1306
+ }, Ve = (e) => {
1307
+ if (typeof e == `object` && e) {
1308
+ let t = e;
1309
+ if (typeof t.then == `function`) {
1310
+ let e = K !== null && G < K.length ? K[G++] : t;
1311
+ switch (e.status) {
1312
+ case `fulfilled`: return Z(`Promise`, e.value, `Use`), e.value;
1313
+ case `rejected`: throw e.reason;
1314
+ }
1315
+ throw Z(`Unresolved`, e, `Use`), q;
1316
+ }
1317
+ if (t.$$typeof === Ie && `_currentValue` in t) {
1318
+ let e = t, n = X(e);
1319
+ return Z(`Context (use)`, n, `Use`, e.displayName || `Context`), n;
1320
+ }
1321
+ }
1322
+ throw Error(`An unsupported type was passed to use(): ` + String(e));
1323
+ }, He = (e) => {
1324
+ let t = X(e);
1325
+ return Z(`Context`, t, `Context`, e.displayName || null), t;
1326
+ }, Ue = (e) => {
1327
+ let t = Y(), n = t === null ? typeof e == `function` ? e() : e : t.memoizedState;
1328
+ return Z(`State`, n, `State`), [n, () => {}];
1329
+ }, We = (e, t, n) => {
1330
+ let r = Y(), i = r === null ? n === void 0 ? t : n(t) : r.memoizedState;
1331
+ return Z(`Reducer`, i, `Reducer`), [i, () => {}];
1332
+ }, Ge = (e) => {
1333
+ let t = Y(), n = t === null ? { current: e } : t.memoizedState;
1334
+ return Z(`Ref`, n.current, `Ref`), n;
1335
+ }, Ke = () => {
1336
+ let e = Y();
1337
+ return Z(`CacheRefresh`, e === null ? () => {} : e.memoizedState, `CacheRefresh`), () => {};
1338
+ }, qe = (e) => {
1339
+ Y(), Z(`LayoutEffect`, e, `LayoutEffect`);
1340
+ }, Je = (e) => {
1341
+ Y(), Z(`InsertionEffect`, e, `InsertionEffect`);
1342
+ }, Ye = (e) => {
1343
+ Y(), Z(`Effect`, e, `Effect`);
1344
+ }, Xe = (e) => {
1345
+ Y();
1346
+ let t;
1347
+ typeof e == `object` && e && `current` in e && (t = e.current), Z(`ImperativeHandle`, t, `ImperativeHandle`);
1348
+ }, Ze = (e, t) => {
1349
+ Z(`DebugValue`, typeof t == `function` ? t(e) : e, `DebugValue`);
1350
+ }, Qe = (e) => {
1351
+ let t = Y();
1352
+ return Z(`Callback`, t === null ? e : t.memoizedState[0], `Callback`), e;
1353
+ }, $e = (e) => {
1354
+ let t = Y(), n = t === null ? e() : t.memoizedState[0];
1355
+ return Z(`Memo`, n, `Memo`), n;
1356
+ }, et = (e, t) => {
1357
+ let n = Y();
1358
+ Y();
1359
+ let r = n === null ? t() : n.memoizedState;
1360
+ return Z(`SyncExternalStore`, r, `SyncExternalStore`), r;
1361
+ }, tt = () => {
1362
+ let e = Y();
1363
+ Y();
1364
+ let t = e === null ? !1 : e.memoizedState;
1365
+ return Z(`Transition`, t, `Transition`), [t, () => {}];
1366
+ }, nt = (e) => {
1367
+ let t = Y(), n = t === null ? e : t.memoizedState;
1368
+ return Z(`DeferredValue`, n, `DeferredValue`), n;
1369
+ }, rt = () => {
1370
+ let e = Y(), t = e === null ? `` : e.memoizedState;
1371
+ return Z(`Id`, t, `Id`), t;
1372
+ }, it = (e) => {
1373
+ let t = H;
1374
+ if (t == null) return [];
1375
+ let n = t.updateQueue?.memoCache;
1376
+ if (n == null) return [];
1377
+ let r = n.data[n.index];
1378
+ return r === void 0 && (r = n.data[n.index] = Array.from({ length: e }, () => Le)), n.index++, r;
1379
+ }, at = (e) => {
1380
+ let t = Y(), n = t === null ? e : t.memoizedState;
1381
+ return Z(`Optimistic`, n, `Optimistic`), [n, () => {}];
1382
+ }, ot = (e, t) => {
1383
+ let n, r = null;
1384
+ if (e !== null) {
1385
+ let t = e.memoizedState;
1386
+ if (typeof t == `object` && t && `then` in t && typeof t.then == `function`) {
1387
+ let e = t;
1388
+ switch (e.status) {
1389
+ case `fulfilled`:
1390
+ n = e.value;
1391
+ break;
1392
+ case `rejected`:
1393
+ r = e.reason;
1394
+ break;
1395
+ default: r = q, n = e;
1396
+ }
1397
+ } else n = t;
1398
+ } else n = t;
1399
+ return {
1400
+ value: n,
1401
+ error: r
1402
+ };
1403
+ }, st = (e) => (t, n) => {
1404
+ let r = Y();
1405
+ Y(), Y();
1406
+ let i = Error(), { value: a, error: o } = ot(r, n);
1407
+ if (B.push({
1408
+ displayName: null,
1409
+ primitive: e,
1410
+ stackError: i,
1411
+ value: a,
1412
+ dispatcherHookName: e
1413
+ }), o !== null) throw o;
1414
+ return [
1415
+ a,
1416
+ () => {},
1417
+ !1
1418
+ ];
1419
+ }, ct = st(`ActionState`), Q = {
1420
+ readContext: X,
1421
+ use: Ve,
1422
+ useCallback: Qe,
1423
+ useContext: He,
1424
+ useEffect: Ye,
1425
+ useImperativeHandle: Xe,
1426
+ useLayoutEffect: qe,
1427
+ useInsertionEffect: Je,
1428
+ useMemo: $e,
1429
+ useReducer: We,
1430
+ useRef: Ge,
1431
+ useState: Ue,
1432
+ useDebugValue: Ze,
1433
+ useDeferredValue: nt,
1434
+ useTransition: tt,
1435
+ useSyncExternalStore: et,
1436
+ useId: rt,
1437
+ useHostTransitionStatus: () => {
1438
+ let e = X({ _currentValue: null });
1439
+ return Z(`HostTransitionStatus`, e, `HostTransitionStatus`), e;
1440
+ },
1441
+ useFormState: st(`FormState`),
1442
+ useActionState: ct,
1443
+ useOptimistic: at,
1444
+ useMemoCache: it,
1445
+ useCacheRefresh: Ke,
1446
+ useEffectEvent: (e) => (Y(), Z(`EffectEvent`, e, `EffectEvent`), e)
1447
+ }, lt = typeof Proxy > `u` ? Q : new Proxy(Q, { get(e, t) {
1448
+ if (Object.prototype.hasOwnProperty.call(e, t)) return e[t];
1449
+ let n = Error(`Missing method in Dispatcher: ` + t);
1450
+ throw n.name = `ReactDebugToolsUnsupportedHookError`, n;
1451
+ } }), ut = () => {
1452
+ if (V !== null) return V;
1453
+ let e = /* @__PURE__ */ new Map(), t;
1454
+ try {
1455
+ if (Q.useContext({ _currentValue: null }), Q.useState(null), Q.useReducer((e) => e, null), Q.useRef(null), typeof Q.useCacheRefresh == `function` && Q.useCacheRefresh(), Q.useLayoutEffect(() => {}), Q.useInsertionEffect(() => {}), Q.useEffect(() => {}), Q.useImperativeHandle(void 0, () => null), Q.useDebugValue(null), Q.useCallback(() => {}), Q.useTransition(), Q.useSyncExternalStore(() => () => {}, () => null, () => null), Q.useDeferredValue(null), Q.useMemo(() => null), Q.useOptimistic(null, (e) => e), Q.useFormState((e) => e, null), Q.useActionState((e) => e, null), Q.useHostTransitionStatus(), typeof Q.useMemoCache == `function` && Q.useMemoCache(0), typeof Q.use == `function`) {
1456
+ Q.use({
1457
+ $$typeof: Ie,
1458
+ _currentValue: null
1459
+ }), Q.use({
1460
+ then() {},
1461
+ status: `fulfilled`,
1462
+ value: null
1463
+ });
1464
+ try {
1465
+ Q.use({ then() {} });
1466
+ } catch {}
1467
+ }
1468
+ Q.useId(), typeof Q.useEffectEvent == `function` && Q.useEffectEvent(() => {});
1469
+ } finally {
1470
+ t = B, B = [];
1471
+ }
1472
+ for (let n of t) e.set(n.primitive, J(n.stackError));
1473
+ return V = e, V;
1474
+ };
1475
+
1476
+ //#endregion
1477
+ //#region ../../node_modules/.pnpm/bippy@0.5.39_react@19.2.6/node_modules/bippy/dist/install-hook-only.js
1478
+ /**
1479
+ * @license bippy
1480
+ *
1481
+ * Copyright (c) Aiden Bai
1482
+ *
1483
+ * This source code is licensed under the MIT license found in the
1484
+ * LICENSE file in the root directory of this source tree.
1485
+ */
1486
+ _$2();
1487
+
1488
+ //#endregion
1489
+ //#region ../../node_modules/.pnpm/bippy@0.5.39_react@19.2.6/node_modules/bippy/dist/index.js
1490
+ /**
1491
+ * @license bippy
1492
+ *
1493
+ * Copyright (c) Aiden Bai
1494
+ *
1495
+ * This source code is licensed under the MIT license found in the
1496
+ * LICENSE file in the root directory of this source tree.
1497
+ */
1498
+
1499
+ //#endregion
1500
+ //#region src/utils/truncate-string.ts
1501
+ const truncateString = (text, maxLength) => text.length > maxLength ? `${text.slice(0, maxLength)}...` : text;
1502
+
1503
+ //#endregion
1504
+ //#region src/utils/get-next-base-path.ts
1505
+ let cachedNextBasePath;
1506
+ const getNextBasePath = () => {
1507
+ if (cachedNextBasePath !== void 0) return cachedNextBasePath;
1508
+ const source = document.querySelector("script[src*=\"/_next/\"]")?.src;
1509
+ const pathname = source ? new URL(source).pathname : "";
1510
+ const assetPathIndex = pathname.indexOf("/_next/");
1511
+ cachedNextBasePath = assetPathIndex > 0 ? pathname.slice(0, assetPathIndex) : "";
1512
+ return cachedNextBasePath;
1513
+ };
1514
+
1515
+ //#endregion
1516
+ //#region src/utils/normalize-file-path.ts
1517
+ const BUNDLER_LAYER_PREFIX_REGEX = /^(?:\.\/)?\/?\([a-z][a-z0-9-]*\)\//;
1518
+ const normalizeFilePath = (fileName) => {
1519
+ let normalized = Me(fileName);
1520
+ normalized = normalized.replace(BUNDLER_LAYER_PREFIX_REGEX, "");
1521
+ if (normalized.startsWith("./")) normalized = normalized.slice(2);
1522
+ return normalized;
1523
+ };
1524
+
1525
+ //#endregion
1526
+ //#region src/utils/strip-internal-attributes.ts
1527
+ const INTERNAL_ATTRIBUTE_PATTERN = /\s+data-react-grab-[\w-]*(="[^"]*")?/g;
1528
+ const isInternalAttribute = (name) => name.startsWith("data-react-grab-");
1529
+ const stripInternalAttributes = (html) => html.replace(INTERNAL_ATTRIBUTE_PATTERN, "");
1530
+
1531
+ //#endregion
1532
+ //#region src/core/context.ts
1533
+ const NON_COMPONENT_PREFIXES = new Set([
1534
+ "_",
1535
+ "$",
1536
+ "motion.",
1537
+ "styled.",
1538
+ "chakra.",
1539
+ "ark.",
1540
+ "Primitive.",
1541
+ "Slot."
1542
+ ]);
1543
+ const NEXT_INTERNAL_COMPONENT_NAMES = new Set([
1544
+ "InnerLayoutRouter",
1545
+ "RedirectErrorBoundary",
1546
+ "RedirectBoundary",
1547
+ "HTTPAccessFallbackErrorBoundary",
1548
+ "HTTPAccessFallbackBoundary",
1549
+ "LoadingBoundary",
1550
+ "ErrorBoundary",
1551
+ "InnerScrollAndFocusHandler",
1552
+ "ScrollAndFocusHandler",
1553
+ "RenderFromTemplateContext",
1554
+ "OuterLayoutRouter",
1555
+ "body",
1556
+ "html",
1557
+ "DevRootHTTPAccessFallbackBoundary",
1558
+ "AppDevOverlayErrorBoundary",
1559
+ "AppDevOverlay",
1560
+ "HotReload",
1561
+ "Router",
1562
+ "ErrorBoundaryHandler",
1563
+ "AppRouter",
1564
+ "ServerRoot",
1565
+ "SegmentStateProvider",
1566
+ "RootErrorBoundary",
1567
+ "LoadableComponent",
1568
+ "MotionDOMComponent"
1569
+ ]);
1570
+ const REACT_INTERNAL_COMPONENT_NAMES = new Set([
1571
+ "Suspense",
1572
+ "Fragment",
1573
+ "StrictMode",
1574
+ "Profiler",
1575
+ "SuspenseList"
1576
+ ]);
1577
+ let cachedIsNextProject;
1578
+ const checkIsNextProject = (revalidate) => {
1579
+ if (revalidate) cachedIsNextProject = void 0;
1580
+ cachedIsNextProject ??= typeof document !== "undefined" && Boolean(document.getElementById("__NEXT_DATA__") || document.querySelector("nextjs-portal"));
1581
+ return cachedIsNextProject;
1582
+ };
1583
+ const isInternalComponentName = (name) => {
1584
+ if (NEXT_INTERNAL_COMPONENT_NAMES.has(name)) return true;
1585
+ if (REACT_INTERNAL_COMPONENT_NAMES.has(name)) return true;
1586
+ for (const prefix of NON_COMPONENT_PREFIXES) if (name.startsWith(prefix)) return true;
1587
+ return false;
1588
+ };
1589
+ const isUsefulComponentName = (name) => {
1590
+ if (!name) return false;
1591
+ if (isInternalComponentName(name)) return false;
1592
+ if (name === "SlotClone" || name === "Slot") return false;
1593
+ return true;
1594
+ };
1595
+ const isSourceComponentName = (name) => {
1596
+ if (name.length <= 1) return false;
1597
+ if (isInternalComponentName(name)) return false;
1598
+ if (name[0] !== name[0].toUpperCase()) return false;
1599
+ if (name.endsWith("Provider") || name.endsWith("Context")) return false;
1600
+ return true;
1601
+ };
1602
+ const SERVER_COMPONENT_URL_PREFIXES = ["about://React/", "rsc://React/"];
1603
+ const isServerComponentUrl = (url) => SERVER_COMPONENT_URL_PREFIXES.some((prefix) => url.startsWith(prefix));
1604
+ const devirtualizeServerUrl = (url) => {
1605
+ for (const prefix of SERVER_COMPONENT_URL_PREFIXES) {
1606
+ if (!url.startsWith(prefix)) continue;
1607
+ const environmentEndIndex = url.indexOf("/", prefix.length);
1608
+ const querySuffixIndex = url.lastIndexOf("?");
1609
+ if (environmentEndIndex > -1 && querySuffixIndex > -1) return decodeURI(url.slice(environmentEndIndex + 1, querySuffixIndex));
1610
+ }
1611
+ return url;
1612
+ };
1613
+ const symbolicateServerFrames = async (frames) => {
1614
+ const serverFrameIndices = [];
1615
+ const requestFrames = [];
1616
+ for (let frameIndex = 0; frameIndex < frames.length; frameIndex++) {
1617
+ const frame = frames[frameIndex];
1618
+ if (!frame.isServer || !frame.fileName) continue;
1619
+ serverFrameIndices.push(frameIndex);
1620
+ requestFrames.push({
1621
+ file: devirtualizeServerUrl(frame.fileName),
1622
+ methodName: frame.functionName ?? "<unknown>",
1623
+ line1: frame.lineNumber ?? null,
1624
+ column1: frame.columnNumber ?? null,
1625
+ arguments: []
1626
+ });
1627
+ }
1628
+ if (requestFrames.length === 0) return frames;
1629
+ const controller = new AbortController();
1630
+ const timeout = setTimeout(() => controller.abort(), SYMBOLICATION_TIMEOUT_MS);
1631
+ try {
1632
+ const response = await fetch(`${getNextBasePath()}/__nextjs_original-stack-frames`, {
1633
+ method: "POST",
1634
+ headers: { "Content-Type": "application/json" },
1635
+ body: JSON.stringify({
1636
+ frames: requestFrames,
1637
+ isServer: true,
1638
+ isEdgeServer: false,
1639
+ isAppDirectory: true
1640
+ }),
1641
+ signal: controller.signal
1642
+ });
1643
+ if (!response.ok) return frames;
1644
+ const results = await response.json();
1645
+ const resolvedFrames = [...frames];
1646
+ for (let resultIndex = 0; resultIndex < serverFrameIndices.length; resultIndex++) {
1647
+ const result = results[resultIndex];
1648
+ if (result?.status !== "fulfilled") continue;
1649
+ const resolved = result.value?.originalStackFrame;
1650
+ if (!resolved?.file || resolved.ignored) continue;
1651
+ const originalFrameIndex = serverFrameIndices[resultIndex];
1652
+ resolvedFrames[originalFrameIndex] = {
1653
+ ...frames[originalFrameIndex],
1654
+ fileName: resolved.file,
1655
+ lineNumber: resolved.line1 ?? void 0,
1656
+ columnNumber: resolved.column1 ?? void 0,
1657
+ isSymbolicated: true
1658
+ };
1659
+ }
1660
+ return resolvedFrames;
1661
+ } catch {
1662
+ return frames;
1663
+ } finally {
1664
+ clearTimeout(timeout);
1665
+ }
1666
+ };
1667
+ const extractServerFramesFromDebugStack = (rootFiber) => {
1668
+ const serverFramesByName = /* @__PURE__ */ new Map();
1669
+ j$1(rootFiber, (currentFiber) => {
1670
+ if (!Se(currentFiber)) return false;
1671
+ const ownerStack = I(currentFiber._debugStack.stack);
1672
+ if (!ownerStack) return false;
1673
+ for (const frame of m(ownerStack)) {
1674
+ if (!frame.functionName || !frame.fileName) continue;
1675
+ if (!isServerComponentUrl(frame.fileName)) continue;
1676
+ if (serverFramesByName.has(frame.functionName)) continue;
1677
+ serverFramesByName.set(frame.functionName, {
1678
+ ...frame,
1679
+ isServer: true
1680
+ });
1681
+ }
1682
+ return false;
1683
+ }, true);
1684
+ return serverFramesByName;
1685
+ };
1686
+ const enrichServerFrameLocations = (rootFiber, frames) => {
1687
+ if (!frames.some((frame) => frame.isServer && !frame.fileName && frame.functionName)) return frames;
1688
+ const serverFramesByName = extractServerFramesFromDebugStack(rootFiber);
1689
+ if (serverFramesByName.size === 0) return frames;
1690
+ return frames.map((frame) => {
1691
+ if (!frame.isServer || frame.fileName || !frame.functionName) return frame;
1692
+ const resolved = serverFramesByName.get(frame.functionName);
1693
+ if (!resolved) return frame;
1694
+ return {
1695
+ ...frame,
1696
+ fileName: resolved.fileName,
1697
+ lineNumber: resolved.lineNumber,
1698
+ columnNumber: resolved.columnNumber
1699
+ };
1700
+ });
1701
+ };
1702
+ const findNearestFiberElement = (element) => {
1703
+ if (!Te$1()) return element;
1704
+ let current = element;
1705
+ while (current) {
1706
+ if (Z$1(current)) return current;
1707
+ current = current.parentElement;
1708
+ }
1709
+ return element;
1710
+ };
1711
+ const stackCache = /* @__PURE__ */ new WeakMap();
1712
+ const fetchStackForElement = async (element) => {
1713
+ try {
1714
+ const fiber = Z$1(element);
1715
+ if (!fiber) return null;
1716
+ const frames = await L(fiber);
1717
+ if (checkIsNextProject()) return await symbolicateServerFrames(enrichServerFrameLocations(fiber, frames));
1718
+ return frames;
1719
+ } catch {
1720
+ return null;
1721
+ }
1722
+ };
1723
+ const getStack = (element) => {
1724
+ if (!Te$1()) return Promise.resolve([]);
1725
+ const resolvedElement = findNearestFiberElement(element);
1726
+ const cached = stackCache.get(resolvedElement);
1727
+ if (cached) return cached;
1728
+ const promise = fetchStackForElement(resolvedElement);
1729
+ stackCache.set(resolvedElement, promise);
1730
+ return promise;
1731
+ };
1732
+ const getNearestComponentName = async (element) => {
1733
+ if (!Te$1()) return null;
1734
+ const stack = await getStack(element);
1735
+ if (!stack) return null;
1736
+ for (const frame of stack) if (frame.functionName && isSourceComponentName(frame.functionName)) return frame.functionName;
1737
+ return null;
1738
+ };
1739
+ const resolveSource = async (element) => {
1740
+ const stack = await getStack(findNearestFiberElement(element));
1741
+ if (!stack || stack.length === 0) return null;
1742
+ const sourceFrames = stack.filter((frame) => frame.fileName && Ne(frame.fileName));
1743
+ const resolvedFrame = sourceFrames.find((frame) => frame.functionName && isSourceComponentName(frame.functionName)) ?? sourceFrames[0];
1744
+ if (!resolvedFrame?.fileName) return null;
1745
+ return {
1746
+ filePath: normalizeFilePath(resolvedFrame.fileName),
1747
+ lineNumber: resolvedFrame.lineNumber ?? null,
1748
+ columnNumber: resolvedFrame.columnNumber ?? null,
1749
+ componentName: resolvedFrame.functionName && isSourceComponentName(resolvedFrame.functionName) ? resolvedFrame.functionName : null
1750
+ };
1751
+ };
1752
+ const getComponentDisplayName = (element) => {
1753
+ if (!Te$1()) return null;
1754
+ const fiber = Z$1(findNearestFiberElement(element));
1755
+ if (!fiber) return null;
1756
+ let currentFiber = fiber.return;
1757
+ while (currentFiber) {
1758
+ if (ve$1(currentFiber)) {
1759
+ const name = we$1(currentFiber.type);
1760
+ if (name && isUsefulComponentName(name)) return name;
1761
+ }
1762
+ currentFiber = currentFiber.return;
1763
+ }
1764
+ return null;
1765
+ };
1766
+ const hasFormattableFrames = (stack) => {
1767
+ if (!stack) return false;
1768
+ return stack.some((frame) => {
1769
+ if (frame.fileName && Ne(frame.fileName)) return true;
1770
+ if (frame.isServer && (!frame.functionName || isSourceComponentName(frame.functionName))) return true;
1771
+ return false;
1772
+ });
1773
+ };
1774
+ const getComponentNamesFromFiber = (element, maxCount) => {
1775
+ if (!Te$1()) return [];
1776
+ const fiber = Z$1(element);
1777
+ if (!fiber) return [];
1778
+ const componentNames = [];
1779
+ j$1(fiber, (currentFiber) => {
1780
+ if (componentNames.length >= maxCount) return true;
1781
+ if (ve$1(currentFiber)) {
1782
+ const name = we$1(currentFiber.type);
1783
+ if (name && isUsefulComponentName(name)) componentNames.push(name);
1784
+ }
1785
+ return false;
1786
+ }, true);
1787
+ return componentNames;
1788
+ };
1789
+ const formatStackContext = (stack, options = {}) => {
1790
+ const { maxLines = 3 } = options;
1791
+ const isNextProject = checkIsNextProject();
1792
+ const formattedLines = [];
1793
+ for (const frame of stack) {
1794
+ if (formattedLines.length >= maxLines) break;
1795
+ const hasResolvedSource = frame.fileName && Ne(frame.fileName);
1796
+ if (frame.isServer && !hasResolvedSource && (!frame.functionName || isSourceComponentName(frame.functionName))) {
1797
+ formattedLines.push(`\n in ${frame.functionName || "<anonymous>"} (at Server)`);
1798
+ continue;
1799
+ }
1800
+ if (hasResolvedSource) {
1801
+ let line = "\n in ";
1802
+ const hasComponentName = frame.functionName && isSourceComponentName(frame.functionName);
1803
+ if (hasComponentName) line += `${frame.functionName} (at `;
1804
+ line += normalizeFilePath(frame.fileName);
1805
+ if (isNextProject && frame.lineNumber) {
1806
+ line += `:${frame.lineNumber}`;
1807
+ if (frame.columnNumber) line += `:${frame.columnNumber}`;
1808
+ }
1809
+ if (hasComponentName) line += `)`;
1810
+ formattedLines.push(line);
1811
+ }
1812
+ }
1813
+ return formattedLines.join("");
1814
+ };
1815
+ const getStackContext = async (element, options = {}) => {
1816
+ const maxLines = options.maxLines ?? 3;
1817
+ const stack = await getStack(element);
1818
+ if (stack && hasFormattableFrames(stack)) return formatStackContext(stack, options);
1819
+ const componentNames = getComponentNamesFromFiber(element, maxLines);
1820
+ if (componentNames.length > 0) return componentNames.map((name) => `\n in ${name}`).join("");
1821
+ return "";
1822
+ };
1823
+ const getElementContext = async (element, options = {}) => {
1824
+ const resolvedElement = findNearestFiberElement(element);
1825
+ const html = getHTMLPreview(resolvedElement);
1826
+ const stackContext = await getStackContext(resolvedElement, options);
1827
+ if (stackContext) return `${html}${stackContext}`;
1828
+ return getFallbackContext(resolvedElement);
1829
+ };
1830
+ const getFallbackContext = (element) => {
1831
+ const tagName = getTagName(element);
1832
+ if (!(element instanceof HTMLElement)) return `<${tagName}${formatPriorityAttrs(element, {
1833
+ truncate: false,
1834
+ maxAttrs: PREVIEW_PRIORITY_ATTRS.length
1835
+ })} />`;
1836
+ const text = element.innerText?.trim() ?? element.textContent?.trim() ?? "";
1837
+ let attrsText = "";
1838
+ for (const { name, value } of element.attributes) {
1839
+ if (isInternalAttribute(name)) continue;
1840
+ attrsText += ` ${name}="${value}"`;
1841
+ }
1842
+ const truncatedText = truncateString(text, 100);
1843
+ if (truncatedText.length > 0) return `<${tagName}${attrsText}>\n ${truncatedText}\n</${tagName}>`;
1844
+ return `<${tagName}${attrsText} />`;
1845
+ };
1846
+ const truncateAttrValue = (value) => truncateString(value, 15);
1847
+ const formatPriorityAttrs = (element, options = {}) => {
1848
+ const { truncate = true, maxAttrs = 3 } = options;
1849
+ const priorityAttrs = [];
1850
+ for (const name of PREVIEW_PRIORITY_ATTRS) {
1851
+ if (priorityAttrs.length >= maxAttrs) break;
1852
+ const value = element.getAttribute(name);
1853
+ if (value) {
1854
+ const formattedValue = truncate ? truncateAttrValue(value) : value;
1855
+ priorityAttrs.push(`${name}="${formattedValue}"`);
1856
+ }
1857
+ }
1858
+ return priorityAttrs.length > 0 ? ` ${priorityAttrs.join(" ")}` : "";
1859
+ };
1860
+ const getHTMLPreview = (element) => {
1861
+ const tagName = getTagName(element);
1862
+ const text = element instanceof HTMLElement ? element.innerText?.trim() ?? element.textContent?.trim() ?? "" : element.textContent?.trim() ?? "";
1863
+ let attrsText = "";
1864
+ for (const { name, value } of element.attributes) {
1865
+ if (isInternalAttribute(name)) continue;
1866
+ attrsText += ` ${name}="${truncateAttrValue(value)}"`;
1867
+ }
1868
+ const topElements = [];
1869
+ const bottomElements = [];
1870
+ let foundFirstText = false;
1871
+ const childNodes = Array.from(element.childNodes);
1872
+ for (const node of childNodes) {
1873
+ if (node.nodeType === Node.COMMENT_NODE) continue;
1874
+ if (node.nodeType === Node.TEXT_NODE) {
1875
+ if (node.textContent && node.textContent.trim().length > 0) foundFirstText = true;
1876
+ } else if (node instanceof Element) if (!foundFirstText) topElements.push(node);
1877
+ else bottomElements.push(node);
1878
+ }
1879
+ const formatElements = (elements) => {
1880
+ if (elements.length === 0) return "";
1881
+ if (elements.length <= 2) return elements.map((childElement) => `<${getTagName(childElement)} ...>`).join("\n ");
1882
+ return `(${elements.length} elements)`;
1883
+ };
1884
+ let content = "";
1885
+ const topElementsStr = formatElements(topElements);
1886
+ if (topElementsStr) content += `\n ${topElementsStr}`;
1887
+ if (text.length > 0) content += `\n ${truncateString(text, 100)}`;
1888
+ const bottomElementsStr = formatElements(bottomElements);
1889
+ if (bottomElementsStr) content += `\n ${bottomElementsStr}`;
1890
+ if (content.length > 0) return `<${tagName}${attrsText}>${content}\n</${tagName}>`;
1891
+ return `<${tagName}${attrsText} />`;
1892
+ };
1893
+
1894
+ //#endregion
1895
+ //#region src/utils/is-element-visible.ts
1896
+ const isElementVisible = (element, computedStyle = window.getComputedStyle(element)) => {
1897
+ return computedStyle.display !== "none" && computedStyle.visibility !== "hidden" && computedStyle.opacity !== "0";
1898
+ };
1899
+
1900
+ //#endregion
1901
+ //#region src/utils/is-root-element.ts
1902
+ const isRootElement = (element) => {
1903
+ const tagName = getTagName(element);
1904
+ return tagName === "html" || tagName === "body";
1905
+ };
1906
+
1907
+ //#endregion
1908
+ //#region src/utils/is-valid-grabbable-element.ts
1909
+ const isReactGrabElement = (element) => {
1910
+ if (element.hasAttribute("data-react-grab")) return true;
1911
+ const rootNode = element.getRootNode();
1912
+ return rootNode instanceof ShadowRoot && rootNode.host.hasAttribute("data-react-grab");
1913
+ };
1914
+ const isUserIgnoredElement = (element) => element.hasAttribute("data-react-grab-ignore") || element.closest(`[${"data-react-grab-ignore"}]`) !== null;
1915
+ const isDevToolsOverlay = (computedStyle) => {
1916
+ const zIndex = parseInt(computedStyle.zIndex, 10);
1917
+ return computedStyle.pointerEvents === "none" && computedStyle.position === "fixed" && !isNaN(zIndex) && zIndex >= 2147483600;
1918
+ };
1919
+ const hasTransparentBackground = (computedStyle) => {
1920
+ const backgroundColor = computedStyle.backgroundColor;
1921
+ return backgroundColor === "transparent" || backgroundColor === "rgba(0, 0, 0, 0)";
1922
+ };
1923
+ const isFullViewportOverlay = (computedStyle) => {
1924
+ const position = computedStyle.position;
1925
+ if (position !== "fixed" && position !== "absolute") return false;
1926
+ if (hasTransparentBackground(computedStyle) || parseFloat(computedStyle.opacity) < .1) return true;
1927
+ const zIndex = parseInt(computedStyle.zIndex, 10);
1928
+ return !isNaN(zIndex) && zIndex > 1e3;
1929
+ };
1930
+ let visibilityCache = /* @__PURE__ */ new WeakMap();
1931
+ const clearVisibilityCache = () => {
1932
+ visibilityCache = /* @__PURE__ */ new WeakMap();
1933
+ };
1934
+ const isValidGrabbableElement = (element) => {
1935
+ if (isRootElement(element)) return false;
1936
+ if (isReactGrabElement(element)) return false;
1937
+ if (isUserIgnoredElement(element)) return false;
1938
+ const now = performance.now();
1939
+ const cached = visibilityCache.get(element);
1940
+ if (cached && now - cached.timestamp < 50) return cached.isVisible;
1941
+ const computedStyle = window.getComputedStyle(element);
1942
+ if (!isElementVisible(element, computedStyle)) {
1943
+ visibilityCache.set(element, {
1944
+ isVisible: false,
1945
+ timestamp: now
1946
+ });
1947
+ return false;
1948
+ }
1949
+ if (element.clientWidth / window.innerWidth >= .9 && element.clientHeight / window.innerHeight >= .9) {
1950
+ if (isDevToolsOverlay(computedStyle)) return false;
1951
+ if (isFullViewportOverlay(computedStyle)) return false;
1952
+ }
1953
+ visibilityCache.set(element, {
1954
+ isVisible: true,
1955
+ timestamp: now
1956
+ });
1957
+ return true;
1958
+ };
1959
+
1960
+ //#endregion
1961
+ //#region src/utils/create-style-element.ts
1962
+ const createStyleElement = (attribute, content) => {
1963
+ const element = document.createElement("style");
1964
+ element.setAttribute(attribute, "");
1965
+ const nonce = detectCspNonce();
1966
+ if (nonce) element.nonce = nonce;
1967
+ hideFromThirdParties(element);
1968
+ element.textContent = content;
1969
+ document.head.appendChild(element);
1970
+ return element;
1971
+ };
1972
+
1973
+ //#endregion
1974
+ //#region src/utils/pointer-events-freeze.ts
1975
+ const POINTER_EVENTS_STYLES = "html { pointer-events: none !important; }";
1976
+ let pointerEventsStyle = null;
1977
+ const isPointerEventsFreezeInstalled = () => pointerEventsStyle !== null;
1978
+ const installPointerEventsFreeze = () => {
1979
+ if (pointerEventsStyle) return;
1980
+ pointerEventsStyle = createStyleElement("data-react-grab-frozen-pseudo", POINTER_EVENTS_STYLES);
1981
+ };
1982
+ const uninstallPointerEventsFreeze = () => {
1983
+ pointerEventsStyle?.remove();
1984
+ pointerEventsStyle = null;
1985
+ };
1986
+ const suspendPointerEventsFreeze = () => {
1987
+ if (pointerEventsStyle) pointerEventsStyle.disabled = true;
1988
+ };
1989
+ const resumePointerEventsFreeze = () => {
1990
+ if (pointerEventsStyle) pointerEventsStyle.disabled = false;
1991
+ };
1992
+
1993
+ //#endregion
1994
+ //#region src/utils/get-element-at-position.ts
1995
+ let cache = null;
1996
+ let hoveredIframe = null;
1997
+ let resumeTimerId = null;
1998
+ const isPointInsideRect = (clientX, clientY, rect) => clientX >= rect.left && clientX <= rect.right && clientY >= rect.top && clientY <= rect.bottom;
1999
+ const scheduleResume = () => {
2000
+ if (resumeTimerId !== null) clearTimeout(resumeTimerId);
2001
+ resumeTimerId = setTimeout(() => {
2002
+ resumeTimerId = null;
2003
+ resumePointerEventsFreeze();
2004
+ }, 100);
2005
+ };
2006
+ const cancelScheduledResume = () => {
2007
+ if (resumeTimerId !== null) {
2008
+ clearTimeout(resumeTimerId);
2009
+ resumeTimerId = null;
2010
+ }
2011
+ };
2012
+ const isWithinThreshold = (x1, y1, x2, y2) => {
2013
+ const deltaX = Math.abs(x1 - x2);
2014
+ const deltaY = Math.abs(y1 - y2);
2015
+ return deltaX <= 2 && deltaY <= 2;
2016
+ };
2017
+ const getElementsAtPoint = (clientX, clientY) => {
2018
+ if (!Number.isFinite(clientX) || !Number.isFinite(clientY)) return [];
2019
+ cancelScheduledResume();
2020
+ suspendPointerEventsFreeze();
2021
+ const elements = document.elementsFromPoint(clientX, clientY);
2022
+ scheduleResume();
2023
+ return elements;
2024
+ };
2025
+ const getElementAtPosition = (clientX, clientY) => {
2026
+ if (!Number.isFinite(clientX) || !Number.isFinite(clientY)) return null;
2027
+ const now = performance.now();
2028
+ if (hoveredIframe && isPointInsideRect(clientX, clientY, hoveredIframe.rect)) return hoveredIframe.element;
2029
+ if (cache) {
2030
+ const isPositionClose = isWithinThreshold(clientX, clientY, cache.clientX, cache.clientY);
2031
+ const isWithinThrottle = now - cache.timestamp < 16;
2032
+ if (isPositionClose || isWithinThrottle) return cache.element;
2033
+ }
2034
+ cancelScheduledResume();
2035
+ suspendPointerEventsFreeze();
2036
+ let result = null;
2037
+ const topElement = document.elementFromPoint(clientX, clientY);
2038
+ if (topElement && isValidGrabbableElement(topElement)) result = topElement;
2039
+ else {
2040
+ const elementsAtPoint = document.elementsFromPoint(clientX, clientY);
2041
+ for (const candidateElement of elementsAtPoint) if (candidateElement !== topElement && isValidGrabbableElement(candidateElement)) {
2042
+ result = candidateElement;
2043
+ break;
2044
+ }
2045
+ }
2046
+ scheduleResume();
2047
+ hoveredIframe = result instanceof HTMLIFrameElement ? {
2048
+ element: result,
2049
+ rect: result.getBoundingClientRect()
2050
+ } : null;
2051
+ cache = {
2052
+ clientX,
2053
+ clientY,
2054
+ element: result,
2055
+ timestamp: now
2056
+ };
2057
+ return result;
2058
+ };
2059
+ const clearElementPositionCache = () => {
2060
+ cancelScheduledResume();
2061
+ resumePointerEventsFreeze();
2062
+ cache = null;
2063
+ hoveredIframe = null;
2064
+ };
2065
+
2066
+ //#endregion
2067
+ //#region src/utils/open-file.ts
2068
+ const OPEN_FILE_BASE_URL = "http://localhost:3000";
2069
+ const tryDevServerOpen = async (filePath, lineNumber) => {
2070
+ const isNextProject = checkIsNextProject();
2071
+ const params = new URLSearchParams({ file: filePath });
2072
+ const lineKey = isNextProject ? "line1" : "line";
2073
+ const columnKey = isNextProject ? "column1" : "column";
2074
+ if (lineNumber) params.set(lineKey, String(lineNumber));
2075
+ params.set(columnKey, "1");
2076
+ const endpoint = isNextProject ? `${getNextBasePath()}/__nextjs_launch-editor` : "/__open-in-editor";
2077
+ return (await fetch(`${endpoint}?${params}`)).ok;
2078
+ };
2079
+ const openFile = async (filePath, lineNumber, transformUrl) => {
2080
+ filePath = normalizeFilePath(filePath);
2081
+ if (await tryDevServerOpen(filePath, lineNumber).catch(() => false)) return;
2082
+ const lineParam = lineNumber ? `&line=${lineNumber}` : "";
2083
+ const rawUrl = `${OPEN_FILE_BASE_URL}/open-file?url=${encodeURIComponent(filePath)}${lineParam}`;
2084
+ const url = transformUrl ? transformUrl(rawUrl, filePath, lineNumber) : rawUrl;
2085
+ window.open(url, "_blank", "noopener,noreferrer");
2086
+ };
2087
+
2088
+ //#endregion
2089
+ //#region src/utils/freeze-gsap.ts
2090
+ let isRafFrozen = false;
2091
+ const pendingRafCallbacks = /* @__PURE__ */ new Map();
2092
+ let nextFakeRafId = -1;
2093
+ const knownAnimationCallbacks = /* @__PURE__ */ new WeakSet();
2094
+ const nativeIdToHeldId = /* @__PURE__ */ new Map();
2095
+ const replayedFakeToNativeId = /* @__PURE__ */ new Map();
2096
+ const isAnimationLibraryCallback = (callback) => {
2097
+ if (knownAnimationCallbacks.has(callback)) return true;
2098
+ if (!isRafFrozen || !("gsapVersions" in window)) return false;
2099
+ if (!((/* @__PURE__ */ new Error()).stack ?? "").includes("_tick")) return false;
2100
+ knownAnimationCallbacks.add(callback);
2101
+ return true;
2102
+ };
2103
+ if (typeof window !== "undefined") {
2104
+ window.requestAnimationFrame = (callback) => {
2105
+ if (!isAnimationLibraryCallback(callback)) return nativeRequestAnimationFrame(callback);
2106
+ if (isRafFrozen) {
2107
+ const identifier = nextFakeRafId--;
2108
+ pendingRafCallbacks.set(identifier, callback);
2109
+ return identifier;
2110
+ }
2111
+ const nativeId = nativeRequestAnimationFrame((timestamp) => {
2112
+ if (isRafFrozen) {
2113
+ const identifier = nextFakeRafId--;
2114
+ pendingRafCallbacks.set(identifier, callback);
2115
+ nativeIdToHeldId.set(nativeId, identifier);
2116
+ return;
2117
+ }
2118
+ callback(timestamp);
2119
+ });
2120
+ return nativeId;
2121
+ };
2122
+ window.cancelAnimationFrame = (identifier) => {
2123
+ if (pendingRafCallbacks.has(identifier)) {
2124
+ pendingRafCallbacks.delete(identifier);
2125
+ return;
2126
+ }
2127
+ const replayed = replayedFakeToNativeId.get(identifier);
2128
+ if (replayed !== void 0) {
2129
+ nativeCancelAnimationFrame(replayed.nativeId);
2130
+ replayedFakeToNativeId.delete(identifier);
2131
+ return;
2132
+ }
2133
+ const heldId = nativeIdToHeldId.get(identifier);
2134
+ if (heldId !== void 0) {
2135
+ pendingRafCallbacks.delete(heldId);
2136
+ nativeIdToHeldId.delete(identifier);
2137
+ return;
2138
+ }
2139
+ nativeCancelAnimationFrame(identifier);
2140
+ };
2141
+ }
2142
+ const freezeGsap = () => {
2143
+ if (isRafFrozen) return;
2144
+ isRafFrozen = true;
2145
+ pendingRafCallbacks.clear();
2146
+ nativeIdToHeldId.clear();
2147
+ for (const [fakeId, { nativeId, callback }] of replayedFakeToNativeId) {
2148
+ nativeCancelAnimationFrame(nativeId);
2149
+ pendingRafCallbacks.set(fakeId, callback);
2150
+ }
2151
+ replayedFakeToNativeId.clear();
2152
+ };
2153
+ const unfreezeGsap = () => {
2154
+ if (!isRafFrozen) return;
2155
+ isRafFrozen = false;
2156
+ for (const [fakeId, callback] of pendingRafCallbacks.entries()) {
2157
+ const nativeId = nativeRequestAnimationFrame((timestamp) => {
2158
+ replayedFakeToNativeId.delete(fakeId);
2159
+ callback(timestamp);
2160
+ });
2161
+ replayedFakeToNativeId.set(fakeId, {
2162
+ nativeId,
2163
+ callback
2164
+ });
2165
+ }
2166
+ pendingRafCallbacks.clear();
2167
+ nativeIdToHeldId.clear();
2168
+ };
2169
+
2170
+ //#endregion
2171
+ //#region src/utils/freeze-animations.ts
2172
+ const FROZEN_STYLES = `
2173
+ [${FROZEN_ELEMENT_ATTRIBUTE}],
2174
+ [${FROZEN_ELEMENT_ATTRIBUTE}] * {
2175
+ animation-play-state: paused !important;
2176
+ transition: none !important;
2177
+ }
2178
+ `;
2179
+ const GLOBAL_FREEZE_STYLES = `
2180
+ *, *::before, *::after {
2181
+ animation-play-state: paused !important;
2182
+ transition: none !important;
2183
+ }
2184
+ `;
2185
+ const SVG_ROOT_SELECTOR = "svg";
2186
+ let styleElement = null;
2187
+ let frozenElements = [];
2188
+ let frozenSvgElements = [];
2189
+ let lastInputElements = [];
2190
+ let globalAnimationStyleElement = null;
2191
+ let globalFrozenSvgElements = [];
2192
+ const svgFreezeDepthMap = /* @__PURE__ */ new Map();
2193
+ let frozenWaapiAnimations = [];
2194
+ const ensureStylesInjected = () => {
2195
+ if (styleElement) return;
2196
+ styleElement = createStyleElement("data-react-grab-frozen-styles", FROZEN_STYLES);
2197
+ };
2198
+ const areElementsSame = (firstElements, secondElements) => firstElements.length === secondElements.length && firstElements.every((currentElement, index) => currentElement === secondElements[index]);
2199
+ const collectFrozenSvgElements = (elements) => {
2200
+ const svgElements = /* @__PURE__ */ new Set();
2201
+ for (const element of elements) {
2202
+ if (element instanceof SVGSVGElement) svgElements.add(element);
2203
+ else if (element instanceof SVGElement && element.ownerSVGElement) svgElements.add(element.ownerSVGElement);
2204
+ for (const innerSvgElement of element.querySelectorAll(SVG_ROOT_SELECTOR)) if (innerSvgElement instanceof SVGSVGElement) svgElements.add(innerSvgElement);
2205
+ }
2206
+ return [...svgElements];
2207
+ };
2208
+ const callSvgAnimationMethod = (svgElement, methodName) => {
2209
+ const animationMethod = Reflect.get(svgElement, methodName);
2210
+ if (typeof animationMethod !== "function") return;
2211
+ animationMethod.call(svgElement);
2212
+ };
2213
+ const pauseSvgAnimations = (svgElements) => {
2214
+ for (const svgElement of svgElements) {
2215
+ const currentFreezeDepth = svgFreezeDepthMap.get(svgElement) ?? 0;
2216
+ if (currentFreezeDepth === 0) callSvgAnimationMethod(svgElement, "pauseAnimations");
2217
+ svgFreezeDepthMap.set(svgElement, currentFreezeDepth + 1);
2218
+ }
2219
+ };
2220
+ const resumeSvgAnimations = (svgElements) => {
2221
+ for (const svgElement of svgElements) {
2222
+ const currentFreezeDepth = svgFreezeDepthMap.get(svgElement);
2223
+ if (!currentFreezeDepth) continue;
2224
+ if (currentFreezeDepth === 1) {
2225
+ svgFreezeDepthMap.delete(svgElement);
2226
+ callSvgAnimationMethod(svgElement, "unpauseAnimations");
2227
+ continue;
2228
+ }
2229
+ svgFreezeDepthMap.set(svgElement, currentFreezeDepth - 1);
2230
+ }
2231
+ };
2232
+ const collectWaapiAnimations = (elements) => {
2233
+ const animations = [];
2234
+ for (const element of elements) for (const animation of element.getAnimations({ subtree: true })) if (animation.playState === "running") animations.push(animation);
2235
+ return animations;
2236
+ };
2237
+ const finishAnimations = (animations) => {
2238
+ for (const animation of animations) try {
2239
+ animation.finish();
2240
+ } catch {}
2241
+ };
2242
+ const freezeAllAnimations = (elements) => {
2243
+ if (elements.length === 0) return;
2244
+ if (areElementsSame(elements, lastInputElements)) return;
2245
+ unfreezeAllAnimations();
2246
+ lastInputElements = [...elements];
2247
+ ensureStylesInjected();
2248
+ frozenElements = elements;
2249
+ frozenSvgElements = collectFrozenSvgElements(frozenElements);
2250
+ pauseSvgAnimations(frozenSvgElements);
2251
+ for (const element of frozenElements) element.setAttribute(FROZEN_ELEMENT_ATTRIBUTE, "");
2252
+ frozenWaapiAnimations = collectWaapiAnimations(frozenElements);
2253
+ for (const animation of frozenWaapiAnimations) animation.pause();
2254
+ };
2255
+ const unfreezeAllAnimations = () => {
2256
+ if (frozenElements.length === 0 && frozenSvgElements.length === 0 && frozenWaapiAnimations.length === 0) return;
2257
+ for (const element of frozenElements) element.removeAttribute(FROZEN_ELEMENT_ATTRIBUTE);
2258
+ resumeSvgAnimations(frozenSvgElements);
2259
+ finishAnimations(frozenWaapiAnimations);
2260
+ frozenElements = [];
2261
+ frozenSvgElements = [];
2262
+ frozenWaapiAnimations = [];
2263
+ lastInputElements = [];
2264
+ };
2265
+ const freezeAnimations = (elements) => {
2266
+ if (elements.length === 0) {
2267
+ unfreezeAllAnimations();
2268
+ return () => {};
2269
+ }
2270
+ freezeAllAnimations(elements);
2271
+ return unfreezeAllAnimations;
2272
+ };
2273
+ const freezeGlobalAnimations = () => {
2274
+ if (globalAnimationStyleElement) return;
2275
+ globalAnimationStyleElement = createStyleElement("data-react-grab-global-freeze", GLOBAL_FREEZE_STYLES);
2276
+ globalFrozenSvgElements = collectFrozenSvgElements(Array.from(document.querySelectorAll(SVG_ROOT_SELECTOR)));
2277
+ pauseSvgAnimations(globalFrozenSvgElements);
2278
+ freezeGsap();
2279
+ };
2280
+ const unfreezeGlobalAnimations = () => {
2281
+ if (!globalAnimationStyleElement) return;
2282
+ globalAnimationStyleElement.textContent = `
2283
+ *, *::before, *::after {
2284
+ transition: none !important;
2285
+ }
2286
+ `;
2287
+ const animationsToFinish = [];
2288
+ for (const animation of document.getAnimations()) {
2289
+ if (animation.effect instanceof KeyframeEffect) {
2290
+ const target = animation.effect.target;
2291
+ if (target instanceof Element && target.getRootNode() instanceof ShadowRoot) continue;
2292
+ }
2293
+ animationsToFinish.push(animation);
2294
+ }
2295
+ finishAnimations(animationsToFinish);
2296
+ globalAnimationStyleElement.remove();
2297
+ globalAnimationStyleElement = null;
2298
+ resumeSvgAnimations(globalFrozenSvgElements);
2299
+ globalFrozenSvgElements = [];
2300
+ unfreezeGsap();
2301
+ };
2302
+
2303
+ //#endregion
2304
+ //#region src/utils/freeze-pseudo-states.ts
2305
+ const MOUSE_EVENTS_TO_BLOCK = [
2306
+ "mouseenter",
2307
+ "mouseleave",
2308
+ "mouseover",
2309
+ "mouseout",
2310
+ "pointerenter",
2311
+ "pointerleave",
2312
+ "pointerover",
2313
+ "pointerout"
2314
+ ];
2315
+ const FOCUS_EVENTS_TO_BLOCK = [
2316
+ "focus",
2317
+ "blur",
2318
+ "focusin",
2319
+ "focusout"
2320
+ ];
2321
+ const HOVER_STYLE_PROPERTIES = [
2322
+ "background-color",
2323
+ "color",
2324
+ "border-color",
2325
+ "box-shadow",
2326
+ "transform",
2327
+ "opacity",
2328
+ "outline",
2329
+ "filter",
2330
+ "scale",
2331
+ "visibility"
2332
+ ];
2333
+ const FOCUS_STYLE_PROPERTIES = [
2334
+ "background-color",
2335
+ "color",
2336
+ "border-color",
2337
+ "box-shadow",
2338
+ "outline",
2339
+ "outline-offset",
2340
+ "outline-width",
2341
+ "outline-color",
2342
+ "outline-style",
2343
+ "filter",
2344
+ "opacity",
2345
+ "ring-color",
2346
+ "ring-width"
2347
+ ];
2348
+ const frozenHoverElements = /* @__PURE__ */ new Map();
2349
+ const frozenFocusElements = /* @__PURE__ */ new Map();
2350
+ const stopEvent = (event) => {
2351
+ event.stopImmediatePropagation();
2352
+ };
2353
+ const preventFocusChange = (event) => {
2354
+ event.preventDefault();
2355
+ event.stopImmediatePropagation();
2356
+ };
2357
+ const collectOriginalPropertyValues = (element, properties) => {
2358
+ const originalPropertyValues = /* @__PURE__ */ new Map();
2359
+ for (const prop of properties) {
2360
+ const inlineValue = element.style.getPropertyValue(prop);
2361
+ if (inlineValue) originalPropertyValues.set(prop, inlineValue);
2362
+ }
2363
+ return originalPropertyValues;
2364
+ };
2365
+ const freezeElement = (element, properties, alreadyFrozen) => {
2366
+ if (alreadyFrozen?.has(element)) return null;
2367
+ const computed = getComputedStyle(element);
2368
+ let frozenStyles = element.style.cssText;
2369
+ const originalPropertyValues = collectOriginalPropertyValues(element, properties);
2370
+ for (const prop of properties) {
2371
+ const computedValue = computed.getPropertyValue(prop);
2372
+ if (computedValue) frozenStyles += `${prop}: ${computedValue} !important; `;
2373
+ }
2374
+ return {
2375
+ element,
2376
+ frozenStyles,
2377
+ originalPropertyValues
2378
+ };
2379
+ };
2380
+ const collectHoveredElements = (cursorX, cursorY) => {
2381
+ const hoveredElements = [];
2382
+ let current = document.elementFromPoint(cursorX, cursorY);
2383
+ while (current && current !== document.documentElement) {
2384
+ if (current instanceof HTMLElement) hoveredElements.push(current);
2385
+ current = current.parentElement;
2386
+ }
2387
+ return hoveredElements;
2388
+ };
2389
+ const collectFocusedElements = () => {
2390
+ const focusedElements = [];
2391
+ let current = document.activeElement;
2392
+ while (current && current !== document.body) {
2393
+ if (current instanceof HTMLElement) focusedElements.push(current);
2394
+ current = current.shadowRoot?.activeElement ?? null;
2395
+ }
2396
+ return focusedElements;
2397
+ };
2398
+ const applyFrozenStates = (states, storageMap) => {
2399
+ for (const { element, frozenStyles, originalPropertyValues } of states) {
2400
+ storageMap.set(element, originalPropertyValues);
2401
+ element.style.cssText = frozenStyles;
2402
+ }
2403
+ };
2404
+ const restoreFrozenStates = (storageMap, styleProperties) => {
2405
+ for (const [element, originalPropertyValues] of storageMap) for (const prop of styleProperties) {
2406
+ const originalValue = originalPropertyValues.get(prop);
2407
+ if (originalValue) element.style.setProperty(prop, originalValue);
2408
+ else element.style.removeProperty(prop);
2409
+ }
2410
+ storageMap.clear();
2411
+ };
2412
+ const freezePseudoStates = (cursorX, cursorY) => {
2413
+ if (isPointerEventsFreezeInstalled()) return;
2414
+ for (const eventType of MOUSE_EVENTS_TO_BLOCK) document.addEventListener(eventType, stopEvent, true);
2415
+ for (const eventType of FOCUS_EVENTS_TO_BLOCK) document.addEventListener(eventType, preventFocusChange, true);
2416
+ const hoverStates = [];
2417
+ const hoveredElements = cursorX !== void 0 && cursorY !== void 0 && cursorX >= 0 && cursorY >= 0 && cursorX < window.innerWidth && cursorY < window.innerHeight ? collectHoveredElements(cursorX, cursorY) : Array.from(document.querySelectorAll(":hover")).filter((element) => element instanceof HTMLElement);
2418
+ for (const element of hoveredElements) {
2419
+ const state = freezeElement(element, HOVER_STYLE_PROPERTIES);
2420
+ if (state) hoverStates.push(state);
2421
+ }
2422
+ const focusStates = [];
2423
+ for (const element of collectFocusedElements()) {
2424
+ const state = freezeElement(element, FOCUS_STYLE_PROPERTIES, frozenFocusElements);
2425
+ if (state) focusStates.push(state);
2426
+ }
2427
+ applyFrozenStates(hoverStates, frozenHoverElements);
2428
+ applyFrozenStates(focusStates, frozenFocusElements);
2429
+ installPointerEventsFreeze();
2430
+ };
2431
+ const unfreezePseudoStates = () => {
2432
+ clearElementPositionCache();
2433
+ for (const eventType of MOUSE_EVENTS_TO_BLOCK) document.removeEventListener(eventType, stopEvent, true);
2434
+ for (const eventType of FOCUS_EVENTS_TO_BLOCK) document.removeEventListener(eventType, preventFocusChange, true);
2435
+ restoreFrozenStates(frozenHoverElements, HOVER_STYLE_PROPERTIES);
2436
+ restoreFrozenStates(frozenFocusElements, FOCUS_STYLE_PROPERTIES);
2437
+ uninstallPointerEventsFreeze();
2438
+ };
2439
+
2440
+ //#endregion
2441
+ //#region src/utils/log-recoverable-error.ts
2442
+ const logRecoverableError = (context, error) => {
2443
+ console.warn(`[react-grab] ${context}:`, error);
2444
+ };
2445
+
2446
+ //#endregion
2447
+ //#region src/utils/freeze-updates.ts
2448
+ let isUpdatesPaused = false;
2449
+ const getOrCache = (cache, key, create) => {
2450
+ const cached = cache.get(key);
2451
+ if (cached) return cached;
2452
+ const value = create();
2453
+ cache.set(key, value);
2454
+ return value;
2455
+ };
2456
+ const patchedDispatchers = /* @__PURE__ */ new WeakMap();
2457
+ const wrappedDispatchCache = /* @__PURE__ */ new WeakMap();
2458
+ const wrappedStartTransitionCache = /* @__PURE__ */ new WeakMap();
2459
+ const pendingStoreCallbacks = /* @__PURE__ */ new Set();
2460
+ const pendingTransitionCallbacks = [];
2461
+ const pendingStateUpdates = [];
2462
+ const pausedQueueStates = /* @__PURE__ */ new WeakMap();
2463
+ const pausedContextStates = /* @__PURE__ */ new WeakMap();
2464
+ const renderersWithPatchedDispatcher = /* @__PURE__ */ new WeakSet();
2465
+ const typedFiberRoots = $;
2466
+ const getFiberRoot = (fiber) => {
2467
+ let current = fiber;
2468
+ while (current.return) current = current.return;
2469
+ return current.stateNode ?? null;
2470
+ };
2471
+ const collectFiberRoots = () => {
2472
+ if (typedFiberRoots.size > 0) return typedFiberRoots;
2473
+ const collectedRoots = /* @__PURE__ */ new Set();
2474
+ const traverseDOM = (element) => {
2475
+ const fiber = Z$1(element);
2476
+ if (fiber) {
2477
+ const fiberRoot = getFiberRoot(fiber);
2478
+ if (fiberRoot) collectedRoots.add(fiberRoot);
2479
+ return;
2480
+ }
2481
+ for (const childElement of Array.from(element.children)) {
2482
+ traverseDOM(childElement);
2483
+ if (collectedRoots.size > 0) return;
2484
+ }
2485
+ };
2486
+ traverseDOM(document.body);
2487
+ return collectedRoots;
2488
+ };
2489
+ const mergePendingChains = (original, buffered) => {
2490
+ if (!original) return buffered;
2491
+ if (!buffered) return original;
2492
+ if (!original.next || !buffered.next) return buffered;
2493
+ const originalFirst = original.next;
2494
+ const bufferedFirst = buffered.next;
2495
+ const isOriginalSingle = original === originalFirst;
2496
+ const isBufferedSingle = buffered === bufferedFirst;
2497
+ if (isOriginalSingle && isBufferedSingle) {
2498
+ original.next = buffered;
2499
+ buffered.next = original;
2500
+ } else if (isOriginalSingle) {
2501
+ original.next = bufferedFirst;
2502
+ buffered.next = original;
2503
+ } else if (isBufferedSingle) {
2504
+ buffered.next = originalFirst;
2505
+ original.next = buffered;
2506
+ } else {
2507
+ original.next = bufferedFirst;
2508
+ buffered.next = originalFirst;
2509
+ }
2510
+ return buffered;
2511
+ };
2512
+ const pauseHookQueue = (queue) => {
2513
+ if (!queue || pausedQueueStates.has(queue)) return;
2514
+ const pauseState = {
2515
+ originalPendingDescriptor: Object.getOwnPropertyDescriptor(queue, "pending"),
2516
+ pendingValueAtPause: queue.pending,
2517
+ bufferedPending: null
2518
+ };
2519
+ if (typeof queue.getSnapshot === "function") {
2520
+ pauseState.originalGetSnapshot = queue.getSnapshot;
2521
+ pauseState.snapshotValueAtPause = queue.getSnapshot();
2522
+ queue.getSnapshot = () => isUpdatesPaused ? pauseState.snapshotValueAtPause : pauseState.originalGetSnapshot();
2523
+ }
2524
+ let currentPendingValue = pauseState.pendingValueAtPause;
2525
+ Object.defineProperty(queue, "pending", {
2526
+ configurable: true,
2527
+ enumerable: true,
2528
+ get: () => isUpdatesPaused ? null : currentPendingValue,
2529
+ set: (newValue) => {
2530
+ if (isUpdatesPaused) {
2531
+ if (newValue !== null) pauseState.bufferedPending = mergePendingChains(pauseState.bufferedPending ?? null, newValue);
2532
+ return;
2533
+ }
2534
+ currentPendingValue = newValue;
2535
+ }
2536
+ });
2537
+ pausedQueueStates.set(queue, pauseState);
2538
+ };
2539
+ const extractActionsFromChain = (pending) => {
2540
+ if (!pending) return [];
2541
+ const actions = [];
2542
+ const first = pending.next;
2543
+ if (!first) return [];
2544
+ let current = first;
2545
+ do
2546
+ if (current) {
2547
+ actions.push(current.action);
2548
+ current = current.next;
2549
+ }
2550
+ while (current && current !== first);
2551
+ return actions;
2552
+ };
2553
+ const resumeHookQueue = (queue) => {
2554
+ const pauseState = pausedQueueStates.get(queue);
2555
+ if (!pauseState) return;
2556
+ if (pauseState.originalGetSnapshot) queue.getSnapshot = pauseState.originalGetSnapshot;
2557
+ if (pauseState.originalPendingDescriptor) Object.defineProperty(queue, "pending", pauseState.originalPendingDescriptor);
2558
+ else delete queue.pending;
2559
+ queue.pending = null;
2560
+ const dispatch = queue.dispatch;
2561
+ if (typeof dispatch === "function") {
2562
+ const pendingActions = extractActionsFromChain(pauseState.pendingValueAtPause ?? null);
2563
+ const bufferedActions = extractActionsFromChain(pauseState.bufferedPending ?? null);
2564
+ for (const action of [...pendingActions, ...bufferedActions]) pendingStateUpdates.push(() => dispatch(action));
2565
+ }
2566
+ pausedQueueStates.delete(queue);
2567
+ };
2568
+ const pauseContextDependency = (contextDependency) => {
2569
+ if (pausedContextStates.has(contextDependency)) return;
2570
+ const pauseState = {
2571
+ originalDescriptor: Object.getOwnPropertyDescriptor(contextDependency, "memoizedValue"),
2572
+ frozenValue: contextDependency.memoizedValue
2573
+ };
2574
+ Object.defineProperty(contextDependency, "memoizedValue", {
2575
+ configurable: true,
2576
+ enumerable: true,
2577
+ get() {
2578
+ if (isUpdatesPaused) return pauseState.frozenValue;
2579
+ if (pauseState.originalDescriptor?.get) return pauseState.originalDescriptor.get.call(this);
2580
+ return this._memoizedValue;
2581
+ },
2582
+ set(value) {
2583
+ if (isUpdatesPaused) {
2584
+ pauseState.pendingValue = value;
2585
+ pauseState.didReceivePendingValue = true;
2586
+ return;
2587
+ }
2588
+ if (pauseState.originalDescriptor?.set) pauseState.originalDescriptor.set.call(this, value);
2589
+ else this._memoizedValue = value;
2590
+ }
2591
+ });
2592
+ if (!pauseState.originalDescriptor?.get) contextDependency._memoizedValue = pauseState.frozenValue;
2593
+ pausedContextStates.set(contextDependency, pauseState);
2594
+ };
2595
+ const resumeContextDependency = (contextDependency) => {
2596
+ const pauseState = pausedContextStates.get(contextDependency);
2597
+ if (!pauseState) return;
2598
+ if (pauseState.originalDescriptor) Object.defineProperty(contextDependency, "memoizedValue", pauseState.originalDescriptor);
2599
+ else delete contextDependency.memoizedValue;
2600
+ if (pauseState.didReceivePendingValue) contextDependency.memoizedValue = pauseState.pendingValue;
2601
+ pausedContextStates.delete(contextDependency);
2602
+ };
2603
+ const forEachHookQueue = (fiber, callback) => {
2604
+ let hookState = fiber.memoizedState;
2605
+ while (hookState) {
2606
+ if (hookState.queue && typeof hookState.queue === "object") callback(hookState.queue);
2607
+ hookState = hookState.next;
2608
+ }
2609
+ };
2610
+ const forEachContextDependency = (fiber, callback) => {
2611
+ let contextDependency = fiber.dependencies?.firstContext;
2612
+ while (contextDependency && typeof contextDependency === "object" && "memoizedValue" in contextDependency) {
2613
+ callback(contextDependency);
2614
+ contextDependency = contextDependency.next;
2615
+ }
2616
+ };
2617
+ const traverseFibers = (fiber, onCompositeFiber) => {
2618
+ if (!fiber) return;
2619
+ if (ve$1(fiber)) onCompositeFiber(fiber);
2620
+ traverseFibers(fiber.child, onCompositeFiber);
2621
+ traverseFibers(fiber.sibling, onCompositeFiber);
2622
+ };
2623
+ const pauseFiber = (fiber) => {
2624
+ forEachHookQueue(fiber, pauseHookQueue);
2625
+ forEachContextDependency(fiber, pauseContextDependency);
2626
+ };
2627
+ const resumeFiber = (fiber) => {
2628
+ forEachHookQueue(fiber, resumeHookQueue);
2629
+ forEachContextDependency(fiber, resumeContextDependency);
2630
+ };
2631
+ const patchDispatcher = (dispatcher) => {
2632
+ if (patchedDispatchers.has(dispatcher)) return;
2633
+ const typedDispatcher = dispatcher;
2634
+ const originalHooks = {
2635
+ useState: typedDispatcher.useState,
2636
+ useReducer: typedDispatcher.useReducer,
2637
+ useTransition: typedDispatcher.useTransition,
2638
+ useSyncExternalStore: typedDispatcher.useSyncExternalStore
2639
+ };
2640
+ patchedDispatchers.set(dispatcher, originalHooks);
2641
+ typedDispatcher.useState = (...args) => {
2642
+ const result = originalHooks.useState.apply(dispatcher, args);
2643
+ if (!isUpdatesPaused) return result;
2644
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2645
+ const [state, dispatch] = result;
2646
+ return [state, getOrCache(wrappedDispatchCache, dispatch, () => (...dispatchArgs) => {
2647
+ if (isUpdatesPaused) pendingStateUpdates.push(() => dispatch(...dispatchArgs));
2648
+ else dispatch(...dispatchArgs);
2649
+ })];
2650
+ };
2651
+ typedDispatcher.useReducer = (...args) => {
2652
+ const result = originalHooks.useReducer.apply(dispatcher, args);
2653
+ if (!isUpdatesPaused) return result;
2654
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2655
+ const [state, dispatch] = result;
2656
+ return [state, getOrCache(wrappedDispatchCache, dispatch, () => (...dispatchArgs) => {
2657
+ if (isUpdatesPaused) pendingStateUpdates.push(() => dispatch(...dispatchArgs));
2658
+ else dispatch(...dispatchArgs);
2659
+ })];
2660
+ };
2661
+ typedDispatcher.useTransition = (...args) => {
2662
+ const result = originalHooks.useTransition.apply(dispatcher, args);
2663
+ if (!isUpdatesPaused) return result;
2664
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2665
+ const [isPending, startTransition] = result;
2666
+ return [isPending, getOrCache(wrappedStartTransitionCache, startTransition, () => (transitionCallback) => {
2667
+ if (isUpdatesPaused) pendingTransitionCallbacks.push(() => startTransition(transitionCallback));
2668
+ else startTransition(transitionCallback);
2669
+ })];
2670
+ };
2671
+ typedDispatcher.useSyncExternalStore = ((subscribe, getSnapshot, getServerSnapshot) => {
2672
+ if (!isUpdatesPaused) return originalHooks.useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);
2673
+ const wrappedSubscribe = (onChange) => subscribe(() => {
2674
+ if (isUpdatesPaused) pendingStoreCallbacks.add(onChange);
2675
+ else onChange();
2676
+ });
2677
+ return originalHooks.useSyncExternalStore(wrappedSubscribe, getSnapshot, getServerSnapshot);
2678
+ });
2679
+ };
2680
+ const installDispatcherPatching = (renderer) => {
2681
+ const dispatcherRef = renderer.currentDispatcherRef;
2682
+ if (!dispatcherRef || typeof dispatcherRef !== "object") return;
2683
+ const dispatcherKey = "H" in dispatcherRef ? "H" : "current";
2684
+ let currentDispatcher = dispatcherRef[dispatcherKey];
2685
+ Object.defineProperty(dispatcherRef, dispatcherKey, {
2686
+ configurable: true,
2687
+ enumerable: true,
2688
+ get: () => {
2689
+ if (currentDispatcher && typeof currentDispatcher === "object") patchDispatcher(currentDispatcher);
2690
+ return currentDispatcher;
2691
+ },
2692
+ set: (newDispatcher) => {
2693
+ currentDispatcher = newDispatcher;
2694
+ }
2695
+ });
2696
+ };
2697
+ const scheduleReactUpdate = (fiberRoots) => {
2698
+ queueMicrotask(() => {
2699
+ try {
2700
+ for (const renderer of h$2().renderers.values()) {
2701
+ if (typeof renderer.scheduleUpdate !== "function") continue;
2702
+ for (const fiberRoot of fiberRoots) if (fiberRoot.current) try {
2703
+ renderer.scheduleUpdate(fiberRoot.current);
2704
+ } catch (error) {
2705
+ logRecoverableError("scheduleUpdate failed during unfreeze", error);
2706
+ }
2707
+ }
2708
+ } catch (error) {
2709
+ logRecoverableError("scheduleReactUpdate failed", error);
2710
+ }
2711
+ });
2712
+ };
2713
+ const invokeCallbacks = (callbacks) => {
2714
+ for (const callback of callbacks) try {
2715
+ callback();
2716
+ } catch (error) {
2717
+ logRecoverableError("Callback failed during state replay", error);
2718
+ }
2719
+ };
2720
+ const initializeFreezeSupport = () => {
2721
+ for (const renderer of h$2().renderers.values()) {
2722
+ if (renderersWithPatchedDispatcher.has(renderer)) continue;
2723
+ installDispatcherPatching(renderer);
2724
+ renderersWithPatchedDispatcher.add(renderer);
2725
+ }
2726
+ };
2727
+ const freezeUpdates = () => {
2728
+ if (isUpdatesPaused) return () => {};
2729
+ initializeFreezeSupport();
2730
+ isUpdatesPaused = true;
2731
+ const fiberRoots = collectFiberRoots();
2732
+ for (const fiberRoot of fiberRoots) traverseFibers(fiberRoot.current, pauseFiber);
2733
+ return () => {
2734
+ if (!isUpdatesPaused) return;
2735
+ try {
2736
+ const fiberRootsToResume = collectFiberRoots();
2737
+ for (const fiberRoot of fiberRootsToResume) traverseFibers(fiberRoot.current, resumeFiber);
2738
+ const storeCallbacksToInvoke = Array.from(pendingStoreCallbacks);
2739
+ const transitionCallbacksToInvoke = pendingTransitionCallbacks.slice();
2740
+ const stateUpdatesToInvoke = pendingStateUpdates.slice();
2741
+ isUpdatesPaused = false;
2742
+ invokeCallbacks(storeCallbacksToInvoke);
2743
+ invokeCallbacks(transitionCallbacksToInvoke);
2744
+ invokeCallbacks(stateUpdatesToInvoke);
2745
+ scheduleReactUpdate(fiberRootsToResume);
2746
+ } finally {
2747
+ pendingStoreCallbacks.clear();
2748
+ pendingTransitionCallbacks.length = 0;
2749
+ pendingStateUpdates.length = 0;
2750
+ }
2751
+ };
2752
+ };
2753
+
2754
+ //#endregion
2755
+ export { OVERLAY_BORDER_COLOR_DEFAULT as $, nativeRequestAnimationFrame as A, DRAG_SELECTION_COVERAGE_THRESHOLD as B, getStack as C, Te$1 as D, stripInternalAttributes as E, ARROW_KEYS as F, LERP_CONVERGENCE_THRESHOLD_PX as G, DROPDOWN_OFFSCREEN_POSITION as H, ARROW_MAX_LABEL_WIDTH_RATIO as I, MODIFIER_KEYS as J, MAX_SELECTOR_COMBINATIONS as K, BASELINE_FRAME_DURATION_MS as L, hideFromThirdParties as M, detectCspNonce as N, Z$1 as O, getTagName as P, OPACITY_CONVERGENCE_THRESHOLD as Q, DEFAULT_ACTION_ID as R, getNearestComponentName as S, resolveSource as T, FEEDBACK_DURATION_MS as U, DROPDOWN_EDGE_TRANSFORM_ORIGIN as V, FROZEN_GLOW_COLOR as W, NEXTJS_REVALIDATION_DELAY_MS as X, MOUNT_ROOT_RECHECK_DELAY_MS as Y, OFFSCREEN_POSITION as Z, isRootElement as _, freezeAllAnimations as a, SELECTION_LERP_FACTOR as at, getElementContext as b, unfreezeGlobalAnimations as c, ZOOM_DETECTION_THRESHOLD as ct, getElementAtPosition as d, supportsDisplayP3 as dt, OVERLAY_BORDER_COLOR_DRAG as et, getElementsAtPoint as f, isValidGrabbableElement as g, clearVisibilityCache as h, unfreezePseudoStates as i, SELECTION_LABEL_OFFSCREEN_PX as it, waitUntilNextFrame as j, nativeCancelAnimationFrame as k, openFile as l, Z_INDEX_OVERLAY as lt, suspendPointerEventsFreeze as m, logRecoverableError as n, OVERLAY_FILL_COLOR_DRAG as nt, freezeAnimations as o, TOOLBAR_DEFAULT_POSITION_RATIO as ot, resumePointerEventsFreeze as p, MAX_SESSION_STORAGE_SIZE_BYTES as q, freezePseudoStates as r, RELEVANT_CSS_PROPERTIES as rt, freezeGlobalAnimations as s, VERSION as st, freezeUpdates as t, OVERLAY_FILL_COLOR_DEFAULT as tt, clearElementPositionCache as u, Z_INDEX_OVERLAY_CANVAS as ut, checkIsNextProject as v, getStackContext as w, getHTMLPreview as x, getComponentDisplayName as y, DRAG_LERP_FACTOR as z };