@expofp/loader 1.0.28 → 1.0.32
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 +77 -88
- package/dist/index.js.map +1 -1
- package/package.json +1 -2
package/dist/index.js
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
function F(e) {
|
|
2
|
-
return i("assetResolver resolveRef:", e),
|
|
2
|
+
return i("assetResolver resolveRef:", e), u(e);
|
|
3
3
|
}
|
|
4
4
|
const _ = {
|
|
5
5
|
schema: "asset",
|
|
6
6
|
resolveRef: async (e) => F(e),
|
|
7
7
|
offlineMethod: "localizeRef"
|
|
8
|
-
},
|
|
8
|
+
}, p = /* @__PURE__ */ new Map(), k = {
|
|
9
9
|
schema: "bundle-assets",
|
|
10
10
|
// canResolve(ref: string) {
|
|
11
11
|
// return canResolveRefSchema(ref, SCHEMA_PREFIX_BASE);
|
|
12
12
|
// },
|
|
13
13
|
async resolveRef(e) {
|
|
14
|
-
if (i("bundleAssetsResolver resolveRef:", e),
|
|
15
|
-
return
|
|
16
|
-
const t =
|
|
14
|
+
if (i("bundleAssetsResolver resolveRef:", e), p.has(e))
|
|
15
|
+
return p.get(e);
|
|
16
|
+
const t = u(e), n = fetch(t).then(async (o) => {
|
|
17
17
|
if (!o.ok)
|
|
18
18
|
throw new Error(`Failed to fetch ref from ${e}`);
|
|
19
19
|
const r = await o.json(), s = t.substring(0, t.lastIndexOf("/") + 1), a = r.map((c) => ({
|
|
@@ -21,7 +21,7 @@ const _ = {
|
|
|
21
21
|
}));
|
|
22
22
|
return l(a), a;
|
|
23
23
|
});
|
|
24
|
-
return
|
|
24
|
+
return p.set(e, n), n;
|
|
25
25
|
},
|
|
26
26
|
// async *makeOfflineRef(ref: string) {
|
|
27
27
|
// log('bundleAssetsResolver makeOfflineRef:', ref);
|
|
@@ -52,22 +52,21 @@ const _ = {
|
|
|
52
52
|
// yield { data, targetFilePath };
|
|
53
53
|
// return { $ref: targetFilePath, [STOP_RESOLVING]: true };
|
|
54
54
|
// },
|
|
55
|
-
},
|
|
55
|
+
}, M = "https://efp-runtime.expofp.com/", m = /* @__PURE__ */ new Map(), T = {
|
|
56
56
|
schema: "expo-runtime-branch",
|
|
57
57
|
// canResolve(ref: string) {
|
|
58
58
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
59
59
|
// },
|
|
60
60
|
async resolveRef(e) {
|
|
61
|
-
if (i("expoRuntimeBranchResolver resolveRef:", e),
|
|
62
|
-
return
|
|
63
|
-
const t =
|
|
61
|
+
if (i("expoRuntimeBranchResolver resolveRef:", e), m.has(e))
|
|
62
|
+
return m.get(e);
|
|
63
|
+
const t = u(e), n = new Promise(async (o, r) => {
|
|
64
64
|
try {
|
|
65
|
-
const s = [`${
|
|
66
|
-
t.startsWith("vite-") || s.push(`${u}branches/vite-${t}.json`), s.includes(`${u}branches/vite-main.json`) || s.push(`${u}branches/vite-main.json`), s.includes(`${u}branches/vite-next.json`) || s.push(`${u}branches/vite-next.json`);
|
|
65
|
+
const s = [`${M}branches/${t}.json`];
|
|
67
66
|
let a;
|
|
68
|
-
for (const
|
|
69
|
-
i("Fetching HTTP:",
|
|
70
|
-
const f = await fetch(
|
|
67
|
+
for (const d of s) {
|
|
68
|
+
i("Fetching HTTP:", d);
|
|
69
|
+
const f = await fetch(d);
|
|
71
70
|
if (f.ok) {
|
|
72
71
|
a = await f.json();
|
|
73
72
|
break;
|
|
@@ -83,7 +82,7 @@ const _ = {
|
|
|
83
82
|
r(s);
|
|
84
83
|
}
|
|
85
84
|
});
|
|
86
|
-
return
|
|
85
|
+
return m.set(e, n), n;
|
|
87
86
|
},
|
|
88
87
|
// async *makeOfflineRef(ref: string) {
|
|
89
88
|
// log('expoRuntimeBranchResolver makeOfflineRef:', ref);
|
|
@@ -103,15 +102,15 @@ const _ = {
|
|
|
103
102
|
// return targetFilePath;
|
|
104
103
|
// },
|
|
105
104
|
offlineMethod: "resolveRef"
|
|
106
|
-
},
|
|
105
|
+
}, v = /* @__PURE__ */ new Map(), j = {
|
|
107
106
|
schema: "expo-runtime-get-branch",
|
|
108
107
|
// canResolve(ref: string) {
|
|
109
108
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
110
109
|
// },
|
|
111
110
|
async resolveRef(e) {
|
|
112
|
-
if (i("expoRuntimeGetBranchResolver resolveRef:", e),
|
|
113
|
-
return
|
|
114
|
-
const t =
|
|
111
|
+
if (i("expoRuntimeGetBranchResolver resolveRef:", e), v.has(e))
|
|
112
|
+
return v.get(e);
|
|
113
|
+
const t = u(e), n = `https://${t}.expofp.com/get-branch`;
|
|
115
114
|
i("Fetching HTTP:", n);
|
|
116
115
|
const o = fetch(n).then(async (r) => {
|
|
117
116
|
if (!r.ok)
|
|
@@ -122,7 +121,7 @@ const _ = {
|
|
|
122
121
|
const c = { $ref: `expo-runtime-branch:${a}` };
|
|
123
122
|
return l(c), c;
|
|
124
123
|
});
|
|
125
|
-
return
|
|
124
|
+
return v.set(e, o), o;
|
|
126
125
|
},
|
|
127
126
|
// async *makeOfflineRef(ref: string) {
|
|
128
127
|
// log('expoRuntimeBranchResolver makeOfflineRef:', ref);
|
|
@@ -142,14 +141,14 @@ const _ = {
|
|
|
142
141
|
// return targetFilePath;
|
|
143
142
|
// },
|
|
144
143
|
offlineMethod: "resolveRef"
|
|
145
|
-
},
|
|
144
|
+
}, A = {
|
|
146
145
|
schema: "expo-runtime",
|
|
147
146
|
// canResolve(ref: string) {
|
|
148
147
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
149
148
|
// },
|
|
150
149
|
async resolveRef(e) {
|
|
151
150
|
i("expoRuntimeResolver resolveRef:", e);
|
|
152
|
-
const t =
|
|
151
|
+
const t = u(e), n = {
|
|
153
152
|
entry: { $ref: `asset+${t}expofp.js` },
|
|
154
153
|
assets: { $ref: `bundle-assets+${t}bundle.json` }
|
|
155
154
|
};
|
|
@@ -173,7 +172,7 @@ const _ = {
|
|
|
173
172
|
// return targetFilePath;
|
|
174
173
|
// },
|
|
175
174
|
offlineMethod: "resolveRef"
|
|
176
|
-
}, y = /* @__PURE__ */ new Map(),
|
|
175
|
+
}, y = /* @__PURE__ */ new Map(), C = {
|
|
177
176
|
canResolve(e) {
|
|
178
177
|
return e.startsWith("http://") || e.startsWith("https://") || e.startsWith("./");
|
|
179
178
|
},
|
|
@@ -209,9 +208,9 @@ const _ = {
|
|
|
209
208
|
// },
|
|
210
209
|
offlineMethod: "resolveRef"
|
|
211
210
|
};
|
|
212
|
-
async function
|
|
211
|
+
async function R(e, t = {}) {
|
|
213
212
|
const { globalVar: n, timeoutMs: o = 1e4, pollIntervalMs: r = 10 } = t;
|
|
214
|
-
I() ? (await
|
|
213
|
+
I() ? (await B(e), n && await b(() => window[n], n, o, r)) : (await N(e), n && await b(
|
|
215
214
|
() => globalThis[n],
|
|
216
215
|
n,
|
|
217
216
|
o,
|
|
@@ -221,7 +220,7 @@ async function C(e, t = {}) {
|
|
|
221
220
|
function I() {
|
|
222
221
|
return typeof window < "u" && typeof document < "u";
|
|
223
222
|
}
|
|
224
|
-
function
|
|
223
|
+
function B(e) {
|
|
225
224
|
return new Promise((t, n) => {
|
|
226
225
|
const o = document.createElement("script");
|
|
227
226
|
o.src = e, o.async = !0;
|
|
@@ -235,9 +234,11 @@ function W(e) {
|
|
|
235
234
|
}, document.head.appendChild(o);
|
|
236
235
|
});
|
|
237
236
|
}
|
|
238
|
-
async function
|
|
237
|
+
async function N(e) {
|
|
239
238
|
if (typeof fetch != "function")
|
|
240
|
-
throw new Error(
|
|
239
|
+
throw new Error(
|
|
240
|
+
"loadAndWaitGlobal: fetch is not available. Use Node 18+ or provide a global fetch."
|
|
241
|
+
);
|
|
241
242
|
const t = await fetch(e);
|
|
242
243
|
if (!t.ok)
|
|
243
244
|
throw new Error(`Failed to load script in Node (HTTP ${t.status}): ${e}`);
|
|
@@ -259,47 +260,47 @@ function b(e, t, n, o) {
|
|
|
259
260
|
c();
|
|
260
261
|
});
|
|
261
262
|
}
|
|
262
|
-
const
|
|
263
|
+
const $ = /* @__PURE__ */ new Map(), S = {
|
|
263
264
|
schema: "legacy-data",
|
|
264
265
|
// canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),
|
|
265
266
|
async resolveRef(e) {
|
|
266
|
-
if (i("legacyDataResolver resolveRef:", e),
|
|
267
|
-
return
|
|
267
|
+
if (i("legacyDataResolver resolveRef:", e), $.has(e))
|
|
268
|
+
return $.get(e);
|
|
268
269
|
const t = (async () => {
|
|
269
|
-
const n =
|
|
270
|
+
const n = u(e);
|
|
270
271
|
try {
|
|
271
|
-
await
|
|
272
|
+
await R(`${n}version.js`);
|
|
272
273
|
} catch {
|
|
273
274
|
console.warn("Could not load version.js, proceeding without it");
|
|
274
275
|
}
|
|
275
|
-
const o =
|
|
276
|
+
const o = globalThis.__fpDataVersion || (+/* @__PURE__ */ new Date()).toString();
|
|
276
277
|
let r = [];
|
|
277
278
|
await Promise.all([
|
|
278
279
|
(async function() {
|
|
279
|
-
const
|
|
280
|
-
if (
|
|
280
|
+
const h = await fetch(`${n}files.json?v=${o}`);
|
|
281
|
+
if (h.ok) r = await h.json();
|
|
281
282
|
else
|
|
282
283
|
throw new Error(`Could not load files.json from ${n}files.json?v=${o}`);
|
|
283
284
|
})(),
|
|
284
|
-
|
|
285
|
+
R(`${n}data.js?v=${o}`, { globalVar: "__data" })
|
|
285
286
|
// injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),
|
|
286
287
|
// injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),
|
|
287
288
|
]);
|
|
288
|
-
const s =
|
|
289
|
+
const s = globalThis.__data || {}, c = [...r, "data.js"].reduce((f, h) => (f[h] = { $ref: `asset+${n}${h}?v=${o}` }, f), {}), d = {
|
|
289
290
|
_to_remove_for_offline_to_work_dataUrlBase: n,
|
|
290
291
|
// dataFiles: dataFiles.reduce((map, file) => {
|
|
291
292
|
// map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };
|
|
292
293
|
// return map;
|
|
293
294
|
// }, {} as Record<string, { $ref: string }>),
|
|
294
|
-
|
|
295
|
+
legacyAssetUrls: { ...c, ...W(n, s) }
|
|
295
296
|
};
|
|
296
|
-
return l(
|
|
297
|
+
return l(d), d;
|
|
297
298
|
})();
|
|
298
|
-
return
|
|
299
|
+
return $.set(e, t), t;
|
|
299
300
|
},
|
|
300
301
|
offlineMethod: "resolveRef"
|
|
301
302
|
};
|
|
302
|
-
function
|
|
303
|
+
function W(e, t) {
|
|
303
304
|
const n = /* @__PURE__ */ new Set();
|
|
304
305
|
function o(r) {
|
|
305
306
|
typeof r == "string" && r.length > 0 && n.add(r);
|
|
@@ -314,27 +315,15 @@ function S(e, t) {
|
|
|
314
315
|
});
|
|
315
316
|
}), Array.from(n).reduce((r, s) => (r[s] = { $ref: `asset+${e}${s}` }, r), {});
|
|
316
317
|
}
|
|
317
|
-
async function P(e, t) {
|
|
318
|
-
return new Promise((n, o) => {
|
|
319
|
-
const r = document.createElement("script");
|
|
320
|
-
r.src = e, r.async = !0, r.onload = () => {
|
|
321
|
-
(() => {
|
|
322
|
-
n();
|
|
323
|
-
})();
|
|
324
|
-
}, r.onerror = () => {
|
|
325
|
-
o(new Error(`Failed to load script: ${e}`));
|
|
326
|
-
}, document.head.appendChild(r);
|
|
327
|
-
});
|
|
328
|
-
}
|
|
329
318
|
const D = [
|
|
330
|
-
|
|
319
|
+
C,
|
|
331
320
|
k,
|
|
332
321
|
_,
|
|
322
|
+
A,
|
|
333
323
|
T,
|
|
334
324
|
j,
|
|
335
|
-
M,
|
|
336
325
|
// expoResolver,
|
|
337
|
-
|
|
326
|
+
S
|
|
338
327
|
];
|
|
339
328
|
async function x(e, t) {
|
|
340
329
|
if (i("Resolving:", t), typeof t != "string")
|
|
@@ -344,16 +333,16 @@ async function x(e, t) {
|
|
|
344
333
|
if (t.length > 1 && t.endsWith("/"))
|
|
345
334
|
throw new Error(`Invalid JSON Pointer: ${t}`);
|
|
346
335
|
if (t === "/")
|
|
347
|
-
return await
|
|
336
|
+
return await g(e);
|
|
348
337
|
const n = t.substring(1).split("/");
|
|
349
338
|
if (n.some((r) => r.length === 0))
|
|
350
339
|
throw new Error(`Invalid JSON Pointer (empty part): ${t}`);
|
|
351
|
-
const o = await
|
|
340
|
+
const o = await P(e, n);
|
|
352
341
|
return i(`Resolved ${t}:`, o), o;
|
|
353
342
|
}
|
|
354
|
-
window && (window.__debugResolve = x);
|
|
355
|
-
async function
|
|
356
|
-
let n = 0, o = await
|
|
343
|
+
typeof window < "u" && (window.__debugResolve = x);
|
|
344
|
+
async function P(e, t) {
|
|
345
|
+
let n = 0, o = await g(e);
|
|
357
346
|
for (; n < t.length; ) {
|
|
358
347
|
const r = t[n];
|
|
359
348
|
if (typeof o != "object" || o === null)
|
|
@@ -363,11 +352,11 @@ async function z(e, t) {
|
|
|
363
352
|
)}, index ${n}'`
|
|
364
353
|
);
|
|
365
354
|
const s = o[r];
|
|
366
|
-
o = await
|
|
355
|
+
o = await g(s), n++;
|
|
367
356
|
}
|
|
368
357
|
return o;
|
|
369
358
|
}
|
|
370
|
-
async function
|
|
359
|
+
async function g(e) {
|
|
371
360
|
i("resolveObject:", e);
|
|
372
361
|
let t = e;
|
|
373
362
|
do {
|
|
@@ -381,11 +370,11 @@ async function R(e) {
|
|
|
381
370
|
}
|
|
382
371
|
if (n.length > 1)
|
|
383
372
|
throw new Error(`Multiple resolvers can resolve ref: ${t.$ref}`);
|
|
384
|
-
const o = await
|
|
373
|
+
const o = await U(n[0], t.$ref);
|
|
385
374
|
t = H(o, t);
|
|
386
375
|
} while (!0);
|
|
387
376
|
}
|
|
388
|
-
async function
|
|
377
|
+
async function U(e, t) {
|
|
389
378
|
if (!O(e, t))
|
|
390
379
|
throw new Error(`Unexpected ref: ${t}`);
|
|
391
380
|
return e.resolveRef(t);
|
|
@@ -394,17 +383,17 @@ function O(e, t) {
|
|
|
394
383
|
if (e.canResolve)
|
|
395
384
|
return e.canResolve(t);
|
|
396
385
|
if (e.schema)
|
|
397
|
-
return
|
|
386
|
+
return z(t, e.schema);
|
|
398
387
|
throw new Error("Resolver is missing canResolve method and schema property");
|
|
399
388
|
}
|
|
400
|
-
function
|
|
389
|
+
function z(e, t) {
|
|
401
390
|
const n = [`${t}+`, `${t}:`];
|
|
402
391
|
for (const o of n)
|
|
403
392
|
if (e.startsWith(o))
|
|
404
393
|
return !0;
|
|
405
394
|
return !1;
|
|
406
395
|
}
|
|
407
|
-
function
|
|
396
|
+
function u(e) {
|
|
408
397
|
if (e.startsWith("http://") || e.startsWith("https://"))
|
|
409
398
|
return e;
|
|
410
399
|
const t = e.indexOf("+http://"), n = e.indexOf("+https://");
|
|
@@ -417,7 +406,7 @@ function d(e) {
|
|
|
417
406
|
return e.substring(o + 1);
|
|
418
407
|
throw new Error(`Error getting URL from: ${e}, no valid prefix found`);
|
|
419
408
|
}
|
|
420
|
-
function
|
|
409
|
+
function w(e) {
|
|
421
410
|
return async (t, ...n) => {
|
|
422
411
|
try {
|
|
423
412
|
const s = (await import(await x(t, "/runtime/entry")))[e];
|
|
@@ -442,7 +431,7 @@ function l(e) {
|
|
|
442
431
|
function E(e) {
|
|
443
432
|
return "structuredClone" in globalThis ? globalThis.structuredClone(e) : JSON.parse(JSON.stringify(e));
|
|
444
433
|
}
|
|
445
|
-
function
|
|
434
|
+
function J(e) {
|
|
446
435
|
if (typeof document > "u") return;
|
|
447
436
|
const t = document.createElement("link");
|
|
448
437
|
t.rel = "preconnect", t.href = e, t.crossOrigin = "anonymous", document.head.appendChild(t);
|
|
@@ -464,39 +453,39 @@ function H(e, t) {
|
|
|
464
453
|
o[r] = t[r];
|
|
465
454
|
return o;
|
|
466
455
|
}
|
|
467
|
-
async function
|
|
456
|
+
async function G(e) {
|
|
468
457
|
const { makeOfflineBundle: t } = await import("./makeOfflineBundle-CDWAdTIW.js");
|
|
469
458
|
return await t(e);
|
|
470
459
|
}
|
|
471
|
-
async function
|
|
460
|
+
async function L(e) {
|
|
472
461
|
const { downloadZip: t } = await import("./downloadZip-DwDnK9eb.js");
|
|
473
462
|
return await t(e);
|
|
474
463
|
}
|
|
475
|
-
async function
|
|
464
|
+
async function V(e) {
|
|
476
465
|
const { makeOffline: t } = await import("./makeOffline-bamiAsgC.js"), n = await t(e);
|
|
477
466
|
for await (const o of (await n).files)
|
|
478
467
|
"data" in o ? console.info(`🗳️ Put ${o.targetFilePath} <=`, o.data) : "url" in o && console.info(`🗳️ Download ${o.targetFilePath} <= ${o.url}`);
|
|
479
468
|
console.info("Offline data: ", n.manifest);
|
|
480
469
|
}
|
|
481
|
-
window && (window.__debugDownloadZip =
|
|
482
|
-
const
|
|
483
|
-
async function
|
|
484
|
-
return await
|
|
470
|
+
typeof window < "u" && (window.__debugDownloadZip = L, window.__debugMakeOfflineBundle = G, window.__debugLogOfflineManifestFiles = V);
|
|
471
|
+
const Z = w("mount"), K = w("load"), q = w("initialize");
|
|
472
|
+
async function Q(e, t, ...n) {
|
|
473
|
+
return await w(e)(t, ...n);
|
|
485
474
|
}
|
|
486
|
-
|
|
475
|
+
J("https://efp-runtime.expofp.com/");
|
|
487
476
|
export {
|
|
488
477
|
H as a,
|
|
489
|
-
|
|
478
|
+
U as b,
|
|
490
479
|
O as c,
|
|
491
|
-
|
|
480
|
+
Q as callFunction_Experimental,
|
|
492
481
|
E as d,
|
|
493
|
-
|
|
494
|
-
|
|
482
|
+
L as downloadZip,
|
|
483
|
+
q as initialize,
|
|
495
484
|
i as l,
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
485
|
+
K as load,
|
|
486
|
+
G as makeOfflineBundle,
|
|
487
|
+
Z as mount,
|
|
488
|
+
u as p,
|
|
500
489
|
D as r,
|
|
501
490
|
x as resolve
|
|
502
491
|
};
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/resolvers/assetResolver.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/legacyDataResolver.ts","../src/resolvers/index.ts","../src/resolve.ts","../src/shared.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 { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA_PREFIX_BASE = 'bundle-assets';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const bundleAssetsResolver: Resolver = {\n schema: 'bundle-assets',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA_PREFIX_BASE);\n // },\n async resolveRef(ref: string) {\n log('bundleAssetsResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const url = parseRefValue(ref);\n\n // if (offline) {\n // return { $ref: `bundle-assets:${makeTargetPathFromUrl(url)}` };\n // }\n const promise = fetch(url).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n const files = await response.json();\n // we fetched xxx/bundle.json which contains an array of file paths\n const baseUrl = url.substring(0, url.lastIndexOf('/') + 1);\n\n // const folderName = encodeFolderName(url);\n // keep is a number of segments to keep in the asset path\n\n const assets = files.map((file: string) => ({\n $ref: `asset+${baseUrl}${file}`,\n }));\n deepFreeze(assets);\n // console.info('Resolved bundle assets:', assets);\n return assets;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('bundleAssetsResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // // const refData = deepFreeze(await this.resolveRef(ref));\n // // yield* makeOfflineInternal(refData);\n // const url = parseRefValue(ref);\n // const targetFilePath = makeTargetPathFromUrl(url);\n // // alert(targetFilePath)\n // yield { url, targetFilePath };\n // return { $ref: `bundle-assets:${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 `bundle-assets:${targetFilePath}`;\n // },\n offlineMethod: 'localizeRef',\n\n // async *makeOfflineRef(ref: string) {\n // log('bundleAssetsResolver makeOfflineRef:', ref);\n\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n // const url = getUrlFromRef(ref);\n\n // // objects data may be changed by further processing\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeTargetPathFromUrl(url);\n // const data = yield* makeOfflineInternal(refData);\n\n // yield { data, targetFilePath };\n\n // return { $ref: targetFilePath, [STOP_RESOLVING]: true };\n // },\n};\n","import { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-bran¿ch';\nconst BASE_URL = 'https://efp-runtime.expofp.com/';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const branch = parseRefValue(ref);\n\n const promise = new Promise(async (resolve, reject) => {\n try {\n const tryUrls = [`${BASE_URL}branches/${branch}.json`];\n if (!branch.startsWith('vite-')) {\n tryUrls.push(`${BASE_URL}branches/vite-${branch}.json`);\n }\n if (!tryUrls.includes(`${BASE_URL}branches/vite-main.json`)) {\n tryUrls.push(`${BASE_URL}branches/vite-main.json`);\n }\n if (!tryUrls.includes(`${BASE_URL}branches/vite-next.json`)) {\n tryUrls.push(`${BASE_URL}branches/vite-next.json`);\n }\n\n // const uniqueUrls = tryUrls.reduce<string[]>(\n // (acc, url) => (acc.includes(url) ? acc : [...acc, url]),\n // []\n // );\n\n // const promises: Promise<string | undefined>[] = tryUrls.map(async (url) => {\n // console.info('Fetching HTTP:', url);\n // const response = await fetch(url);\n // if (response.ok) return await response.json();\n // return undefined;\n // });\n\n let release: string | undefined = undefined;\n // for (const p of promises) {\n // release = await p;\n // if (release) break;\n // }\n\n for (const url of tryUrls) {\n log('Fetching HTTP:', url);\n const response = await fetch(url);\n if (!response.ok) {\n continue;\n }\n release = await response.json();\n break;\n }\n if (!release) {\n throw new Error(`Failed to fetch release from ${ref}`);\n }\n const data = {\n $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n };\n // deep freeze the data\n deepFreeze(data);\n resolve(data);\n } catch (e) {\n reject(e);\n }\n });\n\n // const url = `${BASE_URL}branches/${branch}.json`;\n // log('Fetching HTTP:', url);\n // const promise = fetch(url).then(async (response) => {\n // if (!response.ok) {\n // throw new Error(`Failed to fetch ref from ${ref}`);\n // }\n // const release = await response.json();\n // const data = {\n // $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n // };\n // // deep freeze the data\n // deepFreeze(data);\n // return data;\n // });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeBranchResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const value = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(value, 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 { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nconst cache = new Map<string, Promise<any>>();\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const expo = parseRefValue(ref);\n const url = `https://${expo}.expofp.com/get-branch`;\n log('Fetching HTTP:', url);\n const promise = fetch(url).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n const responseData = await response.json();\n const branch = responseData.branch;\n if (!branch) {\n throw new Error(`Invalid response when fetching branch for expo ${expo}`);\n }\n const data = { $ref: `expo-runtime-branch:${branch}` };\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeBranchResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const value = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(value, 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 { 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 { deepFreeze, log } from '../shared';\nimport { type Resolver } from '../types';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n async resolveRef(ref) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n // if (offline) {\n // const data = await this.resolveRef(ref);\n // const files = await makeOfflineInternal(data);\n // return { manifest: { $ref: makeTargetPathFromUrl(ref), files } };\n // }\n\n log('Fetching HTTP ref:', ref);\n const promise = fetch(ref).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n // options.assetCallback(ref, data)\n const data = await response.json();\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref) {\n // log('httpResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // // objects data may be changed by further processing\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(ref, 'http');\n // const data = yield* makeOfflineInternal(refData);\n // yield { 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} satisfies Resolver;\n","// loadAndWait.ts\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}\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);\n if (globalVar) {\n await waitForGlobal(() => (window as any)[globalVar], globalVar, timeoutMs, pollIntervalMs);\n }\n } else {\n await loadInNode(scriptUrl);\n if (globalVar) {\n await waitForGlobal(\n () => (globalThis as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs\n );\n }\n }\n}\n\nfunction isBrowser(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/* -------------------- Browser implementation -------------------- */\n\nfunction loadInBrowser(scriptUrl: string): 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 };\n\n script.onload = () => {\n cleanup();\n resolve();\n };\n\n script.onerror = () => {\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): Promise<void> {\n if (typeof fetch !== 'function') {\n throw new Error('loadAndWait: fetch is not available. Use Node 18+ or provide a global fetch.');\n }\n\n const res = await fetch(scriptUrl);\n if (!res.ok) {\n throw new Error(`Failed to load script in Node (HTTP ${res.status}): ${scriptUrl}`);\n }\n\n const code = await res.text();\n\n // Indirect eval -> global scope in Node and browser.\n // Assumes the loaded script attaches itself to globalThis/window/global.\n (0, eval)(code);\n}\n\n/* -------------------- Shared helper -------------------- */\n\nfunction waitForGlobal(\n getter: () => any,\n name: string,\n timeoutMs: number,\n pollIntervalMs: number\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const start = performance.now();\n\n const check = () => {\n try {\n if (getter() !== undefined) {\n return resolve();\n }\n } catch {\n // ignore access errors and keep polling\n }\n\n if (performance.now() - start >= timeoutMs) {\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 { loadAndWaitGlobal } from '../loadAndWaitGlobal';\nimport { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n // canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),\n async resolveRef(ref: string) {\n log('legacyDataResolver resolveRef:', ref);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const dataPromise = (async () => {\n const dataUrlBase = parseRefValue(ref);\n // load version.js - it will contain \"window.__fpDataVersion = \"20251129003330106\";\"\n try {\n await injectAndWaitForGlobal(`${dataUrlBase}version.js`);\n } catch {\n console.warn('Could not load version.js, proceeding without it');\n }\n const version = (window as any).__fpDataVersion || (+new Date()).toString();\n\n let files: string[] = [];\n await Promise.all([\n (async function fetchFiles() {\n const response = await fetch(`${dataUrlBase}files.json?v=${version}`);\n if (response.ok) files = await response.json();\n else\n throw new Error(`Could not load files.json from ${dataUrlBase}files.json?v=${version}`);\n })(),\n loadAndWaitGlobal(`${dataUrlBase}data.js?v=${version}`, { globalVar: '__data' }),\n // injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),\n // injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),\n ]);\n\n const data = (window 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 const manifest = {\n _to_remove_for_offline_to_work_dataUrlBase: dataUrlBase,\n // dataFiles: dataFiles.reduce((map, file) => {\n // map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };\n // return map;\n // }, {} as Record<string, { $ref: string }>),\n 'legacy-asset-urls': { ...dataFilesAssets, ...populateDataJsAssetsMap(dataUrlBase, data) },\n };\n deepFreeze(manifest);\n return manifest;\n })();\n\n cache.set(ref, dataPromise);\n return dataPromise;\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\nasync function injectAndWaitForGlobal(scriptUrl: string, globalVar?: string): Promise<void> {\n return new Promise((resolve, reject) => {\n const script = document.createElement('script');\n script.src = scriptUrl;\n script.async = true;\n script.onload = () => {\n const checkGlobal = () => {\n if (!globalVar || (window as any)[globalVar] !== undefined) {\n resolve();\n } else {\n setTimeout(checkGlobal, 10);\n }\n };\n checkGlobal();\n };\n script.onerror = () => {\n reject(new Error(`Failed to load script: ${scriptUrl}`));\n };\n document.head.appendChild(script);\n });\n}\n","import type { Resolver } from '../types';\nimport { assetResolver } from './assetResolver';\nimport { bundleAssetsResolver } from './bundleAssetsResolver';\n// import { expoResolver } from './_OLD_expoResolver';\nimport { expoRuntimeBranchResolver } from './expoRuntimeBranchResolver';\nimport { expoRuntimeGetBranchResolver } from './expoRuntimeGetBranchResolver';\nimport { expoRuntimeResolver } from './expoRuntimeResolver';\nimport { httpResolver } from './httpResolver';\nimport { legacyDataResolver } from './legacyDataResolver';\n\nexport const resolvers: Resolver[] = [\n httpResolver,\n bundleAssetsResolver,\n assetResolver,\n expoRuntimeResolver,\n expoRuntimeBranchResolver,\n expoRuntimeGetBranchResolver,\n // expoResolver,\n legacyDataResolver,\n];\n","import { resolvers } from './resolvers';\nimport { createMergedObjectWithOverridenNonRefProps, deepFreeze, log } from './shared';\nimport type { Resolver } from './types';\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 * @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(object: any, jsonPointer: string): Promise<any> {\n log('Resolving:', jsonPointer);\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 return await resolveObject(object);\n }\n\n const parts = jsonPointer.substring(1).split('/');\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n const value = await resolvePath(object, parts);\n log(`Resolved ${jsonPointer}:`, value);\n return value;\n}\n\nif (window) {\n (window as any)['__debugResolve'] = resolve;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resolvePath(object: any, parts: string[]): Promise<any> {\n let partIndex = 0;\n let currentObject = await resolveObject(object);\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);\n partIndex++;\n }\n\n return currentObject;\n}\n\nasync function resolveObject(object: any): 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);\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(resolver: Resolver, ref: string): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref);\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","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 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\n\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","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 (window) {\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 { 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","cache","bundleAssetsResolver","url","promise","response","files","baseUrl","assets","file","deepFreeze","BASE_URL","expoRuntimeBranchResolver","branch","resolve","reject","tryUrls","release","data","e","expoRuntimeGetBranchResolver","expo","expoRuntimeResolver","httpResolver","loadAndWaitGlobal","scriptUrl","options","globalVar","timeoutMs","pollIntervalMs","isBrowser","loadInBrowser","waitForGlobal","loadInNode","script","cleanup","res","code","getter","name","start","check","legacyDataResolver","dataPromise","dataUrlBase","injectAndWaitForGlobal","version","dataFilesAssets","map","manifest","populateDataJsAssetsMap","links","addLink","link","_a","img","s","resolvers","object","jsonPointer","resolveObject","parts","part","value","resolvePath","partIndex","currentObject","child","obj","resolversToUse","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","createFunction","args","functionToCall","error","key","val","deepClone","preconnectUrl","target","source","nonRefKeys","result","makeOfflineBundle","downloadZip","debugLogOfflineManifestFiles","makeOffline","mount","load","initialize","callFunction_Experimental"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/resolvers/assetResolver.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/legacyDataResolver.ts","../src/resolvers/index.ts","../src/resolve.ts","../src/shared.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 { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA_PREFIX_BASE = 'bundle-assets';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const bundleAssetsResolver: Resolver = {\n schema: 'bundle-assets',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA_PREFIX_BASE);\n // },\n async resolveRef(ref: string) {\n log('bundleAssetsResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const url = parseRefValue(ref);\n\n // if (offline) {\n // return { $ref: `bundle-assets:${makeTargetPathFromUrl(url)}` };\n // }\n const promise = fetch(url).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n const files = await response.json();\n // we fetched xxx/bundle.json which contains an array of file paths\n const baseUrl = url.substring(0, url.lastIndexOf('/') + 1);\n\n // const folderName = encodeFolderName(url);\n // keep is a number of segments to keep in the asset path\n\n const assets = files.map((file: string) => ({\n $ref: `asset+${baseUrl}${file}`,\n }));\n deepFreeze(assets);\n // console.info('Resolved bundle assets:', assets);\n return assets;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('bundleAssetsResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // // const refData = deepFreeze(await this.resolveRef(ref));\n // // yield* makeOfflineInternal(refData);\n // const url = parseRefValue(ref);\n // const targetFilePath = makeTargetPathFromUrl(url);\n // // alert(targetFilePath)\n // yield { url, targetFilePath };\n // return { $ref: `bundle-assets:${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 `bundle-assets:${targetFilePath}`;\n // },\n offlineMethod: 'localizeRef',\n\n // async *makeOfflineRef(ref: string) {\n // log('bundleAssetsResolver makeOfflineRef:', ref);\n\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n // const url = getUrlFromRef(ref);\n\n // // objects data may be changed by further processing\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeTargetPathFromUrl(url);\n // const data = yield* makeOfflineInternal(refData);\n\n // yield { data, targetFilePath };\n\n // return { $ref: targetFilePath, [STOP_RESOLVING]: true };\n // },\n};\n","import { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-bran¿ch';\nconst BASE_URL = 'https://efp-runtime.expofp.com/';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const branch = parseRefValue(ref);\n\n const promise = new Promise(async (resolve, reject) => {\n try {\n const tryUrls = [`${BASE_URL}branches/${branch}.json`];\n // if (!branch.startsWith('vite-')) {\n // tryUrls.push(`${BASE_URL}branches/vite-${branch}.json`);\n // }\n // if (!tryUrls.includes(`${BASE_URL}branches/vite-main.json`)) {\n // tryUrls.push(`${BASE_URL}branches/vite-main.json`);\n // }\n // if (!tryUrls.includes(`${BASE_URL}branches/vite-next.json`)) {\n // tryUrls.push(`${BASE_URL}branches/vite-next.json`);\n // }\n\n // const uniqueUrls = tryUrls.reduce<string[]>(\n // (acc, url) => (acc.includes(url) ? acc : [...acc, url]),\n // []\n // );\n\n // const promises: Promise<string | undefined>[] = tryUrls.map(async (url) => {\n // console.info('Fetching HTTP:', url);\n // const response = await fetch(url);\n // if (response.ok) return await response.json();\n // return undefined;\n // });\n\n let release: string | undefined = undefined;\n // for (const p of promises) {\n // release = await p;\n // if (release) break;\n // }\n\n for (const url of tryUrls) {\n log('Fetching HTTP:', url);\n const response = await fetch(url); //, { credentials: 'omit' }\n if (!response.ok) {\n continue;\n }\n release = await response.json();\n break;\n }\n if (!release) {\n throw new Error(`Failed to fetch release from ${ref}`);\n }\n const data = {\n $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n };\n // deep freeze the data\n deepFreeze(data);\n resolve(data);\n } catch (e) {\n reject(e);\n }\n });\n\n // const url = `${BASE_URL}branches/${branch}.json`;\n // log('Fetching HTTP:', url);\n // const promise = fetch(url).then(async (response) => {\n // if (!response.ok) {\n // throw new Error(`Failed to fetch ref from ${ref}`);\n // }\n // const release = await response.json();\n // const data = {\n // $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n // };\n // // deep freeze the data\n // deepFreeze(data);\n // return data;\n // });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeBranchResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const value = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(value, 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 { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nconst cache = new Map<string, Promise<any>>();\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const expo = parseRefValue(ref);\n const url = `https://${expo}.expofp.com/get-branch`;\n log('Fetching HTTP:', url);\n const promise = fetch(url).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n const responseData = await response.json();\n const branch = responseData.branch;\n if (!branch) {\n throw new Error(`Invalid response when fetching branch for expo ${expo}`);\n }\n const data = { $ref: `expo-runtime-branch:${branch}` };\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref: string) {\n // log('expoRuntimeBranchResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // const value = parseRefValue(ref);\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(value, 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 { 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 { deepFreeze, log } from '../shared';\nimport { type Resolver } from '../types';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n async resolveRef(ref) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n // if (offline) {\n // const data = await this.resolveRef(ref);\n // const files = await makeOfflineInternal(data);\n // return { manifest: { $ref: makeTargetPathFromUrl(ref), files } };\n // }\n\n log('Fetching HTTP ref:', ref);\n const promise = fetch(ref).then(async (response) => {\n if (!response.ok) {\n throw new Error(`Failed to fetch ref from ${ref}`);\n }\n // options.assetCallback(ref, data)\n const data = await response.json();\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n\n cache.set(ref, promise);\n return promise;\n },\n // async *makeOfflineRef(ref) {\n // log('httpResolver makeOfflineRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n // // objects data may be changed by further processing\n // const refData = deepClone(await this.resolveRef(ref));\n // const targetFilePath = makeUniqueJsonTargetPathFromString(ref, 'http');\n // const data = yield* makeOfflineInternal(refData);\n // yield { 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} satisfies Resolver;\n","export 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}\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);\n if (globalVar) {\n await waitForGlobal(() => (window as any)[globalVar], globalVar, timeoutMs, pollIntervalMs);\n }\n } else {\n await loadInNode(scriptUrl);\n if (globalVar) {\n await waitForGlobal(\n () => (globalThis as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs\n );\n }\n }\n}\n\nfunction isBrowser(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\n/* -------------------- Browser implementation -------------------- */\n\nfunction loadInBrowser(scriptUrl: string): 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 };\n\n script.onload = () => {\n cleanup();\n resolve();\n };\n\n script.onerror = () => {\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): Promise<void> {\n if (typeof fetch !== 'function') {\n throw new Error(\n 'loadAndWaitGlobal: fetch is not available. Use Node 18+ or provide a global fetch.'\n );\n }\n\n const res = await fetch(scriptUrl);\n if (!res.ok) {\n throw new Error(`Failed to load script in Node (HTTP ${res.status}): ${scriptUrl}`);\n }\n\n const code = await res.text();\n\n // Indirect eval -> global scope in Node and browser.\n // Assumes the loaded script attaches itself to globalThis/window/global.\n (0, eval)(code);\n}\n\n/* -------------------- Shared helper -------------------- */\n\nfunction waitForGlobal(\n getter: () => any,\n name: string,\n timeoutMs: number,\n pollIntervalMs: number\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const start = performance.now();\n\n const check = () => {\n try {\n if (getter() !== undefined) {\n return resolve();\n }\n } catch {\n // ignore access errors and keep polling\n }\n\n if (performance.now() - start >= timeoutMs) {\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 { loadAndWaitGlobal } from '../loadAndWaitGlobal';\nimport { parseRefValue } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\nconst cache = new Map<string, Promise<any>>();\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n // canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),\n async resolveRef(ref: string) {\n log('legacyDataResolver resolveRef:', ref);\n if (cache.has(ref)) {\n return cache.get(ref);\n }\n\n const dataPromise = (async () => {\n const dataUrlBase = parseRefValue(ref);\n // load version.js - it will contain \"window.__fpDataVersion = \"20251129003330106\";\"\n try {\n await loadAndWaitGlobal(`${dataUrlBase}version.js`);\n } catch {\n console.warn('Could not load version.js, proceeding without it');\n }\n const version = (globalThis as any).__fpDataVersion || (+new Date()).toString();\n\n let files: string[] = [];\n await Promise.all([\n (async function fetchFiles() {\n const response = await fetch(`${dataUrlBase}files.json?v=${version}`);\n if (response.ok) files = await response.json();\n else\n throw new Error(`Could not load files.json from ${dataUrlBase}files.json?v=${version}`);\n })(),\n loadAndWaitGlobal(`${dataUrlBase}data.js?v=${version}`, { globalVar: '__data' }),\n // injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),\n // injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),\n ]);\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 const manifest = {\n _to_remove_for_offline_to_work_dataUrlBase: dataUrlBase,\n // dataFiles: dataFiles.reduce((map, file) => {\n // map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };\n // return map;\n // }, {} as Record<string, { $ref: string }>),\n legacyAssetUrls: { ...dataFilesAssets, ...populateDataJsAssetsMap(dataUrlBase, data) },\n };\n deepFreeze(manifest);\n return manifest;\n })();\n\n cache.set(ref, dataPromise);\n return dataPromise;\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\n// async function injectAndWaitForGlobal(scriptUrl: string, globalVar?: string): Promise<void> {\n// return new Promise((resolve, reject) => {\n// const script = document.createElement('script');\n// script.src = scriptUrl;\n// script.async = true;\n// script.onload = () => {\n// const checkGlobal = () => {\n// if (!globalVar || (window as any)[globalVar] !== undefined) {\n// resolve();\n// } else {\n// setTimeout(checkGlobal, 10);\n// }\n// };\n// checkGlobal();\n// };\n// script.onerror = () => {\n// reject(new Error(`Failed to load script: ${scriptUrl}`));\n// };\n// document.head.appendChild(script);\n// });\n// }\n","import type { Resolver } from '../types';\nimport { assetResolver } from './assetResolver';\nimport { bundleAssetsResolver } from './bundleAssetsResolver';\n// import { expoResolver } from './_OLD_expoResolver';\nimport { expoRuntimeBranchResolver } from './expoRuntimeBranchResolver';\nimport { expoRuntimeGetBranchResolver } from './expoRuntimeGetBranchResolver';\nimport { expoRuntimeResolver } from './expoRuntimeResolver';\nimport { httpResolver } from './httpResolver';\nimport { legacyDataResolver } from './legacyDataResolver';\n\nexport const resolvers: Resolver[] = [\n httpResolver,\n bundleAssetsResolver,\n assetResolver,\n expoRuntimeResolver,\n expoRuntimeBranchResolver,\n expoRuntimeGetBranchResolver,\n // expoResolver,\n legacyDataResolver,\n];\n","import { resolvers } from './resolvers';\nimport { createMergedObjectWithOverridenNonRefProps, deepFreeze, log } from './shared';\nimport type { Resolver } from './types';\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 * @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(object: any, jsonPointer: string): Promise<any> {\n log('Resolving:', jsonPointer);\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 return await resolveObject(object);\n }\n\n const parts = jsonPointer.substring(1).split('/');\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n const value = await resolvePath(object, parts);\n log(`Resolved ${jsonPointer}:`, value);\n return value;\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = resolve;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resolvePath(object: any, parts: string[]): Promise<any> {\n let partIndex = 0;\n let currentObject = await resolveObject(object);\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);\n partIndex++;\n }\n\n return currentObject;\n}\n\nasync function resolveObject(object: any): 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);\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(resolver: Resolver, ref: string): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref);\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","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 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\n\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","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 { 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","cache","bundleAssetsResolver","url","promise","response","files","baseUrl","assets","file","deepFreeze","BASE_URL","expoRuntimeBranchResolver","branch","resolve","reject","tryUrls","release","data","e","expoRuntimeGetBranchResolver","expo","expoRuntimeResolver","httpResolver","loadAndWaitGlobal","scriptUrl","options","globalVar","timeoutMs","pollIntervalMs","isBrowser","loadInBrowser","waitForGlobal","loadInNode","script","cleanup","res","code","getter","name","start","check","legacyDataResolver","dataPromise","dataUrlBase","version","dataFilesAssets","map","manifest","populateDataJsAssetsMap","links","addLink","link","_a","img","s","resolvers","object","jsonPointer","resolveObject","parts","part","value","resolvePath","partIndex","currentObject","child","obj","resolversToUse","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","createFunction","args","functionToCall","error","key","val","deepClone","preconnectUrl","target","source","nonRefKeys","result","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.
|
|
3
|
+
"version": "1.0.32",
|
|
4
4
|
"description": "ExpoFP JavaScript loader library",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"homepage": "https://expofp.com",
|
|
@@ -29,7 +29,6 @@
|
|
|
29
29
|
"preview": "vite preview"
|
|
30
30
|
},
|
|
31
31
|
"devDependencies": {
|
|
32
|
-
"@types/js-untar": "^2.0.0",
|
|
33
32
|
"@types/node": "^24.10.0",
|
|
34
33
|
"jszip": "^3.10.1",
|
|
35
34
|
"typescript": "~5.9.3",
|