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