@expofp/loader 1.0.49 → 1.0.50

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,85 +1,85 @@
1
- function J(t) {
2
- return i("assetResolver resolveRef:", t), l(t);
1
+ function B(t) {
2
+ return i("assetResolver resolveRef:", t), c(t);
3
3
  }
4
- const U = {
4
+ const T = {
5
5
  schema: "asset",
6
- resolveRef: async (t) => J(t),
6
+ resolveRef: async (t) => B(t),
7
7
  offlineMethod: "localizeRef"
8
8
  };
9
- let h;
10
- const N = /* @__PURE__ */ new WeakSet(), _ = new Function("url", 'return import(url, { with: { type: "json" } });');
11
- async function f(t, e) {
9
+ let p;
10
+ const P = /* @__PURE__ */ new WeakSet(), F = new Function("url", 'return import(url, { with: { type: "json" } });');
11
+ async function u(t, e) {
12
12
  var n, o;
13
- if (h === void 0 && !e.forceFetch)
13
+ if (p === void 0 && !e.forceFetch)
14
14
  try {
15
- await _(t), h = !1;
15
+ await F(t), p = !1;
16
16
  } catch {
17
- i("importJson: dynamic import not available, falling back to fetch"), h = !0;
17
+ i("importJson: dynamic import not available, falling back to fetch"), p = !0;
18
18
  }
19
19
  let r;
20
- return !h && !e.forceFetch ? (r = (await _(t)).default, (n = e.importCallback) == null || n.call(e, t, "json")) : (i("importJson: fetch", t), r = await W(t, e.refCache, e.signal || null), (o = e.importCallback) == null || o.call(e, t, "json")), N.has(r) || u(r), r;
20
+ return !p && !e.forceFetch ? (r = (await F(t)).default, (n = e.importCallback) == null || n.call(e, t, "json")) : (i("importJson: fetch", t), r = await I(t, e.refCache, e.signal || null), (o = e.importCallback) == null || o.call(e, t, "json")), P.has(r) || d(r), r;
21
21
  }
22
- async function W(t, e, r) {
22
+ async function I(t, e, r) {
23
23
  const n = "__loadJson__" + t;
24
24
  if (e.has(n))
25
25
  return e.get(n);
26
26
  const o = (async function() {
27
- const a = await fetch(t, { signal: r });
28
- if (!a.ok)
27
+ const s = await fetch(t, { signal: r });
28
+ if (!s.ok)
29
29
  throw new Error(`Failed to fetch JSON from ${t}`);
30
- return await a.json();
30
+ return await s.json();
31
31
  })();
32
32
  return e.set(n, o), o;
33
33
  }
34
- async function p(t, e, r) {
34
+ async function v(t, e, r) {
35
35
  if (e.has(t))
36
36
  return e.get(t);
37
- const n = r().then((o) => (u(o), o));
37
+ const n = r().then((o) => (d(o), o));
38
38
  return e.set(t, n), n;
39
39
  }
40
- const B = {
40
+ const z = {
41
41
  schema: "bundle-assets",
42
42
  async resolveRef(t, e) {
43
43
  i("bundleAssetsResolver resolveRef:", t);
44
- const r = l(t);
45
- return p(t, e.refCache, async () => {
46
- const n = await f(r, e), o = r.substring(0, r.lastIndexOf("/") + 1);
47
- return n.map((a) => ({
48
- $ref: `asset+${o}${a}`
44
+ const r = c(t);
45
+ return v(t, e.refCache, async () => {
46
+ const n = await u(r, e), o = r.substring(0, r.lastIndexOf("/") + 1);
47
+ return n.map((s) => ({
48
+ $ref: `asset+${o}${s}`
49
49
  }));
50
50
  });
51
51
  },
52
52
  offlineMethod: "localizeRef"
53
- }, L = "https://efp-runtime.expofp.com/", T = {
53
+ }, V = "https://efp-runtime.expofp.com/", G = {
54
54
  schema: "expo-runtime-branch",
55
55
  async resolveRef(t, e) {
56
56
  i("expoRuntimeBranchResolver resolveRef:", t);
57
- const r = l(t), n = `${L}branches/${r}.json`;
58
- return p(t, e.refCache, async () => ({
59
- $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${await f(n, e)}/`
57
+ const r = c(t), n = `${V}branches/${r}.json`;
58
+ return v(t, e.refCache, async () => ({
59
+ $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${await u(n, e)}/`
60
60
  }));
61
61
  },
62
62
  offlineMethod: "resolveRef"
63
- }, C = {
63
+ }, Z = {
64
64
  schema: "expo-runtime-get-branch",
65
65
  async resolveRef(t, e) {
66
66
  i("expoRuntimeGetBranchResolver resolveRef:", t);
67
- const n = `https://${l(t)}.expofp.com/get-branch`;
68
- return f(n, e);
67
+ const n = `https://${c(t)}.expofp.com/get-branch`;
68
+ return u(n, e);
69
69
  },
70
70
  offlineMethod: "resolveRef"
71
- }, D = {
71
+ }, H = {
72
72
  schema: "expo-runtime",
73
73
  // canResolve(ref: string) {
74
74
  // return canResolveRefSchema(ref, SCHEMA);
75
75
  // },
76
76
  async resolveRef(t) {
77
77
  i("expoRuntimeResolver resolveRef:", t);
78
- const e = l(t), r = {
78
+ const e = c(t), r = {
79
79
  entry: { $ref: `asset+${e}expofp.js` },
80
80
  assets: { $ref: `bundle-assets+${e}bundle.json` }
81
81
  };
82
- return u(r), r;
82
+ return d(r), r;
83
83
  },
84
84
  // async *makeOfflineRef(ref: string) {
85
85
  // log('expoRuntimeResolver makeOfflineRef:', ref);
@@ -99,25 +99,25 @@ const B = {
99
99
  // return targetFilePath;
100
100
  // },
101
101
  offlineMethod: "resolveRef"
102
- }, I = {
102
+ }, K = {
103
103
  canResolve(t) {
104
104
  return t.startsWith("http://") || t.startsWith("https://") || t.startsWith("./");
105
105
  },
106
106
  resolveRef(t, e) {
107
107
  if (i("httpResolver resolveRef:", t), !this.canResolve(t)) throw new Error(`Unexpected ref in httpResolver: ${t}`);
108
- return f(t, e);
108
+ return u(t, e);
109
109
  },
110
110
  offlineMethod: "resolveRef"
111
111
  };
112
- async function O(t, e) {
112
+ async function m(t, e) {
113
113
  const { globalVar: r, timeoutMs: n = 1e4, pollIntervalMs: o = 10 } = e;
114
- P() ? (await z(t, e.signal), r && await k(
114
+ q() ? (await Q(t, e.signal), r && await A(
115
115
  () => window[r],
116
116
  r,
117
117
  n,
118
118
  o,
119
119
  e.signal
120
- )) : (await V(t, e.signal), r && await k(
120
+ )) : (await X(t, e.signal), r && await A(
121
121
  () => globalThis[r],
122
122
  r,
123
123
  n,
@@ -125,30 +125,30 @@ async function O(t, e) {
125
125
  e.signal
126
126
  ));
127
127
  }
128
- function P() {
128
+ function q() {
129
129
  return typeof window < "u" && typeof document < "u";
130
130
  }
131
- function z(t, e) {
131
+ function Q(t, e) {
132
132
  return new Promise((r, n) => {
133
133
  const o = document.createElement("script");
134
134
  o.src = t, o.async = !0;
135
- const s = () => {
135
+ const a = () => {
136
136
  o.onload = null, o.onerror = null, o.remove();
137
- }, a = () => {
138
- s(), n(new Error("Script load aborted"));
137
+ }, s = () => {
138
+ a(), n(new Error("Script load aborted"));
139
139
  };
140
140
  if (e != null && e.aborted) {
141
- s(), n(new Error("Script load aborted"));
141
+ a(), n(new Error("Script load aborted"));
142
142
  return;
143
143
  }
144
- e == null || e.addEventListener("abort", a, { once: !0 }), o.onload = () => {
145
- e == null || e.removeEventListener("abort", a), s(), r();
144
+ e == null || e.addEventListener("abort", s, { once: !0 }), o.onload = () => {
145
+ e == null || e.removeEventListener("abort", s), a(), r();
146
146
  }, o.onerror = () => {
147
- e == null || e.removeEventListener("abort", a), s(), n(new Error(`Failed to load script: ${t}`));
147
+ e == null || e.removeEventListener("abort", s), a(), n(new Error(`Failed to load script: ${t}`));
148
148
  }, document.head.appendChild(o);
149
149
  });
150
150
  }
151
- async function V(t, e) {
151
+ async function X(t, e) {
152
152
  if (typeof fetch != "function")
153
153
  throw new Error("loadInNode: fetch is not available. Use Node 18+ or provide a global fetch.");
154
154
  if (e != null && e.aborted)
@@ -156,8 +156,8 @@ async function V(t, e) {
156
156
  let r;
157
157
  try {
158
158
  r = await fetch(t, { signal: e });
159
- } catch (a) {
160
- throw a && a.name === "AbortError" ? new Error("Script load aborted") : a;
159
+ } catch (s) {
160
+ throw s && s.name === "AbortError" ? new Error("Script load aborted") : s;
161
161
  }
162
162
  if (!r.ok)
163
163
  throw new Error(`Failed to load script in Node (HTTP ${r.status}): ${t}`);
@@ -166,90 +166,105 @@ async function V(t, e) {
166
166
  let n;
167
167
  try {
168
168
  n = await r.text();
169
- } catch (a) {
170
- throw a && a.name === "AbortError" ? new Error("Script load aborted") : a;
169
+ } catch (s) {
170
+ throw s && s.name === "AbortError" ? new Error("Script load aborted") : s;
171
171
  }
172
172
  if (e != null && e.aborted)
173
173
  throw new Error("Script load aborted");
174
- const o = globalThis, s = o.window;
174
+ const o = globalThis, a = o.window;
175
175
  o.window = o;
176
176
  try {
177
177
  (0, eval)(n);
178
178
  } finally {
179
- s === void 0 ? delete o.window : o.window = s;
179
+ a === void 0 ? delete o.window : o.window = a;
180
180
  }
181
181
  }
182
- function k(t, e, r, n, o) {
183
- return new Promise((s, a) => {
184
- const d = Date.now(), c = () => {
185
- a(new Error("Wait for global aborted"));
182
+ function A(t, e, r, n, o) {
183
+ return new Promise((a, s) => {
184
+ const w = Date.now(), f = () => {
185
+ s(new Error("Wait for global aborted"));
186
186
  };
187
187
  if (o != null && o.aborted) {
188
- a(new Error("Wait for global aborted"));
188
+ s(new Error("Wait for global aborted"));
189
189
  return;
190
190
  }
191
- o == null || o.addEventListener("abort", c, { once: !0 });
192
- const w = () => {
191
+ o == null || o.addEventListener("abort", f, { once: !0 });
192
+ const h = () => {
193
193
  if (o != null && o.aborted)
194
- return a(new Error("Wait for global aborted"));
194
+ return s(new Error("Wait for global aborted"));
195
195
  try {
196
196
  if (t() !== void 0)
197
- return o == null || o.removeEventListener("abort", c), s();
197
+ return o == null || o.removeEventListener("abort", f), a();
198
198
  } catch {
199
199
  }
200
- if (Date.now() - d >= r)
201
- return o == null || o.removeEventListener("abort", c), a(new Error(`Timed out after ${r} ms waiting for global "${e}"`));
202
- setTimeout(w, n);
200
+ if (Date.now() - w >= r)
201
+ return o == null || o.removeEventListener("abort", f), s(new Error(`Timed out after ${r} ms waiting for global "${e}"`));
202
+ setTimeout(h, n);
203
203
  };
204
- w();
204
+ h();
205
205
  });
206
206
  }
207
- const G = {
207
+ const Y = {
208
208
  schema: "legacy-asset-urls",
209
209
  resolveRef(t, e) {
210
- return i("legacyAssetUrlsResolver resolveRef:", t), p(t, e.refCache, async () => {
211
- var b, R;
212
- const r = l(t), n = `${r}version.js`;
210
+ i("legacyAssetUrlsResolver resolveRef:", t);
211
+ const r = e.signal;
212
+ return v(t, e.refCache, async () => {
213
+ var _, O, g;
214
+ const n = c(t), o = `${n}version.js`;
213
215
  try {
214
- await O(n, {
216
+ await m(o, {
215
217
  globalVar: "__fpDataVersion",
216
218
  timeoutMs: 3e4,
217
- signal: e.signal
218
- }), (b = e.importCallback) == null || b.call(e, n, "script");
219
+ signal: r
220
+ }), (_ = e.importCallback) == null || _.call(e, o, "script");
219
221
  } catch {
220
- console.warn(`Could not load version.js at ${n}, proceeding without it`);
222
+ console.warn(`Could not load version.js at ${o}, proceeding without it`);
221
223
  }
222
- const o = globalThis.__fpDataVersion || (+/* @__PURE__ */ new Date()).toString(), s = `${r}files.json?v=${o}`, a = `${r}data.js?v=${o}`, d = f(s, e), c = O(a, {
224
+ const a = globalThis.__fpDataVersion || (+/* @__PURE__ */ new Date()).toString(), s = `${n}files.json?v=${a}`, w = `${n}data.js?v=${a}`, f = u(s, e), h = m(w, {
223
225
  globalVar: "__data",
224
- signal: e.signal
226
+ signal: r
227
+ });
228
+ (O = e.importCallback) == null || O.call(e, w, "script");
229
+ const b = `${n}wf.data.js?v=${a}`, J = m(b, {
230
+ globalVar: "__wfData",
231
+ signal: r
232
+ }).then(() => {
233
+ var l;
234
+ (l = e.importCallback) == null || l.call(e, b, "script");
235
+ }).catch(() => {
236
+ console.warn(`Could not load wf.data.js at ${b}, proceeding without it`);
237
+ }), E = `${n}fp.svg.js?v=${a}`, C = m(E, {
238
+ globalVar: "__fp",
239
+ signal: r
225
240
  });
226
- (R = e.importCallback) == null || R.call(e, a, "script"), await Promise.all([d, c]);
227
- const w = await d, j = globalThis.__data || {};
228
- return { ...[...w, "data.js"].reduce((E, $) => (E[$] = { $ref: `asset+${r}${$}?v=${o}` }, E), {}), ...Z(r, j) };
241
+ (g = e.importCallback) == null || g.call(e, E, "script"), await Promise.all([f, h, J, C]);
242
+ const D = globalThis.__fpLayers.map((l) => `fp.svg.${l.name}.js`), N = await f, W = globalThis.__data || {};
243
+ return { ...[...N, "data.js", "wf.data.js", "fp.svg.js", ...D].reduce((l, k) => (l[k] = { $ref: `asset+${n}${k}?v=${a}` }, l), {}), ...S(n, W) };
229
244
  });
230
245
  },
231
246
  offlineMethod: "resolveRef"
232
247
  };
233
- function Z(t, e) {
248
+ function S(t, e) {
234
249
  const r = /* @__PURE__ */ new Set();
235
250
  function n(o) {
236
251
  typeof o == "string" && o.length > 0 && r.add(o);
237
252
  }
238
253
  return n(e.logo), e.exhibitors.forEach((o) => {
239
- var s;
240
- n(o.logo), (s = o.gallery) == null || s.forEach((a) => n(a));
254
+ var a;
255
+ n(o.logo), (a = o.gallery) == null || a.forEach((s) => n(s));
241
256
  }), e.events.forEach((o) => {
242
- var s;
243
- n(o.logoFile), (s = o.speakers) == null || s.forEach((a) => {
244
- n(a.photoFile);
257
+ var a;
258
+ n(o.logoFile), (a = o.speakers) == null || a.forEach((s) => {
259
+ n(s.photoFile);
245
260
  });
246
- }), Array.from(r).reduce((o, s) => (o[s] = { $ref: `asset+${t}${s}` }, o), {});
261
+ }), Array.from(r).reduce((o, a) => (o[a] = { $ref: `asset+${t}${a}` }, o), {});
247
262
  }
248
- const H = {
263
+ const x = {
249
264
  schema: "legacy-data",
250
265
  resolveRef(t, e) {
251
- return i("legacyDataResolver resolveRef:", t), p(t, e.refCache, async () => {
252
- const r = l(t);
266
+ return i("legacyDataResolver resolveRef:", t), v(t, e.refCache, async () => {
267
+ const r = c(t);
253
268
  return {
254
269
  _to_remove_for_offline_to_work_dataUrlBase: r,
255
270
  legacyAssetUrls: { $ref: `legacy-asset-urls+${r}` }
@@ -257,21 +272,21 @@ const H = {
257
272
  });
258
273
  },
259
274
  offlineMethod: "resolveRef"
260
- }, K = [
261
- I,
262
- B,
263
- U,
264
- D,
275
+ }, ee = [
276
+ K,
277
+ z,
265
278
  T,
266
- C,
267
279
  H,
268
- G
269
- ], q = /* @__PURE__ */ new Map();
270
- async function v(t, e, r) {
280
+ G,
281
+ Z,
282
+ x,
283
+ Y
284
+ ], te = /* @__PURE__ */ new Map();
285
+ async function $(t, e, r) {
271
286
  i("Resolving:", e, "of", t, r), typeof window < "u" && (window.__lastResolveObject = t);
272
287
  const n = {
273
288
  importCallback: r == null ? void 0 : r.importCallback,
274
- refCache: (r == null ? void 0 : r.refCache) || q,
289
+ refCache: (r == null ? void 0 : r.refCache) || te,
275
290
  forceFetch: !!(r != null && r.forceFetch),
276
291
  signal: (r == null ? void 0 : r.signal) || null
277
292
  };
@@ -282,80 +297,80 @@ async function v(t, e, r) {
282
297
  if (e.length > 1 && e.endsWith("/"))
283
298
  throw new Error(`Invalid JSON Pointer: ${e}`);
284
299
  let o;
285
- if (e === "/" ? o = [] : o = e.substring(1).split("/"), o.some((s) => s.length === 0))
300
+ if (e === "/" ? o = [] : o = e.substring(1).split("/"), o.some((a) => a.length === 0))
286
301
  throw new Error(`Invalid JSON Pointer (empty part): ${e}`);
287
302
  if (r != null && r.mutate) {
288
303
  o.unshift("root");
289
- const s = { root: t };
290
- await A(s, o, 0, n), ee(t, s.root);
304
+ const a = { root: t };
305
+ await M(a, o, 0, n), ie(t, a.root);
291
306
  } else
292
- return await g(t, o, 0, n);
307
+ return await L(t, o, 0, n);
293
308
  }
294
- async function A(t, e, r, n) {
309
+ async function M(t, e, r, n) {
295
310
  const o = e[r];
296
- if (await Q(t, o, n), r != e.length - 1) {
311
+ if (await re(t, o, n), r != e.length - 1) {
297
312
  if (t[o] === null || typeof t[o] != "object")
298
313
  throw new Error(
299
314
  `Cannot resolve path, encountered non-object at part '${e.slice(1).join("/")}', index ${r - 1}'`
300
315
  );
301
- return await A(t[o], e, r + 1, n);
316
+ return await M(t[o], e, r + 1, n);
302
317
  }
303
318
  }
304
- async function Q(t, e, r) {
319
+ async function re(t, e, r) {
305
320
  i("resolveObjectMutate:", t, e);
306
321
  let n = t[e];
307
- const o = await y(n, r);
322
+ const o = await R(n, r);
308
323
  o !== void 0 && (t[e] = o);
309
324
  }
310
- async function g(t, e, r, n) {
325
+ async function L(t, e, r, n) {
311
326
  if (r === e.length)
312
- return await y(t, n);
327
+ return await R(t, n);
313
328
  if (t === null || typeof t != "object")
314
329
  throw new Error(
315
330
  `Cannot resolve path, encountered non-object at part '${e.join("/")}', index ${r}'`
316
331
  );
317
332
  const o = e[r];
318
- let s = t[o];
319
- return s === void 0 && (s = (await y(t, n))[o]), await g(s, e, r + 1, n);
333
+ let a = t[o];
334
+ return a === void 0 && (a = (await R(t, n))[o]), await L(a, e, r + 1, n);
320
335
  }
321
- async function y(t, e) {
336
+ async function R(t, e) {
322
337
  i("resolveObject:", t);
323
338
  let r = t;
324
339
  do {
325
340
  if (typeof r != "object" || r === null || !("$ref" in r))
326
341
  return r;
327
- const n = K.filter((s) => M(s, r.$ref));
342
+ const n = ee.filter((a) => U(a, r.$ref));
328
343
  if (n.length === 0) {
329
344
  if (r.$ref)
330
345
  throw new Error(`No resolver found for ref: ${r.$ref}`);
331
- return u(r), r;
346
+ return d(r), r;
332
347
  }
333
348
  if (n.length > 1)
334
349
  throw new Error(`Multiple resolvers can resolve ref: ${r.$ref}`);
335
- const o = await X(n[0], r.$ref, e);
336
- r = S(o, r);
350
+ const o = await oe(n[0], r.$ref, e);
351
+ r = se(o, r);
337
352
  } while (!0);
338
353
  }
339
- async function X(t, e, r) {
340
- if (!M(t, e))
354
+ async function oe(t, e, r) {
355
+ if (!U(t, e))
341
356
  throw new Error(`Unexpected ref: ${e}`);
342
357
  return t.resolveRef(e, r);
343
358
  }
344
- function M(t, e) {
359
+ function U(t, e) {
345
360
  if (t.canResolve)
346
361
  return t.canResolve(e);
347
362
  if (t.schema)
348
- return Y(e, t.schema);
363
+ return ne(e, t.schema);
349
364
  throw new Error("Resolver is missing canResolve method and schema property");
350
365
  }
351
- function Y(t, e) {
366
+ function ne(t, e) {
352
367
  const r = [`${e}+`, `${e}:`];
353
368
  for (const n of r)
354
369
  if (t.startsWith(n))
355
370
  return !0;
356
371
  return !1;
357
372
  }
358
- function l(t) {
373
+ function c(t) {
359
374
  if (t.startsWith("http://") || t.startsWith("https://"))
360
375
  return t;
361
376
  const e = t.indexOf("+http://"), r = t.indexOf("+https://");
@@ -369,14 +384,14 @@ function l(t) {
369
384
  throw new Error(`Error getting URL from: ${t}, no valid prefix found`);
370
385
  }
371
386
  typeof window < "u" && (window.__debugResolve = async function(e, r, n) {
372
- let o, s, a;
373
- return typeof e == "string" ? (o = window.__lastResolveObject, s = e, a = r) : (o = e, s = r, a = n), await v(o, s, a);
387
+ let o, a, s;
388
+ return typeof e == "string" ? (o = window.__lastResolveObject, a = e, s = r) : (o = e, a = r, s = n), await $(o, a, s);
374
389
  });
375
- function m(t) {
390
+ function y(t) {
376
391
  return async (e, ...r) => {
377
392
  try {
378
- const s = (await import(await v(e, "/runtime/entry")))[t];
379
- return s(e, ...r);
393
+ const a = (await import(await $(e, "/runtime/entry")))[t];
394
+ return a(e, ...r);
380
395
  } catch (n) {
381
396
  throw console.error("efp-loader", `Error when trying to import and call "${t}":`, n), n;
382
397
  }
@@ -385,41 +400,41 @@ function m(t) {
385
400
  function i(...t) {
386
401
  globalThis.__EFP_LOADER_DEBUG__ && console.debug("efp-loader", ...t);
387
402
  }
388
- function u(t) {
403
+ function d(t) {
389
404
  if (t === null || typeof t != "object") return t;
390
405
  Object.freeze(t);
391
406
  for (const e of Object.keys(t)) {
392
407
  const r = t[e];
393
- typeof r == "object" && r !== null && !Object.isFrozen(r) && u(r);
408
+ typeof r == "object" && r !== null && !Object.isFrozen(r) && d(r);
394
409
  }
395
410
  return t;
396
411
  }
397
- function F(t) {
412
+ function j(t) {
398
413
  return "structuredClone" in globalThis ? globalThis.structuredClone(t) : JSON.parse(JSON.stringify(t));
399
414
  }
400
- function x(t) {
415
+ function ae(t) {
401
416
  if (typeof document > "u") return;
402
417
  const e = document.createElement("link");
403
418
  e.rel = "preconnect", e.href = t, e.crossOrigin = "anonymous", document.head.appendChild(e);
404
419
  }
405
- function S(t, e) {
420
+ function se(t, e) {
406
421
  if (t === e) return;
407
422
  if (e === null || typeof e != "object")
408
423
  throw new Error("Cannot merge non-object source");
409
424
  if (Array.isArray(e))
410
425
  throw new Error("Cannot merge arrays");
411
426
  const r = Object.keys(e).filter((o) => o !== "$ref");
412
- if (r.length === 0) return F(t);
427
+ if (r.length === 0) return j(t);
413
428
  if (Array.isArray(t))
414
429
  throw new Error("Cannot merge into arrays");
415
430
  if (t === null || typeof t != "object")
416
431
  throw new Error("Cannot merge into non-object target");
417
- const n = F({ ...t });
432
+ const n = j({ ...t });
418
433
  for (const o of r)
419
434
  n[o] = e[o];
420
435
  return n;
421
436
  }
422
- function ee(t, e) {
437
+ function ie(t, e) {
423
438
  if (t !== e) {
424
439
  if (e === null || typeof e != "object")
425
440
  throw new Error("Cannot replace with non-object source");
@@ -439,47 +454,47 @@ function ee(t, e) {
439
454
  t[r] = e[r];
440
455
  }
441
456
  }
442
- async function te(t, e, r) {
457
+ async function le(t, e, r) {
443
458
  r = r || {};
444
459
  for (const n of e)
445
- await v(t, n, { ...r, mutate: !0 });
460
+ await $(t, n, { ...r, mutate: !0 });
446
461
  }
447
- typeof window < "u" && (window.__debugMutateManifest = te);
448
- async function re(t) {
462
+ typeof window < "u" && (window.__debugMutateManifest = le);
463
+ async function ce(t) {
449
464
  const { makeOfflineBundle: e } = await import("./makeOfflineBundle-CdE5LdlF.js");
450
465
  return await e(t);
451
466
  }
452
- async function oe(t) {
467
+ async function fe(t) {
453
468
  const { downloadZip: e } = await import("./downloadZip-D1Leqczj.js");
454
469
  return await e(t);
455
470
  }
456
- async function ne(t) {
471
+ async function ue(t) {
457
472
  const { makeOffline: e } = await import("./makeOffline-DdJq2uGI.js"), r = await e(t);
458
473
  for await (const n of (await r).files)
459
474
  "data" in n ? console.info(`🗳️ Put ${n.targetFilePath} <=`, n.data) : "url" in n && console.info(`🗳️ Download ${n.targetFilePath} <= ${n.url}`);
460
475
  console.info("Offline data: ", r.manifest);
461
476
  }
462
- typeof window < "u" && (window.__debugDownloadZip = oe, window.__debugMakeOfflineBundle = re, window.__debugLogOfflineManifestFiles = ne);
463
- const ie = m("mount"), le = m("load"), ce = m("initialize");
464
- async function fe(t, e, ...r) {
465
- return await m(t)(e, ...r);
477
+ typeof window < "u" && (window.__debugDownloadZip = fe, window.__debugMakeOfflineBundle = ce, window.__debugLogOfflineManifestFiles = ue);
478
+ const pe = y("mount"), me = y("load"), ve = y("initialize");
479
+ async function ye(t, e, ...r) {
480
+ return await y(t)(e, ...r);
466
481
  }
467
- x("https://efp-runtime.expofp.com/");
482
+ ae("https://efp-runtime.expofp.com/");
468
483
  export {
469
- S as a,
470
- X as b,
471
- M as c,
472
- fe as callFunction_Experimental,
473
- F as d,
474
- oe as downloadZip,
475
- ce as initialize,
484
+ se as a,
485
+ oe as b,
486
+ U as c,
487
+ ye as callFunction_Experimental,
488
+ j as d,
489
+ fe as downloadZip,
490
+ ve as initialize,
476
491
  i as l,
477
- le as load,
478
- re as makeOfflineBundle,
479
- ie as mount,
480
- te as mutateManifest,
481
- l as p,
482
- K as r,
483
- v as resolve
492
+ me as load,
493
+ ce as makeOfflineBundle,
494
+ pe as mount,
495
+ le as mutateManifest,
496
+ c as p,
497
+ ee as r,
498
+ $ as resolve
484
499
  };
485
500
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/resolvers/assetResolver.ts","../src/importJson.ts","../src/returnCachedRef.ts","../src/resolvers/bundleAssetsResolver.ts","../src/resolvers/expoRuntimeBranchResolver.ts","../src/resolvers/expoRuntimeGetBranchResolver.ts","../src/resolvers/expoRuntimeResolver.ts","../src/resolvers/httpResolver.ts","../src/loadAndWaitGlobal.ts","../src/resolvers/legacyAssetUrlsResolver.ts","../src/resolvers/legacyDataResolver.ts","../src/resolvers/index.ts","../src/resolve.ts","../src/shared.ts","../src/mutateManifest.ts","../src/offline/index.ts","../src/index.ts"],"sourcesContent":["import { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport function resolveAssetRefSync(ref: string): string {\n log('assetResolver resolveRef:', ref);\n // if (!assetResolver.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n return parseRefValue(ref);\n}\n\nexport const assetResolver = {\n schema: 'asset',\n resolveRef: async (ref: string) => resolveAssetRefSync(ref),\n offlineMethod: 'localizeRef',\n} satisfies Resolver;\n\n// async *makeOfflineRef(ref: string) {\n// log('assetResolver makeOfflineRef:', ref);\n// if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return { $ref: `asset:${targetFilePath}`, [STOP_RESOLVING]: true };\n// },\n// async *makeOfflineRef2(ref: string) {\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return `asset:${targetFilePath}`;\n// },\n","import type { ResolveContextInternal } from './resolve';\nimport { deepFreeze, log } from './shared';\n\nlet importJsonNotAvailable: boolean | undefined;\nconst jsonFrozen = new WeakSet<any>();\n\n// ET: this is a workaround for Vite that analyzes dynamic imports and removes 'with' option\n// to be removed when Vite supports it properly\n// Cons: can have CSP issues in some environments\nconst importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n url: string\n) => Promise<any>;\n\nexport async function importJson(\n url: string,\n resolveContext: ResolveContextInternal\n): Promise<any> {\n // console.warn('importJson:', resolveContext.forceFetch);\n if (importJsonNotAvailable === undefined && !resolveContext.forceFetch) {\n try {\n await importJsonNative(url);\n importJsonNotAvailable = false;\n } catch {\n log('importJson: dynamic import not available, falling back to fetch');\n importJsonNotAvailable = true;\n }\n }\n let result: any = undefined;\n if (!importJsonNotAvailable && !resolveContext.forceFetch) {\n const module = await importJsonNative(url);\n result = module.default;\n resolveContext.importCallback?.(url, 'json');\n } else {\n log('importJson: fetch', url);\n result = await loadJson(url, resolveContext.refCache, resolveContext.signal || null);\n resolveContext.importCallback?.(url, 'json');\n }\n if (!jsonFrozen.has(result)) {\n deepFreeze(result);\n // jsonFrozen.add(result);\n }\n return result;\n}\n\n// const fetchCache = new Map<string, Promise<any>>();\n\nasync function loadJson(\n url: string,\n fetchCache: Map<string, Promise<any>>,\n signal: AbortSignal | null\n): Promise<any> {\n const key = '__loadJson__' + url;\n if (fetchCache.has(key)) {\n return fetchCache.get(key)!;\n }\n\n const dataPromise = (async function loadJsonInner() {\n const response = await fetch(url, { signal });\n if (!response.ok) {\n throw new Error(`Failed to fetch JSON from ${url}`);\n }\n return await response.json();\n })();\n\n fetchCache.set(key, dataPromise);\n return dataPromise;\n}\n","import { deepFreeze } from './shared';\n\nexport async function returnCachedRef(\n ref: string,\n refCache: Map<string, Promise<any>>,\n factory: () => Promise<any>\n) {\n if (refCache.has(ref)) {\n return refCache.get(ref);\n }\n const promise = factory().then((data) => {\n deepFreeze(data);\n return data;\n });\n refCache.set(ref, promise);\n return promise;\n}\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const bundleAssetsResolver: Resolver = {\n schema: 'bundle-assets',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('bundleAssetsResolver resolveRef:', ref);\n\n const url = parseRefValue(ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const files = await importJson(url, context);\n const baseUrl = url.substring(0, url.lastIndexOf('/') + 1);\n\n const assets = files.map((file: string) => ({\n $ref: `asset+${baseUrl}${file}`,\n }));\n return assets;\n });\n },\n offlineMethod: 'localizeRef',\n};\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nconst BASE_URL = 'https://efp-runtime.expofp.com/';\n\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n\n const branch = parseRefValue(ref);\n const branchUrl = `${BASE_URL}branches/${branch}.json`;\n\n return returnCachedRef(ref, context.refCache, async () => {\n const release = await importJson(branchUrl, context);\n return {\n $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n };\n });\n },\n\n offlineMethod: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n async resolveRef(ref, context) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n\n const expo = parseRefValue(ref);\n const url = `https://${expo}.expofp.com/get-branch`;\n return importJson(url, context);\n },\n offlineMethod: 'resolveRef',\n};\n","import { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime';\n\nexport const expoRuntimeResolver: Resolver = {\n schema: 'expo-runtime',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n const url = parseRefValue(ref);\n const data = {\n entry: { $ref: `asset+${url}expofp.js` },\n assets: { $ref: `bundle-assets+${url}bundle.json` },\n };\n deepFreeze(data);\n return data;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const url = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(url, SCHEMA_PREFIX_BASE);\n // const data = yield* makeOfflineInternal(refData);\n // yield { data: data, targetFilePath };\n // return { $ref: targetFilePath, [STOP_RESOLVING]: true };\n // },\n // async *makeOfflineRef2(ref: string) {\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(ref);\n // const data = yield* makeOfflineInternal(refData);\n // yield { data, targetFilePath };\n // return targetFilePath;\n // },\n offlineMethod: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { log } from '../shared';\nimport { type Resolver } from '../types';\n\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n resolveRef(ref, context) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n\n return importJson(ref, context);\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n","//import { log } from './shared';\n\nexport interface LoadAndWaitOptions {\n /** Name of the global variable to wait for */\n globalVar?: string;\n /** How long to wait for the global (ms) */\n timeoutMs?: number;\n /** Poll interval (ms) */\n pollIntervalMs?: number;\n signal: AbortSignal | null;\n}\n\n/**\n * Load a script from `scriptUrl` and optionally wait until `globalVar` appears.\n * Works in both browser (via <script>) and Node 18+ (via fetch + eval).\n */\nexport async function loadAndWaitGlobal(\n scriptUrl: string,\n options: LoadAndWaitOptions\n): Promise<void> {\n const { globalVar, timeoutMs = 10_000, pollIntervalMs = 10 } = options;\n\n if (isBrowser()) {\n await loadInBrowser(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (window as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n } else {\n await loadInNode(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (globalThis as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n }\n}\n\nfunction isBrowser(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/* -------------------- Browser implementation -------------------- */\n\nexport function loadInBrowser(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n return new Promise((resolve, reject) => {\n const script = document.createElement('script');\n script.src = scriptUrl;\n script.async = true;\n\n const cleanup = () => {\n script.onload = null;\n script.onerror = null;\n script.remove();\n };\n\n const onAbort = () => {\n cleanup();\n reject(new Error('Script load aborted'));\n };\n\n if (signal?.aborted) {\n cleanup();\n reject(new Error('Script load aborted'));\n return;\n }\n\n signal?.addEventListener('abort', onAbort, { once: true });\n\n script.onload = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n resolve();\n };\n\n script.onerror = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n reject(new Error(`Failed to load script: ${scriptUrl}`));\n };\n\n document.head.appendChild(script);\n });\n}\n\n/* -------------------- Node implementation -------------------- */\n\nasync function loadInNode(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n if (typeof fetch !== 'function') {\n throw new Error('loadInNode: fetch is not available. Use Node 18+ or provide a global fetch.');\n }\n\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let res: Response;\n\n try {\n res = await fetch(scriptUrl, { signal });\n } catch (err: any) {\n // Node / WHATWG fetch uses AbortError on abort\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (!res.ok) {\n throw new Error(`Failed to load script in Node (HTTP ${res.status}): ${scriptUrl}`);\n }\n\n // If it was aborted between headers and body:\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let code: string;\n try {\n code = await res.text();\n } catch (err: any) {\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n // TEMPORARILY expose window for browser-style UMDs that expect it\n const g = globalThis as any;\n const prevWindow = g.window;\n\n g.window = g;\n\n try {\n // Indirect eval -> global scope in Node\n // Assumes the loaded script attaches itself to globalThis/window/global.\n (0, eval)(code);\n } finally {\n // Restore previous window (if any)\n if (prevWindow === undefined) {\n delete g.window;\n } else {\n g.window = prevWindow;\n }\n }\n}\n\n/* -------------------- Shared helper -------------------- */\n\nfunction waitForGlobal(\n getter: () => any,\n name: string,\n timeoutMs: number,\n pollIntervalMs: number,\n abortSignal: AbortSignal | null\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const start = Date.now();\n\n const onAbort = () => {\n reject(new Error('Wait for global aborted'));\n };\n\n if (abortSignal?.aborted) {\n reject(new Error('Wait for global aborted'));\n return;\n }\n\n abortSignal?.addEventListener('abort', onAbort, { once: true });\n\n const check = () => {\n if (abortSignal?.aborted) {\n return reject(new Error('Wait for global aborted'));\n }\n\n try {\n if (getter() !== undefined) {\n abortSignal?.removeEventListener('abort', onAbort);\n // log(`loadAndWaitGlobal: global \"${name}\" is now available`);\n return resolve();\n }\n } catch {\n // ignore access errors and keep polling\n }\n\n if (Date.now() - start >= timeoutMs) {\n abortSignal?.removeEventListener('abort', onAbort);\n // console.error(`loadAndWaitGlobal: timed out waiting for global \"${name}\"`);\n return reject(new Error(`Timed out after ${timeoutMs} ms waiting for global \"${name}\"`));\n }\n\n setTimeout(check, pollIntervalMs);\n };\n\n check();\n });\n}\n","import { importJson } from '../importJson';\nimport { loadAndWaitGlobal } from '../loadAndWaitGlobal';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyAssetUrlsResolver = {\n schema: 'legacy-asset-urls',\n resolveRef(ref: string, context: ResolveContextInternal) {\n log('legacyAssetUrlsResolver resolveRef:', ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n // load version.js - it will contain \"window.__fpDataVersion = \"20251129003330106\";\"\n const versionUrl = `${dataUrlBase}version.js`;\n try {\n await loadAndWaitGlobal(versionUrl, {\n globalVar: '__fpDataVersion',\n timeoutMs: 30_000,\n signal: context.signal,\n });\n context.importCallback?.(versionUrl, 'script');\n } catch {\n console.warn(`Could not load version.js at ${versionUrl}, proceeding without it`);\n }\n const version = (globalThis as any).__fpDataVersion || (+new Date()).toString();\n\n const filesUrl = `${dataUrlBase}files.json?v=${version}`;\n const dataUrl = `${dataUrlBase}data.js?v=${version}`;\n const filesPromise = importJson(filesUrl, context);\n const dataLoadPromise = loadAndWaitGlobal(dataUrl, {\n globalVar: '__data',\n signal: context.signal,\n });\n context.importCallback?.(dataUrl, 'script');\n await Promise.all([filesPromise, dataLoadPromise]);\n\n const files = await filesPromise;\n\n const data = (globalThis as any).__data || {};\n const dataFiles = [...files, 'data.js'];\n const dataFilesAssets = dataFiles.reduce((map, file) => {\n map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n\n return { ...dataFilesAssets, ...populateDataJsAssetsMap(dataUrlBase, data) };\n });\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n\nfunction populateDataJsAssetsMap(dataUrlBase: string, data: any) {\n const links = new Set<string>();\n function addLink(link: string) {\n if (typeof link === 'string' && link.length > 0) {\n // if (!link.startsWith('http://') && !link.startsWith('https://')) {\n // link = dataUrlBase + link;\n // }\n links.add(link);\n }\n }\n\n addLink(data.logo);\n data.exhibitors.forEach((e: any) => {\n addLink(e.logo);\n e.gallery?.forEach((img: string) => addLink(img));\n });\n\n data.events.forEach((e: any) => {\n addLink(e.logoFile);\n e.speakers?.forEach((s: any) => {\n addLink(s.photoFile);\n });\n });\n\n return Array.from(links).reduce((map, link) => {\n map[link] = { $ref: `asset+${dataUrlBase}${link}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n}\n","import { parseRefValue } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n resolveRef(ref: string, context) {\n log('legacyDataResolver resolveRef:', ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n\n return {\n _to_remove_for_offline_to_work_dataUrlBase: dataUrlBase,\n legacyAssetUrls: { $ref: `legacy-asset-urls+${dataUrlBase}` },\n };\n });\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n","import type { Resolver } from '../types';\nimport { assetResolver } from './assetResolver';\nimport { bundleAssetsResolver } from './bundleAssetsResolver';\nimport { expoRuntimeBranchResolver } from './expoRuntimeBranchResolver';\nimport { expoRuntimeGetBranchResolver } from './expoRuntimeGetBranchResolver';\nimport { expoRuntimeResolver } from './expoRuntimeResolver';\nimport { httpResolver } from './httpResolver';\nimport { legacyAssetUrlsResolver } from './legacyAssetUrlsResolver';\nimport { legacyDataResolver } from './legacyDataResolver';\n\nexport const resolvers: Resolver[] = [\n httpResolver,\n bundleAssetsResolver,\n assetResolver,\n expoRuntimeResolver,\n expoRuntimeBranchResolver,\n expoRuntimeGetBranchResolver,\n legacyDataResolver,\n legacyAssetUrlsResolver,\n];\n","import { resolvers } from './resolvers';\nimport {\n createMergedObjectWithOverridenNonRefProps,\n deepFreeze,\n log,\n replaceObjectFields,\n} from './shared';\nimport type { Resolver } from './types';\n\nconst globalRefCache = new Map<string, Promise<any>>();\n\nexport interface ResolveContextInternal {\n forceFetch: boolean;\n refCache: Map<string, Promise<any>>;\n /**\n * Callback invoked when a URL is fetched or imported.\n */\n importCallback?: (url: string, type: 'json' | 'script') => void;\n signal: AbortSignal | null;\n}\n\nexport interface ResolveOptions extends Partial<ResolveContextInternal> {\n /**\n * Mutate original object during resolution.\n */\n mutate?: boolean;\n signal?: AbortSignal;\n}\n\n/**\n * Resolves a value from an object using a JSON Pointer RFC 6901.\n *\n * @param object - The object to resolve the value from\n * @param jsonPointer - A JSON Pointer string that must start with '/'\n * @param options - Optional context for resolution, including cache and fetch callback\n * @returns A promise that resolves to the value at the specified JSON Pointer path\n * @throws {Error} If the JSON Pointer is not valid or if a $ref cannot be resolved\n *\n * @example\n * ```typescript\n * const obj = { foo: { bar: 'baz' } };\n * const result = await resolve(obj, '/foo/bar');\n * // result === 'baz'\n * ```\n */\nexport async function resolve(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n): Promise<any> {\n log('Resolving:', jsonPointer, 'of', object, options);\n if (typeof window !== 'undefined') {\n (window as any)['__lastResolveObject'] = object;\n }\n\n const resolveContext: ResolveContextInternal = {\n importCallback: options?.importCallback,\n refCache: options?.refCache || globalRefCache,\n forceFetch: !!options?.forceFetch,\n signal: options?.signal || null,\n };\n\n if (typeof jsonPointer !== 'string') {\n throw new Error(`Invalid JSON Pointer (not a string): ${jsonPointer}`);\n }\n if (!jsonPointer.startsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n if (jsonPointer.length > 1 && jsonPointer.endsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n // if (jsonPointer === '/') {\n // const result = await resolveObject(object, resolveContext);\n // if (options?.mutate) {\n // replaceObjectFields(object, result);\n // }\n // return result;\n // }\n\n let parts: string[];\n if (jsonPointer === '/') {\n parts = [];\n } else {\n parts = jsonPointer.substring(1).split('/');\n }\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n if (options?.mutate) {\n // prepend parts with 'root'\n parts.unshift('root');\n const target = { root: object };\n await resovlePartsRecursiveMutate(target, parts, 0, resolveContext);\n replaceObjectFields(object, target.root);\n } else {\n return await resovlePartsRecursive(object, parts, 0, resolveContext);\n }\n // prepend parts with 'root'\n // parts.unshift('root');\n // // if (parts.some((part) => part.length === 0))\n // // throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n // const target = { root: object };\n // const value = await resovlePartsRecursiveMutate(\n // target,\n // // 'root',\n // parts,\n // 0,\n // resolveContext\n // );\n // if (options?.mutate) {\n // replaceObjectFields(object, target.root);\n // }\n // log(`Resolved ${jsonPointer}:`, value);\n // return value;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursiveMutate(\n node: any,\n // key: string,\n parts: string[],\n partsIndex: number,\n context: ResolveContextInternal\n): Promise<void> {\n const key = parts[partsIndex];\n // console.warn('in', key);\n\n await resolveObjectMutate(node, key, context);\n if (partsIndex == parts.length - 1) return;\n\n if (node[key] === null || typeof node[key] !== 'object') {\n // console.error('Cannot resolve path, encountered non-object:', node, key);\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.slice(1).join('/')}', index ${\n partsIndex - 1\n }'`\n );\n }\n return await resovlePartsRecursiveMutate(node[key], parts, partsIndex + 1, context);\n}\n\nasync function resolveObjectMutate(\n node: any,\n key: string,\n context: ResolveContextInternal\n): Promise<void> {\n log('resolveObjectMutate:', node, key);\n let obj = node[key];\n const result = await resolveObject(obj, context);\n if (result !== undefined) node[key] = result;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursive(\n object: any,\n parts: string[],\n index: number,\n context: ResolveContextInternal\n): Promise<any> {\n // should return undefined if last part not found\n // if not last part found - throw error\n // do not resolve object if its children are not needed (needed part exist as key)\n if (index === parts.length) {\n // console.warn('Resolving last part:', object);\n return await resolveObject(object, context);\n }\n if (object === null || typeof object !== 'object') {\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n );\n }\n const part = parts[index];\n let child = object[part];\n if (child === undefined) {\n // console.warn('Resolving, part not found during resolve:', part, object);\n const resolvedObject = await resolveObject(object, context);\n child = resolvedObject[part];\n }\n return await resovlePartsRecursive(child, parts, index + 1, context);\n}\n\nasync function resolveObject(object: any, context: ResolveContextInternal): Promise<any> {\n log('resolveObject:', object);\n let obj = object;\n\n do {\n if (typeof obj !== 'object' || obj === null || !('$ref' in obj)) {\n return obj;\n }\n const resolversToUse = resolvers.filter((r) => canResolve(r, obj.$ref));\n if (resolversToUse.length === 0) {\n if (obj.$ref) {\n throw new Error(`No resolver found for ref: ${obj.$ref}`);\n }\n deepFreeze(obj);\n return obj;\n }\n if (resolversToUse.length > 1) {\n throw new Error(`Multiple resolvers can resolve ref: ${obj.$ref}`);\n }\n\n const data = await resolverResolve(resolversToUse[0], obj.$ref, context);\n\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(\n resolver: Resolver,\n ref: string,\n context: ResolveContextInternal\n): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref, context);\n}\n\nexport function canResolve(resolver: Resolver, ref: string): boolean {\n if (resolver.canResolve) {\n return resolver.canResolve(ref);\n }\n if (resolver.schema) {\n return canResolveRefSchema(ref, resolver.schema);\n }\n throw new Error('Resolver is missing canResolve method and schema property');\n}\n\nexport function canResolveRefSchema(ref: string, prefixBase: string): boolean {\n const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n for (const prefix of prefixes) {\n if (ref.startsWith(prefix)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseRefValue(ref: string): string {\n // look for anything before \":\" or before +https:// or before +http://\n // https://www -> https://www\n // so some+base+https://www -> https://www\n // base+https://www -> https://www\n // base:abc -> abc\n // \"some-base\" can contain only non-:\n if (ref.startsWith('http://') || ref.startsWith('https://')) {\n return ref;\n }\n // if it is something+http:// or something+https://\n const plusHttpIndex = ref.indexOf('+http://');\n const plusHttpsIndex = ref.indexOf('+https://');\n if (plusHttpIndex !== -1) {\n return ref.substring(plusHttpIndex + 1);\n }\n if (plusHttpsIndex !== -1) {\n return ref.substring(plusHttpsIndex + 1);\n }\n // if it is something:abc\n const colonIndex = ref.indexOf(':');\n if (colonIndex !== -1) {\n return ref.substring(colonIndex + 1);\n }\n\n throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n}\n\n// export function parseRefValue(ref: string): string {\n// // look for anything before \":\" or before +https:// or before +http://\n// // https://www -> https://www\n// // so some+base+https://www -> https://www\n// // base+https://www -> https://www\n// // base:abc -> abc\n// // \"some-base\" can contain only non-:\n// if (ref.startsWith('http://') || ref.startsWith('https://')) {\n// return ref;\n// }\n// // if it is something+http:// or something+https://\n// const plusHttpIndex = ref.indexOf('+http://');\n// const plusHttpsIndex = ref.indexOf('+https://');\n// if (plusHttpIndex !== -1) {\n// return ref.substring(plusHttpIndex + 1);\n// }\n// if (plusHttpsIndex !== -1) {\n// return ref.substring(plusHttpsIndex + 1);\n// }\n// // if it is something:abc\n// const colonIndex = ref.indexOf(':');\n// if (colonIndex !== -1) {\n// return ref.substring(colonIndex + 1);\n// }\n\n// throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n\n// // const prefixBase = ref.split('+')[0].split(':')[0];\n// // if (!prefixBase) {\n// // throw new Error(`Invalid ref, missing prefix: ${ref}`);\n// // }\n// // return ref.substring(prefixBase.length + 1);\n\n// // const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// // for (const prefix of prefixes) {\n// // if (ref.startsWith(prefix)) {\n// // const url = ref.substring(prefix.length);\n// // if (!url) {\n// // throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// // }\n// // return url;\n// // }\n// // }\n\n// // throw new Error(\n// // `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// // );\n// }\n\n// export function parseRefValue(ref: string, prefixBase: string): string {\n// const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// for (const prefix of prefixes) {\n// if (ref.startsWith(prefix)) {\n// const url = ref.substring(prefix.length);\n// if (!url) {\n// throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// }\n// return url;\n// }\n// }\n\n// throw new Error(\n// `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// );\n// }\n\n// const importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n// url: string\n// ) => Promise<any>;\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = async function debugResolve(\n objectOrRef: any,\n refOrContext: any,\n context?: any\n ) {\n let object: any;\n let ref: string;\n let resolveContext: ResolveOptions | undefined;\n if (typeof objectOrRef === 'string') {\n object = (window as any)['__lastResolveObject'];\n ref = objectOrRef;\n resolveContext = refOrContext;\n } else {\n object = objectOrRef;\n ref = refOrContext;\n resolveContext = context;\n }\n return await resolve(object, ref, resolveContext);\n };\n\n // (window as any)['__dd'] = async function dd() {\n // const url = 'https://demo.expofp.com/manifest.json';\n // // const imp = import;\n // const zz = (await importJsonNative(url)).default;\n // console.warn('debugResolve demo manifest:', zz);\n // // let object: any;\n // // let ref: string;\n // // let resolveContext: ResolveOptions | undefined;\n // // if (typeof objectOrRef === 'string') {\n // // object = (window as any)['__lastResolveObject'];\n // // ref = objectOrRef;\n // // resolveContext = refOrContext;\n // // } else {\n // // object = objectOrRef;\n // // ref = refOrContext;\n // // resolveContext = context;\n // // }\n // // return await resolve(object, ref, resolveContext);\n // };\n}\n\n// if (index === parts.length - 1) {\n// return await resolveObject(object, context);\n// }\n// if (object === null || typeof object !== 'object') {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n// );\n// }\n// if (!(parts[0] in object)) {\n// return undefined;\n// }\n// let partIndex = 0;\n// let currentObject = await resolveObject(object, context);\n// while (partIndex < parts.length) {\n// const part = parts[partIndex];\n// if (typeof currentObject !== 'object' || currentObject === null) {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join(\n// '/'\n// )}, index ${partIndex}'`\n// );\n// }\n// // console.info(\n// // 'resolvePath currentObject:',\n// // part,\n// // JSON.stringify(currentObject, null, 2),\n// // currentObject[part]\n// // );\n// // debugger;\n// const child = currentObject[part];\n// currentObject = await resolveObject(child, context);\n// partIndex++;\n// }\n// return currentObject;\n","import { resolve } from './resolve';\n\n// export const NOT_APPLICABLE = Symbol('not-applicable');\n// export const STOP_RESOLVING = Symbol('STOP_RESOLVING');\n\nexport function createFunction(name: string) {\n return async (manifest: unknown, ...args: IArguments[]) => {\n try {\n const runtimeEntryPoint = await resolve(manifest, '/runtime/entry');\n const moduleExports = await import(/* @vite-ignore */ runtimeEntryPoint);\n const functionToCall = moduleExports[name];\n return functionToCall(manifest, ...args);\n } catch (error) {\n console.error('efp-loader', `Error when trying to import and call \"${name}\":`, error);\n throw error;\n }\n };\n}\n\nexport function log(...args: any[]) {\n if (!(globalThis as any).__EFP_LOADER_DEBUG__ && !import.meta.env.DEV) return;\n console.debug('efp-loader', ...args);\n}\n\nexport function deepFreeze(obj: any) {\n if (obj === null || typeof obj !== 'object') return obj;\n\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const val = obj[key];\n if (typeof val === 'object' && val !== null && !Object.isFrozen(val)) {\n deepFreeze(val);\n }\n }\n\n return obj;\n}\n\nexport function deepClone<T>(obj: T): T {\n if ('structuredClone' in globalThis) {\n return (globalThis as any).structuredClone(obj);\n }\n return JSON.parse(JSON.stringify(obj));\n}\n\nexport function preloadJson(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preload';\n link.as = 'fetch';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n\nexport function preconnectUrl(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preconnect';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n// export function hashString(str: string): string {\n// let hash = 0;\n\n// for (let i = 0; i < str.length; i++) {\n// const chr = str.charCodeAt(i);\n// hash = (hash << 5) - hash + chr;\n// hash |= 0; // force 32-bit int\n// }\n\n// // >>> 0 makes it unsigned (no '-' in front)\n// return (hash >>> 0).toString(16); // hex, [0-9a-f]\n// }\n\n// Deterministic ID\n// export async function hashString(str: string): Promise<string> {\n// const encoder = new TextEncoder();\n// const data = encoder.encode(str);\n\n// const digest = await crypto.subtle.digest('SHA-1', data);\n// return bufferToHex(digest);\n// }\n\n// murmur32\n// export function hashString(str: string): string {\n// let h = 0x811c9dc5;\n\n// for (let i = 0; i < str.length; i++) {\n// h ^= str.charCodeAt(i);\n// h = Math.imul(h, 0x01000193);\n// }\n\n// return (h >>> 0).toString(16).padStart(24, '0');\n// }\n\n// function bufferToHex(buffer: ArrayBuffer): string {\n// const bytes = new Uint8Array(buffer);\n// let hex = '';\n// for (let i = 0; i < bytes.length; i++) {\n// const byteHex = bytes[i].toString(16).padStart(2, '0');\n// hex += byteHex;\n// }\n// return hex;\n// }\n\n// export function mergeNonRefFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonRefFields does not support merging arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonRefFields does not support merging into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function mergeNonExitingFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonExitingFields does not support merging arrays');\n// }\n\n// const keys = Object.keys(source);\n// if (keys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonExitingFields does not support merging into arrays');\n// }\n\n// for (const key of Object.keys(source)) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// if (!(key in target)) {\n// target[key] = source[key];\n// }\n// }\n// }\n\n// export function replaceObjectFields(target: any, source: any) {\n// if (target === source) {\n// throw new Error('Cannot replace object with itself');\n// }\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object') {\n// throw new Error('Cannot replace with non-object source');\n// }\n// // throw if any is array\n// if (Array.isArray(target) || Array.isArray(source)) {\n// throw new Error('replaceObjectFields does not support arrays');\n// }\n\n// // delete keys in target that are not in source\n// for (const key of Object.keys(target)) {\n// if (!(key in source)) {\n// delete target[key];\n// }\n// }\n\n// // copy keys from source to target\n// for (const key of Object.keys(source)) {\n// target[key] = source[key];\n// }\n// }\n\n// export function isObject(v: any): boolean {\n// return v !== null && typeof v === 'object' && !Array.isArray(v);\n// }\n\n// export function mergeOriginalFieldsIntoResolvedObject(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function createMergedObject(target: any, source: any) {\n// if (target === source) return; //throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return target;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// if (target === null || typeof target !== 'object') {\n// throw new Error('Cannot merge into non-object target');\n// }\n\n// const result = { ...target };\n// for (const key of nonRefKeys) {\n// result[key] = source[key];\n// }\n// deepFreeze(result);\n// return result;\n// }\n\nexport function createMergedObjectWithOverridenNonRefProps(target: any, source: any) {\n if (target === source) return; //throw new Error('Cannot merge object with itself');\n // if source is primitive, throw\n if (source === null || typeof source !== 'object')\n throw new Error('Cannot merge non-object source');\n if (Array.isArray(source)) {\n throw new Error('Cannot merge arrays');\n }\n const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n if (nonRefKeys.length === 0) return deepClone(target);\n\n // throw if any is array\n if (Array.isArray(target)) {\n throw new Error('Cannot merge into arrays');\n }\n\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot merge into non-object target');\n }\n\n const result = deepClone({ ...target });\n for (const key of nonRefKeys) {\n result[key] = source[key];\n }\n // deepFreeze(result);\n return result;\n}\n\nexport function replaceObjectFields(target: any, source: any): void {\n if (target === source) {\n return;\n // throw new Error('Cannot replace object with itself');\n }\n // if source is primitive, throw\n if (source === null || typeof source !== 'object') {\n throw new Error('Cannot replace with non-object source');\n }\n // if target is primitive, throw\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot replace non-object target');\n }\n\n if (Array.isArray(target)) {\n if (!Array.isArray(source)) {\n throw new Error('replaceObjectFields does not support mixing arrays and objects');\n }\n // both are arrays - replace contents\n target.length = 0;\n for (const item of source) {\n target.push(item);\n }\n return;\n }\n\n // delete keys in target that are not in source\n for (const key of Object.keys(target)) {\n if (!(key in source)) {\n delete target[key];\n }\n }\n\n // copy keys from source to target\n for (const key of Object.keys(source)) {\n target[key] = source[key];\n }\n}\n","import { resolve } from './resolve';\nimport type { ResolveOptions } from './resolve';\n\nexport async function mutateManifest(\n manifest: any,\n paths: string[],\n resolveContext?: Omit<ResolveOptions, 'mutate'>\n): Promise<void> {\n resolveContext = resolveContext || {};\n\n for (const path of paths) {\n await resolve(manifest, path, { ...resolveContext, mutate: true });\n }\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugMutateManifest'] = mutateManifest;\n}\n","export async function makeOfflineBundle(manifest: unknown) {\n const { makeOfflineBundle } = await import('./makeOfflineBundle');\n return await makeOfflineBundle(manifest);\n}\n\nexport async function downloadZip(manifest: unknown) {\n const { downloadZip } = await import('./downloadZip');\n return await downloadZip(manifest);\n}\n\nasync function debugLogOfflineManifestFiles(manifest: unknown): Promise<void> {\n // console.log('Offline files:');\n const { makeOffline } = await import('./makeOffline');\n const result = await makeOffline(manifest);\n // const allFiles = [];\n for await (const file of (await result).files) {\n if ('data' in file) {\n console.info(`🗳️ Put ${file.targetFilePath} <=`, file.data);\n } else if ('url' in file) {\n console.info(`🗳️ Download ${file.targetFilePath} <= ${file.url}`);\n }\n // allFiles.push(file);\n }\n console.info('Offline data: ', result.manifest);\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugDownloadZip'] = downloadZip;\n (window as any)['__debugMakeOfflineBundle'] = makeOfflineBundle;\n (window as any)['__debugLogOfflineManifestFiles'] = debugLogOfflineManifestFiles;\n}\n","import { createFunction, preconnectUrl } from './shared';\n\nexport const mount = createFunction('mount');\nexport const load = createFunction('load');\nexport const initialize = createFunction('initialize');\n\n// extra\n// export const createFloorPlan = createFunction('createFloorPlan');\n// export const rewriteManifestToLocalFiles = createFunction('rewriteManifestToLocalFiles');\n\nexport async function callFunction_Experimental(\n name: string,\n manifest: unknown,\n ...args: IArguments[]\n) {\n const fn = createFunction(name);\n return await fn(manifest, ...args);\n}\n\nexport { resolve } from './resolve';\nexport { mutateManifest } from './mutateManifest';\nexport { makeOfflineBundle, downloadZip } from './offline';\n\n// preloadJson('https://efp-runtime.expofp.com/branches/main.json');\npreconnectUrl('https://efp-runtime.expofp.com/');\n"],"names":["resolveAssetRefSync","ref","log","parseRefValue","assetResolver","importJsonNotAvailable","jsonFrozen","importJsonNative","importJson","url","resolveContext","_a","_b","result","loadJson","deepFreeze","fetchCache","signal","key","dataPromise","response","returnCachedRef","refCache","factory","promise","data","bundleAssetsResolver","context","files","baseUrl","file","BASE_URL","expoRuntimeBranchResolver","branch","branchUrl","expoRuntimeGetBranchResolver","expoRuntimeResolver","httpResolver","loadAndWaitGlobal","scriptUrl","options","globalVar","timeoutMs","pollIntervalMs","isBrowser","loadInBrowser","waitForGlobal","loadInNode","resolve","reject","script","cleanup","onAbort","res","err","code","g","prevWindow","getter","name","abortSignal","start","check","legacyAssetUrlsResolver","dataUrlBase","versionUrl","version","filesUrl","dataUrl","filesPromise","dataLoadPromise","map","populateDataJsAssetsMap","links","addLink","link","e","img","s","legacyDataResolver","resolvers","globalRefCache","object","jsonPointer","parts","part","target","resovlePartsRecursiveMutate","replaceObjectFields","resovlePartsRecursive","node","partsIndex","resolveObjectMutate","obj","resolveObject","index","child","resolversToUse","r","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","objectOrRef","refOrContext","createFunction","manifest","args","functionToCall","error","val","deepClone","preconnectUrl","source","nonRefKeys","item","mutateManifest","paths","path","makeOfflineBundle","downloadZip","debugLogOfflineManifestFiles","makeOffline","mount","load","initialize","callFunction_Experimental"],"mappings":"AAIO,SAASA,EAAoBC,GAAqB;AACvD,SAAAC,EAAI,6BAA6BD,CAAG,GAG7BE,EAAcF,CAAG;AAC1B;AAEO,MAAMG,IAAgB;AAAA,EAC3B,QAAQ;AAAA,EACR,YAAY,OAAOH,MAAgBD,EAAoBC,CAAG;AAAA,EAC1D,eAAe;AACjB;ACZA,IAAII;AACJ,MAAMC,wBAAiB,QAAA,GAKjBC,IAAmB,IAAI,SAAS,OAAO,iDAAiD;AAI9F,eAAsBC,EACpBC,GACAC,GACc;ADZT,MAAAC,GAAAC;ACcL,MAAIP,MAA2B,UAAa,CAACK,EAAe;AAC1D,QAAI;AACF,YAAMH,EAAiBE,CAAG,GAC1BJ,IAAyB;AAAA,IAC3B,QAAQ;AACN,MAAAH,EAAI,iEAAiE,GACrEG,IAAyB;AAAA,IAC3B;AAEF,MAAIQ;AACJ,SAAI,CAACR,KAA0B,CAACK,EAAe,cAE7CG,KADe,MAAMN,EAAiBE,CAAG,GACzB,UAChBE,IAAAD,EAAe,mBAAf,QAAAC,EAAA,KAAAD,GAAgCD,GAAK,YAErCP,EAAI,qBAAqBO,CAAG,GAC5BI,IAAS,MAAMC,EAASL,GAAKC,EAAe,UAAUA,EAAe,UAAU,IAAI,IACnFE,IAAAF,EAAe,mBAAf,QAAAE,EAAA,KAAAF,GAAgCD,GAAK,UAElCH,EAAW,IAAIO,CAAM,KACxBE,EAAWF,CAAM,GAGZA;AACT;AAIA,eAAeC,EACbL,GACAO,GACAC,GACc;AACd,QAAMC,IAAM,iBAAiBT;AAC7B,MAAIO,EAAW,IAAIE,CAAG;AACpB,WAAOF,EAAW,IAAIE,CAAG;AAG3B,QAAMC,KAAe,iBAA+B;AAClD,UAAMC,IAAW,MAAM,MAAMX,GAAK,EAAE,QAAAQ,GAAQ;AAC5C,QAAI,CAACG,EAAS;AACZ,YAAM,IAAI,MAAM,6BAA6BX,CAAG,EAAE;AAEpD,WAAO,MAAMW,EAAS,KAAA;AAAA,EACxB,GAAA;AAEA,SAAAJ,EAAW,IAAIE,GAAKC,CAAW,GACxBA;AACT;AChEA,eAAsBE,EACpBpB,GACAqB,GACAC,GACA;AACA,MAAID,EAAS,IAAIrB,CAAG;AAClB,WAAOqB,EAAS,IAAIrB,CAAG;AAEzB,QAAMuB,IAAUD,EAAA,EAAU,KAAK,CAACE,OAC9BV,EAAWU,CAAI,GACRA,EACR;AACD,SAAAH,EAAS,IAAIrB,GAAKuB,CAAO,GAClBA;AACT;ACVO,MAAME,IAAiC;AAAA,EAC5C,QAAQ;AAAA,EACR,MAAM,WAAWzB,GAAa0B,GAAiC;AAC7D,IAAAzB,EAAI,oCAAoCD,CAAG;AAE3C,UAAMQ,IAAMN,EAAcF,CAAG;AAE7B,WAAOoB,EAAgBpB,GAAK0B,EAAQ,UAAU,YAAY;AACxD,YAAMC,IAAQ,MAAMpB,EAAWC,GAAKkB,CAAO,GACrCE,IAAUpB,EAAI,UAAU,GAAGA,EAAI,YAAY,GAAG,IAAI,CAAC;AAKzD,aAHemB,EAAM,IAAI,CAACE,OAAkB;AAAA,QAC1C,MAAM,SAASD,CAAO,GAAGC,CAAI;AAAA,MAAA,EAC7B;AAAA,IAEJ,CAAC;AAAA,EACH;AAAA,EACA,eAAe;AACjB,GClBMC,IAAW,mCAEJC,IAAsC;AAAA,EACjD,QAAQ;AAAA,EACR,MAAM,WAAW/B,GAAa0B,GAAiC;AAC7D,IAAAzB,EAAI,yCAAyCD,CAAG;AAEhD,UAAMgC,IAAS9B,EAAcF,CAAG,GAC1BiC,IAAY,GAAGH,CAAQ,YAAYE,CAAM;AAE/C,WAAOZ,EAAgBpB,GAAK0B,EAAQ,UAAU,aAErC;AAAA,MACL,MAAM,wDAFQ,MAAMnB,EAAW0B,GAAWP,CAAO,CAEoB;AAAA,IAAA,EAExE;AAAA,EACH;AAAA,EAEA,eAAe;AACjB,GClBaQ,IAAyC;AAAA,EACpD,QAAQ;AAAA,EACR,MAAM,WAAWlC,GAAK0B,GAAS;AAC7B,IAAAzB,EAAI,4CAA4CD,CAAG;AAGnD,UAAMQ,IAAM,WADCN,EAAcF,CAAG,CACH;AAC3B,WAAOO,EAAWC,GAAKkB,CAAO;AAAA,EAChC;AAAA,EACA,eAAe;AACjB,GCXaS,IAAgC;AAAA,EAC3C,QAAQ;AAAA;AAAA;AAAA;AAAA,EAIR,MAAM,WAAWnC,GAAa;AAC5B,IAAAC,EAAI,mCAAmCD,CAAG;AAG1C,UAAMQ,IAAMN,EAAcF,CAAG,GACvBwB,IAAO;AAAA,MACX,OAAO,EAAE,MAAM,SAAShB,CAAG,YAAA;AAAA,MAC3B,QAAQ,EAAE,MAAM,iBAAiBA,CAAG,cAAA;AAAA,IAAc;AAEpD,WAAAM,EAAWU,CAAI,GACRA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,eAAe;AACjB,GCrCaY,IAAe;AAAA,EAC1B,WAAWpC,GAAK;AACd,WAAOA,EAAI,WAAW,SAAS,KAAKA,EAAI,WAAW,UAAU,KAAKA,EAAI,WAAW,IAAI;AAAA,EACvF;AAAA,EACA,WAAWA,GAAK0B,GAAS;AAEvB,QADAzB,EAAI,4BAA4BD,CAAG,GAC/B,CAAC,KAAK,WAAYA,CAAG,SAAS,IAAI,MAAM,mCAAmCA,CAAG,EAAE;AAEpF,WAAOO,EAAWP,GAAK0B,CAAO;AAAA,EAChC;AAAA,EACA,eAAe;AACjB;ACCA,eAAsBW,EACpBC,GACAC,GACe;AACf,QAAM,EAAE,WAAAC,GAAW,WAAAC,IAAY,KAAQ,gBAAAC,IAAiB,OAAOH;AAE/D,EAAII,OACF,MAAMC,EAAcN,GAAWC,EAAQ,MAAM,GACzCC,KACF,MAAMK;AAAA,IACJ,MAAO,OAAeL,CAAS;AAAA,IAC/BA;AAAA,IACAC;AAAA,IACAC;AAAA,IACAH,EAAQ;AAAA,EAAA,MAIZ,MAAMO,EAAWR,GAAWC,EAAQ,MAAM,GACtCC,KACF,MAAMK;AAAA,IACJ,MAAO,WAAmBL,CAAS;AAAA,IACnCA;AAAA,IACAC;AAAA,IACAC;AAAA,IACAH,EAAQ;AAAA,EAAA;AAIhB;AAEA,SAASI,IAAqB;AAC5B,SAAO,OAAO,SAAW,OAAe,OAAO,WAAa;AAC9D;AAIO,SAASC,EAAcN,GAAmBtB,GAA2C;AAC1F,SAAO,IAAI,QAAQ,CAAC+B,GAASC,MAAW;AACtC,UAAMC,IAAS,SAAS,cAAc,QAAQ;AAC9C,IAAAA,EAAO,MAAMX,GACbW,EAAO,QAAQ;AAEf,UAAMC,IAAU,MAAM;AACpB,MAAAD,EAAO,SAAS,MAChBA,EAAO,UAAU,MACjBA,EAAO,OAAA;AAAA,IACT,GAEME,IAAU,MAAM;AACpB,MAAAD,EAAA,GACAF,EAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,IACzC;AAEA,QAAIhC,KAAA,QAAAA,EAAQ,SAAS;AACnB,MAAAkC,EAAA,GACAF,EAAO,IAAI,MAAM,qBAAqB,CAAC;AACvC;AAAA,IACF;AAEA,IAAAhC,KAAA,QAAAA,EAAQ,iBAAiB,SAASmC,GAAS,EAAE,MAAM,OAEnDF,EAAO,SAAS,MAAM;AACpB,MAAAjC,KAAA,QAAAA,EAAQ,oBAAoB,SAASmC,IACrCD,EAAA,GACAH,EAAA;AAAA,IACF,GAEAE,EAAO,UAAU,MAAM;AACrB,MAAAjC,KAAA,QAAAA,EAAQ,oBAAoB,SAASmC,IACrCD,EAAA,GACAF,EAAO,IAAI,MAAM,0BAA0BV,CAAS,EAAE,CAAC;AAAA,IACzD,GAEA,SAAS,KAAK,YAAYW,CAAM;AAAA,EAClC,CAAC;AACH;AAIA,eAAeH,EAAWR,GAAmBtB,GAA2C;AACtF,MAAI,OAAO,SAAU;AACnB,UAAM,IAAI,MAAM,6EAA6E;AAG/F,MAAIA,KAAA,QAAAA,EAAQ;AACV,UAAM,IAAI,MAAM,qBAAqB;AAGvC,MAAIoC;AAEJ,MAAI;AACF,IAAAA,IAAM,MAAM,MAAMd,GAAW,EAAE,QAAAtB,GAAQ;AAAA,EACzC,SAASqC,GAAU;AAEjB,UAAIA,KAAOA,EAAI,SAAS,eAChB,IAAI,MAAM,qBAAqB,IAEjCA;AAAA,EACR;AAEA,MAAI,CAACD,EAAI;AACP,UAAM,IAAI,MAAM,uCAAuCA,EAAI,MAAM,MAAMd,CAAS,EAAE;AAIpF,MAAItB,KAAA,QAAAA,EAAQ;AACV,UAAM,IAAI,MAAM,qBAAqB;AAGvC,MAAIsC;AACJ,MAAI;AACF,IAAAA,IAAO,MAAMF,EAAI,KAAA;AAAA,EACnB,SAASC,GAAU;AACjB,UAAIA,KAAOA,EAAI,SAAS,eAChB,IAAI,MAAM,qBAAqB,IAEjCA;AAAA,EACR;AAEA,MAAIrC,KAAA,QAAAA,EAAQ;AACV,UAAM,IAAI,MAAM,qBAAqB;AAIvC,QAAMuC,IAAI,YACJC,IAAaD,EAAE;AAErB,EAAAA,EAAE,SAASA;AAEX,MAAI;AAGF,QAAI,MAAMD,CAAI;AAAA,EAChB,UAAA;AAEE,IAAIE,MAAe,SACjB,OAAOD,EAAE,SAETA,EAAE,SAASC;AAAA,EAEf;AACF;AAIA,SAASX,EACPY,GACAC,GACAjB,GACAC,GACAiB,GACe;AACf,SAAO,IAAI,QAAQ,CAACZ,GAASC,MAAW;AACtC,UAAMY,IAAQ,KAAK,IAAA,GAEbT,IAAU,MAAM;AACpB,MAAAH,EAAO,IAAI,MAAM,yBAAyB,CAAC;AAAA,IAC7C;AAEA,QAAIW,KAAA,QAAAA,EAAa,SAAS;AACxB,MAAAX,EAAO,IAAI,MAAM,yBAAyB,CAAC;AAC3C;AAAA,IACF;AAEA,IAAAW,KAAA,QAAAA,EAAa,iBAAiB,SAASR,GAAS,EAAE,MAAM;AAExD,UAAMU,IAAQ,MAAM;AAClB,UAAIF,KAAA,QAAAA,EAAa;AACf,eAAOX,EAAO,IAAI,MAAM,yBAAyB,CAAC;AAGpD,UAAI;AACF,YAAIS,EAAA,MAAa;AACf,iBAAAE,KAAA,QAAAA,EAAa,oBAAoB,SAASR,IAEnCJ,EAAA;AAAA,MAEX,QAAQ;AAAA,MAER;AAEA,UAAI,KAAK,QAAQa,KAASnB;AACxB,eAAAkB,KAAA,QAAAA,EAAa,oBAAoB,SAASR,IAEnCH,EAAO,IAAI,MAAM,mBAAmBP,CAAS,2BAA2BiB,CAAI,GAAG,CAAC;AAGzF,iBAAWG,GAAOnB,CAAc;AAAA,IAClC;AAEA,IAAAmB,EAAA;AAAA,EACF,CAAC;AACH;AC1MO,MAAMC,IAA0B;AAAA,EACrC,QAAQ;AAAA,EACR,WAAW9D,GAAa0B,GAAiC;AACvD,WAAAzB,EAAI,uCAAuCD,CAAG,GAEvCoB,EAAgBpB,GAAK0B,EAAQ,UAAU,YAAY;ATRvD,UAAAhB,GAAAC;ASSD,YAAMoD,IAAc7D,EAAcF,CAAG,GAE/BgE,IAAa,GAAGD,CAAW;AACjC,UAAI;AACF,cAAM1B,EAAkB2B,GAAY;AAAA,UAClC,WAAW;AAAA,UACX,WAAW;AAAA,UACX,QAAQtC,EAAQ;AAAA,QAAA,CACjB,IACDhB,IAAAgB,EAAQ,mBAAR,QAAAhB,EAAA,KAAAgB,GAAyBsC,GAAY;AAAA,MACvC,QAAQ;AACN,gBAAQ,KAAK,gCAAgCA,CAAU,yBAAyB;AAAA,MAClF;AACA,YAAMC,IAAW,WAAmB,oBAAoB,CAAC,oBAAI,KAAA,GAAQ,SAAA,GAE/DC,IAAW,GAAGH,CAAW,gBAAgBE,CAAO,IAChDE,IAAU,GAAGJ,CAAW,aAAaE,CAAO,IAC5CG,IAAe7D,EAAW2D,GAAUxC,CAAO,GAC3C2C,IAAkBhC,EAAkB8B,GAAS;AAAA,QACjD,WAAW;AAAA,QACX,QAAQzC,EAAQ;AAAA,MAAA,CACjB;AACD,OAAAf,IAAAe,EAAQ,mBAAR,QAAAf,EAAA,KAAAe,GAAyByC,GAAS,WAClC,MAAM,QAAQ,IAAI,CAACC,GAAcC,CAAe,CAAC;AAEjD,YAAM1C,IAAQ,MAAMyC,GAEd5C,IAAQ,WAAmB,UAAU,CAAA;AAO3C,aAAO,EAAE,GANS,CAAC,GAAGG,GAAO,SAAS,EACJ,OAAO,CAAC2C,GAAKzC,OAC7CyC,EAAIzC,CAAI,IAAI,EAAE,MAAM,SAASkC,CAAW,GAAGlC,CAAI,MAAMoC,CAAO,GAAA,GACrDK,IACN,CAAA,CAAsC,GAEZ,GAAGC,EAAwBR,GAAavC,CAAI,EAAA;AAAA,IAC3E,CAAC;AAAA,EACH;AAAA,EACA,eAAe;AACjB;AAEA,SAAS+C,EAAwBR,GAAqBvC,GAAW;AAC/D,QAAMgD,wBAAY,IAAA;AAClB,WAASC,EAAQC,GAAc;AAC7B,IAAI,OAAOA,KAAS,YAAYA,EAAK,SAAS,KAI5CF,EAAM,IAAIE,CAAI;AAAA,EAElB;AAEA,SAAAD,EAAQjD,EAAK,IAAI,GACjBA,EAAK,WAAW,QAAQ,CAACmD,MAAW;AT7D/B,QAAAjE;AS8DH,IAAA+D,EAAQE,EAAE,IAAI,IACdjE,IAAAiE,EAAE,YAAF,QAAAjE,EAAW,QAAQ,CAACkE,MAAgBH,EAAQG,CAAG;AAAA,EACjD,CAAC,GAEDpD,EAAK,OAAO,QAAQ,CAACmD,MAAW;ATlE3B,QAAAjE;ASmEH,IAAA+D,EAAQE,EAAE,QAAQ,IAClBjE,IAAAiE,EAAE,aAAF,QAAAjE,EAAY,QAAQ,CAACmE,MAAW;AAC9B,MAAAJ,EAAQI,EAAE,SAAS;AAAA,IACrB;AAAA,EACF,CAAC,GAEM,MAAM,KAAKL,CAAK,EAAE,OAAO,CAACF,GAAKI,OACpCJ,EAAII,CAAI,IAAI,EAAE,MAAM,SAASX,CAAW,GAAGW,CAAI,GAAA,GACxCJ,IACN,CAAA,CAAsC;AAC3C;AC5EO,MAAMQ,IAAqB;AAAA,EAChC,QAAQ;AAAA,EACR,WAAW9E,GAAa0B,GAAS;AAC/B,WAAAzB,EAAI,kCAAkCD,CAAG,GAElCoB,EAAgBpB,GAAK0B,EAAQ,UAAU,YAAY;AACxD,YAAMqC,IAAc7D,EAAcF,CAAG;AAErC,aAAO;AAAA,QACL,4CAA4C+D;AAAA,QAC5C,iBAAiB,EAAE,MAAM,qBAAqBA,CAAW,GAAA;AAAA,MAAG;AAAA,IAEhE,CAAC;AAAA,EACH;AAAA,EACA,eAAe;AACjB,GCVagB,IAAwB;AAAA,EACnC3C;AAAA,EACAX;AAAA,EACAtB;AAAA,EACAgC;AAAA,EACAJ;AAAA,EACAG;AAAA,EACA4C;AAAA,EACAhB;AACF,GCVMkB,wBAAqB,IAAA;AAoC3B,eAAsBjC,EACpBkC,GACAC,GACA3C,GACc;AACd,EAAAtC,EAAI,cAAciF,GAAa,MAAMD,GAAQ1C,CAAO,GAChD,OAAO,SAAW,QACnB,OAAe,sBAAyB0C;AAG3C,QAAMxE,IAAyC;AAAA,IAC7C,gBAAgB8B,KAAA,gBAAAA,EAAS;AAAA,IACzB,WAAUA,KAAA,gBAAAA,EAAS,aAAYyC;AAAA,IAC/B,YAAY,CAAC,EAACzC,KAAA,QAAAA,EAAS;AAAA,IACvB,SAAQA,KAAA,gBAAAA,EAAS,WAAU;AAAA,EAAA;AAG7B,MAAI,OAAO2C,KAAgB;AACzB,UAAM,IAAI,MAAM,wCAAwCA,CAAW,EAAE;AAEvE,MAAI,CAACA,EAAY,WAAW,GAAG;AAC7B,UAAM,IAAI,MAAM,yBAAyBA,CAAW,EAAE;AAExD,MAAIA,EAAY,SAAS,KAAKA,EAAY,SAAS,GAAG;AACpD,UAAM,IAAI,MAAM,yBAAyBA,CAAW,EAAE;AAUxD,MAAIC;AAMJ,MALID,MAAgB,MAClBC,IAAQ,CAAA,IAERA,IAAQD,EAAY,UAAU,CAAC,EAAE,MAAM,GAAG,GAExCC,EAAM,KAAK,CAACC,MAASA,EAAK,WAAW,CAAC;AACxC,UAAM,IAAI,MAAM,sCAAsCF,CAAW,EAAE;AACrE,MAAI3C,KAAA,QAAAA,EAAS,QAAQ;AAEnB,IAAA4C,EAAM,QAAQ,MAAM;AACpB,UAAME,IAAS,EAAE,MAAMJ,EAAA;AACvB,UAAMK,EAA4BD,GAAQF,GAAO,GAAG1E,CAAc,GAClE8E,GAAoBN,GAAQI,EAAO,IAAI;AAAA,EACzC;AACE,WAAO,MAAMG,EAAsBP,GAAQE,GAAO,GAAG1E,CAAc;AAmBvE;AAGA,eAAe6E,EACbG,GAEAN,GACAO,GACAhE,GACe;AACf,QAAMT,IAAMkE,EAAMO,CAAU;AAI5B,MADA,MAAMC,EAAoBF,GAAMxE,GAAKS,CAAO,GACxCgE,KAAcP,EAAM,SAAS,GAEjC;AAAA,QAAIM,EAAKxE,CAAG,MAAM,QAAQ,OAAOwE,EAAKxE,CAAG,KAAM;AAE7C,YAAM,IAAI;AAAA,QACR,wDAAwDkE,EAAM,MAAM,CAAC,EAAE,KAAK,GAAG,CAAC,YAC9EO,IAAa,CACf;AAAA,MAAA;AAGJ,WAAO,MAAMJ,EAA4BG,EAAKxE,CAAG,GAAGkE,GAAOO,IAAa,GAAGhE,CAAO;AAAA;AACpF;AAEA,eAAeiE,EACbF,GACAxE,GACAS,GACe;AACf,EAAAzB,EAAI,wBAAwBwF,GAAMxE,CAAG;AACrC,MAAI2E,IAAMH,EAAKxE,CAAG;AAClB,QAAML,IAAS,MAAMiF,EAAcD,GAAKlE,CAAO;AAC/C,EAAId,MAAW,WAAW6E,EAAKxE,CAAG,IAAIL;AACxC;AAGA,eAAe4E,EACbP,GACAE,GACAW,GACApE,GACc;AAId,MAAIoE,MAAUX,EAAM;AAElB,WAAO,MAAMU,EAAcZ,GAAQvD,CAAO;AAE5C,MAAIuD,MAAW,QAAQ,OAAOA,KAAW;AACvC,UAAM,IAAI;AAAA,MACR,wDAAwDE,EAAM,KAAK,GAAG,CAAC,YAAYW,CAAK;AAAA,IAAA;AAG5F,QAAMV,IAAOD,EAAMW,CAAK;AACxB,MAAIC,IAAQd,EAAOG,CAAI;AACvB,SAAIW,MAAU,WAGZA,KADuB,MAAMF,EAAcZ,GAAQvD,CAAO,GACnC0D,CAAI,IAEtB,MAAMI,EAAsBO,GAAOZ,GAAOW,IAAQ,GAAGpE,CAAO;AACrE;AAEA,eAAemE,EAAcZ,GAAavD,GAA+C;AACvF,EAAAzB,EAAI,kBAAkBgF,CAAM;AAC5B,MAAIW,IAAMX;AAEV,KAAG;AACD,QAAI,OAAOW,KAAQ,YAAYA,MAAQ,QAAQ,EAAE,UAAUA;AACzD,aAAOA;AAET,UAAMI,IAAiBjB,EAAU,OAAO,CAACkB,MAAMC,EAAWD,GAAGL,EAAI,IAAI,CAAC;AACtE,QAAII,EAAe,WAAW,GAAG;AAC/B,UAAIJ,EAAI;AACN,cAAM,IAAI,MAAM,8BAA8BA,EAAI,IAAI,EAAE;AAE1D,aAAA9E,EAAW8E,CAAG,GACPA;AAAA,IACT;AACA,QAAII,EAAe,SAAS;AAC1B,YAAM,IAAI,MAAM,uCAAuCJ,EAAI,IAAI,EAAE;AAGnE,UAAMpE,IAAO,MAAM2E,EAAgBH,EAAe,CAAC,GAAGJ,EAAI,MAAMlE,CAAO;AAEvE,IAAAkE,IAAMQ,EAA2C5E,GAAMoE,CAAG;AAAA,EAC5D,SAAS;AACX;AAEA,eAAsBO,EACpBE,GACArG,GACA0B,GACc;AACd,MAAI,CAACwE,EAAWG,GAAUrG,CAAG;AAC3B,UAAM,IAAI,MAAM,mBAAmBA,CAAG,EAAE;AAE1C,SAAOqG,EAAS,WAAWrG,GAAK0B,CAAO;AACzC;AAEO,SAASwE,EAAWG,GAAoBrG,GAAsB;AACnE,MAAIqG,EAAS;AACX,WAAOA,EAAS,WAAWrG,CAAG;AAEhC,MAAIqG,EAAS;AACX,WAAOC,EAAoBtG,GAAKqG,EAAS,MAAM;AAEjD,QAAM,IAAI,MAAM,2DAA2D;AAC7E;AAEO,SAASC,EAAoBtG,GAAauG,GAA6B;AAC5E,QAAMC,IAAW,CAAC,GAAGD,CAAU,KAAK,GAAGA,CAAU,GAAG;AACpD,aAAWE,KAAUD;AACnB,QAAIxG,EAAI,WAAWyG,CAAM;AACvB,aAAO;AAGX,SAAO;AACT;AAEO,SAASvG,EAAcF,GAAqB;AAOjD,MAAIA,EAAI,WAAW,SAAS,KAAKA,EAAI,WAAW,UAAU;AACxD,WAAOA;AAGT,QAAM0G,IAAgB1G,EAAI,QAAQ,UAAU,GACtC2G,IAAiB3G,EAAI,QAAQ,WAAW;AAC9C,MAAI0G,MAAkB;AACpB,WAAO1G,EAAI,UAAU0G,IAAgB,CAAC;AAExC,MAAIC,MAAmB;AACrB,WAAO3G,EAAI,UAAU2G,IAAiB,CAAC;AAGzC,QAAMC,IAAa5G,EAAI,QAAQ,GAAG;AAClC,MAAI4G,MAAe;AACjB,WAAO5G,EAAI,UAAU4G,IAAa,CAAC;AAGrC,QAAM,IAAI,MAAM,2BAA2B5G,CAAG,yBAAyB;AACzE;AAwEI,OAAO,SAAW,QACnB,OAAe,iBAAoB,eAClC6G,GACAC,GACApF,GACA;AACA,MAAIuD,GACAjF,GACAS;AACJ,SAAI,OAAOoG,KAAgB,YACzB5B,IAAU,OAAe,qBACzBjF,IAAM6G,GACNpG,IAAiBqG,MAEjB7B,IAAS4B,GACT7G,IAAM8G,GACNrG,IAAiBiB,IAEZ,MAAMqB,EAAQkC,GAAQjF,GAAKS,CAAc;AAClD;AC7VK,SAASsG,EAAerD,GAAc;AAC3C,SAAO,OAAOsD,MAAsBC,MAAuB;AACzD,QAAI;AAGF,YAAMC,KADgB,MAAM,OADF,MAAMnE,EAAQiE,GAAU,gBAAgB,IAE7BtD,CAAI;AACzC,aAAOwD,EAAeF,GAAU,GAAGC,CAAI;AAAA,IACzC,SAASE,GAAO;AACd,oBAAQ,MAAM,cAAc,yCAAyCzD,CAAI,MAAMyD,CAAK,GAC9EA;AAAA,IACR;AAAA,EACF;AACF;AAEO,SAASlH,KAAOgH,GAAa;AAClC,EAAM,WAAmB,wBACzB,QAAQ,MAAM,cAAc,GAAGA,CAAI;AACrC;AAEO,SAASnG,EAAW8E,GAAU;AACnC,MAAIA,MAAQ,QAAQ,OAAOA,KAAQ,SAAU,QAAOA;AAEpD,SAAO,OAAOA,CAAG;AAEjB,aAAW3E,KAAO,OAAO,KAAK2E,CAAG,GAAG;AAClC,UAAMwB,IAAMxB,EAAI3E,CAAG;AACnB,IAAI,OAAOmG,KAAQ,YAAYA,MAAQ,QAAQ,CAAC,OAAO,SAASA,CAAG,KACjEtG,EAAWsG,CAAG;AAAA,EAElB;AAEA,SAAOxB;AACT;AAEO,SAASyB,EAAazB,GAAW;AACtC,SAAI,qBAAqB,aACf,WAAmB,gBAAgBA,CAAG,IAEzC,KAAK,MAAM,KAAK,UAAUA,CAAG,CAAC;AACvC;AAaO,SAAS0B,EAAc9G,GAAa;AACzC,MAAI,OAAO,WAAa,IAAa;AAErC,QAAMkE,IAAO,SAAS,cAAc,MAAM;AAC1C,EAAAA,EAAK,MAAM,cACXA,EAAK,OAAOlE,GACZkE,EAAK,cAAc,aACnB,SAAS,KAAK,YAAYA,CAAI;AAChC;AAkLO,SAAS0B,EAA2Cf,GAAakC,GAAa;AACnF,MAAIlC,MAAWkC,EAAQ;AAEvB,MAAIA,MAAW,QAAQ,OAAOA,KAAW;AACvC,UAAM,IAAI,MAAM,gCAAgC;AAClD,MAAI,MAAM,QAAQA,CAAM;AACtB,UAAM,IAAI,MAAM,qBAAqB;AAEvC,QAAMC,IAAa,OAAO,KAAKD,CAAM,EAAE,OAAO,CAACtG,MAAQA,MAAQ,MAAM;AACrE,MAAIuG,EAAW,WAAW,EAAG,QAAOH,EAAUhC,CAAM;AAGpD,MAAI,MAAM,QAAQA,CAAM;AACtB,UAAM,IAAI,MAAM,0BAA0B;AAG5C,MAAIA,MAAW,QAAQ,OAAOA,KAAW;AACvC,UAAM,IAAI,MAAM,qCAAqC;AAGvD,QAAMzE,IAASyG,EAAU,EAAE,GAAGhC,GAAQ;AACtC,aAAWpE,KAAOuG;AAChB,IAAA5G,EAAOK,CAAG,IAAIsG,EAAOtG,CAAG;AAG1B,SAAOL;AACT;AAEO,SAAS2E,GAAoBF,GAAakC,GAAmB;AAClE,MAAIlC,MAAWkC,GAKf;AAAA,QAAIA,MAAW,QAAQ,OAAOA,KAAW;AACvC,YAAM,IAAI,MAAM,uCAAuC;AAGzD,QAAIlC,MAAW,QAAQ,OAAOA,KAAW;AACvC,YAAM,IAAI,MAAM,kCAAkC;AAGpD,QAAI,MAAM,QAAQA,CAAM,GAAG;AACzB,UAAI,CAAC,MAAM,QAAQkC,CAAM;AACvB,cAAM,IAAI,MAAM,gEAAgE;AAGlF,MAAAlC,EAAO,SAAS;AAChB,iBAAWoC,KAAQF;AACjB,QAAAlC,EAAO,KAAKoC,CAAI;AAElB;AAAA,IACF;AAGA,eAAWxG,KAAO,OAAO,KAAKoE,CAAM;AAClC,MAAMpE,KAAOsG,KACX,OAAOlC,EAAOpE,CAAG;AAKrB,eAAWA,KAAO,OAAO,KAAKsG,CAAM;AAClC,MAAAlC,EAAOpE,CAAG,IAAIsG,EAAOtG,CAAG;AAAA;AAE5B;ACjTA,eAAsByG,GACpBV,GACAW,GACAlH,GACe;AACf,EAAAA,IAAiBA,KAAkB,CAAA;AAEnC,aAAWmH,KAAQD;AACjB,UAAM5E,EAAQiE,GAAUY,GAAM,EAAE,GAAGnH,GAAgB,QAAQ,IAAM;AAErE;AAEI,OAAO,SAAW,QACnB,OAAe,wBAA2BiH;AChB7C,eAAsBG,GAAkBb,GAAmB;AACzD,QAAM,EAAE,mBAAAa,MAAsB,MAAM,OAAO,iCAAqB;AAChE,SAAO,MAAMA,EAAkBb,CAAQ;AACzC;AAEA,eAAsBc,GAAYd,GAAmB;AACnD,QAAM,EAAE,aAAAc,MAAgB,MAAM,OAAO,2BAAe;AACpD,SAAO,MAAMA,EAAYd,CAAQ;AACnC;AAEA,eAAee,GAA6Bf,GAAkC;AAE5E,QAAM,EAAE,aAAAgB,EAAA,IAAgB,MAAM,OAAO,2BAAe,GAC9CpH,IAAS,MAAMoH,EAAYhB,CAAQ;AAEzC,mBAAiBnF,MAAS,MAAMjB,GAAQ;AACtC,IAAI,UAAUiB,IACZ,QAAQ,KAAK,WAAWA,EAAK,cAAc,OAAOA,EAAK,IAAI,IAClD,SAASA,KAClB,QAAQ,KAAK,gBAAgBA,EAAK,cAAc,OAAOA,EAAK,GAAG,EAAE;AAIrE,UAAQ,KAAK,kBAAkBjB,EAAO,QAAQ;AAChD;AAEI,OAAO,SAAW,QACnB,OAAe,qBAAwBkH,IACvC,OAAe,2BAA8BD,IAC7C,OAAe,iCAAoCE;AC3B/C,MAAME,KAAQlB,EAAe,OAAO,GAC9BmB,KAAOnB,EAAe,MAAM,GAC5BoB,KAAapB,EAAe,YAAY;AAMrD,eAAsBqB,GACpB1E,GACAsD,MACGC,GACH;AAEA,SAAO,MADIF,EAAerD,CAAI,EACdsD,GAAU,GAAGC,CAAI;AACnC;AAOAK,EAAc,iCAAiC;"}
1
+ {"version":3,"file":"index.js","sources":["../src/resolvers/assetResolver.ts","../src/importJson.ts","../src/returnCachedRef.ts","../src/resolvers/bundleAssetsResolver.ts","../src/resolvers/expoRuntimeBranchResolver.ts","../src/resolvers/expoRuntimeGetBranchResolver.ts","../src/resolvers/expoRuntimeResolver.ts","../src/resolvers/httpResolver.ts","../src/loadAndWaitGlobal.ts","../src/resolvers/legacyAssetUrlsResolver.ts","../src/resolvers/legacyDataResolver.ts","../src/resolvers/index.ts","../src/resolve.ts","../src/shared.ts","../src/mutateManifest.ts","../src/offline/index.ts","../src/index.ts"],"sourcesContent":["import { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport function resolveAssetRefSync(ref: string): string {\n log('assetResolver resolveRef:', ref);\n // if (!assetResolver.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n return parseRefValue(ref);\n}\n\nexport const assetResolver = {\n schema: 'asset',\n resolveRef: async (ref: string) => resolveAssetRefSync(ref),\n offlineMethod: 'localizeRef',\n} satisfies Resolver;\n\n// async *makeOfflineRef(ref: string) {\n// log('assetResolver makeOfflineRef:', ref);\n// if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return { $ref: `asset:${targetFilePath}`, [STOP_RESOLVING]: true };\n// },\n// async *makeOfflineRef2(ref: string) {\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return `asset:${targetFilePath}`;\n// },\n","import type { ResolveContextInternal } from './resolve';\nimport { deepFreeze, log } from './shared';\n\nlet importJsonNotAvailable: boolean | undefined;\nconst jsonFrozen = new WeakSet<any>();\n\n// ET: this is a workaround for Vite that analyzes dynamic imports and removes 'with' option\n// to be removed when Vite supports it properly\n// Cons: can have CSP issues in some environments\nconst importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n url: string\n) => Promise<any>;\n\nexport async function importJson(\n url: string,\n resolveContext: ResolveContextInternal\n): Promise<any> {\n // console.warn('importJson:', resolveContext.forceFetch);\n if (importJsonNotAvailable === undefined && !resolveContext.forceFetch) {\n try {\n await importJsonNative(url);\n importJsonNotAvailable = false;\n } catch {\n log('importJson: dynamic import not available, falling back to fetch');\n importJsonNotAvailable = true;\n }\n }\n let result: any = undefined;\n if (!importJsonNotAvailable && !resolveContext.forceFetch) {\n const module = await importJsonNative(url);\n result = module.default;\n resolveContext.importCallback?.(url, 'json');\n } else {\n log('importJson: fetch', url);\n result = await loadJson(url, resolveContext.refCache, resolveContext.signal || null);\n resolveContext.importCallback?.(url, 'json');\n }\n if (!jsonFrozen.has(result)) {\n deepFreeze(result);\n // jsonFrozen.add(result);\n }\n return result;\n}\n\n// const fetchCache = new Map<string, Promise<any>>();\n\nasync function loadJson(\n url: string,\n fetchCache: Map<string, Promise<any>>,\n signal: AbortSignal | null\n): Promise<any> {\n const key = '__loadJson__' + url;\n if (fetchCache.has(key)) {\n return fetchCache.get(key)!;\n }\n\n const dataPromise = (async function loadJsonInner() {\n const response = await fetch(url, { signal });\n if (!response.ok) {\n throw new Error(`Failed to fetch JSON from ${url}`);\n }\n return await response.json();\n })();\n\n fetchCache.set(key, dataPromise);\n return dataPromise;\n}\n","import { deepFreeze } from './shared';\n\nexport async function returnCachedRef(\n ref: string,\n refCache: Map<string, Promise<any>>,\n factory: () => Promise<any>\n) {\n if (refCache.has(ref)) {\n return refCache.get(ref);\n }\n const promise = factory().then((data) => {\n deepFreeze(data);\n return data;\n });\n refCache.set(ref, promise);\n return promise;\n}\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const bundleAssetsResolver: Resolver = {\n schema: 'bundle-assets',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('bundleAssetsResolver resolveRef:', ref);\n\n const url = parseRefValue(ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const files = await importJson(url, context);\n const baseUrl = url.substring(0, url.lastIndexOf('/') + 1);\n\n const assets = files.map((file: string) => ({\n $ref: `asset+${baseUrl}${file}`,\n }));\n return assets;\n });\n },\n offlineMethod: 'localizeRef',\n};\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nconst BASE_URL = 'https://efp-runtime.expofp.com/';\n\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n\n const branch = parseRefValue(ref);\n const branchUrl = `${BASE_URL}branches/${branch}.json`;\n\n return returnCachedRef(ref, context.refCache, async () => {\n const release = await importJson(branchUrl, context);\n return {\n $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n };\n });\n },\n\n offlineMethod: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n async resolveRef(ref, context) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n\n const expo = parseRefValue(ref);\n const url = `https://${expo}.expofp.com/get-branch`;\n return importJson(url, context);\n },\n offlineMethod: 'resolveRef',\n};\n","import { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime';\n\nexport const expoRuntimeResolver: Resolver = {\n schema: 'expo-runtime',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n const url = parseRefValue(ref);\n const data = {\n entry: { $ref: `asset+${url}expofp.js` },\n assets: { $ref: `bundle-assets+${url}bundle.json` },\n };\n deepFreeze(data);\n return data;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const url = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(url, SCHEMA_PREFIX_BASE);\n // const data = yield* makeOfflineInternal(refData);\n // yield { data: data, targetFilePath };\n // return { $ref: targetFilePath, [STOP_RESOLVING]: true };\n // },\n // async *makeOfflineRef2(ref: string) {\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(ref);\n // const data = yield* makeOfflineInternal(refData);\n // yield { data, targetFilePath };\n // return targetFilePath;\n // },\n offlineMethod: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { log } from '../shared';\nimport { type Resolver } from '../types';\n\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n resolveRef(ref, context) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n\n return importJson(ref, context);\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n","//import { log } from './shared';\n\nexport interface LoadAndWaitOptions {\n /** Name of the global variable to wait for */\n globalVar?: string;\n /** How long to wait for the global (ms) */\n timeoutMs?: number;\n /** Poll interval (ms) */\n pollIntervalMs?: number;\n signal: AbortSignal | null;\n}\n\n/**\n * Load a script from `scriptUrl` and optionally wait until `globalVar` appears.\n * Works in both browser (via <script>) and Node 18+ (via fetch + eval).\n */\nexport async function loadAndWaitGlobal(\n scriptUrl: string,\n options: LoadAndWaitOptions\n): Promise<void> {\n const { globalVar, timeoutMs = 10_000, pollIntervalMs = 10 } = options;\n\n if (isBrowser()) {\n await loadInBrowser(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (window as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n } else {\n await loadInNode(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (globalThis as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n }\n}\n\nfunction isBrowser(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/* -------------------- Browser implementation -------------------- */\n\nexport function loadInBrowser(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n return new Promise((resolve, reject) => {\n const script = document.createElement('script');\n script.src = scriptUrl;\n script.async = true;\n\n const cleanup = () => {\n script.onload = null;\n script.onerror = null;\n script.remove();\n };\n\n const onAbort = () => {\n cleanup();\n reject(new Error('Script load aborted'));\n };\n\n if (signal?.aborted) {\n cleanup();\n reject(new Error('Script load aborted'));\n return;\n }\n\n signal?.addEventListener('abort', onAbort, { once: true });\n\n script.onload = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n resolve();\n };\n\n script.onerror = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n reject(new Error(`Failed to load script: ${scriptUrl}`));\n };\n\n document.head.appendChild(script);\n });\n}\n\n/* -------------------- Node implementation -------------------- */\n\nasync function loadInNode(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n if (typeof fetch !== 'function') {\n throw new Error('loadInNode: fetch is not available. Use Node 18+ or provide a global fetch.');\n }\n\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let res: Response;\n\n try {\n res = await fetch(scriptUrl, { signal });\n } catch (err: any) {\n // Node / WHATWG fetch uses AbortError on abort\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (!res.ok) {\n throw new Error(`Failed to load script in Node (HTTP ${res.status}): ${scriptUrl}`);\n }\n\n // If it was aborted between headers and body:\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let code: string;\n try {\n code = await res.text();\n } catch (err: any) {\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n // TEMPORARILY expose window for browser-style UMDs that expect it\n const g = globalThis as any;\n const prevWindow = g.window;\n\n g.window = g;\n\n try {\n // Indirect eval -> global scope in Node\n // Assumes the loaded script attaches itself to globalThis/window/global.\n (0, eval)(code);\n } finally {\n // Restore previous window (if any)\n if (prevWindow === undefined) {\n delete g.window;\n } else {\n g.window = prevWindow;\n }\n }\n}\n\n/* -------------------- Shared helper -------------------- */\n\nfunction waitForGlobal(\n getter: () => any,\n name: string,\n timeoutMs: number,\n pollIntervalMs: number,\n abortSignal: AbortSignal | null\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const start = Date.now();\n\n const onAbort = () => {\n reject(new Error('Wait for global aborted'));\n };\n\n if (abortSignal?.aborted) {\n reject(new Error('Wait for global aborted'));\n return;\n }\n\n abortSignal?.addEventListener('abort', onAbort, { once: true });\n\n const check = () => {\n if (abortSignal?.aborted) {\n return reject(new Error('Wait for global aborted'));\n }\n\n try {\n if (getter() !== undefined) {\n abortSignal?.removeEventListener('abort', onAbort);\n // log(`loadAndWaitGlobal: global \"${name}\" is now available`);\n return resolve();\n }\n } catch {\n // ignore access errors and keep polling\n }\n\n if (Date.now() - start >= timeoutMs) {\n abortSignal?.removeEventListener('abort', onAbort);\n // console.error(`loadAndWaitGlobal: timed out waiting for global \"${name}\"`);\n return reject(new Error(`Timed out after ${timeoutMs} ms waiting for global \"${name}\"`));\n }\n\n setTimeout(check, pollIntervalMs);\n };\n\n check();\n });\n}\n","import { importJson } from '../importJson';\nimport { loadAndWaitGlobal } from '../loadAndWaitGlobal';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyAssetUrlsResolver = {\n schema: 'legacy-asset-urls',\n resolveRef(ref: string, context: ResolveContextInternal) {\n log('legacyAssetUrlsResolver resolveRef:', ref);\n const signal = context.signal;\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n // load version.js - it will contain \"window.__fpDataVersion = \"20251129003330106\";\"\n const versionUrl = `${dataUrlBase}version.js`;\n try {\n await loadAndWaitGlobal(versionUrl, {\n globalVar: '__fpDataVersion',\n timeoutMs: 30_000,\n signal,\n });\n context.importCallback?.(versionUrl, 'script');\n } catch {\n console.warn(`Could not load version.js at ${versionUrl}, proceeding without it`);\n }\n const version = (globalThis as any).__fpDataVersion || (+new Date()).toString();\n\n const filesUrl = `${dataUrlBase}files.json?v=${version}`;\n const dataUrl = `${dataUrlBase}data.js?v=${version}`;\n const filesPromise = importJson(filesUrl, context);\n\n // data.js\n const dataLoadPromise = loadAndWaitGlobal(dataUrl, {\n globalVar: '__data',\n signal,\n });\n context.importCallback?.(dataUrl, 'script');\n\n // wf.data.js\n const wfDataUrl = `${dataUrlBase}wf.data.js?v=${version}`;\n const wfDataLoadPromise = loadAndWaitGlobal(wfDataUrl, {\n globalVar: '__wfData',\n signal,\n })\n .then(() => {\n context.importCallback?.(wfDataUrl, 'script');\n })\n .catch(() => {\n console.warn(`Could not load wf.data.js at ${wfDataUrl}, proceeding without it`);\n });\n\n // fp.svg.js\n const fpSvgUrl = `${dataUrlBase}fp.svg.js?v=${version}`;\n const fpSvgLoadPromise = loadAndWaitGlobal(fpSvgUrl, {\n globalVar: '__fp',\n signal,\n });\n context.importCallback?.(fpSvgUrl, 'script');\n\n await Promise.all([filesPromise, dataLoadPromise, wfDataLoadPromise, fpSvgLoadPromise]);\n\n const __fpLayers = (globalThis as any).__fpLayers as Array<{ name: string }>;\n const fpLayerFiles = __fpLayers.map((x) => `fp.svg.${x.name}.js`);\n\n const files = await filesPromise;\n\n const data = (globalThis as any).__data || {};\n const dataFiles = [...files, 'data.js', 'wf.data.js', 'fp.svg.js', ...fpLayerFiles];\n const dataFilesAssets = dataFiles.reduce((map, file) => {\n map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n\n return { ...dataFilesAssets, ...populateDataJsAssetsMap(dataUrlBase, data) };\n });\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n\nfunction populateDataJsAssetsMap(dataUrlBase: string, data: any) {\n const links = new Set<string>();\n function addLink(link: string) {\n if (typeof link === 'string' && link.length > 0) {\n // if (!link.startsWith('http://') && !link.startsWith('https://')) {\n // link = dataUrlBase + link;\n // }\n links.add(link);\n }\n }\n\n addLink(data.logo);\n data.exhibitors.forEach((e: any) => {\n addLink(e.logo);\n e.gallery?.forEach((img: string) => addLink(img));\n });\n\n data.events.forEach((e: any) => {\n addLink(e.logoFile);\n e.speakers?.forEach((s: any) => {\n addLink(s.photoFile);\n });\n });\n\n return Array.from(links).reduce((map, link) => {\n map[link] = { $ref: `asset+${dataUrlBase}${link}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n}\n","import { parseRefValue } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n resolveRef(ref: string, context) {\n log('legacyDataResolver resolveRef:', ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n\n return {\n _to_remove_for_offline_to_work_dataUrlBase: dataUrlBase,\n legacyAssetUrls: { $ref: `legacy-asset-urls+${dataUrlBase}` },\n };\n });\n },\n offlineMethod: 'resolveRef',\n} satisfies Resolver;\n","import type { Resolver } from '../types';\nimport { assetResolver } from './assetResolver';\nimport { bundleAssetsResolver } from './bundleAssetsResolver';\nimport { expoRuntimeBranchResolver } from './expoRuntimeBranchResolver';\nimport { expoRuntimeGetBranchResolver } from './expoRuntimeGetBranchResolver';\nimport { expoRuntimeResolver } from './expoRuntimeResolver';\nimport { httpResolver } from './httpResolver';\nimport { legacyAssetUrlsResolver } from './legacyAssetUrlsResolver';\nimport { legacyDataResolver } from './legacyDataResolver';\n\nexport const resolvers: Resolver[] = [\n httpResolver,\n bundleAssetsResolver,\n assetResolver,\n expoRuntimeResolver,\n expoRuntimeBranchResolver,\n expoRuntimeGetBranchResolver,\n legacyDataResolver,\n legacyAssetUrlsResolver,\n];\n","import { resolvers } from './resolvers';\nimport {\n createMergedObjectWithOverridenNonRefProps,\n deepFreeze,\n log,\n replaceObjectFields,\n} from './shared';\nimport type { Resolver } from './types';\n\nconst globalRefCache = new Map<string, Promise<any>>();\n\nexport interface ResolveContextInternal {\n forceFetch: boolean;\n refCache: Map<string, Promise<any>>;\n /**\n * Callback invoked when a URL is fetched or imported.\n */\n importCallback?: (url: string, type: 'json' | 'script') => void;\n signal: AbortSignal | null;\n}\n\nexport interface ResolveOptions extends Partial<ResolveContextInternal> {\n /**\n * Mutate original object during resolution.\n */\n mutate?: boolean;\n signal?: AbortSignal;\n}\n\n/**\n * Resolves a value from an object using a JSON Pointer RFC 6901.\n *\n * @param object - The object to resolve the value from\n * @param jsonPointer - A JSON Pointer string that must start with '/'\n * @param options - Optional context for resolution, including cache and fetch callback\n * @returns A promise that resolves to the value at the specified JSON Pointer path\n * @throws {Error} If the JSON Pointer is not valid or if a $ref cannot be resolved\n *\n * @example\n * ```typescript\n * const obj = { foo: { bar: 'baz' } };\n * const result = await resolve(obj, '/foo/bar');\n * // result === 'baz'\n * ```\n */\nexport async function resolve(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n): Promise<any> {\n log('Resolving:', jsonPointer, 'of', object, options);\n if (typeof window !== 'undefined') {\n (window as any)['__lastResolveObject'] = object;\n }\n\n const resolveContext: ResolveContextInternal = {\n importCallback: options?.importCallback,\n refCache: options?.refCache || globalRefCache,\n forceFetch: !!options?.forceFetch,\n signal: options?.signal || null,\n };\n\n if (typeof jsonPointer !== 'string') {\n throw new Error(`Invalid JSON Pointer (not a string): ${jsonPointer}`);\n }\n if (!jsonPointer.startsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n if (jsonPointer.length > 1 && jsonPointer.endsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n // if (jsonPointer === '/') {\n // const result = await resolveObject(object, resolveContext);\n // if (options?.mutate) {\n // replaceObjectFields(object, result);\n // }\n // return result;\n // }\n\n let parts: string[];\n if (jsonPointer === '/') {\n parts = [];\n } else {\n parts = jsonPointer.substring(1).split('/');\n }\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n if (options?.mutate) {\n // prepend parts with 'root'\n parts.unshift('root');\n const target = { root: object };\n await resovlePartsRecursiveMutate(target, parts, 0, resolveContext);\n replaceObjectFields(object, target.root);\n } else {\n return await resovlePartsRecursive(object, parts, 0, resolveContext);\n }\n // prepend parts with 'root'\n // parts.unshift('root');\n // // if (parts.some((part) => part.length === 0))\n // // throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n // const target = { root: object };\n // const value = await resovlePartsRecursiveMutate(\n // target,\n // // 'root',\n // parts,\n // 0,\n // resolveContext\n // );\n // if (options?.mutate) {\n // replaceObjectFields(object, target.root);\n // }\n // log(`Resolved ${jsonPointer}:`, value);\n // return value;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursiveMutate(\n node: any,\n // key: string,\n parts: string[],\n partsIndex: number,\n context: ResolveContextInternal\n): Promise<void> {\n const key = parts[partsIndex];\n // console.warn('in', key);\n\n await resolveObjectMutate(node, key, context);\n if (partsIndex == parts.length - 1) return;\n\n if (node[key] === null || typeof node[key] !== 'object') {\n // console.error('Cannot resolve path, encountered non-object:', node, key);\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.slice(1).join('/')}', index ${\n partsIndex - 1\n }'`\n );\n }\n return await resovlePartsRecursiveMutate(node[key], parts, partsIndex + 1, context);\n}\n\nasync function resolveObjectMutate(\n node: any,\n key: string,\n context: ResolveContextInternal\n): Promise<void> {\n log('resolveObjectMutate:', node, key);\n let obj = node[key];\n const result = await resolveObject(obj, context);\n if (result !== undefined) node[key] = result;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursive(\n object: any,\n parts: string[],\n index: number,\n context: ResolveContextInternal\n): Promise<any> {\n // should return undefined if last part not found\n // if not last part found - throw error\n // do not resolve object if its children are not needed (needed part exist as key)\n if (index === parts.length) {\n // console.warn('Resolving last part:', object);\n return await resolveObject(object, context);\n }\n if (object === null || typeof object !== 'object') {\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n );\n }\n const part = parts[index];\n let child = object[part];\n if (child === undefined) {\n // console.warn('Resolving, part not found during resolve:', part, object);\n const resolvedObject = await resolveObject(object, context);\n child = resolvedObject[part];\n }\n return await resovlePartsRecursive(child, parts, index + 1, context);\n}\n\nasync function resolveObject(object: any, context: ResolveContextInternal): Promise<any> {\n log('resolveObject:', object);\n let obj = object;\n\n do {\n if (typeof obj !== 'object' || obj === null || !('$ref' in obj)) {\n return obj;\n }\n const resolversToUse = resolvers.filter((r) => canResolve(r, obj.$ref));\n if (resolversToUse.length === 0) {\n if (obj.$ref) {\n throw new Error(`No resolver found for ref: ${obj.$ref}`);\n }\n deepFreeze(obj);\n return obj;\n }\n if (resolversToUse.length > 1) {\n throw new Error(`Multiple resolvers can resolve ref: ${obj.$ref}`);\n }\n\n const data = await resolverResolve(resolversToUse[0], obj.$ref, context);\n\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(\n resolver: Resolver,\n ref: string,\n context: ResolveContextInternal\n): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref, context);\n}\n\nexport function canResolve(resolver: Resolver, ref: string): boolean {\n if (resolver.canResolve) {\n return resolver.canResolve(ref);\n }\n if (resolver.schema) {\n return canResolveRefSchema(ref, resolver.schema);\n }\n throw new Error('Resolver is missing canResolve method and schema property');\n}\n\nexport function canResolveRefSchema(ref: string, prefixBase: string): boolean {\n const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n for (const prefix of prefixes) {\n if (ref.startsWith(prefix)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseRefValue(ref: string): string {\n // look for anything before \":\" or before +https:// or before +http://\n // https://www -> https://www\n // so some+base+https://www -> https://www\n // base+https://www -> https://www\n // base:abc -> abc\n // \"some-base\" can contain only non-:\n if (ref.startsWith('http://') || ref.startsWith('https://')) {\n return ref;\n }\n // if it is something+http:// or something+https://\n const plusHttpIndex = ref.indexOf('+http://');\n const plusHttpsIndex = ref.indexOf('+https://');\n if (plusHttpIndex !== -1) {\n return ref.substring(plusHttpIndex + 1);\n }\n if (plusHttpsIndex !== -1) {\n return ref.substring(plusHttpsIndex + 1);\n }\n // if it is something:abc\n const colonIndex = ref.indexOf(':');\n if (colonIndex !== -1) {\n return ref.substring(colonIndex + 1);\n }\n\n throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n}\n\n// export function parseRefValue(ref: string): string {\n// // look for anything before \":\" or before +https:// or before +http://\n// // https://www -> https://www\n// // so some+base+https://www -> https://www\n// // base+https://www -> https://www\n// // base:abc -> abc\n// // \"some-base\" can contain only non-:\n// if (ref.startsWith('http://') || ref.startsWith('https://')) {\n// return ref;\n// }\n// // if it is something+http:// or something+https://\n// const plusHttpIndex = ref.indexOf('+http://');\n// const plusHttpsIndex = ref.indexOf('+https://');\n// if (plusHttpIndex !== -1) {\n// return ref.substring(plusHttpIndex + 1);\n// }\n// if (plusHttpsIndex !== -1) {\n// return ref.substring(plusHttpsIndex + 1);\n// }\n// // if it is something:abc\n// const colonIndex = ref.indexOf(':');\n// if (colonIndex !== -1) {\n// return ref.substring(colonIndex + 1);\n// }\n\n// throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n\n// // const prefixBase = ref.split('+')[0].split(':')[0];\n// // if (!prefixBase) {\n// // throw new Error(`Invalid ref, missing prefix: ${ref}`);\n// // }\n// // return ref.substring(prefixBase.length + 1);\n\n// // const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// // for (const prefix of prefixes) {\n// // if (ref.startsWith(prefix)) {\n// // const url = ref.substring(prefix.length);\n// // if (!url) {\n// // throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// // }\n// // return url;\n// // }\n// // }\n\n// // throw new Error(\n// // `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// // );\n// }\n\n// export function parseRefValue(ref: string, prefixBase: string): string {\n// const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// for (const prefix of prefixes) {\n// if (ref.startsWith(prefix)) {\n// const url = ref.substring(prefix.length);\n// if (!url) {\n// throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// }\n// return url;\n// }\n// }\n\n// throw new Error(\n// `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// );\n// }\n\n// const importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n// url: string\n// ) => Promise<any>;\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = async function debugResolve(\n objectOrRef: any,\n refOrContext: any,\n context?: any\n ) {\n let object: any;\n let ref: string;\n let resolveContext: ResolveOptions | undefined;\n if (typeof objectOrRef === 'string') {\n object = (window as any)['__lastResolveObject'];\n ref = objectOrRef;\n resolveContext = refOrContext;\n } else {\n object = objectOrRef;\n ref = refOrContext;\n resolveContext = context;\n }\n return await resolve(object, ref, resolveContext);\n };\n\n // (window as any)['__dd'] = async function dd() {\n // const url = 'https://demo.expofp.com/manifest.json';\n // // const imp = import;\n // const zz = (await importJsonNative(url)).default;\n // console.warn('debugResolve demo manifest:', zz);\n // // let object: any;\n // // let ref: string;\n // // let resolveContext: ResolveOptions | undefined;\n // // if (typeof objectOrRef === 'string') {\n // // object = (window as any)['__lastResolveObject'];\n // // ref = objectOrRef;\n // // resolveContext = refOrContext;\n // // } else {\n // // object = objectOrRef;\n // // ref = refOrContext;\n // // resolveContext = context;\n // // }\n // // return await resolve(object, ref, resolveContext);\n // };\n}\n\n// if (index === parts.length - 1) {\n// return await resolveObject(object, context);\n// }\n// if (object === null || typeof object !== 'object') {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n// );\n// }\n// if (!(parts[0] in object)) {\n// return undefined;\n// }\n// let partIndex = 0;\n// let currentObject = await resolveObject(object, context);\n// while (partIndex < parts.length) {\n// const part = parts[partIndex];\n// if (typeof currentObject !== 'object' || currentObject === null) {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join(\n// '/'\n// )}, index ${partIndex}'`\n// );\n// }\n// // console.info(\n// // 'resolvePath currentObject:',\n// // part,\n// // JSON.stringify(currentObject, null, 2),\n// // currentObject[part]\n// // );\n// // debugger;\n// const child = currentObject[part];\n// currentObject = await resolveObject(child, context);\n// partIndex++;\n// }\n// return currentObject;\n","import { resolve } from './resolve';\n\n// export const NOT_APPLICABLE = Symbol('not-applicable');\n// export const STOP_RESOLVING = Symbol('STOP_RESOLVING');\n\nexport function createFunction(name: string) {\n return async (manifest: unknown, ...args: IArguments[]) => {\n try {\n const runtimeEntryPoint = await resolve(manifest, '/runtime/entry');\n const moduleExports = await import(/* @vite-ignore */ runtimeEntryPoint);\n const functionToCall = moduleExports[name];\n return functionToCall(manifest, ...args);\n } catch (error) {\n console.error('efp-loader', `Error when trying to import and call \"${name}\":`, error);\n throw error;\n }\n };\n}\n\nexport function log(...args: any[]) {\n if (!(globalThis as any).__EFP_LOADER_DEBUG__ && !import.meta.env.DEV) return;\n console.debug('efp-loader', ...args);\n}\n\nexport function deepFreeze(obj: any) {\n if (obj === null || typeof obj !== 'object') return obj;\n\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const val = obj[key];\n if (typeof val === 'object' && val !== null && !Object.isFrozen(val)) {\n deepFreeze(val);\n }\n }\n\n return obj;\n}\n\nexport function deepClone<T>(obj: T): T {\n if ('structuredClone' in globalThis) {\n return (globalThis as any).structuredClone(obj);\n }\n return JSON.parse(JSON.stringify(obj));\n}\n\nexport function preloadJson(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preload';\n link.as = 'fetch';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n\nexport function preconnectUrl(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preconnect';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n// export function hashString(str: string): string {\n// let hash = 0;\n\n// for (let i = 0; i < str.length; i++) {\n// const chr = str.charCodeAt(i);\n// hash = (hash << 5) - hash + chr;\n// hash |= 0; // force 32-bit int\n// }\n\n// // >>> 0 makes it unsigned (no '-' in front)\n// return (hash >>> 0).toString(16); // hex, [0-9a-f]\n// }\n\n// Deterministic ID\n// export async function hashString(str: string): Promise<string> {\n// const encoder = new TextEncoder();\n// const data = encoder.encode(str);\n\n// const digest = await crypto.subtle.digest('SHA-1', data);\n// return bufferToHex(digest);\n// }\n\n// murmur32\n// export function hashString(str: string): string {\n// let h = 0x811c9dc5;\n\n// for (let i = 0; i < str.length; i++) {\n// h ^= str.charCodeAt(i);\n// h = Math.imul(h, 0x01000193);\n// }\n\n// return (h >>> 0).toString(16).padStart(24, '0');\n// }\n\n// function bufferToHex(buffer: ArrayBuffer): string {\n// const bytes = new Uint8Array(buffer);\n// let hex = '';\n// for (let i = 0; i < bytes.length; i++) {\n// const byteHex = bytes[i].toString(16).padStart(2, '0');\n// hex += byteHex;\n// }\n// return hex;\n// }\n\n// export function mergeNonRefFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonRefFields does not support merging arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonRefFields does not support merging into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function mergeNonExitingFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonExitingFields does not support merging arrays');\n// }\n\n// const keys = Object.keys(source);\n// if (keys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonExitingFields does not support merging into arrays');\n// }\n\n// for (const key of Object.keys(source)) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// if (!(key in target)) {\n// target[key] = source[key];\n// }\n// }\n// }\n\n// export function replaceObjectFields(target: any, source: any) {\n// if (target === source) {\n// throw new Error('Cannot replace object with itself');\n// }\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object') {\n// throw new Error('Cannot replace with non-object source');\n// }\n// // throw if any is array\n// if (Array.isArray(target) || Array.isArray(source)) {\n// throw new Error('replaceObjectFields does not support arrays');\n// }\n\n// // delete keys in target that are not in source\n// for (const key of Object.keys(target)) {\n// if (!(key in source)) {\n// delete target[key];\n// }\n// }\n\n// // copy keys from source to target\n// for (const key of Object.keys(source)) {\n// target[key] = source[key];\n// }\n// }\n\n// export function isObject(v: any): boolean {\n// return v !== null && typeof v === 'object' && !Array.isArray(v);\n// }\n\n// export function mergeOriginalFieldsIntoResolvedObject(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function createMergedObject(target: any, source: any) {\n// if (target === source) return; //throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return target;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// if (target === null || typeof target !== 'object') {\n// throw new Error('Cannot merge into non-object target');\n// }\n\n// const result = { ...target };\n// for (const key of nonRefKeys) {\n// result[key] = source[key];\n// }\n// deepFreeze(result);\n// return result;\n// }\n\nexport function createMergedObjectWithOverridenNonRefProps(target: any, source: any) {\n if (target === source) return; //throw new Error('Cannot merge object with itself');\n // if source is primitive, throw\n if (source === null || typeof source !== 'object')\n throw new Error('Cannot merge non-object source');\n if (Array.isArray(source)) {\n throw new Error('Cannot merge arrays');\n }\n const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n if (nonRefKeys.length === 0) return deepClone(target);\n\n // throw if any is array\n if (Array.isArray(target)) {\n throw new Error('Cannot merge into arrays');\n }\n\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot merge into non-object target');\n }\n\n const result = deepClone({ ...target });\n for (const key of nonRefKeys) {\n result[key] = source[key];\n }\n // deepFreeze(result);\n return result;\n}\n\nexport function replaceObjectFields(target: any, source: any): void {\n if (target === source) {\n return;\n // throw new Error('Cannot replace object with itself');\n }\n // if source is primitive, throw\n if (source === null || typeof source !== 'object') {\n throw new Error('Cannot replace with non-object source');\n }\n // if target is primitive, throw\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot replace non-object target');\n }\n\n if (Array.isArray(target)) {\n if (!Array.isArray(source)) {\n throw new Error('replaceObjectFields does not support mixing arrays and objects');\n }\n // both are arrays - replace contents\n target.length = 0;\n for (const item of source) {\n target.push(item);\n }\n return;\n }\n\n // delete keys in target that are not in source\n for (const key of Object.keys(target)) {\n if (!(key in source)) {\n delete target[key];\n }\n }\n\n // copy keys from source to target\n for (const key of Object.keys(source)) {\n target[key] = source[key];\n }\n}\n","import { resolve } from './resolve';\nimport type { ResolveOptions } from './resolve';\n\nexport async function mutateManifest(\n manifest: any,\n paths: string[],\n resolveContext?: Omit<ResolveOptions, 'mutate'>\n): Promise<void> {\n resolveContext = resolveContext || {};\n\n for (const path of paths) {\n await resolve(manifest, path, { ...resolveContext, mutate: true });\n }\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugMutateManifest'] = mutateManifest;\n}\n","export async function makeOfflineBundle(manifest: unknown) {\n const { makeOfflineBundle } = await import('./makeOfflineBundle');\n return await makeOfflineBundle(manifest);\n}\n\nexport async function downloadZip(manifest: unknown) {\n const { downloadZip } = await import('./downloadZip');\n return await downloadZip(manifest);\n}\n\nasync function debugLogOfflineManifestFiles(manifest: unknown): Promise<void> {\n // console.log('Offline files:');\n const { makeOffline } = await import('./makeOffline');\n const result = await makeOffline(manifest);\n // const allFiles = [];\n for await (const file of (await result).files) {\n if ('data' in file) {\n console.info(`🗳️ Put ${file.targetFilePath} <=`, file.data);\n } else if ('url' in file) {\n console.info(`🗳️ Download ${file.targetFilePath} <= ${file.url}`);\n }\n // allFiles.push(file);\n }\n console.info('Offline data: ', result.manifest);\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugDownloadZip'] = downloadZip;\n (window as any)['__debugMakeOfflineBundle'] = makeOfflineBundle;\n (window as any)['__debugLogOfflineManifestFiles'] = debugLogOfflineManifestFiles;\n}\n","import { createFunction, preconnectUrl } from './shared';\n\nexport const mount = createFunction('mount');\nexport const load = createFunction('load');\nexport const initialize = createFunction('initialize');\n\n// extra\n// export const createFloorPlan = createFunction('createFloorPlan');\n// export const rewriteManifestToLocalFiles = createFunction('rewriteManifestToLocalFiles');\n\nexport async function callFunction_Experimental(\n name: string,\n manifest: unknown,\n ...args: IArguments[]\n) {\n const fn = createFunction(name);\n return await fn(manifest, ...args);\n}\n\nexport { resolve } from './resolve';\nexport { mutateManifest } from './mutateManifest';\nexport { makeOfflineBundle, downloadZip } from './offline';\n\n// preloadJson('https://efp-runtime.expofp.com/branches/main.json');\npreconnectUrl('https://efp-runtime.expofp.com/');\n"],"names":["resolveAssetRefSync","ref","log","parseRefValue","assetResolver","importJsonNotAvailable","jsonFrozen","importJsonNative","importJson","url","resolveContext","_a","_b","result","loadJson","deepFreeze","fetchCache","signal","key","dataPromise","response","returnCachedRef","refCache","factory","promise","data","bundleAssetsResolver","context","files","baseUrl","file","BASE_URL","expoRuntimeBranchResolver","branch","branchUrl","expoRuntimeGetBranchResolver","expoRuntimeResolver","httpResolver","loadAndWaitGlobal","scriptUrl","options","globalVar","timeoutMs","pollIntervalMs","isBrowser","loadInBrowser","waitForGlobal","loadInNode","resolve","reject","script","cleanup","onAbort","res","err","code","g","prevWindow","getter","name","abortSignal","start","check","legacyAssetUrlsResolver","_c","dataUrlBase","versionUrl","version","filesUrl","dataUrl","filesPromise","dataLoadPromise","wfDataUrl","wfDataLoadPromise","fpSvgUrl","fpSvgLoadPromise","fpLayerFiles","x","map","populateDataJsAssetsMap","links","addLink","link","e","img","legacyDataResolver","resolvers","globalRefCache","object","jsonPointer","parts","part","target","resovlePartsRecursiveMutate","replaceObjectFields","resovlePartsRecursive","node","partsIndex","resolveObjectMutate","obj","resolveObject","index","child","resolversToUse","r","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","objectOrRef","refOrContext","createFunction","manifest","args","functionToCall","error","val","deepClone","preconnectUrl","source","nonRefKeys","item","mutateManifest","paths","path","makeOfflineBundle","downloadZip","debugLogOfflineManifestFiles","makeOffline","mount","load","initialize","callFunction_Experimental"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@expofp/loader",
3
- "version": "1.0.49",
3
+ "version": "1.0.50",
4
4
  "description": "ExpoFP JavaScript loader library",
5
5
  "license": "MIT",
6
6
  "homepage": "https://expofp.com",