grab 0.1.35 → 0.1.36

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 (86) hide show
  1. package/dist/copy-content-3pnWacho.d.cts +218 -0
  2. package/dist/copy-content-DH6fBB50.d.ts +218 -0
  3. package/dist/core/index.cjs +1 -1
  4. package/dist/core/index.d.cts +2 -2
  5. package/dist/core/index.d.ts +2 -2
  6. package/dist/core/index.js +1 -1
  7. package/dist/core-B9aCRu_r.cjs +4374 -0
  8. package/dist/core-BNG77P9u.js +20 -0
  9. package/dist/core-BaM4pWDg.cjs +20 -0
  10. package/dist/core-BgAHCKe7.js +4492 -0
  11. package/dist/core-BnZu88Zq.js +20 -0
  12. package/dist/core-BoXxu65H.js +20 -0
  13. package/dist/core-Bw1MUegr.cjs +4374 -0
  14. package/dist/core-C-uBKPnx.js +20 -0
  15. package/dist/core-CMd2PuB-.cjs +20 -0
  16. package/dist/core-CN7fVz1T.cjs +4377 -0
  17. package/dist/core-C_moHA9D.js +20 -0
  18. package/dist/core-CoEZwalZ.js +4489 -0
  19. package/dist/core-Cyu0n7SO.js +20 -0
  20. package/dist/core-DMVlP9g5.js +20 -0
  21. package/dist/core-XXPjZNnn.cjs +20 -0
  22. package/dist/core-_t0msYhT.cjs +20 -0
  23. package/dist/core-eVrmPJ2u.cjs +20 -0
  24. package/dist/core-epcog0yL.cjs +20 -0
  25. package/dist/core-foLKkb5_.cjs +20 -0
  26. package/dist/core-kGODXK-N.js +4489 -0
  27. package/dist/create-element-selector-B5J9_3Fw.cjs +9 -0
  28. package/dist/create-element-selector-BEaSanPh.cjs +9 -0
  29. package/dist/create-element-selector-BR_zDrcL.js +296 -0
  30. package/dist/create-element-selector-C3VxTCEX.js +9 -0
  31. package/dist/create-element-selector-CIj_4oMe.js +9 -0
  32. package/dist/create-element-selector-C_6sG1Bd.js +296 -0
  33. package/dist/create-element-selector-ChuWL5x4.cjs +9 -0
  34. package/dist/create-element-selector-CufggNcJ.js +9 -0
  35. package/dist/create-element-selector-D1FizysC.js +9 -0
  36. package/dist/create-element-selector-D4_cMOfX.cjs +307 -0
  37. package/dist/create-element-selector-Dw4Hh5vX.cjs +307 -0
  38. package/dist/create-element-selector-pHsYuaOR.cjs +9 -0
  39. package/dist/freeze-updates-1bWq0iRj.cjs +3340 -0
  40. package/dist/freeze-updates-7yZ9p4Jb.cjs +52 -0
  41. package/dist/freeze-updates-B2R6sKrS.js +52 -0
  42. package/dist/freeze-updates-BUIl_I9a.js +52 -0
  43. package/dist/freeze-updates-D7wc1FFo.js +52 -0
  44. package/dist/freeze-updates-DC22uWxG.cjs +3347 -0
  45. package/dist/freeze-updates-DFjQ3htO.js +52 -0
  46. package/dist/freeze-updates-DIifOZze.js +2921 -0
  47. package/dist/freeze-updates-D_ae-e4T.js +2920 -0
  48. package/dist/freeze-updates-DdIqMW8Y.cjs +52 -0
  49. package/dist/freeze-updates-DvAOKSWG.cjs +52 -0
  50. package/dist/freeze-updates-F-dFqbvY.cjs +52 -0
  51. package/dist/index-CkMIwkYj.d.ts +413 -0
  52. package/dist/index-DR5AjI5S.d.cts +413 -0
  53. package/dist/index.cjs +1 -1
  54. package/dist/index.d.cts +2 -2
  55. package/dist/index.d.ts +2 -2
  56. package/dist/index.global.js +13 -13
  57. package/dist/index.js +1 -1
  58. package/dist/primitives.cjs +1 -1
  59. package/dist/primitives.d.cts +1 -1
  60. package/dist/primitives.d.ts +1 -1
  61. package/dist/primitives.js +1 -1
  62. package/dist/renderer-B65BudlT.cjs +9 -0
  63. package/dist/renderer-BRENw6lS.cjs +3205 -0
  64. package/dist/renderer-Bxc3RS-J.cjs +3205 -0
  65. package/dist/renderer-CD-Ju8A3.js +3205 -0
  66. package/dist/renderer-D0a4h1bK.cjs +9 -0
  67. package/dist/renderer-D3dvNcvm.cjs +9 -0
  68. package/dist/renderer-DQoIdFmy.js +9 -0
  69. package/dist/renderer-Dc20mGte.js +9 -0
  70. package/dist/renderer-DmNPMFh8.js +3205 -0
  71. package/dist/renderer-Dnyqr-yC.cjs +9 -0
  72. package/dist/renderer-gEdmDcCb.js +9 -0
  73. package/dist/renderer-kDb-jNJX.js +9 -0
  74. package/dist/state-BAZpSiUU.js +9 -0
  75. package/dist/state-BPvTpQtD.js +9 -0
  76. package/dist/state-Bn3fhsQ8.cjs +9 -0
  77. package/dist/state-BwCmdtcN.cjs +1306 -0
  78. package/dist/state-CFntkBxv.js +1696 -0
  79. package/dist/state-CR6-uxRM.cjs +9 -0
  80. package/dist/state-DQNAhhCY.cjs +1306 -0
  81. package/dist/state-Dgr3LbNH.cjs +9 -0
  82. package/dist/state-Ds-1VLFt.js +9 -0
  83. package/dist/state-Dt16Hkud.js +9 -0
  84. package/dist/state-LuyoMylH.js +1696 -0
  85. package/dist/state-x2vKMZfm.cjs +9 -0
  86. package/package.json +2 -2
@@ -0,0 +1,3347 @@
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
+
10
+ //#region src/utils/supports-display-p3.ts
11
+ let cachedResult = null;
12
+ const supportsDisplayP3 = () => {
13
+ if (cachedResult !== null) return cachedResult;
14
+ try {
15
+ cachedResult = window.matchMedia("(color-gamut: p3)").matches;
16
+ } catch {
17
+ cachedResult = false;
18
+ }
19
+ return cachedResult;
20
+ };
21
+
22
+ //#endregion
23
+ //#region src/utils/overlay-color.ts
24
+ const isWideGamut = supportsDisplayP3();
25
+ const SRGB_COMPONENTS = "210, 57, 192";
26
+ const P3_COMPONENTS = "0.84 0.19 0.78";
27
+ const overlayColor = (alpha) => isWideGamut ? `color(display-p3 ${P3_COMPONENTS} / ${alpha})` : `rgba(${SRGB_COMPONENTS}, ${alpha})`;
28
+
29
+ //#endregion
30
+ //#region src/constants.ts
31
+ const VERSION = "[DEV]";
32
+ const PANEL_BACKGROUND = "var(--rg-panel-bg)";
33
+ const PANEL_SHADOW = "var(--rg-shadow)";
34
+ const OFFSCREEN_POSITION = -1e3;
35
+ const SELECTION_LERP_FACTOR = .95;
36
+ const FEEDBACK_DURATION_MS = 1500;
37
+ const COPY_DEBUG_GRABBING_DELAY_MS = 1e3;
38
+ const SYMBOLICATION_TIMEOUT_MS = 5e3;
39
+ const MAX_SELECTOR_COMBINATIONS = 1e4;
40
+ const Z_INDEX_OVERLAY = 2147483647;
41
+ const Z_INDEX_OVERLAY_CANVAS = 2147483645;
42
+ const DRAG_LERP_FACTOR = .7;
43
+ const BASELINE_FRAME_DURATION_MS = 1e3 / 60;
44
+ const LERP_CONVERGENCE_THRESHOLD_PX = .5;
45
+ const OPACITY_CONVERGENCE_THRESHOLD = .01;
46
+ const OVERLAY_BORDER_COLOR_DRAG = overlayColor(.4);
47
+ const OVERLAY_FILL_COLOR_DRAG = overlayColor(.05);
48
+ const OVERLAY_BORDER_COLOR_DEFAULT = overlayColor(.5);
49
+ const OVERLAY_FILL_COLOR_DEFAULT = overlayColor(.08);
50
+ const FROZEN_GLOW_COLOR = overlayColor(.15);
51
+ const ARROW_MAX_LABEL_WIDTH_RATIO = .2;
52
+ const PREVIEW_PRIORITY_ATTRS = [
53
+ "id",
54
+ "class",
55
+ "aria-label",
56
+ "data-testid",
57
+ "role",
58
+ "name",
59
+ "title"
60
+ ];
61
+ const COMPACT_IDENTIFYING_ATTRS = ["id", "data-testid"];
62
+ const PREVIEW_IDENTIFYING_ATTRS = new Set([
63
+ "id",
64
+ "data-testid",
65
+ "aria-label",
66
+ "href",
67
+ "src",
68
+ "alt",
69
+ "type",
70
+ "name",
71
+ "placeholder",
72
+ "role",
73
+ "for",
74
+ "action",
75
+ "method",
76
+ "title",
77
+ "disabled",
78
+ "checked",
79
+ "readonly",
80
+ "required",
81
+ "selected",
82
+ "open"
83
+ ]);
84
+ const MODIFIER_KEYS = [
85
+ "Meta",
86
+ "Control",
87
+ "Shift",
88
+ "Alt"
89
+ ];
90
+ const ARROW_KEYS = new Set([
91
+ "ArrowUp",
92
+ "ArrowDown",
93
+ "ArrowLeft",
94
+ "ArrowRight"
95
+ ]);
96
+ const FROZEN_ELEMENT_ATTRIBUTE = "data-react-grab-frozen";
97
+ const USER_IGNORE_ATTRIBUTE = "data-react-grab-ignore";
98
+ const VIEWPORT_COVERAGE_THRESHOLD = .9;
99
+ const OVERLAY_Z_INDEX_THRESHOLD = 1e3;
100
+ const DEV_TOOLS_OVERLAY_Z_INDEX_THRESHOLD = 2147483600;
101
+ const TOOLBAR_DEFAULT_POSITION_RATIO = .5;
102
+ const DEFAULT_ACTION_ID = "comment";
103
+ const DRAG_SELECTION_COVERAGE_THRESHOLD = .75;
104
+ const ZOOM_DETECTION_THRESHOLD = .01;
105
+ const MOUNT_ROOT_RECHECK_DELAY_MS = 1e3;
106
+ const MAX_SESSION_STORAGE_SIZE_BYTES = 2 * 1024 * 1024;
107
+ const DROPDOWN_OFFSCREEN_POSITION = {
108
+ left: -9999,
109
+ top: -9999
110
+ };
111
+ const DROPDOWN_EDGE_TRANSFORM_ORIGIN = {
112
+ left: "left center",
113
+ right: "right center",
114
+ top: "center top",
115
+ bottom: "center bottom"
116
+ };
117
+ const NEXTJS_REVALIDATION_DELAY_MS = 1e3;
118
+ const SELECTION_LABEL_OFFSCREEN_PX = -9999;
119
+ const RELEVANT_CSS_PROPERTIES = new Set([
120
+ "display",
121
+ "position",
122
+ "top",
123
+ "right",
124
+ "bottom",
125
+ "left",
126
+ "z-index",
127
+ "overflow",
128
+ "overflow-x",
129
+ "overflow-y",
130
+ "width",
131
+ "height",
132
+ "min-width",
133
+ "min-height",
134
+ "max-width",
135
+ "max-height",
136
+ "margin-top",
137
+ "margin-right",
138
+ "margin-bottom",
139
+ "margin-left",
140
+ "padding-top",
141
+ "padding-right",
142
+ "padding-bottom",
143
+ "padding-left",
144
+ "flex-direction",
145
+ "flex-wrap",
146
+ "justify-content",
147
+ "align-items",
148
+ "align-self",
149
+ "align-content",
150
+ "flex-grow",
151
+ "flex-shrink",
152
+ "flex-basis",
153
+ "order",
154
+ "gap",
155
+ "row-gap",
156
+ "column-gap",
157
+ "grid-template-columns",
158
+ "grid-template-rows",
159
+ "grid-template-areas",
160
+ "font-family",
161
+ "font-size",
162
+ "font-weight",
163
+ "font-style",
164
+ "line-height",
165
+ "letter-spacing",
166
+ "text-align",
167
+ "text-decoration-line",
168
+ "text-decoration-style",
169
+ "text-transform",
170
+ "text-overflow",
171
+ "text-shadow",
172
+ "white-space",
173
+ "word-break",
174
+ "overflow-wrap",
175
+ "vertical-align",
176
+ "color",
177
+ "background-color",
178
+ "background-image",
179
+ "background-position",
180
+ "background-size",
181
+ "background-repeat",
182
+ "border-top-width",
183
+ "border-right-width",
184
+ "border-bottom-width",
185
+ "border-left-width",
186
+ "border-top-style",
187
+ "border-right-style",
188
+ "border-bottom-style",
189
+ "border-left-style",
190
+ "border-top-color",
191
+ "border-right-color",
192
+ "border-bottom-color",
193
+ "border-left-color",
194
+ "border-top-left-radius",
195
+ "border-top-right-radius",
196
+ "border-bottom-left-radius",
197
+ "border-bottom-right-radius",
198
+ "box-shadow",
199
+ "opacity",
200
+ "transform",
201
+ "filter",
202
+ "backdrop-filter",
203
+ "object-fit",
204
+ "object-position"
205
+ ]);
206
+
207
+ //#endregion
208
+ //#region src/utils/get-tag-name.ts
209
+ const getTagName = (element) => (element.tagName || "").toLowerCase();
210
+
211
+ //#endregion
212
+ //#region src/utils/detect-csp-nonce.ts
213
+ let cachedNonce;
214
+ const detectCspNonce = () => {
215
+ if (cachedNonce !== void 0) return cachedNonce;
216
+ const existingElement = document.querySelector("script[nonce], style[nonce]");
217
+ const nonce = existingElement?.nonce || existingElement?.getAttribute("nonce") || null;
218
+ if (nonce) cachedNonce = nonce;
219
+ return nonce;
220
+ };
221
+
222
+ //#endregion
223
+ //#region src/utils/hide-from-third-parties.ts
224
+ const THIRD_PARTY_PRIVACY_ATTRIBUTES = [
225
+ ["data-rr-block", ""],
226
+ ["data-rr-ignore", ""],
227
+ ["data-rr-mask", ""],
228
+ ["data-sentry-block", ""],
229
+ ["data-sentry-ignore", ""],
230
+ ["data-sentry-mask", ""],
231
+ ["data-dd-privacy", "hidden"],
232
+ ["data-fs-exclude", ""],
233
+ ["data-lr-exclude", ""],
234
+ ["data-hj-suppress", ""],
235
+ ["data-recording-disable", ""],
236
+ ["data-clarity-mask", "true"],
237
+ ["data-heap-redact-text", ""]
238
+ ];
239
+ const hideFromThirdParties = (element) => {
240
+ for (const [attributeName, attributeValue] of THIRD_PARTY_PRIVACY_ATTRIBUTES) element.setAttribute(attributeName, attributeValue);
241
+ element.setAttribute("data-testid", "react-grab-overlay");
242
+ element.classList.add("ph-no-capture");
243
+ };
244
+
245
+ //#endregion
246
+ //#region src/utils/native-raf.ts
247
+ const isClientSide = typeof window !== "undefined";
248
+ const noopAnimationFrame = (_callback) => 0;
249
+ const noopCancelFrame = (_id) => {};
250
+ const nativeRequestAnimationFrame = isClientSide ? (Object.getOwnPropertyDescriptor(Window.prototype, "requestAnimationFrame")?.value ?? window.requestAnimationFrame).bind(window) : noopAnimationFrame;
251
+ const nativeCancelAnimationFrame = isClientSide ? (Object.getOwnPropertyDescriptor(Window.prototype, "cancelAnimationFrame")?.value ?? window.cancelAnimationFrame).bind(window) : noopCancelFrame;
252
+ const waitUntilNextFrame = () => isClientSide ? new Promise((resolve) => nativeRequestAnimationFrame(() => resolve())) : Promise.resolve();
253
+
254
+ //#endregion
255
+ //#region ../../node_modules/.pnpm/bippy@0.5.41_react@19.2.6/node_modules/bippy/dist/rdt-hook.js
256
+ /**
257
+ * @license bippy
258
+ *
259
+ * Copyright (c) Aiden Bai
260
+ *
261
+ * This source code is licensed under the MIT license found in the
262
+ * LICENSE file in the root directory of this source tree.
263
+ */
264
+ const e = `0.5.41`, t = `bippy-${e}`, n = Object.defineProperty, r = Object.prototype.hasOwnProperty, i$1 = () => {}, a$1 = (e) => {
265
+ try {
266
+ Function.prototype.toString.call(e).indexOf(`^_^`) > -1 && setTimeout(() => {
267
+ 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`);
268
+ });
269
+ } catch {}
270
+ }, o$1 = (e = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__) => !!(e && `getFiberRoots` in e);
271
+ let s$1 = !1, c$1;
272
+ 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) => {
273
+ let r = /* @__PURE__ */ new Map(), o = 0, s = {
274
+ _instrumentationIsActive: !1,
275
+ _instrumentationSource: t,
276
+ checkDCE: a$1,
277
+ hasUnsupportedRendererAttached: !1,
278
+ inject(e) {
279
+ let t = ++o;
280
+ return r.set(t, e), d$2.add(e), s._instrumentationIsActive || (s._instrumentationIsActive = !0, u$1.forEach((e) => e())), t;
281
+ },
282
+ on: i$1,
283
+ onCommitFiberRoot: i$1,
284
+ onCommitFiberUnmount: i$1,
285
+ onPostCommitFiberRoot: i$1,
286
+ renderers: r,
287
+ supportsFiber: !0,
288
+ supportsFlight: !0
289
+ };
290
+ try {
291
+ n(globalThis, `__REACT_DEVTOOLS_GLOBAL_HOOK__`, {
292
+ configurable: !0,
293
+ enumerable: !0,
294
+ get() {
295
+ return s;
296
+ },
297
+ set(t) {
298
+ if (t && typeof t == `object`) {
299
+ let n = s.renderers;
300
+ s = t, n.size > 0 && (n.forEach((e, n) => {
301
+ d$2.add(e), t.renderers.set(n, e);
302
+ }), p$2(e));
303
+ }
304
+ }
305
+ });
306
+ let t = window.hasOwnProperty, r = !1;
307
+ n(window, `hasOwnProperty`, {
308
+ configurable: !0,
309
+ value: function(...e) {
310
+ try {
311
+ if (!r && e[0] === `__REACT_DEVTOOLS_GLOBAL_HOOK__`) return globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__ = void 0, r = !0, -0;
312
+ } catch {}
313
+ return t.apply(this, e);
314
+ },
315
+ writable: !0
316
+ });
317
+ } catch {
318
+ p$2(e);
319
+ }
320
+ return s;
321
+ }, p$2 = (e) => {
322
+ e && u$1.add(e);
323
+ try {
324
+ let n = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
325
+ if (!n) return;
326
+ if (!n._instrumentationSource) {
327
+ n.checkDCE = a$1, n.supportsFiber = !0, n.supportsFlight = !0, n.hasUnsupportedRendererAttached = !1, n._instrumentationSource = t, n._instrumentationIsActive = !1;
328
+ let e = o$1(n);
329
+ if (e || (n.on = i$1), n.renderers.size) {
330
+ n._instrumentationIsActive = !0, u$1.forEach((e) => e());
331
+ return;
332
+ }
333
+ let r = n.inject, c = l$1(n);
334
+ c && !e && (s$1 = !0, n.inject({ scheduleRefresh() {} }) && (n._instrumentationIsActive = !0)), n.inject = (e) => {
335
+ let t = r(e);
336
+ return d$2.add(e), c && n.renderers.set(t, e), n._instrumentationIsActive = !0, u$1.forEach((e) => e()), t;
337
+ };
338
+ }
339
+ (n.renderers.size || n._instrumentationIsActive || l$1()) && e?.();
340
+ } catch {}
341
+ }, 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 = () => {
342
+ try {
343
+ g$2() && h$2();
344
+ } catch {}
345
+ };
346
+
347
+ //#endregion
348
+ //#region ../../node_modules/.pnpm/bippy@0.5.41_react@19.2.6/node_modules/bippy/dist/core.js
349
+ /**
350
+ * @license bippy
351
+ *
352
+ * Copyright (c) Aiden Bai
353
+ *
354
+ * This source code is licensed under the MIT license found in the
355
+ * LICENSE file in the root directory of this source tree.
356
+ */
357
+ const d$1 = 0, ee$1 = 1, f$1 = 3, p$1 = 4, m$1 = 5, h$1 = 6, te$1 = 7, ne$1 = 9, re$1 = 11, ie$1 = 13, ae$1 = 14, oe$1 = 15, se$1 = 16, ce$1 = 18, le$1 = 19, ue$1 = 22, de$1 = 23, fe$1 = 26, pe$1 = 27, me$1 = 28, he$1 = 30, g$1 = 60111, ge$1 = `Symbol(react.element)`, _e$1 = `Symbol(react.transitional.element)`, _$1 = `Symbol(react.concurrent_mode)`, v$1 = `Symbol(react.async_mode)`, y$1 = 13366, ve$1 = (e) => typeof e == `object` && !!e && `$$typeof` in e && [`Symbol(react.element)`, `Symbol(react.transitional.element)`].includes(String(e.$$typeof)), ye$1 = (e) => typeof e == `object` && !!e && `tag` in e && `stateNode` in e && `return` in e && `child` in e && `sibling` in e && `flags` in e, b$1 = (e) => {
358
+ switch (e.tag) {
359
+ case 5:
360
+ case 26:
361
+ case 27: return !0;
362
+ default: return typeof e.type == `string`;
363
+ }
364
+ }, be$1 = (e) => {
365
+ switch (e.tag) {
366
+ case 1:
367
+ case 11:
368
+ case 0:
369
+ case 14:
370
+ case 15: return !0;
371
+ default: return !1;
372
+ }
373
+ }, xe$1 = (e) => !e || typeof e != `object` ? !1 : `pendingProps` in e && !(`containerInfo` in e), Se$1 = (e, t) => e === t || e.alternate === t || t.alternate === e, Ce$1 = (e, t) => {
374
+ try {
375
+ let n = e.dependencies, r = e.alternate?.dependencies;
376
+ if (!n || !r || typeof n != `object` || !(`firstContext` in n) || typeof r != `object` || !(`firstContext` in r)) return !1;
377
+ let i = n.firstContext, a = r.firstContext;
378
+ for (; i && typeof i == `object` && `memoizedValue` in i || a && typeof a == `object` && `memoizedValue` in a;) {
379
+ if (t(i, a) === !0) return !0;
380
+ i = i?.next, a = a?.next;
381
+ }
382
+ } catch {}
383
+ return !1;
384
+ }, x$1 = (e, t) => {
385
+ try {
386
+ let n = e.memoizedState, r = e.alternate?.memoizedState;
387
+ for (; n || r;) {
388
+ if (t(n, r) === !0) return !0;
389
+ n = n?.next, r = r?.next;
390
+ }
391
+ } catch {}
392
+ return !1;
393
+ }, S$1 = (e, t) => {
394
+ try {
395
+ let n = e.memoizedProps, r = e.alternate?.memoizedProps || {}, i = new Set([...Object.keys(n), ...Object.keys(r)]);
396
+ for (let e of i) {
397
+ let i = r?.[e], a = n?.[e];
398
+ if (t(e, a, i) === !0) return !0;
399
+ }
400
+ } catch {}
401
+ return !1;
402
+ }, C$1 = (e) => {
403
+ let t = e.memoizedProps, n = e.alternate?.memoizedProps || {}, r = e.flags ?? e.effectTag ?? 0;
404
+ switch (e.tag) {
405
+ case 1:
406
+ case 9:
407
+ case 11:
408
+ case 0:
409
+ case 14:
410
+ case 15: return (r & 1) == 1;
411
+ default: return e.alternate ? n !== t || e.alternate.memoizedState !== e.memoizedState || e.alternate.ref !== e.ref : !0;
412
+ }
413
+ }, w$1 = (e) => !!(e.flags & (y$1 | 8) || e.subtreeFlags & (y$1 | 8)), T$1 = (e) => {
414
+ let t = [], n = [e];
415
+ for (; n.length;) {
416
+ let e = n.pop();
417
+ e && (b$1(e) && w$1(e) && C$1(e) && t.push(e), e.child && n.push(e.child), e.sibling && n.push(e.sibling));
418
+ }
419
+ return t;
420
+ }, E$1 = (e) => {
421
+ let t = [], n = e;
422
+ for (; n.return;) t.push(n), n = n.return;
423
+ return t;
424
+ }, D$1 = (e) => {
425
+ switch (e.tag) {
426
+ case 18: return !0;
427
+ case 7:
428
+ case 6:
429
+ case 23:
430
+ case 22: return !0;
431
+ case 3: return !1;
432
+ default: {
433
+ let t = typeof e.type == `object` && e.type !== null ? e.type.$$typeof : e.type;
434
+ switch (typeof t == `symbol` ? t.toString() : t) {
435
+ case g$1:
436
+ case _$1:
437
+ case v$1: return !0;
438
+ default: return !1;
439
+ }
440
+ }
441
+ }
442
+ }, O$1 = (e, t = !1) => {
443
+ let n = A$1(e, b$1, t);
444
+ return n ||= A$1(e, b$1, !t), n;
445
+ }, k$1 = (e) => {
446
+ let t = [], n = [];
447
+ for (b$1(e) ? t.push(e) : e.child && n.push(e.child); n.length;) {
448
+ let e = n.pop();
449
+ if (!e) break;
450
+ b$1(e) ? t.push(e) : e.child && n.push(e.child), e.sibling && n.push(e.sibling);
451
+ }
452
+ return t;
453
+ };
454
+ function A$1(e, t, n = !1) {
455
+ if (!e) return null;
456
+ let r = t(e);
457
+ if (r instanceof Promise) return (async () => {
458
+ if (await r === !0) return e;
459
+ let i = n ? e.return : e.child;
460
+ for (; i;) {
461
+ let e = await M$1(i, t, n);
462
+ if (e) return e;
463
+ i = n ? null : i.sibling;
464
+ }
465
+ return null;
466
+ })();
467
+ if (r === !0) return e;
468
+ let i = n ? e.return : e.child;
469
+ for (; i;) {
470
+ let e = j$1(i, t, n);
471
+ if (e) return e;
472
+ i = n ? null : i.sibling;
473
+ }
474
+ return null;
475
+ }
476
+ const j$1 = (e, t, n = !1) => {
477
+ if (!e) return null;
478
+ if (t(e) === !0) return e;
479
+ let r = n ? e.return : e.child;
480
+ for (; r;) {
481
+ let e = j$1(r, t, n);
482
+ if (e) return e;
483
+ r = n ? null : r.sibling;
484
+ }
485
+ return null;
486
+ }, M$1 = async (e, t, n = !1) => {
487
+ if (!e) return null;
488
+ if (await t(e) === !0) return e;
489
+ let r = n ? e.return : e.child;
490
+ for (; r;) {
491
+ let e = await M$1(r, t, n);
492
+ if (e) return e;
493
+ r = n ? null : r.sibling;
494
+ }
495
+ return null;
496
+ }, we$1 = (e) => {
497
+ let t = e?.actualDuration ?? 0, n = t, r = e?.child ?? null;
498
+ for (; t > 0 && r != null;) n -= r.actualDuration ?? 0, r = r.sibling;
499
+ return {
500
+ selfTime: n,
501
+ totalTime: t
502
+ };
503
+ }, Te$1 = (e) => !!e.updateQueue?.memoCache, N$1 = (e) => {
504
+ let t = e;
505
+ return typeof t == `function` ? t : typeof t == `object` && t ? N$1(t.type || t.render) : null;
506
+ }, Ee$1 = (e) => {
507
+ let t = e;
508
+ if (typeof t == `string`) return t;
509
+ if (typeof t != `function` && !(typeof t == `object` && t)) return null;
510
+ let n = t.displayName || t.name || null;
511
+ if (n) return n;
512
+ let r = N$1(t);
513
+ return r && (r.displayName || r.name) || null;
514
+ }, P$1 = (e) => {
515
+ try {
516
+ if (typeof e.version == `string` && e.bundleType > 0) return `development`;
517
+ } catch {}
518
+ return `production`;
519
+ }, De$1 = () => {
520
+ let e = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
521
+ return !!e?._instrumentationIsActive || o$1(e) || l$1(e);
522
+ }, Oe$1 = (e) => {
523
+ let t = e.alternate;
524
+ if (!t) return e;
525
+ if (t.actualStartTime && e.actualStartTime) return t.actualStartTime > e.actualStartTime ? t : e;
526
+ for (let t of Q$1) {
527
+ let n = A$1(t.current, (t) => {
528
+ if (t === e) return !0;
529
+ });
530
+ if (n) return n;
531
+ }
532
+ return e;
533
+ };
534
+ let W$1 = null, G$1 = null, K$1 = null;
535
+ const q$1 = () => {
536
+ if (!m$2()) return null;
537
+ let e = h$2();
538
+ if (!e?.renderers) return null;
539
+ if (W$1 || G$1 || K$1) return {
540
+ overrideContext: K$1,
541
+ overrideHookState: G$1,
542
+ overrideProps: W$1
543
+ };
544
+ for (let [, t] of Array.from(e.renderers)) try {
545
+ if (G$1) {
546
+ let e = G$1;
547
+ G$1 = (n, r, i, a) => {
548
+ let o = n.memoizedState;
549
+ for (let e = 0; e < Number(r) && o?.next; e++) o = o.next;
550
+ if (o?.queue) {
551
+ let e = o.queue;
552
+ if (J$1(e) && `dispatch` in e) {
553
+ let t = e.dispatch;
554
+ t(a);
555
+ return;
556
+ }
557
+ }
558
+ e(n, r, i, a), t.overrideHookState?.(n, r, i, a);
559
+ };
560
+ } else t.overrideHookState && (G$1 = t.overrideHookState);
561
+ if (W$1) {
562
+ let e = W$1;
563
+ W$1 = (n, r, i) => {
564
+ e(n, r, i), t.overrideProps?.(n, r, i);
565
+ };
566
+ } else t.overrideProps && (W$1 = t.overrideProps);
567
+ K$1 = (e, t, n, r) => {
568
+ let i = e;
569
+ for (; i;) {
570
+ let e = i.type;
571
+ if (e === t || e?.Provider === t) {
572
+ W$1 && (W$1(i, [`value`, ...n], r), i.alternate && W$1(i.alternate, [`value`, ...n], r));
573
+ break;
574
+ }
575
+ i = i.return;
576
+ }
577
+ };
578
+ } catch {}
579
+ }, J$1 = (e) => Object.prototype.toString.call(e) === `[object Object]` && (Object.getPrototypeOf(e) === Object.prototype || Object.getPrototypeOf(e) === null), Y$1 = (e, t = []) => {
580
+ if (!J$1(e)) return [{
581
+ path: t,
582
+ value: e
583
+ }];
584
+ let n = [];
585
+ for (let r in e) {
586
+ let i = e[r], a = t.concat(r);
587
+ J$1(i) ? n.push(...Y$1(i, a)) : n.push({
588
+ path: a,
589
+ value: i
590
+ });
591
+ }
592
+ return n;
593
+ }, je$1 = (e, t) => {
594
+ q$1();
595
+ let n = Y$1(t);
596
+ for (let { path: t, value: r } of n) try {
597
+ W$1?.(e, t, r);
598
+ } catch {}
599
+ }, X$1 = (e, t, n) => {
600
+ q$1();
601
+ let r = String(t);
602
+ if (J$1(n)) {
603
+ let t = Y$1(n);
604
+ for (let { path: n, value: i } of t) try {
605
+ G$1?.(e, r, n, i);
606
+ } catch {}
607
+ } else try {
608
+ G$1?.(e, r, [], n);
609
+ } catch {}
610
+ }, Me$1 = (e, t, n) => {
611
+ if (q$1(), J$1(n)) {
612
+ let r = Y$1(n);
613
+ for (let { path: n, value: i } of r) try {
614
+ K$1?.(e, t, n, i);
615
+ } catch {}
616
+ } else try {
617
+ K$1?.(e, t, [], n);
618
+ } catch {}
619
+ }, Ne$1 = (e) => {
620
+ let t$1 = h$2(e.onActive);
621
+ t$1._instrumentationSource = e.name ?? t;
622
+ let n = t$1.onCommitFiberRoot;
623
+ if (e.onCommitFiberRoot) {
624
+ let r = (t, i, a) => {
625
+ n !== r && (n?.(t, i, a), e.onCommitFiberRoot?.(t, i, a));
626
+ };
627
+ t$1.onCommitFiberRoot = r;
628
+ }
629
+ let r = t$1.onCommitFiberUnmount;
630
+ if (e.onCommitFiberUnmount) {
631
+ let n = (i, a) => {
632
+ t$1.onCommitFiberUnmount === n && (r?.(i, a), e.onCommitFiberUnmount?.(i, a));
633
+ };
634
+ t$1.onCommitFiberUnmount = n;
635
+ }
636
+ let i = t$1.onPostCommitFiberRoot;
637
+ if (e.onPostCommitFiberRoot) {
638
+ let n = (r, a) => {
639
+ t$1.onPostCommitFiberRoot === n && (i?.(r, a), e.onPostCommitFiberRoot?.(r, a));
640
+ };
641
+ t$1.onPostCommitFiberRoot = n;
642
+ }
643
+ return t$1;
644
+ }, Pe$1 = (e) => {
645
+ let t = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
646
+ if (t?.renderers) for (let n of t.renderers.values()) try {
647
+ let t = n.findFiberByHostInstance?.(e);
648
+ if (t) return t;
649
+ } catch {}
650
+ if (typeof e == `object` && e) {
651
+ if (`_reactRootContainer` in e) return e._reactRootContainer?._internalRoot?.current?.child;
652
+ for (let t in e) if (t.startsWith(`__reactContainer$`) || t.startsWith(`__reactInternalInstance$`) || t.startsWith(`__reactFiber`)) return e[t] || null;
653
+ }
654
+ return null;
655
+ }, Z$1 = Error(), Q$1 = /* @__PURE__ */ new Set(), Fe$1 = (e, n = {}) => {
656
+ let i = e.onActive, a = m$2(), o = o$1(), l = l$1(), u, d = !n.isProduction;
657
+ return e.onActive = () => {
658
+ clearTimeout(u);
659
+ let t = !0;
660
+ try {
661
+ let e = h$2();
662
+ for (let r of e.renderers.values()) {
663
+ let [e] = r.version.split(`.`);
664
+ Number(e) < (n.minReactMajorVersion ?? 17) && (t = !1), P$1(r) === `development` ? d = !0 : n.dangerouslyRunInProduction || (t = !1);
665
+ }
666
+ } catch (e) {
667
+ n.onError?.(e);
668
+ }
669
+ if (!t) {
670
+ e.onCommitFiberRoot = void 0, e.onCommitFiberUnmount = void 0, e.onPostCommitFiberRoot = void 0, e.onActive = void 0;
671
+ return;
672
+ }
673
+ i?.();
674
+ try {
675
+ let t = e.onCommitFiberRoot;
676
+ t && (e.onCommitFiberRoot = (e, r, i) => {
677
+ Q$1.has(r) || Q$1.add(r);
678
+ try {
679
+ t(e, r, i);
680
+ } catch (e) {
681
+ n.onError?.(e);
682
+ }
683
+ });
684
+ let r = e.onCommitFiberUnmount;
685
+ r && (e.onCommitFiberUnmount = (e, t) => {
686
+ try {
687
+ r(e, t);
688
+ } catch (e) {
689
+ n.onError?.(e);
690
+ }
691
+ });
692
+ let i = e.onPostCommitFiberRoot;
693
+ i && (e.onPostCommitFiberRoot = (e, t) => {
694
+ try {
695
+ i(e, t);
696
+ } catch (e) {
697
+ n.onError?.(e);
698
+ }
699
+ });
700
+ } catch (e) {
701
+ n.onError?.(e);
702
+ }
703
+ }, !a && !o && !l && (u = setTimeout(() => {
704
+ d && n.onError?.(Z$1), stop();
705
+ }, n.installCheckTimeout ?? 100)), e;
706
+ }, $ = (e, t, n) => {
707
+ e.type = t, e.alternate && (e.alternate.type = t), e.memoizedProps = { ...e.memoizedProps }, n.scheduleUpdate && n.scheduleUpdate(e);
708
+ }, Ie$1 = (e, t) => {
709
+ let n = globalThis.__REACT_DEVTOOLS_GLOBAL_HOOK__;
710
+ if (!n?.renderers) return;
711
+ let r = Array.from(n.renderers.values()).find((e) => !!e.scheduleUpdate);
712
+ if (!r) return;
713
+ let i = N$1(e.type);
714
+ if (!i) {
715
+ $(e, t, r);
716
+ return;
717
+ }
718
+ let a = e;
719
+ for (; a.return;) a = a.return;
720
+ j$1(a, (e) => {
721
+ N$1(e.type) === i && $(e, t, r);
722
+ });
723
+ };
724
+
725
+ //#endregion
726
+ //#region ../../node_modules/.pnpm/bippy@0.5.41_react@19.2.6/node_modules/bippy/dist/source.js
727
+ /**
728
+ * @license bippy
729
+ *
730
+ * Copyright (c) Aiden Bai
731
+ *
732
+ * This source code is licensed under the MIT license found in the
733
+ * LICENSE file in the root directory of this source tree.
734
+ */
735
+ const i = /^[a-zA-Z][a-zA-Z\d+\-.]*:/, a = [
736
+ `rsc://`,
737
+ `file:///`,
738
+ `webpack-internal://`,
739
+ `webpack://`,
740
+ `node:`,
741
+ `turbopack://`,
742
+ `metro://`,
743
+ `/app-pages-browser/`,
744
+ `/(app-pages-browser)/`
745
+ ], o = [
746
+ `<anonymous>`,
747
+ `eval`,
748
+ ``
749
+ ], 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 = /\(at [^)]+\)$/, d = /(^|@)\S+:\d+/, f = /^\s*at .*(\S+:\d+|\(native\))/m, ee = /^(eval@)?(\[native code\])?$/, p = (e) => {
750
+ if (e && typeof e == `object`) {
751
+ let t = e.stacktrace;
752
+ return typeof t == `string` ? t : null;
753
+ }
754
+ return null;
755
+ }, m = (e, t) => {
756
+ if (t?.includeInElement !== !1) {
757
+ let n = e.split(`
758
+ `), r = [];
759
+ for (let e of n) if (/^\s*at\s+/.test(e)) {
760
+ let t = _(e, void 0)[0];
761
+ t && r.push(t);
762
+ } else if (/^\s*in\s+/.test(e)) {
763
+ let t = e.replace(/^\s*in\s+/, ``).replace(/\s*\(at .*\)$/, ``);
764
+ r.push({
765
+ functionName: t,
766
+ source: e
767
+ });
768
+ } else if (e.match(d)) {
769
+ let t = v(e, void 0)[0];
770
+ t && r.push(t);
771
+ }
772
+ return g(r, t);
773
+ }
774
+ return e.match(f) ? _(e, t) : v(e, t);
775
+ }, h = (e) => {
776
+ if (!e.includes(`:`)) return [
777
+ e,
778
+ void 0,
779
+ void 0
780
+ ];
781
+ let t = e.startsWith(`(`) && /:\d+\)$/.test(e) ? e.slice(1, -1) : e, n = /(.+?)(?::(\d+))?(?::(\d+))?$/.exec(t);
782
+ return n ? [
783
+ n[1],
784
+ n[2] || void 0,
785
+ n[3] || void 0
786
+ ] : [
787
+ t,
788
+ void 0,
789
+ void 0
790
+ ];
791
+ }, 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, te = (e, t) => _(e.stack, t), _ = (e, t) => g(e.split(`
792
+ `).filter((e) => !!e.match(f)), t).map((e) => {
793
+ let t = e;
794
+ t.includes(`(eval `) && (t = t.replace(/eval code/g, `eval`).replace(/(\(eval at [^()]*)|(,.*$)/g, ``));
795
+ let n = t.replace(/^\s+/, ``).replace(/\(eval code/g, `(`).replace(/^.*?\s+/, ``), r = n.match(/ (\(.+\)$)/);
796
+ n = r ? n.replace(r[0], ``) : n;
797
+ let i = h(r ? r[1] : n);
798
+ return {
799
+ functionName: r && n || void 0,
800
+ fileName: [`eval`, `<anonymous>`].includes(i[0]) ? void 0 : i[0],
801
+ lineNumber: i[1] ? +i[1] : void 0,
802
+ columnNumber: i[2] ? +i[2] : void 0,
803
+ source: t
804
+ };
805
+ }), ne = (e, t) => v(e.stack, t), v = (e, t) => g(e.split(`
806
+ `).filter((e) => !e.match(ee)), t).map((e) => {
807
+ let t = e;
808
+ if (t.includes(` > eval`) && (t = t.replace(/ line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g, `:$1`)), !t.includes(`@`) && !t.includes(`:`)) return { functionName: t };
809
+ {
810
+ 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, ``));
811
+ return {
812
+ functionName: r,
813
+ fileName: i[0],
814
+ lineNumber: i[1] ? +i[1] : void 0,
815
+ columnNumber: i[2] ? +i[2] : void 0,
816
+ source: t
817
+ };
818
+ }
819
+ }), re = (e, t) => {
820
+ let n = p(e);
821
+ return !n || e.message.includes(`
822
+ `) && e.message.split(`
823
+ `).length > n.split(`
824
+ `).length ? ie(e, t) : e.stack ? oe(e, t) : ae(e, t);
825
+ }, ie = (e, t) => {
826
+ let n = /Line (\d+).*script (?:in )?(\S+)/i, r = e.message.split(`
827
+ `), i = [];
828
+ for (let e = 2, t = r.length; e < t; e += 2) {
829
+ let t = n.exec(r[e]);
830
+ t && i.push({
831
+ fileName: t[2],
832
+ lineNumber: +t[1],
833
+ source: r[e]
834
+ });
835
+ }
836
+ return g(i, t);
837
+ }, ae = (e, t) => {
838
+ let n = /Line (\d+).*script (?:in )?(\S+)(?:: In function (\S+))?$/i, r = (p(e) || ``).split(`
839
+ `), i = [];
840
+ for (let e = 0, t = r.length; e < t; e += 2) {
841
+ let t = n.exec(r[e]);
842
+ t && i.push({
843
+ functionName: t[3] || void 0,
844
+ fileName: t[2],
845
+ lineNumber: t[1] ? +t[1] : void 0,
846
+ source: r[e]
847
+ });
848
+ }
849
+ return g(i, t);
850
+ }, oe = (e, t) => g(e.stack.split(`
851
+ `).filter((e) => !!e.match(d) && !e.match(/^Error created at/)), t).map((e) => {
852
+ let t = e.split(`@`), n = h(t.pop()), r = t.shift() || ``, i = r.replace(/<anonymous function(: (\w+))?>/, `$2`).replace(/\([^)]*\)/g, ``) || void 0, a;
853
+ return r.match(/\(([^)]*)\)/) && (a = r.replace(/^[^(]+\(([^)]*)\)$/, `$1`)), {
854
+ functionName: i,
855
+ args: a === void 0 || a === `[arguments not available]` ? void 0 : a.split(`,`),
856
+ fileName: n[0],
857
+ lineNumber: n[1] ? +n[1] : void 0,
858
+ columnNumber: n[2] ? +n[2] : void 0,
859
+ source: e
860
+ };
861
+ });
862
+ var se = 44, y = `ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/`, ce = new Uint8Array(64), le = new Uint8Array(128);
863
+ for (let e = 0; e < y.length; e++) {
864
+ let t = y.charCodeAt(e);
865
+ ce[e] = t, le[t] = e;
866
+ }
867
+ function b(e, t) {
868
+ let n = 0, r = 0, i = 0;
869
+ do
870
+ i = le[e.next()], n |= (i & 31) << r, r += 5;
871
+ while (i & 32);
872
+ let a = n & 1;
873
+ return n >>>= 1, a && (n = -2147483648 | -n), t + n;
874
+ }
875
+ function ue(e, t) {
876
+ return e.pos >= t ? !1 : e.peek() !== se;
877
+ }
878
+ var de = class {
879
+ constructor(e) {
880
+ this.pos = 0, this.buffer = e;
881
+ }
882
+ next() {
883
+ return this.buffer.charCodeAt(this.pos++);
884
+ }
885
+ peek() {
886
+ return this.buffer.charCodeAt(this.pos);
887
+ }
888
+ indexOf(e) {
889
+ let { buffer: t, pos: n } = this, r = t.indexOf(e, n);
890
+ return r === -1 ? t.length : r;
891
+ }
892
+ };
893
+ function x(e) {
894
+ let { length: t } = e, n = new de(e), r = [], i = 0, a = 0, o = 0, s = 0, c = 0;
895
+ do {
896
+ let e = n.indexOf(`;`), t = [], l = !0, u = 0;
897
+ for (i = 0; n.pos < e;) {
898
+ let r;
899
+ i = b(n, i), i < u && (l = !1), u = i, ue(n, e) ? (a = b(n, a), o = b(n, o), s = b(n, s), ue(n, e) ? (c = b(n, c), r = [
900
+ i,
901
+ a,
902
+ o,
903
+ s,
904
+ c
905
+ ]) : r = [
906
+ i,
907
+ a,
908
+ o,
909
+ s
910
+ ]) : r = [i], t.push(r), n.pos++;
911
+ }
912
+ l || fe(t), r.push(t), n.pos = e + 1;
913
+ } while (n.pos <= t);
914
+ return r;
915
+ }
916
+ function fe(e) {
917
+ e.sort(pe);
918
+ }
919
+ function pe(e, t) {
920
+ return e[0] - t[0];
921
+ }
922
+ const me = /^[a-zA-Z][a-zA-Z\d+\-.]*:/, he = /^data:application\/json[^,]+base64,/, ge = /(?:\/\/[@#][ \t]+sourceMappingURL=([^\s'"]+?)[ \t]*$)|(?:\/\*[@#][ \t]+sourceMappingURL=([^*]+?)[ \t]*(?:\*\/)[ \t]*$)/, S = /* @__PURE__ */ new Map(), C = /* @__PURE__ */ new Map(), _e = (e, t, n, r) => {
923
+ if (n < 0 || n >= e.length) return null;
924
+ let i = e[n];
925
+ if (!i || i.length === 0) return null;
926
+ let a = null;
927
+ for (let e of i) if (e[0] <= r) a = e;
928
+ else break;
929
+ if (!a || a.length < 4) return null;
930
+ let [, o, s, c] = a;
931
+ if (o === void 0 || s === void 0 || c === void 0) return null;
932
+ let l = t[o];
933
+ return l ? {
934
+ columnNumber: c,
935
+ fileName: l,
936
+ lineNumber: s + 1
937
+ } : null;
938
+ }, w = (e, t, n) => {
939
+ if (e.sections) {
940
+ let r = null;
941
+ for (let i of e.sections) if (t > i.offset.line || t === i.offset.line && n >= i.offset.column) r = i;
942
+ else break;
943
+ if (!r) return null;
944
+ let i = t - r.offset.line, a = t === r.offset.line ? n - r.offset.column : n;
945
+ return _e(r.map.mappings, r.map.sources, i, a);
946
+ }
947
+ return _e(e.mappings, e.sources, t - 1, n);
948
+ }, ve = (e, t) => {
949
+ let n = t.split(`
950
+ `), r;
951
+ for (let e = n.length - 1; e >= 0 && !r; e--) {
952
+ let t = n[e].match(ge);
953
+ t && (r = t[1] || t[2]);
954
+ }
955
+ if (!r) return null;
956
+ let i = me.test(r);
957
+ if (!(he.test(r) || i || r.startsWith(`/`))) {
958
+ let t = e.split(`/`);
959
+ t[t.length - 1] = r, r = t.join(`/`);
960
+ }
961
+ return r;
962
+ }, ye = (e) => ({
963
+ file: e.file,
964
+ mappings: x(e.mappings),
965
+ names: e.names,
966
+ sourceRoot: e.sourceRoot,
967
+ sources: e.sources,
968
+ sourcesContent: e.sourcesContent,
969
+ version: 3
970
+ }), be = (e) => {
971
+ let t = e.sections.map(({ map: e, offset: t }) => ({
972
+ map: {
973
+ ...e,
974
+ mappings: x(e.mappings)
975
+ },
976
+ offset: t
977
+ })), n = /* @__PURE__ */ new Set();
978
+ for (let e of t) for (let t of e.map.sources) n.add(t);
979
+ return {
980
+ file: e.file,
981
+ mappings: [],
982
+ names: [],
983
+ sections: t,
984
+ sourceRoot: void 0,
985
+ sources: Array.from(n),
986
+ sourcesContent: void 0,
987
+ version: 3
988
+ };
989
+ }, T = (e) => {
990
+ if (!e) return !1;
991
+ let t = e.trim();
992
+ if (!t) return !1;
993
+ let n = t.match(me);
994
+ if (!n) return !0;
995
+ let r = n[0].toLowerCase();
996
+ return r === `http:` || r === `https:`;
997
+ }, E = async (e, t = fetch) => {
998
+ if (!T(e)) return null;
999
+ let n;
1000
+ try {
1001
+ let r = await t(e);
1002
+ if (!r.ok) return null;
1003
+ n = await r.text();
1004
+ } catch {
1005
+ return null;
1006
+ }
1007
+ if (!n) return null;
1008
+ let r = ve(e, n);
1009
+ if (!r || !T(r)) return null;
1010
+ try {
1011
+ let e = await t(r);
1012
+ if (!e.ok) return null;
1013
+ let n = await e.json();
1014
+ return `sections` in n ? be(n) : ye(n);
1015
+ } catch {
1016
+ return null;
1017
+ }
1018
+ }, D = async (e, t = !0, n) => {
1019
+ if (t && S.has(e)) return S.get(e) ?? null;
1020
+ if (t && C.has(e)) return C.get(e);
1021
+ let r = E(e, n);
1022
+ t && C.set(e, r);
1023
+ let i = await r;
1024
+ return t && C.delete(e), t && (i === null ? S.set(e, null) : S.set(e, i)), i;
1025
+ }, O = async (e, t = !0, n) => await Promise.all(e.map(async (e) => {
1026
+ if (!e.fileName) return e;
1027
+ let r = await D(e.fileName, t, n);
1028
+ if (!r || typeof e.lineNumber != `number` || typeof e.columnNumber != `number`) return e;
1029
+ let i = w(r, e.lineNumber, e.columnNumber);
1030
+ return i ? {
1031
+ ...e,
1032
+ source: i.fileName && e.source ? e.source.replace(e.fileName, i.fileName) : e.source,
1033
+ fileName: i.fileName,
1034
+ lineNumber: i.lineNumber,
1035
+ columnNumber: i.columnNumber,
1036
+ isSymbolicated: !0
1037
+ } : e;
1038
+ })), k = (e) => e._debugStack instanceof Error && typeof e._debugStack?.stack == `string`, xe = () => {
1039
+ let n = h$2();
1040
+ for (let t of [...Array.from(d$2), ...Array.from(n.renderers.values())]) {
1041
+ let e = t.currentDispatcherRef;
1042
+ if (e && typeof e == `object`) return `H` in e ? e.H : e.current;
1043
+ }
1044
+ return null;
1045
+ }, A = (t) => {
1046
+ for (let n of d$2) {
1047
+ let e = n.currentDispatcherRef;
1048
+ e && typeof e == `object` && (`H` in e ? e.H = t : e.current = t);
1049
+ }
1050
+ }, j = (e) => `\n in ${e}`, M = (e, t) => {
1051
+ let n = j(e);
1052
+ return t && (n += ` (at ${t})`), n;
1053
+ };
1054
+ let N = !1;
1055
+ const P = (e, t) => {
1056
+ if (!e || N) return ``;
1057
+ let r = Error.prepareStackTrace;
1058
+ Error.prepareStackTrace = void 0, N = !0;
1059
+ let i = xe();
1060
+ A(null);
1061
+ let a = console.error, o = console.warn;
1062
+ console.error = () => {}, console.warn = () => {};
1063
+ try {
1064
+ let r = { DetermineComponentFrameRoot() {
1065
+ let n;
1066
+ try {
1067
+ if (t) {
1068
+ let t = function() {
1069
+ throw Error();
1070
+ };
1071
+ if (Object.defineProperty(t.prototype, `props`, { set: function() {
1072
+ throw Error();
1073
+ } }), typeof Reflect == `object` && Reflect.construct) {
1074
+ try {
1075
+ Reflect.construct(t, []);
1076
+ } catch (e) {
1077
+ n = e;
1078
+ }
1079
+ Reflect.construct(e, [], t);
1080
+ } else {
1081
+ try {
1082
+ t.call();
1083
+ } catch (e) {
1084
+ n = e;
1085
+ }
1086
+ e.call(t.prototype);
1087
+ }
1088
+ } else {
1089
+ try {
1090
+ throw Error();
1091
+ } catch (e) {
1092
+ n = e;
1093
+ }
1094
+ let t = e();
1095
+ t && typeof t.catch == `function` && t.catch(() => {});
1096
+ }
1097
+ } catch (e) {
1098
+ if (e instanceof Error && n instanceof Error && typeof e.stack == `string`) return [e.stack, n.stack];
1099
+ }
1100
+ return [null, null];
1101
+ } };
1102
+ r.DetermineComponentFrameRoot.displayName = `DetermineComponentFrameRoot`, Object.getOwnPropertyDescriptor(r.DetermineComponentFrameRoot, `name`)?.configurable && Object.defineProperty(r.DetermineComponentFrameRoot, `name`, { value: `DetermineComponentFrameRoot` });
1103
+ let [i, a] = r.DetermineComponentFrameRoot();
1104
+ if (i && a) {
1105
+ let t = i.split(`
1106
+ `), r = a.split(`
1107
+ `), o = 0, s = 0;
1108
+ for (; o < t.length && !t[o].includes(`DetermineComponentFrameRoot`);) o++;
1109
+ for (; s < r.length && !r[s].includes(`DetermineComponentFrameRoot`);) s++;
1110
+ 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--;
1111
+ for (; o >= 1 && s >= 0; o--, s--) if (t[o] !== r[s]) {
1112
+ if (o !== 1 || s !== 1) do
1113
+ if (o--, s--, s < 0 || t[o] !== r[s]) {
1114
+ let r = `\n${t[o].replace(` at new `, ` at `)}`, i = Ee$1(e);
1115
+ return i && r.includes(`<anonymous>`) && (r = r.replace(`<anonymous>`, i)), r;
1116
+ }
1117
+ while (o >= 1 && s >= 0);
1118
+ break;
1119
+ }
1120
+ }
1121
+ } finally {
1122
+ N = !1, Error.prepareStackTrace = r, A(i), console.error = a, console.warn = o;
1123
+ }
1124
+ let s = e ? Ee$1(e) : ``;
1125
+ return s ? j(s) : ``;
1126
+ }, F = (e, t) => {
1127
+ let n = e.tag, r = ``;
1128
+ switch (n) {
1129
+ case 28:
1130
+ r = j(`Activity`);
1131
+ break;
1132
+ case 1:
1133
+ r = P(e.type, !0);
1134
+ break;
1135
+ case 11:
1136
+ r = P(e.type.render, !1);
1137
+ break;
1138
+ case 0:
1139
+ case 15:
1140
+ r = P(e.type, !1);
1141
+ break;
1142
+ case 5:
1143
+ case 26:
1144
+ case 27:
1145
+ r = j(e.type);
1146
+ break;
1147
+ case 16:
1148
+ r = j(`Lazy`);
1149
+ break;
1150
+ case 13:
1151
+ r = e.child !== t && t !== null ? j(`Suspense Fallback`) : j(`Suspense`);
1152
+ break;
1153
+ case 19:
1154
+ r = j(`SuspenseList`);
1155
+ break;
1156
+ case 30:
1157
+ r = j(`ViewTransition`);
1158
+ break;
1159
+ default: return ``;
1160
+ }
1161
+ return r;
1162
+ }, I = (e) => {
1163
+ try {
1164
+ let t = ``, n = e, r = null;
1165
+ do {
1166
+ t += F(n, r);
1167
+ let e = n._debugInfo;
1168
+ if (e && Array.isArray(e)) for (let n = e.length - 1; n >= 0; n--) {
1169
+ let r = e[n];
1170
+ typeof r.name == `string` && (t += M(r.name, r.env));
1171
+ }
1172
+ r = n, n = n.return;
1173
+ } while (n);
1174
+ return t;
1175
+ } catch (e) {
1176
+ return e instanceof Error ? `\nError generating stack: ${e.message}\n${e.stack}` : ``;
1177
+ }
1178
+ }, L = (e) => {
1179
+ let t = Error.prepareStackTrace;
1180
+ Error.prepareStackTrace = void 0;
1181
+ let n = e;
1182
+ if (!n) return ``;
1183
+ Error.prepareStackTrace = t, n.startsWith(`Error: react-stack-top-frame
1184
+ `) && (n = n.slice(29));
1185
+ let r = n.indexOf(`
1186
+ `);
1187
+ 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(`
1188
+ `, r)), r !== -1) n = n.slice(0, r);
1189
+ else return ``;
1190
+ return n;
1191
+ }, Se = (e) => !!(e.functionName && e.fileName && (e.fileName.startsWith(`rsc://`) || e.fileName.startsWith(`about://React/`))), Ce = (e, t) => e.fileName === t.fileName && e.lineNumber === t.lineNumber && e.columnNumber === t.columnNumber, we = (e) => {
1192
+ let t = /* @__PURE__ */ new Map();
1193
+ for (let n of e) for (let e of n.stackFrames) {
1194
+ if (!Se(e)) continue;
1195
+ let n = e.functionName, r = t.get(n) ?? [];
1196
+ r.some((t) => Ce(t, e)) || (r.push(e), t.set(n, r));
1197
+ }
1198
+ return t;
1199
+ }, Te = (e, t, n) => {
1200
+ if (!e.functionName) return {
1201
+ ...e,
1202
+ isServer: !0
1203
+ };
1204
+ let r = t.get(e.functionName);
1205
+ if (!r || r.length === 0) return {
1206
+ ...e,
1207
+ isServer: !0
1208
+ };
1209
+ let i = n.get(e.functionName) ?? 0, a = r[i % r.length];
1210
+ return n.set(e.functionName, i + 1), {
1211
+ ...e,
1212
+ isServer: !0,
1213
+ fileName: a.fileName,
1214
+ lineNumber: a.lineNumber,
1215
+ columnNumber: a.columnNumber,
1216
+ source: e.source?.replace(`(at Server)`, `(${a.fileName}:${a.lineNumber}:${a.columnNumber})`)
1217
+ };
1218
+ }, Ee = (e) => {
1219
+ let t = [];
1220
+ return A$1(e, (e) => {
1221
+ if (!k(e)) return;
1222
+ let r = typeof e.type == `string` ? e.type : Ee$1(e.type) || `<anonymous>`;
1223
+ t.push({
1224
+ componentName: r,
1225
+ stackFrames: m(L(e._debugStack?.stack))
1226
+ });
1227
+ }, !0), t;
1228
+ }, R = async (e, t = !0, n) => {
1229
+ let r = Ee(e), i = m(I(e)), a = we(r), o = /* @__PURE__ */ new Map();
1230
+ return O(i.map((e) => (e.source?.includes(`(at Server)`) ?? !1) || e.source != null && u.test(e.source) ? Te(e, a, o) : e).filter((e, t, n) => {
1231
+ if (t === 0) return !0;
1232
+ let r = n[t - 1];
1233
+ return e.functionName !== r.functionName;
1234
+ }), t, n);
1235
+ }, z = (e) => {
1236
+ let t = e._debugSource;
1237
+ return t ? typeof t == `object` && !!t && `fileName` in t && typeof t.fileName == `string` && `lineNumber` in t && typeof t.lineNumber == `number` : !1;
1238
+ }, De = async (e, t = !0, n) => {
1239
+ if (z(e)) return e._debugSource || null;
1240
+ let r = await R(e, t, n);
1241
+ for (let e of r) if (e.fileName) return {
1242
+ fileName: e.fileName,
1243
+ lineNumber: e.lineNumber,
1244
+ columnNumber: e.columnNumber,
1245
+ functionName: e.functionName
1246
+ };
1247
+ return null;
1248
+ }, Oe = (e) => e.split(`/`).filter(Boolean).length, ke = (e) => e.split(`/`).filter(Boolean)[0] ?? null, Ae = (e) => {
1249
+ let t = e.indexOf(`/`, 1);
1250
+ if (t === -1 || Oe(e.slice(0, t)) !== 1) return e;
1251
+ let n = e.slice(t);
1252
+ if (!s.test(n) || Oe(n) < 2) return e;
1253
+ let r = ke(n);
1254
+ return !r || r.startsWith(`@`) || r.length > 4 ? e : n;
1255
+ }, je = (e) => {
1256
+ if (!e || o.some((t) => t === e)) return ``;
1257
+ let t = e, n = t.startsWith(`http://`) || t.startsWith(`https://`);
1258
+ if (n) try {
1259
+ t = new URL(t).pathname;
1260
+ } catch {}
1261
+ if (n && (t = Ae(t)), t.startsWith(`about://React/`)) {
1262
+ let e = t.slice(14), n = e.indexOf(`/`), r = e.indexOf(`:`);
1263
+ t = n !== -1 && (r === -1 || n < r) ? e.slice(n + 1) : e;
1264
+ }
1265
+ let r = !0;
1266
+ for (; r;) {
1267
+ r = !1;
1268
+ for (let e of a) if (t.startsWith(e)) {
1269
+ t = t.slice(e.length), e === `file:///` && (t = `/${t.replace(/^\/+/, ``)}`), r = !0;
1270
+ break;
1271
+ }
1272
+ }
1273
+ if (i.test(t)) {
1274
+ let e = t.match(i);
1275
+ e && (t = t.slice(e[0].length));
1276
+ }
1277
+ if (t.startsWith(`//`)) {
1278
+ let e = t.indexOf(`/`, 2);
1279
+ t = e === -1 ? `` : t.slice(e);
1280
+ }
1281
+ let s = t.indexOf(`?`);
1282
+ if (s !== -1) {
1283
+ let e = t.slice(s);
1284
+ l.test(e) && (t = t.slice(0, s));
1285
+ }
1286
+ return t;
1287
+ }, Me = (e) => {
1288
+ let t = je(e);
1289
+ return !(!t || !s.test(t) || c.test(t));
1290
+ }, Ne = (e, t) => {
1291
+ let n = e.split(`
1292
+ `), r = t - 1;
1293
+ if (r < 0 || r >= n.length) return null;
1294
+ let i = Math.max(0, r - 5), a = Math.min(n.length, r + 5), o = n.slice(i, a).join(`
1295
+ `), 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);
1296
+ if (u?.[1]) return u[1];
1297
+ let d = o.match(c);
1298
+ if (d?.[1]) return d[1];
1299
+ let f = o.match(l);
1300
+ return f?.[1] ? f[1] : null;
1301
+ }, Pe = async (e, t = !0, r) => {
1302
+ let i = (await R(e, t, r)).filter((e) => e.fileName)[0];
1303
+ if (!i?.fileName) return Ee$1(e.type);
1304
+ let a = await D(i.fileName, t, r);
1305
+ if (!a) return Ee$1(e.type);
1306
+ let o = null;
1307
+ if (typeof i.lineNumber == `number` && typeof i.columnNumber == `number` && (o = w(a, i.lineNumber, i.columnNumber)), !o?.fileName || !o.lineNumber || !a.sourcesContent) return Ee$1(e.type);
1308
+ let s = a.sources.indexOf(o.fileName);
1309
+ if (s === -1 || !a.sourcesContent[s]) return Ee$1(e.type);
1310
+ let c = a.sourcesContent[s];
1311
+ return Ne(c, o.lineNumber) || Ee$1(e.type);
1312
+ }, Fe = Symbol.for(`react.context`), Ie = Symbol.for(`react.memo_cache_sentinel`);
1313
+ let B = [], V = null, H = null, U = null, W = null, G = 0, K = null;
1314
+ 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 = () => {
1315
+ let e = U;
1316
+ return e !== null && (U = e.next), e;
1317
+ }, X = (e) => {
1318
+ if (H === null) return e._currentValue;
1319
+ if (W === null) throw Error(`Context reads do not line up with context dependencies.`);
1320
+ if (Object.prototype.hasOwnProperty.call(W, `memoizedValue`)) {
1321
+ let e = W.memoizedValue;
1322
+ return W = W.next, e;
1323
+ }
1324
+ return e._currentValue;
1325
+ }, Le = () => {
1326
+ let n = h$2(), r = [...d$2, ...n.renderers.values()];
1327
+ for (let e of r) {
1328
+ let t = e.currentDispatcherRef;
1329
+ if (t && typeof t == `object`) return t;
1330
+ }
1331
+ return null;
1332
+ }, Re = (e) => `H` in e ? e.H : e.current, ze = (e, t) => {
1333
+ `H` in e ? e.H = t : e.current = t;
1334
+ }, Z = (e, t, n, r = null) => {
1335
+ B.push({
1336
+ displayName: r,
1337
+ primitive: e,
1338
+ stackError: Error(),
1339
+ value: t,
1340
+ dispatcherHookName: n
1341
+ });
1342
+ }, Be = (e) => {
1343
+ if (typeof e == `object` && e) {
1344
+ let t = e;
1345
+ if (typeof t.then == `function`) {
1346
+ let e = K !== null && G < K.length ? K[G++] : t;
1347
+ switch (e.status) {
1348
+ case `fulfilled`: return Z(`Promise`, e.value, `Use`), e.value;
1349
+ case `rejected`: throw e.reason;
1350
+ }
1351
+ throw Z(`Unresolved`, e, `Use`), q;
1352
+ }
1353
+ if (t.$$typeof === Fe && `_currentValue` in t) {
1354
+ let e = t, n = X(e);
1355
+ return Z(`Context (use)`, n, `Use`, e.displayName || `Context`), n;
1356
+ }
1357
+ }
1358
+ throw Error(`An unsupported type was passed to use(): ` + String(e));
1359
+ }, Ve = (e) => {
1360
+ let t = X(e);
1361
+ return Z(`Context`, t, `Context`, e.displayName || null), t;
1362
+ }, He = (e) => {
1363
+ let t = Y(), n = t === null ? typeof e == `function` ? e() : e : t.memoizedState;
1364
+ return Z(`State`, n, `State`), [n, () => {}];
1365
+ }, Ue = (e, t, n) => {
1366
+ let r = Y(), i = r === null ? n === void 0 ? t : n(t) : r.memoizedState;
1367
+ return Z(`Reducer`, i, `Reducer`), [i, () => {}];
1368
+ }, We = (e) => {
1369
+ let t = Y(), n = t === null ? { current: e } : t.memoizedState;
1370
+ return Z(`Ref`, n.current, `Ref`), n;
1371
+ }, Ge = () => {
1372
+ let e = Y();
1373
+ return Z(`CacheRefresh`, e === null ? () => {} : e.memoizedState, `CacheRefresh`), () => {};
1374
+ }, Ke = (e) => {
1375
+ Y(), Z(`LayoutEffect`, e, `LayoutEffect`);
1376
+ }, qe = (e) => {
1377
+ Y(), Z(`InsertionEffect`, e, `InsertionEffect`);
1378
+ }, Je = (e) => {
1379
+ Y(), Z(`Effect`, e, `Effect`);
1380
+ }, Ye = (e) => {
1381
+ Y();
1382
+ let t;
1383
+ typeof e == `object` && e && `current` in e && (t = e.current), Z(`ImperativeHandle`, t, `ImperativeHandle`);
1384
+ }, Xe = (e, t) => {
1385
+ Z(`DebugValue`, typeof t == `function` ? t(e) : e, `DebugValue`);
1386
+ }, Ze = (e) => {
1387
+ let t = Y();
1388
+ return Z(`Callback`, t === null ? e : t.memoizedState[0], `Callback`), e;
1389
+ }, Qe = (e) => {
1390
+ let t = Y(), n = t === null ? e() : t.memoizedState[0];
1391
+ return Z(`Memo`, n, `Memo`), n;
1392
+ }, $e = (e, t) => {
1393
+ let n = Y();
1394
+ Y();
1395
+ let r = n === null ? t() : n.memoizedState;
1396
+ return Z(`SyncExternalStore`, r, `SyncExternalStore`), r;
1397
+ }, et = () => {
1398
+ let e = Y();
1399
+ Y();
1400
+ let t = e === null ? !1 : e.memoizedState;
1401
+ return Z(`Transition`, t, `Transition`), [t, () => {}];
1402
+ }, tt = (e) => {
1403
+ let t = Y(), n = t === null ? e : t.memoizedState;
1404
+ return Z(`DeferredValue`, n, `DeferredValue`), n;
1405
+ }, nt = () => {
1406
+ let e = Y(), t = e === null ? `` : e.memoizedState;
1407
+ return Z(`Id`, t, `Id`), t;
1408
+ }, rt = (e) => {
1409
+ let t = H;
1410
+ if (t == null) return [];
1411
+ let n = t.updateQueue?.memoCache;
1412
+ if (n == null) return [];
1413
+ let r = n.data[n.index];
1414
+ return r === void 0 && (r = n.data[n.index] = Array.from({ length: e }, () => Ie)), n.index++, r;
1415
+ }, it = (e) => {
1416
+ let t = Y(), n = t === null ? e : t.memoizedState;
1417
+ return Z(`Optimistic`, n, `Optimistic`), [n, () => {}];
1418
+ }, at = (e, t) => {
1419
+ let n, r = null;
1420
+ if (e !== null) {
1421
+ let t = e.memoizedState;
1422
+ if (typeof t == `object` && t && `then` in t && typeof t.then == `function`) {
1423
+ let e = t;
1424
+ switch (e.status) {
1425
+ case `fulfilled`:
1426
+ n = e.value;
1427
+ break;
1428
+ case `rejected`:
1429
+ r = e.reason;
1430
+ break;
1431
+ default: r = q, n = e;
1432
+ }
1433
+ } else n = t;
1434
+ } else n = t;
1435
+ return {
1436
+ value: n,
1437
+ error: r
1438
+ };
1439
+ }, ot = (e) => (t, n) => {
1440
+ let r = Y();
1441
+ Y(), Y();
1442
+ let i = Error(), { value: a, error: o } = at(r, n);
1443
+ if (B.push({
1444
+ displayName: null,
1445
+ primitive: e,
1446
+ stackError: i,
1447
+ value: a,
1448
+ dispatcherHookName: e
1449
+ }), o !== null) throw o;
1450
+ return [
1451
+ a,
1452
+ () => {},
1453
+ !1
1454
+ ];
1455
+ }, st = ot(`ActionState`), Q = {
1456
+ readContext: X,
1457
+ use: Be,
1458
+ useCallback: Ze,
1459
+ useContext: Ve,
1460
+ useEffect: Je,
1461
+ useImperativeHandle: Ye,
1462
+ useLayoutEffect: Ke,
1463
+ useInsertionEffect: qe,
1464
+ useMemo: Qe,
1465
+ useReducer: Ue,
1466
+ useRef: We,
1467
+ useState: He,
1468
+ useDebugValue: Xe,
1469
+ useDeferredValue: tt,
1470
+ useTransition: et,
1471
+ useSyncExternalStore: $e,
1472
+ useId: nt,
1473
+ useHostTransitionStatus: () => {
1474
+ let e = X({ _currentValue: null });
1475
+ return Z(`HostTransitionStatus`, e, `HostTransitionStatus`), e;
1476
+ },
1477
+ useFormState: ot(`FormState`),
1478
+ useActionState: st,
1479
+ useOptimistic: it,
1480
+ useMemoCache: rt,
1481
+ useCacheRefresh: Ge,
1482
+ useEffectEvent: (e) => (Y(), Z(`EffectEvent`, e, `EffectEvent`), e)
1483
+ }, ct = typeof Proxy > `u` ? Q : new Proxy(Q, { get(e, t) {
1484
+ if (Object.prototype.hasOwnProperty.call(e, t)) return e[t];
1485
+ let n = Error(`Missing method in Dispatcher: ` + t);
1486
+ throw n.name = `ReactDebugToolsUnsupportedHookError`, n;
1487
+ } }), lt = () => {
1488
+ if (V !== null) return V;
1489
+ let e = /* @__PURE__ */ new Map(), t;
1490
+ try {
1491
+ 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`) {
1492
+ Q.use({
1493
+ $$typeof: Fe,
1494
+ _currentValue: null
1495
+ }), Q.use({
1496
+ then() {},
1497
+ status: `fulfilled`,
1498
+ value: null
1499
+ });
1500
+ try {
1501
+ Q.use({ then() {} });
1502
+ } catch {}
1503
+ }
1504
+ Q.useId(), typeof Q.useEffectEvent == `function` && Q.useEffectEvent(() => {});
1505
+ } finally {
1506
+ t = B, B = [];
1507
+ }
1508
+ for (let n of t) e.set(n.primitive, J(n.stackError));
1509
+ return V = e, V;
1510
+ };
1511
+
1512
+ //#endregion
1513
+ //#region ../../node_modules/.pnpm/bippy@0.5.41_react@19.2.6/node_modules/bippy/dist/install-hook-only.js
1514
+ /**
1515
+ * @license bippy
1516
+ *
1517
+ * Copyright (c) Aiden Bai
1518
+ *
1519
+ * This source code is licensed under the MIT license found in the
1520
+ * LICENSE file in the root directory of this source tree.
1521
+ */
1522
+ _$2();
1523
+
1524
+ //#endregion
1525
+ //#region ../../node_modules/.pnpm/bippy@0.5.41_react@19.2.6/node_modules/bippy/dist/index.js
1526
+ /**
1527
+ * @license bippy
1528
+ *
1529
+ * Copyright (c) Aiden Bai
1530
+ *
1531
+ * This source code is licensed under the MIT license found in the
1532
+ * LICENSE file in the root directory of this source tree.
1533
+ */
1534
+
1535
+ //#endregion
1536
+ //#region src/utils/truncate-string.ts
1537
+ const truncateString = (text, maxLength) => text.length > maxLength ? `${text.slice(0, maxLength)}...` : text;
1538
+
1539
+ //#endregion
1540
+ //#region src/utils/get-next-base-path.ts
1541
+ let cachedNextBasePath;
1542
+ const getNextBasePath = () => {
1543
+ if (cachedNextBasePath !== void 0) return cachedNextBasePath;
1544
+ const source = document.querySelector("script[src*=\"/_next/\"]")?.src;
1545
+ const pathname = source ? new URL(source).pathname : "";
1546
+ const assetPathIndex = pathname.indexOf("/_next/");
1547
+ cachedNextBasePath = assetPathIndex > 0 ? pathname.slice(0, assetPathIndex) : "";
1548
+ return cachedNextBasePath;
1549
+ };
1550
+
1551
+ //#endregion
1552
+ //#region src/utils/normalize-file-path.ts
1553
+ const BUNDLER_LAYER_PREFIX_REGEX = /^(?:\.\/)?\/?\([a-z][a-z0-9-]*\)\//;
1554
+ const normalizeFilePath = (fileName) => {
1555
+ let normalized = je(fileName);
1556
+ normalized = normalized.replace(BUNDLER_LAYER_PREFIX_REGEX, "");
1557
+ if (normalized.startsWith("./")) normalized = normalized.slice(2);
1558
+ return normalized;
1559
+ };
1560
+
1561
+ //#endregion
1562
+ //#region src/utils/safe-decode-uri-component.ts
1563
+ const safeDecodeURIComponent = (input) => {
1564
+ try {
1565
+ return decodeURIComponent(input);
1566
+ } catch {
1567
+ return input;
1568
+ }
1569
+ };
1570
+
1571
+ //#endregion
1572
+ //#region src/utils/parse-package-name.ts
1573
+ const NODE_MODULES_PATTERN = /(?:^|[/\\])node_modules[/\\]/g;
1574
+ const VITE_OPTIMIZED_DEPS_PATTERN = /[/\\]\.vite[/\\]deps[^/\\]*[/\\]/g;
1575
+ const FILE_EXTENSION_PATTERN = /\.[mc]?[jt]sx?$/i;
1576
+ const VITE_INTERNAL_CHUNK_PATTERN = /^chunk-[A-Za-z0-9_-]+$/;
1577
+ const PATH_SEPARATOR_PATTERN = /[/\\]/;
1578
+ const NAME_AT_VERSION_PATTERN = /^(.+?)@v?\d/;
1579
+ const splitPathSegments = (path) => path.split(PATH_SEPARATOR_PATTERN).filter(Boolean);
1580
+ const readNodeModulesPackage = (afterMarker) => {
1581
+ const [first, second] = splitPathSegments(afterMarker);
1582
+ if (!first || first.startsWith(".")) return null;
1583
+ if (!first.startsWith("@")) return first;
1584
+ return second ? `${first}/${second}` : null;
1585
+ };
1586
+ const readViteOptimizedDepPackage = (afterMarker) => {
1587
+ const firstSegment = splitPathSegments(afterMarker)[0];
1588
+ if (!firstSegment) return null;
1589
+ const stem = firstSegment.replace(FILE_EXTENSION_PATTERN, "");
1590
+ if (VITE_INTERNAL_CHUNK_PATTERN.test(stem)) return null;
1591
+ if (!stem.startsWith("@")) return stem;
1592
+ const scopeBoundary = stem.indexOf("_");
1593
+ if (scopeBoundary === -1) return null;
1594
+ return `${stem.slice(0, scopeBoundary)}/${stem.slice(scopeBoundary + 1)}`;
1595
+ };
1596
+ const extractAfterLastMarker = (input, pattern, read) => {
1597
+ let lastMatch = null;
1598
+ let match;
1599
+ while ((match = pattern.exec(input)) !== null) lastMatch = match;
1600
+ if (!lastMatch) return null;
1601
+ return read(input.slice(lastMatch.index + lastMatch[0].length));
1602
+ };
1603
+ const extractNameAtVersion = (segment) => segment?.match(NAME_AT_VERSION_PATTERN)?.[1] ?? null;
1604
+ const extractVersionedPackageFromUrl = (rawFileName) => {
1605
+ let url;
1606
+ try {
1607
+ url = new URL(rawFileName);
1608
+ } catch {
1609
+ return null;
1610
+ }
1611
+ if (!url.hostname) return null;
1612
+ const segments = splitPathSegments(url.pathname).map(safeDecodeURIComponent);
1613
+ for (const [index, segment] of segments.entries()) {
1614
+ if (segment.startsWith("@")) {
1615
+ const name = extractNameAtVersion(segments[index + 1]);
1616
+ if (name) return `${segment}/${name}`;
1617
+ continue;
1618
+ }
1619
+ const name = extractNameAtVersion(segment);
1620
+ if (name) return name;
1621
+ }
1622
+ return null;
1623
+ };
1624
+ const extractFromLocalPath = (normalizedPath) => extractAfterLastMarker(normalizedPath, VITE_OPTIMIZED_DEPS_PATTERN, readViteOptimizedDepPackage) ?? extractAfterLastMarker(normalizedPath, NODE_MODULES_PATTERN, readNodeModulesPackage);
1625
+ const parsePackageName = (fileName) => {
1626
+ if (!fileName) return null;
1627
+ const normalized = je(fileName);
1628
+ if (!normalized) return null;
1629
+ const localResult = extractFromLocalPath(safeDecodeURIComponent(normalized));
1630
+ if (localResult) return localResult;
1631
+ const cdnResult = extractVersionedPackageFromUrl(fileName);
1632
+ if (cdnResult) return cdnResult;
1633
+ return null;
1634
+ };
1635
+
1636
+ //#endregion
1637
+ //#region src/utils/strip-internal-attributes.ts
1638
+ const isInternalAttribute = (name) => name.startsWith("data-react-grab-");
1639
+
1640
+ //#endregion
1641
+ //#region src/utils/is-useful-component-name.ts
1642
+ const NON_COMPONENT_PREFIXES = new Set([
1643
+ "_",
1644
+ "$",
1645
+ "motion.",
1646
+ "styled.",
1647
+ "chakra.",
1648
+ "ark.",
1649
+ "Primitive.",
1650
+ "Slot."
1651
+ ]);
1652
+ const NEXT_INTERNAL_COMPONENT_NAMES = new Set([
1653
+ "AppRouter",
1654
+ "AppRouterAnnouncer",
1655
+ "AppDevOverlay",
1656
+ "AppDevOverlayErrorBoundary",
1657
+ "ClientPageRoot",
1658
+ "ClientSegmentRoot",
1659
+ "DevRootHTTPAccessFallbackBoundary",
1660
+ "ErrorBoundary",
1661
+ "ErrorBoundaryHandler",
1662
+ "GracefulDegradeBoundary",
1663
+ "HTTPAccessErrorFallback",
1664
+ "HTTPAccessFallbackBoundary",
1665
+ "HTTPAccessFallbackErrorBoundary",
1666
+ "HandleRedirect",
1667
+ "Head",
1668
+ "HistoryUpdater",
1669
+ "HotReload",
1670
+ "InnerLayoutRouter",
1671
+ "InnerScrollAndFocusHandler",
1672
+ "InnerScrollAndFocusHandlerOld",
1673
+ "InnerScrollAndMaybeFocusHandler",
1674
+ "InnerScrollHandlerNew",
1675
+ "LoadableComponent",
1676
+ "LoadingBoundary",
1677
+ "LoadingBoundaryProvider",
1678
+ "NotAllowedRootHTTPFallbackError",
1679
+ "OfflineProvider",
1680
+ "OuterLayoutRouter",
1681
+ "RedirectBoundary",
1682
+ "RedirectErrorBoundary",
1683
+ "RenderFromTemplateContext",
1684
+ "RenderValidationBoundaryAtThisLevel",
1685
+ "ReplaySsrOnlyErrors",
1686
+ "RootErrorBoundary",
1687
+ "RootLevelDevOverlayElement",
1688
+ "Router",
1689
+ "ScrollAndFocusHandler",
1690
+ "ScrollAndMaybeFocusHandler",
1691
+ "SegmentBoundaryTrigger",
1692
+ "SegmentBoundaryTriggerNode",
1693
+ "SegmentStateProvider",
1694
+ "SegmentTrieNode",
1695
+ "SegmentViewNode",
1696
+ "SegmentViewStateNode",
1697
+ "ServerRoot",
1698
+ "body",
1699
+ "html"
1700
+ ]);
1701
+ const REACT_INTERNAL_COMPONENT_NAMES = new Set([
1702
+ "Suspense",
1703
+ "Fragment",
1704
+ "StrictMode",
1705
+ "Profiler",
1706
+ "SuspenseList"
1707
+ ]);
1708
+ const LIBRARY_INTERNAL_COMPONENT_NAMES = new Set(["MotionDOMComponent"]);
1709
+ const isInternalComponentName = (name) => {
1710
+ if (NEXT_INTERNAL_COMPONENT_NAMES.has(name)) return true;
1711
+ if (REACT_INTERNAL_COMPONENT_NAMES.has(name)) return true;
1712
+ if (LIBRARY_INTERNAL_COMPONENT_NAMES.has(name)) return true;
1713
+ for (const prefix of NON_COMPONENT_PREFIXES) if (name.startsWith(prefix)) return true;
1714
+ return false;
1715
+ };
1716
+ const isUsefulComponentName = (name) => {
1717
+ if (!name) return false;
1718
+ if (isInternalComponentName(name)) return false;
1719
+ if (name === "SlotClone" || name === "Slot") return false;
1720
+ return true;
1721
+ };
1722
+
1723
+ //#endregion
1724
+ //#region src/core/context.ts
1725
+ let cachedIsNextProject;
1726
+ const checkIsNextProject = (revalidate) => {
1727
+ if (revalidate) cachedIsNextProject = void 0;
1728
+ cachedIsNextProject ??= typeof document !== "undefined" && Boolean(document.getElementById("__NEXT_DATA__") || document.querySelector("nextjs-portal"));
1729
+ return cachedIsNextProject;
1730
+ };
1731
+ const isSourceComponentName = (name) => {
1732
+ if (name.length <= 1) return false;
1733
+ if (isInternalComponentName(name)) return false;
1734
+ if (name[0] !== name[0].toUpperCase()) return false;
1735
+ if (name.endsWith("Provider") || name.endsWith("Context")) return false;
1736
+ return true;
1737
+ };
1738
+ const SERVER_COMPONENT_URL_PREFIXES = ["about://React/", "rsc://React/"];
1739
+ const isServerComponentUrl = (url) => SERVER_COMPONENT_URL_PREFIXES.some((prefix) => url.startsWith(prefix));
1740
+ const devirtualizeServerUrl = (url) => {
1741
+ for (const prefix of SERVER_COMPONENT_URL_PREFIXES) {
1742
+ if (!url.startsWith(prefix)) continue;
1743
+ const environmentEndIndex = url.indexOf("/", prefix.length);
1744
+ if (environmentEndIndex === -1) continue;
1745
+ const pathStart = environmentEndIndex + 1;
1746
+ const querySuffixIndex = url.lastIndexOf("?");
1747
+ return safeDecodeURIComponent(querySuffixIndex > pathStart ? url.slice(pathStart, querySuffixIndex) : url.slice(pathStart));
1748
+ }
1749
+ return url;
1750
+ };
1751
+ const symbolicateServerFrames = async (frames) => {
1752
+ const serverFrameIndices = [];
1753
+ const requestFrames = [];
1754
+ for (let frameIndex = 0; frameIndex < frames.length; frameIndex++) {
1755
+ const frame = frames[frameIndex];
1756
+ if (!frame.isServer || !frame.fileName) continue;
1757
+ serverFrameIndices.push(frameIndex);
1758
+ requestFrames.push({
1759
+ file: devirtualizeServerUrl(frame.fileName),
1760
+ methodName: frame.functionName ?? "<unknown>",
1761
+ line1: frame.lineNumber ?? null,
1762
+ column1: frame.columnNumber ?? null,
1763
+ arguments: []
1764
+ });
1765
+ }
1766
+ if (requestFrames.length === 0) return frames;
1767
+ const controller = new AbortController();
1768
+ const timeout = setTimeout(() => controller.abort(), SYMBOLICATION_TIMEOUT_MS);
1769
+ try {
1770
+ const response = await fetch(`${getNextBasePath()}/__nextjs_original-stack-frames`, {
1771
+ method: "POST",
1772
+ headers: { "Content-Type": "application/json" },
1773
+ body: JSON.stringify({
1774
+ frames: requestFrames,
1775
+ isServer: true,
1776
+ isEdgeServer: false,
1777
+ isAppDirectory: true
1778
+ }),
1779
+ signal: controller.signal
1780
+ });
1781
+ if (!response.ok) return frames;
1782
+ const results = await response.json();
1783
+ const resolvedFrames = [...frames];
1784
+ for (let resultIndex = 0; resultIndex < serverFrameIndices.length; resultIndex++) {
1785
+ const result = results[resultIndex];
1786
+ if (result?.status !== "fulfilled") continue;
1787
+ const resolved = result.value?.originalStackFrame;
1788
+ if (!resolved?.file || resolved.ignored) continue;
1789
+ const originalFrameIndex = serverFrameIndices[resultIndex];
1790
+ resolvedFrames[originalFrameIndex] = {
1791
+ ...frames[originalFrameIndex],
1792
+ fileName: resolved.file,
1793
+ lineNumber: resolved.line1 ?? void 0,
1794
+ columnNumber: resolved.column1 ?? void 0,
1795
+ isSymbolicated: true
1796
+ };
1797
+ }
1798
+ return resolvedFrames;
1799
+ } catch {
1800
+ return frames;
1801
+ } finally {
1802
+ clearTimeout(timeout);
1803
+ }
1804
+ };
1805
+ const extractServerFramesFromDebugStack = (rootFiber) => {
1806
+ const serverFramesByName = /* @__PURE__ */ new Map();
1807
+ A$1(rootFiber, (currentFiber) => {
1808
+ if (!k(currentFiber)) return false;
1809
+ const ownerStack = L(currentFiber._debugStack.stack);
1810
+ if (!ownerStack) return false;
1811
+ for (const frame of m(ownerStack)) {
1812
+ if (!frame.functionName || !frame.fileName) continue;
1813
+ if (!isServerComponentUrl(frame.fileName)) continue;
1814
+ if (serverFramesByName.has(frame.functionName)) continue;
1815
+ serverFramesByName.set(frame.functionName, {
1816
+ ...frame,
1817
+ isServer: true
1818
+ });
1819
+ }
1820
+ return false;
1821
+ }, true);
1822
+ return serverFramesByName;
1823
+ };
1824
+ const enrichServerFrameLocations = (rootFiber, frames) => {
1825
+ if (!frames.some((frame) => frame.isServer && !frame.fileName && frame.functionName)) return frames;
1826
+ const serverFramesByName = extractServerFramesFromDebugStack(rootFiber);
1827
+ if (serverFramesByName.size === 0) return frames;
1828
+ return frames.map((frame) => {
1829
+ if (!frame.isServer || frame.fileName || !frame.functionName) return frame;
1830
+ const resolved = serverFramesByName.get(frame.functionName);
1831
+ if (!resolved) return frame;
1832
+ return {
1833
+ ...frame,
1834
+ fileName: resolved.fileName,
1835
+ lineNumber: resolved.lineNumber,
1836
+ columnNumber: resolved.columnNumber
1837
+ };
1838
+ });
1839
+ };
1840
+ const findNearestFiberElement = (element) => {
1841
+ if (!De$1()) return element;
1842
+ let current = element;
1843
+ while (current) {
1844
+ if (Pe$1(current)) return current;
1845
+ current = current.parentElement;
1846
+ }
1847
+ return element;
1848
+ };
1849
+ const stackCache = /* @__PURE__ */ new WeakMap();
1850
+ const fetchStackForElement = async (element) => {
1851
+ try {
1852
+ const fiber = Pe$1(element);
1853
+ if (!fiber) return null;
1854
+ const frames = await R(fiber);
1855
+ if (checkIsNextProject()) return await symbolicateServerFrames(enrichServerFrameLocations(fiber, frames));
1856
+ return frames;
1857
+ } catch {
1858
+ return null;
1859
+ }
1860
+ };
1861
+ const getStack = (element) => {
1862
+ if (!De$1()) return Promise.resolve([]);
1863
+ const resolvedElement = findNearestFiberElement(element);
1864
+ const cached = stackCache.get(resolvedElement);
1865
+ if (cached) return cached;
1866
+ const promise = fetchStackForElement(resolvedElement);
1867
+ stackCache.set(resolvedElement, promise);
1868
+ return promise;
1869
+ };
1870
+ const getNearestComponentName = async (element) => {
1871
+ if (!De$1()) return null;
1872
+ const stack = await getStack(element);
1873
+ if (!stack) return null;
1874
+ for (const frame of stack) if (frame.functionName && isSourceComponentName(frame.functionName)) return frame.functionName;
1875
+ return null;
1876
+ };
1877
+ const resolveSource = async (element) => {
1878
+ const stack = await getStack(findNearestFiberElement(element));
1879
+ if (!stack || stack.length === 0) return null;
1880
+ const sourceFrames = stack.filter((frame) => frame.fileName && Me(frame.fileName));
1881
+ const resolvedFrame = sourceFrames.find((frame) => frame.functionName && isSourceComponentName(frame.functionName)) ?? sourceFrames[0];
1882
+ if (!resolvedFrame?.fileName) return null;
1883
+ return {
1884
+ filePath: normalizeFilePath(resolvedFrame.fileName),
1885
+ lineNumber: resolvedFrame.lineNumber ?? null,
1886
+ columnNumber: resolvedFrame.columnNumber ?? null,
1887
+ componentName: resolvedFrame.functionName && isSourceComponentName(resolvedFrame.functionName) ? resolvedFrame.functionName : null
1888
+ };
1889
+ };
1890
+ const getComponentDisplayName = (element) => {
1891
+ if (!De$1()) return null;
1892
+ const fiber = Pe$1(findNearestFiberElement(element));
1893
+ if (!fiber) return null;
1894
+ let currentFiber = fiber.return;
1895
+ while (currentFiber) {
1896
+ if (be$1(currentFiber)) {
1897
+ const name = Ee$1(currentFiber.type);
1898
+ if (name && isUsefulComponentName(name)) return name;
1899
+ }
1900
+ currentFiber = currentFiber.return;
1901
+ }
1902
+ return null;
1903
+ };
1904
+ const hasFormattableFrames = (stack) => {
1905
+ if (!stack) return false;
1906
+ return stack.some((frame) => {
1907
+ if (frame.fileName && Me(frame.fileName)) return true;
1908
+ if (frame.isServer && (!frame.functionName || isSourceComponentName(frame.functionName))) return true;
1909
+ if (frame.functionName && isSourceComponentName(frame.functionName)) return true;
1910
+ return false;
1911
+ });
1912
+ };
1913
+ const getComponentNamesFromFiber = (element, maxCount) => {
1914
+ if (!De$1()) return [];
1915
+ const fiber = Pe$1(element);
1916
+ if (!fiber) return [];
1917
+ const componentNames = [];
1918
+ A$1(fiber, (currentFiber) => {
1919
+ if (componentNames.length >= maxCount) return true;
1920
+ if (be$1(currentFiber)) {
1921
+ const name = Ee$1(currentFiber.type);
1922
+ if (name && isUsefulComponentName(name)) componentNames.push(name);
1923
+ }
1924
+ return false;
1925
+ }, true);
1926
+ return componentNames;
1927
+ };
1928
+ const formatResolvedSourceLine = (frame, filePath, componentName, isNextProject) => {
1929
+ const location = isNextProject && frame.lineNumber ? `${normalizeFilePath(filePath)}:${frame.lineNumber}${frame.columnNumber ? `:${frame.columnNumber}` : ""}` : normalizeFilePath(filePath);
1930
+ return componentName ? `\n in ${componentName} (at ${location})` : `\n in ${location}`;
1931
+ };
1932
+ const formatStackContext = (stack, options = {}) => {
1933
+ const { maxLines = 3 } = options;
1934
+ const isNextProject = checkIsNextProject();
1935
+ const lines = [];
1936
+ let previousLibraryPackage = null;
1937
+ const emit = (line, libraryPackage) => {
1938
+ lines.push(line);
1939
+ previousLibraryPackage = libraryPackage;
1940
+ };
1941
+ for (const frame of stack) {
1942
+ if (lines.length >= maxLines) break;
1943
+ const resolvedSource = frame.fileName && Me(frame.fileName) ? frame.fileName : null;
1944
+ const libraryPackage = resolvedSource ? null : parsePackageName(frame.fileName);
1945
+ if (libraryPackage && libraryPackage === previousLibraryPackage) continue;
1946
+ const componentName = frame.functionName && isSourceComponentName(frame.functionName) ? frame.functionName : null;
1947
+ if (frame.isServer && !resolvedSource && (componentName || !frame.functionName)) {
1948
+ const tag = libraryPackage ? `${libraryPackage} at Server` : "at Server";
1949
+ emit(`\n in ${componentName ?? "<anonymous>"} (${tag})`, libraryPackage);
1950
+ continue;
1951
+ }
1952
+ if (!resolvedSource && componentName) {
1953
+ emit(libraryPackage ? `\n in ${componentName} (${libraryPackage})` : `\n in ${componentName}`, libraryPackage);
1954
+ continue;
1955
+ }
1956
+ if (resolvedSource) emit(formatResolvedSourceLine(frame, resolvedSource, componentName, isNextProject), null);
1957
+ }
1958
+ return lines.join("");
1959
+ };
1960
+ const getStackContext = async (element, options = {}) => {
1961
+ const maxLines = options.maxLines ?? 3;
1962
+ const stack = await getStack(element);
1963
+ if (stack && hasFormattableFrames(stack)) return formatStackContext(stack, options);
1964
+ const componentNames = getComponentNamesFromFiber(element, maxLines);
1965
+ if (componentNames.length > 0) return componentNames.map((name) => `\n in ${name}`).join("");
1966
+ return "";
1967
+ };
1968
+ const getElementContext = async (element, options = {}) => {
1969
+ const resolvedElement = findNearestFiberElement(element);
1970
+ const html = getHTMLPreview(resolvedElement);
1971
+ const stackContext = await getStackContext(resolvedElement, options);
1972
+ if (stackContext) return `${html}${stackContext}`;
1973
+ return getFallbackContext(resolvedElement);
1974
+ };
1975
+ const getFallbackContext = (element) => {
1976
+ if (!(element instanceof HTMLElement)) return getInlineHTMLPreview(element);
1977
+ const tagName = getTagName(element);
1978
+ const attrsText = formatAttrsForPreview(element);
1979
+ const truncatedText = truncateString(getDirectTextContent(element), 100);
1980
+ if (truncatedText.length > 0) return `<${tagName}${attrsText}>\n ${truncatedText}\n</${tagName}>`;
1981
+ return `<${tagName}${attrsText} />`;
1982
+ };
1983
+ const truncateAttrValue = (value) => truncateString(value, 15);
1984
+ const formatPriorityAttrs = (element, options = {}) => {
1985
+ const { truncate = true, maxAttrs = 3 } = options;
1986
+ const priorityAttrs = [];
1987
+ for (const name of PREVIEW_PRIORITY_ATTRS) {
1988
+ if (priorityAttrs.length >= maxAttrs) break;
1989
+ const value = element.getAttribute(name);
1990
+ if (value) {
1991
+ const formattedValue = truncate ? truncateAttrValue(value) : value;
1992
+ priorityAttrs.push(`${name}="${formattedValue}"`);
1993
+ }
1994
+ }
1995
+ return priorityAttrs.length > 0 ? ` ${priorityAttrs.join(" ")}` : "";
1996
+ };
1997
+ const isClassOrStyleAttr = (name) => name === "class" || name === "className" || name === "style";
1998
+ const formatAttrsForPreview = (element) => {
1999
+ const identifyingParts = [];
2000
+ const remainingParts = [];
2001
+ let classAttr = "";
2002
+ for (const { name, value } of element.attributes) {
2003
+ if (isInternalAttribute(name)) continue;
2004
+ if (isClassOrStyleAttr(name)) {
2005
+ if (name !== "style" && value) classAttr = ` class="${truncateAttrValue(value)}"`;
2006
+ continue;
2007
+ }
2008
+ if (PREVIEW_IDENTIFYING_ATTRS.has(name)) identifyingParts.push(value ? ` ${name}="${value}"` : ` ${name}`);
2009
+ else if (value) remainingParts.push(` ${name}="${truncateAttrValue(value)}"`);
2010
+ }
2011
+ return identifyingParts.join("") + remainingParts.join("") + classAttr;
2012
+ };
2013
+ const getDirectTextContent = (element) => {
2014
+ let directText = "";
2015
+ for (const node of element.childNodes) if (node.nodeType === Node.TEXT_NODE) {
2016
+ const trimmed = node.textContent?.trim() ?? "";
2017
+ if (trimmed) directText += (directText ? " " : "") + trimmed;
2018
+ }
2019
+ return directText;
2020
+ };
2021
+ const formatChildElements = (elements) => {
2022
+ if (elements.length === 0) return "";
2023
+ if (elements.length <= 2) return elements.map((childElement) => `<${getTagName(childElement)} ...>`).join("\n ");
2024
+ return `(${elements.length} elements)`;
2025
+ };
2026
+ const getInlineHTMLPreview = (element) => {
2027
+ const tagName = getTagName(element);
2028
+ if (!(element instanceof HTMLElement)) return `<${tagName}${formatPriorityAttrs(element, {
2029
+ truncate: false,
2030
+ maxAttrs: PREVIEW_PRIORITY_ATTRS.length
2031
+ })} />`;
2032
+ const attrsText = formatAttrsForPreview(element);
2033
+ const truncatedText = truncateString(getDirectTextContent(element), 100);
2034
+ if (truncatedText) return `<${tagName}${attrsText}>${truncatedText}</${tagName}>`;
2035
+ return `<${tagName}${attrsText} />`;
2036
+ };
2037
+ const getHTMLPreview = (element) => {
2038
+ const tagName = getTagName(element);
2039
+ const attrsText = formatAttrsForPreview(element);
2040
+ const directText = getDirectTextContent(element);
2041
+ const topElements = [];
2042
+ const bottomElements = [];
2043
+ let foundFirstText = false;
2044
+ for (const node of element.childNodes) {
2045
+ if (node.nodeType === Node.COMMENT_NODE) continue;
2046
+ if (node.nodeType === Node.TEXT_NODE) {
2047
+ if (node.textContent && node.textContent.trim().length > 0) foundFirstText = true;
2048
+ } else if (node instanceof Element) if (!foundFirstText) topElements.push(node);
2049
+ else bottomElements.push(node);
2050
+ }
2051
+ let content = "";
2052
+ const topElementsStr = formatChildElements(topElements);
2053
+ if (topElementsStr) content += `\n ${topElementsStr}`;
2054
+ if (directText.length > 0) content += `\n ${truncateString(directText, 100)}`;
2055
+ const bottomElementsStr = formatChildElements(bottomElements);
2056
+ if (bottomElementsStr) content += `\n ${bottomElementsStr}`;
2057
+ if (content.length > 0) return `<${tagName}${attrsText}>${content}\n</${tagName}>`;
2058
+ return `<${tagName}${attrsText} />`;
2059
+ };
2060
+
2061
+ //#endregion
2062
+ //#region src/utils/is-element-visible.ts
2063
+ const isElementVisible = (element, computedStyle = window.getComputedStyle(element)) => {
2064
+ return computedStyle.display !== "none" && computedStyle.visibility !== "hidden" && computedStyle.opacity !== "0";
2065
+ };
2066
+
2067
+ //#endregion
2068
+ //#region src/utils/is-root-element.ts
2069
+ const isRootElement = (element) => {
2070
+ const tagName = getTagName(element);
2071
+ return tagName === "html" || tagName === "body";
2072
+ };
2073
+
2074
+ //#endregion
2075
+ //#region src/utils/is-valid-grabbable-element.ts
2076
+ const isReactGrabElement = (element) => {
2077
+ if (element.hasAttribute("data-react-grab")) return true;
2078
+ const rootNode = element.getRootNode();
2079
+ return rootNode instanceof ShadowRoot && rootNode.host.hasAttribute("data-react-grab");
2080
+ };
2081
+ const isUserIgnoredElement = (element) => element.hasAttribute("data-react-grab-ignore") || element.closest(`[${"data-react-grab-ignore"}]`) !== null;
2082
+ const isDevToolsOverlay = (computedStyle) => {
2083
+ const zIndex = parseInt(computedStyle.zIndex, 10);
2084
+ return computedStyle.pointerEvents === "none" && computedStyle.position === "fixed" && !isNaN(zIndex) && zIndex >= 2147483600;
2085
+ };
2086
+ const hasTransparentBackground = (computedStyle) => {
2087
+ const backgroundColor = computedStyle.backgroundColor;
2088
+ return backgroundColor === "transparent" || backgroundColor === "rgba(0, 0, 0, 0)";
2089
+ };
2090
+ const isFullViewportOverlay = (computedStyle) => {
2091
+ const position = computedStyle.position;
2092
+ if (position !== "fixed" && position !== "absolute") return false;
2093
+ if (hasTransparentBackground(computedStyle) || parseFloat(computedStyle.opacity) < .1) return true;
2094
+ const zIndex = parseInt(computedStyle.zIndex, 10);
2095
+ return !isNaN(zIndex) && zIndex > 1e3;
2096
+ };
2097
+ let visibilityCache = /* @__PURE__ */ new WeakMap();
2098
+ const clearVisibilityCache = () => {
2099
+ visibilityCache = /* @__PURE__ */ new WeakMap();
2100
+ };
2101
+ const isValidGrabbableElement = (element) => {
2102
+ if (isRootElement(element)) return false;
2103
+ if (isReactGrabElement(element)) return false;
2104
+ if (isUserIgnoredElement(element)) return false;
2105
+ const now = performance.now();
2106
+ const cached = visibilityCache.get(element);
2107
+ if (cached && now - cached.timestamp < 50) return cached.isVisible;
2108
+ const computedStyle = window.getComputedStyle(element);
2109
+ if (!isElementVisible(element, computedStyle)) {
2110
+ visibilityCache.set(element, {
2111
+ isVisible: false,
2112
+ timestamp: now
2113
+ });
2114
+ return false;
2115
+ }
2116
+ if (element.clientWidth / window.innerWidth >= .9 && element.clientHeight / window.innerHeight >= .9) {
2117
+ if (isDevToolsOverlay(computedStyle)) return false;
2118
+ if (isFullViewportOverlay(computedStyle)) return false;
2119
+ }
2120
+ visibilityCache.set(element, {
2121
+ isVisible: true,
2122
+ timestamp: now
2123
+ });
2124
+ return true;
2125
+ };
2126
+
2127
+ //#endregion
2128
+ //#region src/utils/create-style-element.ts
2129
+ const createStyleElement = (attribute, content) => {
2130
+ const element = document.createElement("style");
2131
+ element.setAttribute(attribute, "");
2132
+ const nonce = detectCspNonce();
2133
+ if (nonce) element.nonce = nonce;
2134
+ hideFromThirdParties(element);
2135
+ element.textContent = content;
2136
+ document.head.appendChild(element);
2137
+ return element;
2138
+ };
2139
+
2140
+ //#endregion
2141
+ //#region src/utils/pointer-events-freeze.ts
2142
+ const POINTER_EVENTS_STYLES = "html { pointer-events: none !important; }";
2143
+ let pointerEventsStyle = null;
2144
+ const isPointerEventsFreezeInstalled = () => pointerEventsStyle !== null;
2145
+ const installPointerEventsFreeze = () => {
2146
+ if (pointerEventsStyle) return;
2147
+ pointerEventsStyle = createStyleElement("data-react-grab-frozen-pseudo", POINTER_EVENTS_STYLES);
2148
+ };
2149
+ const uninstallPointerEventsFreeze = () => {
2150
+ pointerEventsStyle?.remove();
2151
+ pointerEventsStyle = null;
2152
+ };
2153
+ const suspendPointerEventsFreeze = () => {
2154
+ if (pointerEventsStyle) pointerEventsStyle.disabled = true;
2155
+ };
2156
+ const resumePointerEventsFreeze = () => {
2157
+ if (pointerEventsStyle) pointerEventsStyle.disabled = false;
2158
+ };
2159
+
2160
+ //#endregion
2161
+ //#region src/utils/get-element-at-position.ts
2162
+ let cache = null;
2163
+ let hoveredIframe = null;
2164
+ let resumeTimerId = null;
2165
+ const isPointInsideRect = (clientX, clientY, rect) => clientX >= rect.left && clientX <= rect.right && clientY >= rect.top && clientY <= rect.bottom;
2166
+ const scheduleResume = () => {
2167
+ if (resumeTimerId !== null) clearTimeout(resumeTimerId);
2168
+ resumeTimerId = setTimeout(() => {
2169
+ resumeTimerId = null;
2170
+ resumePointerEventsFreeze();
2171
+ }, 100);
2172
+ };
2173
+ const cancelScheduledResume = () => {
2174
+ if (resumeTimerId !== null) {
2175
+ clearTimeout(resumeTimerId);
2176
+ resumeTimerId = null;
2177
+ }
2178
+ };
2179
+ const isWithinThreshold = (x1, y1, x2, y2) => {
2180
+ const deltaX = Math.abs(x1 - x2);
2181
+ const deltaY = Math.abs(y1 - y2);
2182
+ return deltaX <= 2 && deltaY <= 2;
2183
+ };
2184
+ const getElementsAtPoint = (clientX, clientY) => {
2185
+ if (!Number.isFinite(clientX) || !Number.isFinite(clientY)) return [];
2186
+ cancelScheduledResume();
2187
+ suspendPointerEventsFreeze();
2188
+ const elements = document.elementsFromPoint(clientX, clientY);
2189
+ scheduleResume();
2190
+ return elements;
2191
+ };
2192
+ const getElementAtPosition = (clientX, clientY) => {
2193
+ if (!Number.isFinite(clientX) || !Number.isFinite(clientY)) return null;
2194
+ const now = performance.now();
2195
+ if (hoveredIframe && isPointInsideRect(clientX, clientY, hoveredIframe.rect)) return hoveredIframe.element;
2196
+ if (cache) {
2197
+ const isPositionClose = isWithinThreshold(clientX, clientY, cache.clientX, cache.clientY);
2198
+ const isWithinThrottle = now - cache.timestamp < 16;
2199
+ if (isPositionClose || isWithinThrottle) return cache.element;
2200
+ }
2201
+ cancelScheduledResume();
2202
+ suspendPointerEventsFreeze();
2203
+ let result = null;
2204
+ const topElement = document.elementFromPoint(clientX, clientY);
2205
+ if (topElement && isValidGrabbableElement(topElement)) result = topElement;
2206
+ else {
2207
+ const elementsAtPoint = document.elementsFromPoint(clientX, clientY);
2208
+ for (const candidateElement of elementsAtPoint) if (candidateElement !== topElement && isValidGrabbableElement(candidateElement)) {
2209
+ result = candidateElement;
2210
+ break;
2211
+ }
2212
+ }
2213
+ scheduleResume();
2214
+ hoveredIframe = result instanceof HTMLIFrameElement ? {
2215
+ element: result,
2216
+ rect: result.getBoundingClientRect()
2217
+ } : null;
2218
+ cache = {
2219
+ clientX,
2220
+ clientY,
2221
+ element: result,
2222
+ timestamp: now
2223
+ };
2224
+ return result;
2225
+ };
2226
+ const clearElementPositionCache = () => {
2227
+ cancelScheduledResume();
2228
+ resumePointerEventsFreeze();
2229
+ cache = null;
2230
+ hoveredIframe = null;
2231
+ };
2232
+
2233
+ //#endregion
2234
+ //#region src/utils/open-file.ts
2235
+ const OPEN_FILE_BASE_URL = "http://localhost:3000";
2236
+ const tryDevServerOpen = async (filePath, lineNumber) => {
2237
+ const isNextProject = checkIsNextProject();
2238
+ const params = new URLSearchParams({ file: filePath });
2239
+ const lineKey = isNextProject ? "line1" : "line";
2240
+ const columnKey = isNextProject ? "column1" : "column";
2241
+ if (lineNumber) params.set(lineKey, String(lineNumber));
2242
+ params.set(columnKey, "1");
2243
+ const endpoint = isNextProject ? `${getNextBasePath()}/__nextjs_launch-editor` : "/__open-in-editor";
2244
+ return (await fetch(`${endpoint}?${params}`)).ok;
2245
+ };
2246
+ const openFile = async (filePath, lineNumber, transformUrl) => {
2247
+ filePath = normalizeFilePath(filePath);
2248
+ if (await tryDevServerOpen(filePath, lineNumber).catch(() => false)) return;
2249
+ const lineParam = lineNumber ? `&line=${lineNumber}` : "";
2250
+ const rawUrl = `${OPEN_FILE_BASE_URL}/open-file?url=${encodeURIComponent(filePath)}${lineParam}`;
2251
+ const url = transformUrl ? transformUrl(rawUrl, filePath, lineNumber) : rawUrl;
2252
+ window.open(url, "_blank", "noopener,noreferrer");
2253
+ };
2254
+
2255
+ //#endregion
2256
+ //#region src/utils/freeze-gsap.ts
2257
+ let isRafFrozen = false;
2258
+ const pendingRafCallbacks = /* @__PURE__ */ new Map();
2259
+ let nextFakeRafId = -1;
2260
+ const knownAnimationCallbacks = /* @__PURE__ */ new WeakSet();
2261
+ const nativeIdToHeldId = /* @__PURE__ */ new Map();
2262
+ const replayedFakeToNativeId = /* @__PURE__ */ new Map();
2263
+ const isAnimationLibraryCallback = (callback) => {
2264
+ if (knownAnimationCallbacks.has(callback)) return true;
2265
+ if (!isRafFrozen || !("gsapVersions" in window)) return false;
2266
+ if (!((/* @__PURE__ */ new Error()).stack ?? "").includes("_tick")) return false;
2267
+ knownAnimationCallbacks.add(callback);
2268
+ return true;
2269
+ };
2270
+ if (typeof window !== "undefined") {
2271
+ window.requestAnimationFrame = (callback) => {
2272
+ if (!isAnimationLibraryCallback(callback)) return nativeRequestAnimationFrame(callback);
2273
+ if (isRafFrozen) {
2274
+ const identifier = nextFakeRafId--;
2275
+ pendingRafCallbacks.set(identifier, callback);
2276
+ return identifier;
2277
+ }
2278
+ const nativeId = nativeRequestAnimationFrame((timestamp) => {
2279
+ if (isRafFrozen) {
2280
+ const identifier = nextFakeRafId--;
2281
+ pendingRafCallbacks.set(identifier, callback);
2282
+ nativeIdToHeldId.set(nativeId, identifier);
2283
+ return;
2284
+ }
2285
+ callback(timestamp);
2286
+ });
2287
+ return nativeId;
2288
+ };
2289
+ window.cancelAnimationFrame = (identifier) => {
2290
+ if (pendingRafCallbacks.has(identifier)) {
2291
+ pendingRafCallbacks.delete(identifier);
2292
+ return;
2293
+ }
2294
+ const replayed = replayedFakeToNativeId.get(identifier);
2295
+ if (replayed !== void 0) {
2296
+ nativeCancelAnimationFrame(replayed.nativeId);
2297
+ replayedFakeToNativeId.delete(identifier);
2298
+ return;
2299
+ }
2300
+ const heldId = nativeIdToHeldId.get(identifier);
2301
+ if (heldId !== void 0) {
2302
+ pendingRafCallbacks.delete(heldId);
2303
+ nativeIdToHeldId.delete(identifier);
2304
+ return;
2305
+ }
2306
+ nativeCancelAnimationFrame(identifier);
2307
+ };
2308
+ }
2309
+ const freezeGsap = () => {
2310
+ if (isRafFrozen) return;
2311
+ isRafFrozen = true;
2312
+ pendingRafCallbacks.clear();
2313
+ nativeIdToHeldId.clear();
2314
+ for (const [fakeId, { nativeId, callback }] of replayedFakeToNativeId) {
2315
+ nativeCancelAnimationFrame(nativeId);
2316
+ pendingRafCallbacks.set(fakeId, callback);
2317
+ }
2318
+ replayedFakeToNativeId.clear();
2319
+ };
2320
+ const unfreezeGsap = () => {
2321
+ if (!isRafFrozen) return;
2322
+ isRafFrozen = false;
2323
+ for (const [fakeId, callback] of pendingRafCallbacks.entries()) {
2324
+ const nativeId = nativeRequestAnimationFrame((timestamp) => {
2325
+ replayedFakeToNativeId.delete(fakeId);
2326
+ callback(timestamp);
2327
+ });
2328
+ replayedFakeToNativeId.set(fakeId, {
2329
+ nativeId,
2330
+ callback
2331
+ });
2332
+ }
2333
+ pendingRafCallbacks.clear();
2334
+ nativeIdToHeldId.clear();
2335
+ };
2336
+
2337
+ //#endregion
2338
+ //#region src/utils/freeze-animations.ts
2339
+ const FROZEN_STYLES = `
2340
+ [${FROZEN_ELEMENT_ATTRIBUTE}],
2341
+ [${FROZEN_ELEMENT_ATTRIBUTE}] * {
2342
+ animation-play-state: paused !important;
2343
+ transition: none !important;
2344
+ }
2345
+ `;
2346
+ const GLOBAL_FREEZE_STYLES = `
2347
+ *, *::before, *::after {
2348
+ animation-play-state: paused !important;
2349
+ transition: none !important;
2350
+ }
2351
+ `;
2352
+ const SVG_ROOT_SELECTOR = "svg";
2353
+ let styleElement = null;
2354
+ let frozenElements = [];
2355
+ let frozenSvgElements = [];
2356
+ let lastInputElements = [];
2357
+ let globalAnimationStyleElement = null;
2358
+ let globalFrozenSvgElements = [];
2359
+ const svgFreezeDepthMap = /* @__PURE__ */ new Map();
2360
+ let frozenWaapiAnimations = [];
2361
+ const ensureStylesInjected = () => {
2362
+ if (styleElement) return;
2363
+ styleElement = createStyleElement("data-react-grab-frozen-styles", FROZEN_STYLES);
2364
+ };
2365
+ const areElementsSame = (firstElements, secondElements) => firstElements.length === secondElements.length && firstElements.every((currentElement, index) => currentElement === secondElements[index]);
2366
+ const collectFrozenSvgElements = (elements) => {
2367
+ const svgElements = /* @__PURE__ */ new Set();
2368
+ for (const element of elements) {
2369
+ if (element instanceof SVGSVGElement) svgElements.add(element);
2370
+ else if (element instanceof SVGElement && element.ownerSVGElement) svgElements.add(element.ownerSVGElement);
2371
+ for (const innerSvgElement of element.querySelectorAll(SVG_ROOT_SELECTOR)) if (innerSvgElement instanceof SVGSVGElement) svgElements.add(innerSvgElement);
2372
+ }
2373
+ return [...svgElements];
2374
+ };
2375
+ const callSvgAnimationMethod = (svgElement, methodName) => {
2376
+ const animationMethod = Reflect.get(svgElement, methodName);
2377
+ if (typeof animationMethod !== "function") return;
2378
+ animationMethod.call(svgElement);
2379
+ };
2380
+ const pauseSvgAnimations = (svgElements) => {
2381
+ for (const svgElement of svgElements) {
2382
+ const currentFreezeDepth = svgFreezeDepthMap.get(svgElement) ?? 0;
2383
+ if (currentFreezeDepth === 0) callSvgAnimationMethod(svgElement, "pauseAnimations");
2384
+ svgFreezeDepthMap.set(svgElement, currentFreezeDepth + 1);
2385
+ }
2386
+ };
2387
+ const resumeSvgAnimations = (svgElements) => {
2388
+ for (const svgElement of svgElements) {
2389
+ const currentFreezeDepth = svgFreezeDepthMap.get(svgElement);
2390
+ if (!currentFreezeDepth) continue;
2391
+ if (currentFreezeDepth === 1) {
2392
+ svgFreezeDepthMap.delete(svgElement);
2393
+ callSvgAnimationMethod(svgElement, "unpauseAnimations");
2394
+ continue;
2395
+ }
2396
+ svgFreezeDepthMap.set(svgElement, currentFreezeDepth - 1);
2397
+ }
2398
+ };
2399
+ const collectWaapiAnimations = (elements) => {
2400
+ const animations = [];
2401
+ for (const element of elements) for (const animation of element.getAnimations({ subtree: true })) if (animation.playState === "running") animations.push(animation);
2402
+ return animations;
2403
+ };
2404
+ const finishAnimations = (animations) => {
2405
+ for (const animation of animations) try {
2406
+ animation.finish();
2407
+ } catch {}
2408
+ };
2409
+ const freezeAllAnimations = (elements) => {
2410
+ if (elements.length === 0) return;
2411
+ if (areElementsSame(elements, lastInputElements)) return;
2412
+ unfreezeAllAnimations();
2413
+ lastInputElements = [...elements];
2414
+ ensureStylesInjected();
2415
+ frozenElements = elements;
2416
+ frozenSvgElements = collectFrozenSvgElements(frozenElements);
2417
+ pauseSvgAnimations(frozenSvgElements);
2418
+ for (const element of frozenElements) element.setAttribute(FROZEN_ELEMENT_ATTRIBUTE, "");
2419
+ frozenWaapiAnimations = collectWaapiAnimations(frozenElements);
2420
+ for (const animation of frozenWaapiAnimations) animation.pause();
2421
+ };
2422
+ const unfreezeAllAnimations = () => {
2423
+ if (frozenElements.length === 0 && frozenSvgElements.length === 0 && frozenWaapiAnimations.length === 0) return;
2424
+ for (const element of frozenElements) element.removeAttribute(FROZEN_ELEMENT_ATTRIBUTE);
2425
+ resumeSvgAnimations(frozenSvgElements);
2426
+ finishAnimations(frozenWaapiAnimations);
2427
+ frozenElements = [];
2428
+ frozenSvgElements = [];
2429
+ frozenWaapiAnimations = [];
2430
+ lastInputElements = [];
2431
+ };
2432
+ const freezeAnimations = (elements) => {
2433
+ if (elements.length === 0) {
2434
+ unfreezeAllAnimations();
2435
+ return () => {};
2436
+ }
2437
+ freezeAllAnimations(elements);
2438
+ return unfreezeAllAnimations;
2439
+ };
2440
+ const freezeGlobalAnimations = () => {
2441
+ if (globalAnimationStyleElement) return;
2442
+ globalAnimationStyleElement = createStyleElement("data-react-grab-global-freeze", GLOBAL_FREEZE_STYLES);
2443
+ globalFrozenSvgElements = collectFrozenSvgElements(Array.from(document.querySelectorAll(SVG_ROOT_SELECTOR)));
2444
+ pauseSvgAnimations(globalFrozenSvgElements);
2445
+ freezeGsap();
2446
+ };
2447
+ const unfreezeGlobalAnimations = () => {
2448
+ if (!globalAnimationStyleElement) return;
2449
+ globalAnimationStyleElement.textContent = `
2450
+ *, *::before, *::after {
2451
+ transition: none !important;
2452
+ }
2453
+ `;
2454
+ const animationsToFinish = [];
2455
+ for (const animation of document.getAnimations()) {
2456
+ if (animation.effect instanceof KeyframeEffect) {
2457
+ const target = animation.effect.target;
2458
+ if (target instanceof Element && target.getRootNode() instanceof ShadowRoot) continue;
2459
+ }
2460
+ animationsToFinish.push(animation);
2461
+ }
2462
+ finishAnimations(animationsToFinish);
2463
+ globalAnimationStyleElement.remove();
2464
+ globalAnimationStyleElement = null;
2465
+ resumeSvgAnimations(globalFrozenSvgElements);
2466
+ globalFrozenSvgElements = [];
2467
+ unfreezeGsap();
2468
+ };
2469
+
2470
+ //#endregion
2471
+ //#region src/utils/freeze-pseudo-states.ts
2472
+ const MOUSE_EVENTS_TO_BLOCK = [
2473
+ "mouseenter",
2474
+ "mouseleave",
2475
+ "mouseover",
2476
+ "mouseout",
2477
+ "pointerenter",
2478
+ "pointerleave",
2479
+ "pointerover",
2480
+ "pointerout"
2481
+ ];
2482
+ const FOCUS_EVENTS_TO_BLOCK = [
2483
+ "focus",
2484
+ "blur",
2485
+ "focusin",
2486
+ "focusout"
2487
+ ];
2488
+ const HOVER_STYLE_PROPERTIES = [
2489
+ "background-color",
2490
+ "color",
2491
+ "border-color",
2492
+ "box-shadow",
2493
+ "transform",
2494
+ "opacity",
2495
+ "outline",
2496
+ "filter",
2497
+ "scale",
2498
+ "visibility"
2499
+ ];
2500
+ const FOCUS_STYLE_PROPERTIES = [
2501
+ "background-color",
2502
+ "color",
2503
+ "border-color",
2504
+ "box-shadow",
2505
+ "outline",
2506
+ "outline-offset",
2507
+ "outline-width",
2508
+ "outline-color",
2509
+ "outline-style",
2510
+ "filter",
2511
+ "opacity",
2512
+ "ring-color",
2513
+ "ring-width"
2514
+ ];
2515
+ const frozenHoverElements = /* @__PURE__ */ new Map();
2516
+ const frozenFocusElements = /* @__PURE__ */ new Map();
2517
+ const stopEvent = (event) => {
2518
+ event.stopImmediatePropagation();
2519
+ };
2520
+ const preventFocusChange = (event) => {
2521
+ event.preventDefault();
2522
+ event.stopImmediatePropagation();
2523
+ };
2524
+ const collectOriginalPropertyValues = (element, properties) => {
2525
+ const originalPropertyValues = /* @__PURE__ */ new Map();
2526
+ for (const prop of properties) {
2527
+ const inlineValue = element.style.getPropertyValue(prop);
2528
+ if (inlineValue) originalPropertyValues.set(prop, inlineValue);
2529
+ }
2530
+ return originalPropertyValues;
2531
+ };
2532
+ const freezeElement = (element, properties, alreadyFrozen) => {
2533
+ if (alreadyFrozen?.has(element)) return null;
2534
+ const computed = getComputedStyle(element);
2535
+ let frozenStyles = element.style.cssText;
2536
+ const originalPropertyValues = collectOriginalPropertyValues(element, properties);
2537
+ for (const prop of properties) {
2538
+ const computedValue = computed.getPropertyValue(prop);
2539
+ if (computedValue) frozenStyles += `${prop}: ${computedValue} !important; `;
2540
+ }
2541
+ return {
2542
+ element,
2543
+ frozenStyles,
2544
+ originalPropertyValues
2545
+ };
2546
+ };
2547
+ const collectHoveredElements = (cursorX, cursorY) => {
2548
+ const hoveredElements = [];
2549
+ let current = document.elementFromPoint(cursorX, cursorY);
2550
+ while (current && current !== document.documentElement) {
2551
+ if (current instanceof HTMLElement) hoveredElements.push(current);
2552
+ current = current.parentElement;
2553
+ }
2554
+ return hoveredElements;
2555
+ };
2556
+ const collectFocusedElements = () => {
2557
+ const focusedElements = [];
2558
+ let current = document.activeElement;
2559
+ while (current && current !== document.body) {
2560
+ if (current instanceof HTMLElement) focusedElements.push(current);
2561
+ current = current.shadowRoot?.activeElement ?? null;
2562
+ }
2563
+ return focusedElements;
2564
+ };
2565
+ const applyFrozenStates = (states, storageMap) => {
2566
+ for (const { element, frozenStyles, originalPropertyValues } of states) {
2567
+ storageMap.set(element, originalPropertyValues);
2568
+ element.style.cssText = frozenStyles;
2569
+ }
2570
+ };
2571
+ const restoreFrozenStates = (storageMap, styleProperties) => {
2572
+ for (const [element, originalPropertyValues] of storageMap) for (const prop of styleProperties) {
2573
+ const originalValue = originalPropertyValues.get(prop);
2574
+ if (originalValue) element.style.setProperty(prop, originalValue);
2575
+ else element.style.removeProperty(prop);
2576
+ }
2577
+ storageMap.clear();
2578
+ };
2579
+ const freezePseudoStates = (cursorX, cursorY) => {
2580
+ if (isPointerEventsFreezeInstalled()) return;
2581
+ for (const eventType of MOUSE_EVENTS_TO_BLOCK) document.addEventListener(eventType, stopEvent, true);
2582
+ for (const eventType of FOCUS_EVENTS_TO_BLOCK) document.addEventListener(eventType, preventFocusChange, true);
2583
+ const hoverStates = [];
2584
+ 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);
2585
+ for (const element of hoveredElements) {
2586
+ const state = freezeElement(element, HOVER_STYLE_PROPERTIES);
2587
+ if (state) hoverStates.push(state);
2588
+ }
2589
+ const focusStates = [];
2590
+ for (const element of collectFocusedElements()) {
2591
+ const state = freezeElement(element, FOCUS_STYLE_PROPERTIES, frozenFocusElements);
2592
+ if (state) focusStates.push(state);
2593
+ }
2594
+ applyFrozenStates(hoverStates, frozenHoverElements);
2595
+ applyFrozenStates(focusStates, frozenFocusElements);
2596
+ installPointerEventsFreeze();
2597
+ };
2598
+ const unfreezePseudoStates = () => {
2599
+ clearElementPositionCache();
2600
+ for (const eventType of MOUSE_EVENTS_TO_BLOCK) document.removeEventListener(eventType, stopEvent, true);
2601
+ for (const eventType of FOCUS_EVENTS_TO_BLOCK) document.removeEventListener(eventType, preventFocusChange, true);
2602
+ restoreFrozenStates(frozenHoverElements, HOVER_STYLE_PROPERTIES);
2603
+ restoreFrozenStates(frozenFocusElements, FOCUS_STYLE_PROPERTIES);
2604
+ uninstallPointerEventsFreeze();
2605
+ };
2606
+
2607
+ //#endregion
2608
+ //#region src/utils/log-recoverable-error.ts
2609
+ const logRecoverableError = (context, error) => {
2610
+ console.warn(`[react-grab] ${context}:`, error);
2611
+ };
2612
+
2613
+ //#endregion
2614
+ //#region src/utils/freeze-updates.ts
2615
+ let isUpdatesPaused = false;
2616
+ const getOrCache = (cache, key, create) => {
2617
+ const cached = cache.get(key);
2618
+ if (cached) return cached;
2619
+ const value = create();
2620
+ cache.set(key, value);
2621
+ return value;
2622
+ };
2623
+ const patchedDispatchers = /* @__PURE__ */ new WeakMap();
2624
+ const wrappedDispatchCache = /* @__PURE__ */ new WeakMap();
2625
+ const wrappedStartTransitionCache = /* @__PURE__ */ new WeakMap();
2626
+ const pendingStoreCallbacks = /* @__PURE__ */ new Set();
2627
+ const pendingTransitionCallbacks = [];
2628
+ const pendingStateUpdates = [];
2629
+ const pausedQueueStates = /* @__PURE__ */ new WeakMap();
2630
+ const pausedContextStates = /* @__PURE__ */ new WeakMap();
2631
+ const renderersWithPatchedDispatcher = /* @__PURE__ */ new WeakSet();
2632
+ const typedFiberRoots = Q$1;
2633
+ const getFiberRoot = (fiber) => {
2634
+ let current = fiber;
2635
+ while (current.return) current = current.return;
2636
+ return current.stateNode ?? null;
2637
+ };
2638
+ const collectFiberRoots = () => {
2639
+ if (typedFiberRoots.size > 0) return typedFiberRoots;
2640
+ const collectedRoots = /* @__PURE__ */ new Set();
2641
+ const traverseDOM = (element) => {
2642
+ const fiber = Pe$1(element);
2643
+ if (fiber) {
2644
+ const fiberRoot = getFiberRoot(fiber);
2645
+ if (fiberRoot) collectedRoots.add(fiberRoot);
2646
+ return;
2647
+ }
2648
+ for (const childElement of Array.from(element.children)) {
2649
+ traverseDOM(childElement);
2650
+ if (collectedRoots.size > 0) return;
2651
+ }
2652
+ };
2653
+ traverseDOM(document.body);
2654
+ return collectedRoots;
2655
+ };
2656
+ const mergePendingChains = (original, buffered) => {
2657
+ if (!original) return buffered;
2658
+ if (!buffered) return original;
2659
+ if (!original.next || !buffered.next) return buffered;
2660
+ const originalFirst = original.next;
2661
+ const bufferedFirst = buffered.next;
2662
+ const isOriginalSingle = original === originalFirst;
2663
+ const isBufferedSingle = buffered === bufferedFirst;
2664
+ if (isOriginalSingle && isBufferedSingle) {
2665
+ original.next = buffered;
2666
+ buffered.next = original;
2667
+ } else if (isOriginalSingle) {
2668
+ original.next = bufferedFirst;
2669
+ buffered.next = original;
2670
+ } else if (isBufferedSingle) {
2671
+ buffered.next = originalFirst;
2672
+ original.next = buffered;
2673
+ } else {
2674
+ original.next = bufferedFirst;
2675
+ buffered.next = originalFirst;
2676
+ }
2677
+ return buffered;
2678
+ };
2679
+ const pauseHookQueue = (queue) => {
2680
+ if (!queue || pausedQueueStates.has(queue)) return;
2681
+ const pauseState = {
2682
+ originalPendingDescriptor: Object.getOwnPropertyDescriptor(queue, "pending"),
2683
+ pendingValueAtPause: queue.pending,
2684
+ bufferedPending: null
2685
+ };
2686
+ if (typeof queue.getSnapshot === "function") {
2687
+ pauseState.originalGetSnapshot = queue.getSnapshot;
2688
+ pauseState.snapshotValueAtPause = queue.getSnapshot();
2689
+ queue.getSnapshot = () => isUpdatesPaused ? pauseState.snapshotValueAtPause : pauseState.originalGetSnapshot();
2690
+ }
2691
+ let currentPendingValue = pauseState.pendingValueAtPause;
2692
+ Object.defineProperty(queue, "pending", {
2693
+ configurable: true,
2694
+ enumerable: true,
2695
+ get: () => isUpdatesPaused ? null : currentPendingValue,
2696
+ set: (newValue) => {
2697
+ if (isUpdatesPaused) {
2698
+ if (newValue !== null) pauseState.bufferedPending = mergePendingChains(pauseState.bufferedPending ?? null, newValue);
2699
+ return;
2700
+ }
2701
+ currentPendingValue = newValue;
2702
+ }
2703
+ });
2704
+ pausedQueueStates.set(queue, pauseState);
2705
+ };
2706
+ const extractActionsFromChain = (pending) => {
2707
+ if (!pending) return [];
2708
+ const actions = [];
2709
+ const first = pending.next;
2710
+ if (!first) return [];
2711
+ let current = first;
2712
+ do
2713
+ if (current) {
2714
+ actions.push(current.action);
2715
+ current = current.next;
2716
+ }
2717
+ while (current && current !== first);
2718
+ return actions;
2719
+ };
2720
+ const resumeHookQueue = (queue) => {
2721
+ const pauseState = pausedQueueStates.get(queue);
2722
+ if (!pauseState) return;
2723
+ if (pauseState.originalGetSnapshot) queue.getSnapshot = pauseState.originalGetSnapshot;
2724
+ if (pauseState.originalPendingDescriptor) Object.defineProperty(queue, "pending", pauseState.originalPendingDescriptor);
2725
+ else delete queue.pending;
2726
+ queue.pending = null;
2727
+ const dispatch = queue.dispatch;
2728
+ if (typeof dispatch === "function") {
2729
+ const pendingActions = extractActionsFromChain(pauseState.pendingValueAtPause ?? null);
2730
+ const bufferedActions = extractActionsFromChain(pauseState.bufferedPending ?? null);
2731
+ for (const action of [...pendingActions, ...bufferedActions]) pendingStateUpdates.push(() => dispatch(action));
2732
+ }
2733
+ pausedQueueStates.delete(queue);
2734
+ };
2735
+ const pauseContextDependency = (contextDependency) => {
2736
+ if (pausedContextStates.has(contextDependency)) return;
2737
+ const pauseState = {
2738
+ originalDescriptor: Object.getOwnPropertyDescriptor(contextDependency, "memoizedValue"),
2739
+ frozenValue: contextDependency.memoizedValue
2740
+ };
2741
+ Object.defineProperty(contextDependency, "memoizedValue", {
2742
+ configurable: true,
2743
+ enumerable: true,
2744
+ get() {
2745
+ if (isUpdatesPaused) return pauseState.frozenValue;
2746
+ if (pauseState.originalDescriptor?.get) return pauseState.originalDescriptor.get.call(this);
2747
+ return this._memoizedValue;
2748
+ },
2749
+ set(value) {
2750
+ if (isUpdatesPaused) {
2751
+ pauseState.pendingValue = value;
2752
+ pauseState.didReceivePendingValue = true;
2753
+ return;
2754
+ }
2755
+ if (pauseState.originalDescriptor?.set) pauseState.originalDescriptor.set.call(this, value);
2756
+ else this._memoizedValue = value;
2757
+ }
2758
+ });
2759
+ if (!pauseState.originalDescriptor?.get) contextDependency._memoizedValue = pauseState.frozenValue;
2760
+ pausedContextStates.set(contextDependency, pauseState);
2761
+ };
2762
+ const resumeContextDependency = (contextDependency) => {
2763
+ const pauseState = pausedContextStates.get(contextDependency);
2764
+ if (!pauseState) return;
2765
+ if (pauseState.originalDescriptor) Object.defineProperty(contextDependency, "memoizedValue", pauseState.originalDescriptor);
2766
+ else delete contextDependency.memoizedValue;
2767
+ if (pauseState.didReceivePendingValue) contextDependency.memoizedValue = pauseState.pendingValue;
2768
+ pausedContextStates.delete(contextDependency);
2769
+ };
2770
+ const forEachHookQueue = (fiber, callback) => {
2771
+ let hookState = fiber.memoizedState;
2772
+ while (hookState) {
2773
+ if (hookState.queue && typeof hookState.queue === "object") callback(hookState.queue);
2774
+ hookState = hookState.next;
2775
+ }
2776
+ };
2777
+ const forEachContextDependency = (fiber, callback) => {
2778
+ let contextDependency = fiber.dependencies?.firstContext;
2779
+ while (contextDependency && typeof contextDependency === "object" && "memoizedValue" in contextDependency) {
2780
+ callback(contextDependency);
2781
+ contextDependency = contextDependency.next;
2782
+ }
2783
+ };
2784
+ const traverseFibers = (fiber, onCompositeFiber) => {
2785
+ if (!fiber) return;
2786
+ if (be$1(fiber)) onCompositeFiber(fiber);
2787
+ traverseFibers(fiber.child, onCompositeFiber);
2788
+ traverseFibers(fiber.sibling, onCompositeFiber);
2789
+ };
2790
+ const pauseFiber = (fiber) => {
2791
+ forEachHookQueue(fiber, pauseHookQueue);
2792
+ forEachContextDependency(fiber, pauseContextDependency);
2793
+ };
2794
+ const resumeFiber = (fiber) => {
2795
+ forEachHookQueue(fiber, resumeHookQueue);
2796
+ forEachContextDependency(fiber, resumeContextDependency);
2797
+ };
2798
+ const patchDispatcher = (dispatcher) => {
2799
+ if (patchedDispatchers.has(dispatcher)) return;
2800
+ const typedDispatcher = dispatcher;
2801
+ const originalHooks = {
2802
+ useState: typedDispatcher.useState,
2803
+ useReducer: typedDispatcher.useReducer,
2804
+ useTransition: typedDispatcher.useTransition,
2805
+ useSyncExternalStore: typedDispatcher.useSyncExternalStore
2806
+ };
2807
+ patchedDispatchers.set(dispatcher, originalHooks);
2808
+ typedDispatcher.useState = (...args) => {
2809
+ const result = originalHooks.useState.apply(dispatcher, args);
2810
+ if (!isUpdatesPaused) return result;
2811
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2812
+ const [state, dispatch] = result;
2813
+ return [state, getOrCache(wrappedDispatchCache, dispatch, () => (...dispatchArgs) => {
2814
+ if (isUpdatesPaused) pendingStateUpdates.push(() => dispatch(...dispatchArgs));
2815
+ else dispatch(...dispatchArgs);
2816
+ })];
2817
+ };
2818
+ typedDispatcher.useReducer = (...args) => {
2819
+ const result = originalHooks.useReducer.apply(dispatcher, args);
2820
+ if (!isUpdatesPaused) return result;
2821
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2822
+ const [state, dispatch] = result;
2823
+ return [state, getOrCache(wrappedDispatchCache, dispatch, () => (...dispatchArgs) => {
2824
+ if (isUpdatesPaused) pendingStateUpdates.push(() => dispatch(...dispatchArgs));
2825
+ else dispatch(...dispatchArgs);
2826
+ })];
2827
+ };
2828
+ typedDispatcher.useTransition = (...args) => {
2829
+ const result = originalHooks.useTransition.apply(dispatcher, args);
2830
+ if (!isUpdatesPaused) return result;
2831
+ if (!Array.isArray(result) || typeof result[1] !== "function") return result;
2832
+ const [isPending, startTransition] = result;
2833
+ return [isPending, getOrCache(wrappedStartTransitionCache, startTransition, () => (transitionCallback) => {
2834
+ if (isUpdatesPaused) pendingTransitionCallbacks.push(() => startTransition(transitionCallback));
2835
+ else startTransition(transitionCallback);
2836
+ })];
2837
+ };
2838
+ typedDispatcher.useSyncExternalStore = ((subscribe, getSnapshot, getServerSnapshot) => {
2839
+ if (!isUpdatesPaused) return originalHooks.useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);
2840
+ const wrappedSubscribe = (onChange) => subscribe(() => {
2841
+ if (isUpdatesPaused) pendingStoreCallbacks.add(onChange);
2842
+ else onChange();
2843
+ });
2844
+ return originalHooks.useSyncExternalStore(wrappedSubscribe, getSnapshot, getServerSnapshot);
2845
+ });
2846
+ };
2847
+ const installDispatcherPatching = (renderer) => {
2848
+ const dispatcherRef = renderer.currentDispatcherRef;
2849
+ if (!dispatcherRef || typeof dispatcherRef !== "object") return;
2850
+ const dispatcherKey = "H" in dispatcherRef ? "H" : "current";
2851
+ let currentDispatcher = dispatcherRef[dispatcherKey];
2852
+ Object.defineProperty(dispatcherRef, dispatcherKey, {
2853
+ configurable: true,
2854
+ enumerable: true,
2855
+ get: () => {
2856
+ if (currentDispatcher && typeof currentDispatcher === "object") patchDispatcher(currentDispatcher);
2857
+ return currentDispatcher;
2858
+ },
2859
+ set: (newDispatcher) => {
2860
+ currentDispatcher = newDispatcher;
2861
+ }
2862
+ });
2863
+ };
2864
+ const scheduleReactUpdate = (fiberRoots) => {
2865
+ queueMicrotask(() => {
2866
+ try {
2867
+ for (const renderer of h$2().renderers.values()) {
2868
+ if (typeof renderer.scheduleUpdate !== "function") continue;
2869
+ for (const fiberRoot of fiberRoots) if (fiberRoot.current) try {
2870
+ renderer.scheduleUpdate(fiberRoot.current);
2871
+ } catch (error) {
2872
+ logRecoverableError("scheduleUpdate failed during unfreeze", error);
2873
+ }
2874
+ }
2875
+ } catch (error) {
2876
+ logRecoverableError("scheduleReactUpdate failed", error);
2877
+ }
2878
+ });
2879
+ };
2880
+ const invokeCallbacks = (callbacks) => {
2881
+ for (const callback of callbacks) try {
2882
+ callback();
2883
+ } catch (error) {
2884
+ logRecoverableError("Callback failed during state replay", error);
2885
+ }
2886
+ };
2887
+ const initializeFreezeSupport = () => {
2888
+ for (const renderer of h$2().renderers.values()) {
2889
+ if (renderersWithPatchedDispatcher.has(renderer)) continue;
2890
+ installDispatcherPatching(renderer);
2891
+ renderersWithPatchedDispatcher.add(renderer);
2892
+ }
2893
+ };
2894
+ const freezeUpdates = () => {
2895
+ if (isUpdatesPaused) return () => {};
2896
+ initializeFreezeSupport();
2897
+ isUpdatesPaused = true;
2898
+ const fiberRoots = collectFiberRoots();
2899
+ for (const fiberRoot of fiberRoots) traverseFibers(fiberRoot.current, pauseFiber);
2900
+ return () => {
2901
+ if (!isUpdatesPaused) return;
2902
+ try {
2903
+ const fiberRootsToResume = collectFiberRoots();
2904
+ for (const fiberRoot of fiberRootsToResume) traverseFibers(fiberRoot.current, resumeFiber);
2905
+ const storeCallbacksToInvoke = Array.from(pendingStoreCallbacks);
2906
+ const transitionCallbacksToInvoke = pendingTransitionCallbacks.slice();
2907
+ const stateUpdatesToInvoke = pendingStateUpdates.slice();
2908
+ isUpdatesPaused = false;
2909
+ invokeCallbacks(storeCallbacksToInvoke);
2910
+ invokeCallbacks(transitionCallbacksToInvoke);
2911
+ invokeCallbacks(stateUpdatesToInvoke);
2912
+ scheduleReactUpdate(fiberRootsToResume);
2913
+ } finally {
2914
+ pendingStoreCallbacks.clear();
2915
+ pendingTransitionCallbacks.length = 0;
2916
+ pendingStateUpdates.length = 0;
2917
+ }
2918
+ };
2919
+ };
2920
+
2921
+ //#endregion
2922
+ Object.defineProperty(exports, 'ARROW_KEYS', {
2923
+ enumerable: true,
2924
+ get: function () {
2925
+ return ARROW_KEYS;
2926
+ }
2927
+ });
2928
+ Object.defineProperty(exports, 'ARROW_MAX_LABEL_WIDTH_RATIO', {
2929
+ enumerable: true,
2930
+ get: function () {
2931
+ return ARROW_MAX_LABEL_WIDTH_RATIO;
2932
+ }
2933
+ });
2934
+ Object.defineProperty(exports, 'BASELINE_FRAME_DURATION_MS', {
2935
+ enumerable: true,
2936
+ get: function () {
2937
+ return BASELINE_FRAME_DURATION_MS;
2938
+ }
2939
+ });
2940
+ Object.defineProperty(exports, 'COMPACT_IDENTIFYING_ATTRS', {
2941
+ enumerable: true,
2942
+ get: function () {
2943
+ return COMPACT_IDENTIFYING_ATTRS;
2944
+ }
2945
+ });
2946
+ Object.defineProperty(exports, 'COPY_DEBUG_GRABBING_DELAY_MS', {
2947
+ enumerable: true,
2948
+ get: function () {
2949
+ return COPY_DEBUG_GRABBING_DELAY_MS;
2950
+ }
2951
+ });
2952
+ Object.defineProperty(exports, 'DEFAULT_ACTION_ID', {
2953
+ enumerable: true,
2954
+ get: function () {
2955
+ return DEFAULT_ACTION_ID;
2956
+ }
2957
+ });
2958
+ Object.defineProperty(exports, 'DRAG_LERP_FACTOR', {
2959
+ enumerable: true,
2960
+ get: function () {
2961
+ return DRAG_LERP_FACTOR;
2962
+ }
2963
+ });
2964
+ Object.defineProperty(exports, 'DRAG_SELECTION_COVERAGE_THRESHOLD', {
2965
+ enumerable: true,
2966
+ get: function () {
2967
+ return DRAG_SELECTION_COVERAGE_THRESHOLD;
2968
+ }
2969
+ });
2970
+ Object.defineProperty(exports, 'DROPDOWN_EDGE_TRANSFORM_ORIGIN', {
2971
+ enumerable: true,
2972
+ get: function () {
2973
+ return DROPDOWN_EDGE_TRANSFORM_ORIGIN;
2974
+ }
2975
+ });
2976
+ Object.defineProperty(exports, 'DROPDOWN_OFFSCREEN_POSITION', {
2977
+ enumerable: true,
2978
+ get: function () {
2979
+ return DROPDOWN_OFFSCREEN_POSITION;
2980
+ }
2981
+ });
2982
+ Object.defineProperty(exports, 'De', {
2983
+ enumerable: true,
2984
+ get: function () {
2985
+ return De$1;
2986
+ }
2987
+ });
2988
+ Object.defineProperty(exports, 'FEEDBACK_DURATION_MS', {
2989
+ enumerable: true,
2990
+ get: function () {
2991
+ return FEEDBACK_DURATION_MS;
2992
+ }
2993
+ });
2994
+ Object.defineProperty(exports, 'FROZEN_GLOW_COLOR', {
2995
+ enumerable: true,
2996
+ get: function () {
2997
+ return FROZEN_GLOW_COLOR;
2998
+ }
2999
+ });
3000
+ Object.defineProperty(exports, 'LERP_CONVERGENCE_THRESHOLD_PX', {
3001
+ enumerable: true,
3002
+ get: function () {
3003
+ return LERP_CONVERGENCE_THRESHOLD_PX;
3004
+ }
3005
+ });
3006
+ Object.defineProperty(exports, 'MAX_SELECTOR_COMBINATIONS', {
3007
+ enumerable: true,
3008
+ get: function () {
3009
+ return MAX_SELECTOR_COMBINATIONS;
3010
+ }
3011
+ });
3012
+ Object.defineProperty(exports, 'MAX_SESSION_STORAGE_SIZE_BYTES', {
3013
+ enumerable: true,
3014
+ get: function () {
3015
+ return MAX_SESSION_STORAGE_SIZE_BYTES;
3016
+ }
3017
+ });
3018
+ Object.defineProperty(exports, 'MODIFIER_KEYS', {
3019
+ enumerable: true,
3020
+ get: function () {
3021
+ return MODIFIER_KEYS;
3022
+ }
3023
+ });
3024
+ Object.defineProperty(exports, 'MOUNT_ROOT_RECHECK_DELAY_MS', {
3025
+ enumerable: true,
3026
+ get: function () {
3027
+ return MOUNT_ROOT_RECHECK_DELAY_MS;
3028
+ }
3029
+ });
3030
+ Object.defineProperty(exports, 'NEXTJS_REVALIDATION_DELAY_MS', {
3031
+ enumerable: true,
3032
+ get: function () {
3033
+ return NEXTJS_REVALIDATION_DELAY_MS;
3034
+ }
3035
+ });
3036
+ Object.defineProperty(exports, 'OFFSCREEN_POSITION', {
3037
+ enumerable: true,
3038
+ get: function () {
3039
+ return OFFSCREEN_POSITION;
3040
+ }
3041
+ });
3042
+ Object.defineProperty(exports, 'OPACITY_CONVERGENCE_THRESHOLD', {
3043
+ enumerable: true,
3044
+ get: function () {
3045
+ return OPACITY_CONVERGENCE_THRESHOLD;
3046
+ }
3047
+ });
3048
+ Object.defineProperty(exports, 'OVERLAY_BORDER_COLOR_DEFAULT', {
3049
+ enumerable: true,
3050
+ get: function () {
3051
+ return OVERLAY_BORDER_COLOR_DEFAULT;
3052
+ }
3053
+ });
3054
+ Object.defineProperty(exports, 'OVERLAY_BORDER_COLOR_DRAG', {
3055
+ enumerable: true,
3056
+ get: function () {
3057
+ return OVERLAY_BORDER_COLOR_DRAG;
3058
+ }
3059
+ });
3060
+ Object.defineProperty(exports, 'OVERLAY_FILL_COLOR_DEFAULT', {
3061
+ enumerable: true,
3062
+ get: function () {
3063
+ return OVERLAY_FILL_COLOR_DEFAULT;
3064
+ }
3065
+ });
3066
+ Object.defineProperty(exports, 'OVERLAY_FILL_COLOR_DRAG', {
3067
+ enumerable: true,
3068
+ get: function () {
3069
+ return OVERLAY_FILL_COLOR_DRAG;
3070
+ }
3071
+ });
3072
+ Object.defineProperty(exports, 'PANEL_BACKGROUND', {
3073
+ enumerable: true,
3074
+ get: function () {
3075
+ return PANEL_BACKGROUND;
3076
+ }
3077
+ });
3078
+ Object.defineProperty(exports, 'PANEL_SHADOW', {
3079
+ enumerable: true,
3080
+ get: function () {
3081
+ return PANEL_SHADOW;
3082
+ }
3083
+ });
3084
+ Object.defineProperty(exports, 'Pe', {
3085
+ enumerable: true,
3086
+ get: function () {
3087
+ return Pe$1;
3088
+ }
3089
+ });
3090
+ Object.defineProperty(exports, 'RELEVANT_CSS_PROPERTIES', {
3091
+ enumerable: true,
3092
+ get: function () {
3093
+ return RELEVANT_CSS_PROPERTIES;
3094
+ }
3095
+ });
3096
+ Object.defineProperty(exports, 'SELECTION_LABEL_OFFSCREEN_PX', {
3097
+ enumerable: true,
3098
+ get: function () {
3099
+ return SELECTION_LABEL_OFFSCREEN_PX;
3100
+ }
3101
+ });
3102
+ Object.defineProperty(exports, 'SELECTION_LERP_FACTOR', {
3103
+ enumerable: true,
3104
+ get: function () {
3105
+ return SELECTION_LERP_FACTOR;
3106
+ }
3107
+ });
3108
+ Object.defineProperty(exports, 'TOOLBAR_DEFAULT_POSITION_RATIO', {
3109
+ enumerable: true,
3110
+ get: function () {
3111
+ return TOOLBAR_DEFAULT_POSITION_RATIO;
3112
+ }
3113
+ });
3114
+ Object.defineProperty(exports, 'VERSION', {
3115
+ enumerable: true,
3116
+ get: function () {
3117
+ return VERSION;
3118
+ }
3119
+ });
3120
+ Object.defineProperty(exports, 'ZOOM_DETECTION_THRESHOLD', {
3121
+ enumerable: true,
3122
+ get: function () {
3123
+ return ZOOM_DETECTION_THRESHOLD;
3124
+ }
3125
+ });
3126
+ Object.defineProperty(exports, 'Z_INDEX_OVERLAY', {
3127
+ enumerable: true,
3128
+ get: function () {
3129
+ return Z_INDEX_OVERLAY;
3130
+ }
3131
+ });
3132
+ Object.defineProperty(exports, 'Z_INDEX_OVERLAY_CANVAS', {
3133
+ enumerable: true,
3134
+ get: function () {
3135
+ return Z_INDEX_OVERLAY_CANVAS;
3136
+ }
3137
+ });
3138
+ Object.defineProperty(exports, 'checkIsNextProject', {
3139
+ enumerable: true,
3140
+ get: function () {
3141
+ return checkIsNextProject;
3142
+ }
3143
+ });
3144
+ Object.defineProperty(exports, 'clearElementPositionCache', {
3145
+ enumerable: true,
3146
+ get: function () {
3147
+ return clearElementPositionCache;
3148
+ }
3149
+ });
3150
+ Object.defineProperty(exports, 'clearVisibilityCache', {
3151
+ enumerable: true,
3152
+ get: function () {
3153
+ return clearVisibilityCache;
3154
+ }
3155
+ });
3156
+ Object.defineProperty(exports, 'detectCspNonce', {
3157
+ enumerable: true,
3158
+ get: function () {
3159
+ return detectCspNonce;
3160
+ }
3161
+ });
3162
+ Object.defineProperty(exports, 'freezeAllAnimations', {
3163
+ enumerable: true,
3164
+ get: function () {
3165
+ return freezeAllAnimations;
3166
+ }
3167
+ });
3168
+ Object.defineProperty(exports, 'freezeAnimations', {
3169
+ enumerable: true,
3170
+ get: function () {
3171
+ return freezeAnimations;
3172
+ }
3173
+ });
3174
+ Object.defineProperty(exports, 'freezeGlobalAnimations', {
3175
+ enumerable: true,
3176
+ get: function () {
3177
+ return freezeGlobalAnimations;
3178
+ }
3179
+ });
3180
+ Object.defineProperty(exports, 'freezePseudoStates', {
3181
+ enumerable: true,
3182
+ get: function () {
3183
+ return freezePseudoStates;
3184
+ }
3185
+ });
3186
+ Object.defineProperty(exports, 'freezeUpdates', {
3187
+ enumerable: true,
3188
+ get: function () {
3189
+ return freezeUpdates;
3190
+ }
3191
+ });
3192
+ Object.defineProperty(exports, 'getComponentDisplayName', {
3193
+ enumerable: true,
3194
+ get: function () {
3195
+ return getComponentDisplayName;
3196
+ }
3197
+ });
3198
+ Object.defineProperty(exports, 'getDirectTextContent', {
3199
+ enumerable: true,
3200
+ get: function () {
3201
+ return getDirectTextContent;
3202
+ }
3203
+ });
3204
+ Object.defineProperty(exports, 'getElementAtPosition', {
3205
+ enumerable: true,
3206
+ get: function () {
3207
+ return getElementAtPosition;
3208
+ }
3209
+ });
3210
+ Object.defineProperty(exports, 'getElementContext', {
3211
+ enumerable: true,
3212
+ get: function () {
3213
+ return getElementContext;
3214
+ }
3215
+ });
3216
+ Object.defineProperty(exports, 'getElementsAtPoint', {
3217
+ enumerable: true,
3218
+ get: function () {
3219
+ return getElementsAtPoint;
3220
+ }
3221
+ });
3222
+ Object.defineProperty(exports, 'getHTMLPreview', {
3223
+ enumerable: true,
3224
+ get: function () {
3225
+ return getHTMLPreview;
3226
+ }
3227
+ });
3228
+ Object.defineProperty(exports, 'getInlineHTMLPreview', {
3229
+ enumerable: true,
3230
+ get: function () {
3231
+ return getInlineHTMLPreview;
3232
+ }
3233
+ });
3234
+ Object.defineProperty(exports, 'getNearestComponentName', {
3235
+ enumerable: true,
3236
+ get: function () {
3237
+ return getNearestComponentName;
3238
+ }
3239
+ });
3240
+ Object.defineProperty(exports, 'getStack', {
3241
+ enumerable: true,
3242
+ get: function () {
3243
+ return getStack;
3244
+ }
3245
+ });
3246
+ Object.defineProperty(exports, 'getStackContext', {
3247
+ enumerable: true,
3248
+ get: function () {
3249
+ return getStackContext;
3250
+ }
3251
+ });
3252
+ Object.defineProperty(exports, 'getTagName', {
3253
+ enumerable: true,
3254
+ get: function () {
3255
+ return getTagName;
3256
+ }
3257
+ });
3258
+ Object.defineProperty(exports, 'hideFromThirdParties', {
3259
+ enumerable: true,
3260
+ get: function () {
3261
+ return hideFromThirdParties;
3262
+ }
3263
+ });
3264
+ Object.defineProperty(exports, 'isRootElement', {
3265
+ enumerable: true,
3266
+ get: function () {
3267
+ return isRootElement;
3268
+ }
3269
+ });
3270
+ Object.defineProperty(exports, 'isValidGrabbableElement', {
3271
+ enumerable: true,
3272
+ get: function () {
3273
+ return isValidGrabbableElement;
3274
+ }
3275
+ });
3276
+ Object.defineProperty(exports, 'logRecoverableError', {
3277
+ enumerable: true,
3278
+ get: function () {
3279
+ return logRecoverableError;
3280
+ }
3281
+ });
3282
+ Object.defineProperty(exports, 'nativeCancelAnimationFrame', {
3283
+ enumerable: true,
3284
+ get: function () {
3285
+ return nativeCancelAnimationFrame;
3286
+ }
3287
+ });
3288
+ Object.defineProperty(exports, 'nativeRequestAnimationFrame', {
3289
+ enumerable: true,
3290
+ get: function () {
3291
+ return nativeRequestAnimationFrame;
3292
+ }
3293
+ });
3294
+ Object.defineProperty(exports, 'openFile', {
3295
+ enumerable: true,
3296
+ get: function () {
3297
+ return openFile;
3298
+ }
3299
+ });
3300
+ Object.defineProperty(exports, 'resolveSource', {
3301
+ enumerable: true,
3302
+ get: function () {
3303
+ return resolveSource;
3304
+ }
3305
+ });
3306
+ Object.defineProperty(exports, 'resumePointerEventsFreeze', {
3307
+ enumerable: true,
3308
+ get: function () {
3309
+ return resumePointerEventsFreeze;
3310
+ }
3311
+ });
3312
+ Object.defineProperty(exports, 'supportsDisplayP3', {
3313
+ enumerable: true,
3314
+ get: function () {
3315
+ return supportsDisplayP3;
3316
+ }
3317
+ });
3318
+ Object.defineProperty(exports, 'suspendPointerEventsFreeze', {
3319
+ enumerable: true,
3320
+ get: function () {
3321
+ return suspendPointerEventsFreeze;
3322
+ }
3323
+ });
3324
+ Object.defineProperty(exports, 'truncateString', {
3325
+ enumerable: true,
3326
+ get: function () {
3327
+ return truncateString;
3328
+ }
3329
+ });
3330
+ Object.defineProperty(exports, 'unfreezeGlobalAnimations', {
3331
+ enumerable: true,
3332
+ get: function () {
3333
+ return unfreezeGlobalAnimations;
3334
+ }
3335
+ });
3336
+ Object.defineProperty(exports, 'unfreezePseudoStates', {
3337
+ enumerable: true,
3338
+ get: function () {
3339
+ return unfreezePseudoStates;
3340
+ }
3341
+ });
3342
+ Object.defineProperty(exports, 'waitUntilNextFrame', {
3343
+ enumerable: true,
3344
+ get: function () {
3345
+ return waitUntilNextFrame;
3346
+ }
3347
+ });