@expofp/loader 1.0.35 → 1.0.37
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 +170 -187
- package/dist/index.js.map +1 -1
- package/dist/resolve.d.ts +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -10,21 +10,21 @@ const T = {
|
|
|
10
10
|
// canResolve(ref: string) {
|
|
11
11
|
// return canResolveRefSchema(ref, SCHEMA_PREFIX_BASE);
|
|
12
12
|
// },
|
|
13
|
-
async resolveRef(e,
|
|
13
|
+
async resolveRef(e, r) {
|
|
14
14
|
var o, a;
|
|
15
|
-
if (l("bundleAssetsResolver resolveRef:", e), (o =
|
|
16
|
-
return
|
|
17
|
-
const
|
|
15
|
+
if (l("bundleAssetsResolver resolveRef:", e), (o = r.refCache) != null && o.has(e))
|
|
16
|
+
return r.refCache.get(e);
|
|
17
|
+
const t = p(e), n = fetch(t).then(async (s) => {
|
|
18
18
|
var c;
|
|
19
19
|
if (!s.ok)
|
|
20
20
|
throw new Error(`Failed to fetch ref from ${e}`);
|
|
21
|
-
(c =
|
|
22
|
-
const i = await s.json(), u =
|
|
21
|
+
(c = r.fetchCallback) == null || c.call(r, t, "json");
|
|
22
|
+
const i = await s.json(), u = t.substring(0, t.lastIndexOf("/") + 1), f = i.map((h) => ({
|
|
23
23
|
$ref: `asset+${u}${h}`
|
|
24
24
|
}));
|
|
25
25
|
return d(f), f;
|
|
26
26
|
});
|
|
27
|
-
return (a =
|
|
27
|
+
return (a = r.refCache) == null || a.set(e, n), n;
|
|
28
28
|
},
|
|
29
29
|
// async *makeOfflineRef(ref: string) {
|
|
30
30
|
// log('bundleAssetsResolver makeOfflineRef:', ref);
|
|
@@ -55,25 +55,25 @@ const T = {
|
|
|
55
55
|
// yield { data, targetFilePath };
|
|
56
56
|
// return { $ref: targetFilePath, [STOP_RESOLVING]: true };
|
|
57
57
|
// },
|
|
58
|
-
}, U = "https://efp-runtime.expofp.com/",
|
|
58
|
+
}, U = "https://efp-runtime.expofp.com/", P = {
|
|
59
59
|
schema: "expo-runtime-branch",
|
|
60
60
|
// canResolve(ref: string) {
|
|
61
61
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
62
62
|
// },
|
|
63
|
-
async resolveRef(e,
|
|
63
|
+
async resolveRef(e, r) {
|
|
64
64
|
var o, a;
|
|
65
|
-
if (l("expoRuntimeBranchResolver resolveRef:", e), (o =
|
|
66
|
-
return
|
|
67
|
-
const
|
|
65
|
+
if (l("expoRuntimeBranchResolver resolveRef:", e), (o = r.refCache) != null && o.has(e))
|
|
66
|
+
return r.refCache.get(e);
|
|
67
|
+
const t = p(e), n = new Promise(async (s, i) => {
|
|
68
68
|
var u;
|
|
69
69
|
try {
|
|
70
|
-
const f = [`${U}branches/${
|
|
70
|
+
const f = [`${U}branches/${t}.json`];
|
|
71
71
|
let c;
|
|
72
72
|
for (const m of f) {
|
|
73
73
|
l("Fetching HTTP:", m);
|
|
74
74
|
const v = await fetch(m);
|
|
75
75
|
if (v.ok) {
|
|
76
|
-
(u =
|
|
76
|
+
(u = r.fetchCallback) == null || u.call(r, m, "json"), c = await v.json();
|
|
77
77
|
break;
|
|
78
78
|
}
|
|
79
79
|
}
|
|
@@ -87,7 +87,7 @@ const T = {
|
|
|
87
87
|
i(f);
|
|
88
88
|
}
|
|
89
89
|
});
|
|
90
|
-
return (a =
|
|
90
|
+
return (a = r.refCache) == null || a.set(e, n), n;
|
|
91
91
|
},
|
|
92
92
|
// async *makeOfflineRef(ref: string) {
|
|
93
93
|
// log('expoRuntimeBranchResolver makeOfflineRef:', ref);
|
|
@@ -107,29 +107,29 @@ const T = {
|
|
|
107
107
|
// return targetFilePath;
|
|
108
108
|
// },
|
|
109
109
|
offlineMethod: "resolveRef"
|
|
110
|
-
},
|
|
110
|
+
}, D = {
|
|
111
111
|
schema: "expo-runtime-get-branch",
|
|
112
112
|
// canResolve(ref: string) {
|
|
113
113
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
114
114
|
// },
|
|
115
|
-
async resolveRef(e,
|
|
115
|
+
async resolveRef(e, r) {
|
|
116
116
|
var a, s;
|
|
117
|
-
if (l("expoRuntimeGetBranchResolver resolveRef:", e), (a =
|
|
118
|
-
return
|
|
119
|
-
const
|
|
117
|
+
if (l("expoRuntimeGetBranchResolver resolveRef:", e), (a = r.refCache) != null && a.has(e))
|
|
118
|
+
return r.refCache.get(e);
|
|
119
|
+
const t = p(e), n = `https://${t}.expofp.com/get-branch`;
|
|
120
120
|
l("Fetching HTTP:", n);
|
|
121
121
|
const o = fetch(n).then(async (i) => {
|
|
122
122
|
var h;
|
|
123
123
|
if (!i.ok)
|
|
124
124
|
throw new Error(`Failed to fetch ref from ${e}`);
|
|
125
|
-
(h =
|
|
125
|
+
(h = r.fetchCallback) == null || h.call(r, n, "json");
|
|
126
126
|
const f = (await i.json()).branch;
|
|
127
127
|
if (!f)
|
|
128
|
-
throw new Error(`Invalid response when fetching branch for expo ${
|
|
128
|
+
throw new Error(`Invalid response when fetching branch for expo ${t}`);
|
|
129
129
|
const c = { $ref: `expo-runtime-branch:${f}` };
|
|
130
130
|
return d(c), c;
|
|
131
131
|
});
|
|
132
|
-
return (s =
|
|
132
|
+
return (s = r.refCache) == null || s.set(e, o), o;
|
|
133
133
|
},
|
|
134
134
|
// async *makeOfflineRef(ref: string) {
|
|
135
135
|
// log('expoRuntimeBranchResolver makeOfflineRef:', ref);
|
|
@@ -149,18 +149,18 @@ const T = {
|
|
|
149
149
|
// return targetFilePath;
|
|
150
150
|
// },
|
|
151
151
|
offlineMethod: "resolveRef"
|
|
152
|
-
},
|
|
152
|
+
}, N = {
|
|
153
153
|
schema: "expo-runtime",
|
|
154
154
|
// canResolve(ref: string) {
|
|
155
155
|
// return canResolveRefSchema(ref, SCHEMA);
|
|
156
156
|
// },
|
|
157
157
|
async resolveRef(e) {
|
|
158
158
|
l("expoRuntimeResolver resolveRef:", e);
|
|
159
|
-
const
|
|
160
|
-
entry: { $ref: `asset+${
|
|
161
|
-
assets: { $ref: `bundle-assets+${
|
|
159
|
+
const r = p(e), t = {
|
|
160
|
+
entry: { $ref: `asset+${r}expofp.js` },
|
|
161
|
+
assets: { $ref: `bundle-assets+${r}bundle.json` }
|
|
162
162
|
};
|
|
163
|
-
return d(
|
|
163
|
+
return d(t), t;
|
|
164
164
|
},
|
|
165
165
|
// async *makeOfflineRef(ref: string) {
|
|
166
166
|
// log('expoRuntimeResolver makeOfflineRef:', ref);
|
|
@@ -180,68 +180,51 @@ const T = {
|
|
|
180
180
|
// return targetFilePath;
|
|
181
181
|
// },
|
|
182
182
|
offlineMethod: "resolveRef"
|
|
183
|
-
},
|
|
183
|
+
}, S = {
|
|
184
184
|
canResolve(e) {
|
|
185
185
|
return e.startsWith("http://") || e.startsWith("https://") || e.startsWith("./");
|
|
186
186
|
},
|
|
187
|
-
async resolveRef(e,
|
|
187
|
+
async resolveRef(e, r) {
|
|
188
188
|
var n, o;
|
|
189
189
|
if (l("httpResolver resolveRef:", e), !this.canResolve(e)) throw new Error(`Unexpected ref in httpResolver: ${e}`);
|
|
190
|
-
if ((n =
|
|
191
|
-
return
|
|
190
|
+
if ((n = r.refCache) != null && n.has(e))
|
|
191
|
+
return r.refCache.get(e);
|
|
192
192
|
l("Fetching HTTP ref:", e);
|
|
193
|
-
const
|
|
193
|
+
const t = fetch(e).then(async (a) => {
|
|
194
194
|
var i;
|
|
195
195
|
if (!a.ok)
|
|
196
196
|
throw new Error(`Failed to fetch ref from ${e}`);
|
|
197
|
-
(i =
|
|
197
|
+
(i = r.fetchCallback) == null || i.call(r, e, "json");
|
|
198
198
|
const s = await a.json();
|
|
199
199
|
return d(s), s;
|
|
200
200
|
});
|
|
201
|
-
return (o =
|
|
201
|
+
return (o = r.refCache) == null || o.set(e, t), t;
|
|
202
202
|
},
|
|
203
|
-
// async *makeOfflineRef(ref) {
|
|
204
|
-
// log('httpResolver makeOfflineRef:', ref);
|
|
205
|
-
// if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);
|
|
206
|
-
// // objects data may be changed by further processing
|
|
207
|
-
// const refData = deepClone(await this.resolveRef(ref));
|
|
208
|
-
// const targetFilePath = makeUniqueJsonTargetPathFromString(ref, 'http');
|
|
209
|
-
// const data = yield* makeOfflineInternal(refData);
|
|
210
|
-
// yield { data, targetFilePath };
|
|
211
|
-
// return { $ref: targetFilePath, [STOP_RESOLVING]: true };
|
|
212
|
-
// },
|
|
213
|
-
// async *makeOfflineRef2(ref: string) {
|
|
214
|
-
// const refData = deepClone(await this.resolveRef(ref));
|
|
215
|
-
// const targetFilePath = makeUniqueJsonTargetPathFromString(ref);
|
|
216
|
-
// const data = yield* makeOfflineInternal(refData);
|
|
217
|
-
// yield { data, targetFilePath };
|
|
218
|
-
// return targetFilePath;
|
|
219
|
-
// },
|
|
220
203
|
offlineMethod: "resolveRef"
|
|
221
204
|
};
|
|
222
|
-
async function O(e,
|
|
223
|
-
const { globalVar:
|
|
224
|
-
|
|
225
|
-
() => globalThis[
|
|
226
|
-
|
|
205
|
+
async function O(e, r = {}) {
|
|
206
|
+
const { globalVar: t, timeoutMs: n = 1e4, pollIntervalMs: o = 10 } = r;
|
|
207
|
+
W() ? (await I(e), t && await _(() => window[t], t, n, o)) : (await z(e), t && await _(
|
|
208
|
+
() => globalThis[t],
|
|
209
|
+
t,
|
|
227
210
|
n,
|
|
228
211
|
o
|
|
229
212
|
));
|
|
230
213
|
}
|
|
231
|
-
function
|
|
214
|
+
function W() {
|
|
232
215
|
return typeof window < "u" && typeof document < "u";
|
|
233
216
|
}
|
|
234
217
|
function I(e) {
|
|
235
|
-
return new Promise((
|
|
218
|
+
return new Promise((r, t) => {
|
|
236
219
|
const n = document.createElement("script");
|
|
237
220
|
n.src = e, n.async = !0;
|
|
238
221
|
const o = () => {
|
|
239
222
|
n.onload = null, n.onerror = null;
|
|
240
223
|
};
|
|
241
224
|
n.onload = () => {
|
|
242
|
-
o(),
|
|
225
|
+
o(), r();
|
|
243
226
|
}, n.onerror = () => {
|
|
244
|
-
o(),
|
|
227
|
+
o(), t(new Error(`Failed to load script: ${e}`));
|
|
245
228
|
}, document.head.appendChild(n);
|
|
246
229
|
});
|
|
247
230
|
}
|
|
@@ -250,13 +233,13 @@ async function z(e) {
|
|
|
250
233
|
throw new Error(
|
|
251
234
|
"loadAndWaitGlobal: fetch is not available. Use Node 18+ or provide a global fetch."
|
|
252
235
|
);
|
|
253
|
-
const
|
|
254
|
-
if (!
|
|
255
|
-
throw new Error(`Failed to load script in Node (HTTP ${
|
|
256
|
-
const
|
|
257
|
-
(0, eval)(
|
|
236
|
+
const r = await fetch(e);
|
|
237
|
+
if (!r.ok)
|
|
238
|
+
throw new Error(`Failed to load script in Node (HTTP ${r.status}): ${e}`);
|
|
239
|
+
const t = await r.text();
|
|
240
|
+
(0, eval)(t);
|
|
258
241
|
}
|
|
259
|
-
function
|
|
242
|
+
function _(e, r, t, n) {
|
|
260
243
|
return new Promise((o, a) => {
|
|
261
244
|
const s = performance.now(), i = () => {
|
|
262
245
|
try {
|
|
@@ -264,8 +247,8 @@ function j(e, t, r, n) {
|
|
|
264
247
|
return o();
|
|
265
248
|
} catch {
|
|
266
249
|
}
|
|
267
|
-
if (performance.now() - s >=
|
|
268
|
-
return a(new Error(`Timed out after ${
|
|
250
|
+
if (performance.now() - s >= t)
|
|
251
|
+
return a(new Error(`Timed out after ${t} ms waiting for global "${r}"`));
|
|
269
252
|
setTimeout(i, n);
|
|
270
253
|
};
|
|
271
254
|
i();
|
|
@@ -274,16 +257,16 @@ function j(e, t, r, n) {
|
|
|
274
257
|
const J = {
|
|
275
258
|
schema: "legacy-data",
|
|
276
259
|
// canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),
|
|
277
|
-
async resolveRef(e,
|
|
260
|
+
async resolveRef(e, r) {
|
|
278
261
|
var n, o;
|
|
279
|
-
if (l("legacyDataResolver resolveRef:", e), (n =
|
|
280
|
-
return
|
|
281
|
-
const
|
|
282
|
-
var $,
|
|
262
|
+
if (l("legacyDataResolver resolveRef:", e), (n = r.refCache) != null && n.has(e))
|
|
263
|
+
return r.refCache.get(e);
|
|
264
|
+
const t = (async () => {
|
|
265
|
+
var $, E, C;
|
|
283
266
|
const a = p(e);
|
|
284
267
|
try {
|
|
285
268
|
const w = `${a}version.js`;
|
|
286
|
-
await O(w), ($ =
|
|
269
|
+
await O(w), ($ = r.fetchCallback) == null || $.call(r, w, "script");
|
|
287
270
|
} catch {
|
|
288
271
|
console.warn("Could not load version.js, proceeding without it");
|
|
289
272
|
}
|
|
@@ -301,130 +284,130 @@ const J = {
|
|
|
301
284
|
O(f, { globalVar: "__data" })
|
|
302
285
|
// injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),
|
|
303
286
|
// injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),
|
|
304
|
-
]), (
|
|
287
|
+
]), (E = r.fetchCallback) == null || E.call(r, u, "json"), (C = r.fetchCallback) == null || C.call(r, f, "script");
|
|
305
288
|
const c = globalThis.__data || {}, m = [...i, "data.js"].reduce((w, y) => (w[y] = { $ref: `asset+${a}${y}?v=${s}` }, w), {}), v = {
|
|
306
289
|
_to_remove_for_offline_to_work_dataUrlBase: a,
|
|
307
290
|
// dataFiles: dataFiles.reduce((map, file) => {
|
|
308
291
|
// map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };
|
|
309
292
|
// return map;
|
|
310
293
|
// }, {} as Record<string, { $ref: string }>),
|
|
311
|
-
legacyAssetUrls: { ...m, ...
|
|
294
|
+
legacyAssetUrls: { ...m, ...G(a, c) }
|
|
312
295
|
};
|
|
313
296
|
return d(v), v;
|
|
314
297
|
})();
|
|
315
|
-
return (o =
|
|
298
|
+
return (o = r.refCache) == null || o.set(e, t), t;
|
|
316
299
|
},
|
|
317
300
|
offlineMethod: "resolveRef"
|
|
318
301
|
};
|
|
319
|
-
function
|
|
320
|
-
const
|
|
302
|
+
function G(e, r) {
|
|
303
|
+
const t = /* @__PURE__ */ new Set();
|
|
321
304
|
function n(o) {
|
|
322
|
-
typeof o == "string" && o.length > 0 &&
|
|
305
|
+
typeof o == "string" && o.length > 0 && t.add(o);
|
|
323
306
|
}
|
|
324
|
-
return n(
|
|
307
|
+
return n(r.logo), r.exhibitors.forEach((o) => {
|
|
325
308
|
var a;
|
|
326
309
|
n(o.logo), (a = o.gallery) == null || a.forEach((s) => n(s));
|
|
327
|
-
}),
|
|
310
|
+
}), r.events.forEach((o) => {
|
|
328
311
|
var a;
|
|
329
312
|
n(o.logoFile), (a = o.speakers) == null || a.forEach((s) => {
|
|
330
313
|
n(s.photoFile);
|
|
331
314
|
});
|
|
332
|
-
}), Array.from(
|
|
315
|
+
}), Array.from(t).reduce((o, a) => (o[a] = { $ref: `asset+${e}${a}` }, o), {});
|
|
333
316
|
}
|
|
334
|
-
const
|
|
335
|
-
|
|
317
|
+
const H = [
|
|
318
|
+
S,
|
|
336
319
|
B,
|
|
337
320
|
T,
|
|
338
|
-
S,
|
|
339
321
|
N,
|
|
340
322
|
P,
|
|
323
|
+
D,
|
|
341
324
|
// expoResolver,
|
|
342
325
|
J
|
|
343
326
|
], L = /* @__PURE__ */ new Map();
|
|
344
|
-
async function R(e,
|
|
345
|
-
l("Resolving:",
|
|
327
|
+
async function R(e, r, t) {
|
|
328
|
+
l("Resolving:", r), typeof window < "u" && (window.__lastResolveObject = e);
|
|
346
329
|
let n;
|
|
347
|
-
!
|
|
330
|
+
!t || t.refCache === "global" ? n = L : (t == null ? void 0 : t.refCache) === "temp" ? n = /* @__PURE__ */ new Map() : (t == null ? void 0 : t.refCache) === "disable" ? n = void 0 : n = t == null ? void 0 : t.refCache;
|
|
348
331
|
const o = {
|
|
349
332
|
refCache: n,
|
|
350
|
-
fetchCallback:
|
|
333
|
+
fetchCallback: t == null ? void 0 : t.fetchCallback
|
|
351
334
|
};
|
|
352
|
-
if (typeof
|
|
353
|
-
throw new Error(`Invalid JSON Pointer (not a string): ${
|
|
354
|
-
if (!
|
|
355
|
-
throw new Error(`Invalid JSON Pointer: ${
|
|
356
|
-
if (
|
|
357
|
-
throw new Error(`Invalid JSON Pointer: ${
|
|
335
|
+
if (typeof r != "string")
|
|
336
|
+
throw new Error(`Invalid JSON Pointer (not a string): ${r}`);
|
|
337
|
+
if (!r.startsWith("/"))
|
|
338
|
+
throw new Error(`Invalid JSON Pointer: ${r}`);
|
|
339
|
+
if (r.length > 1 && r.endsWith("/"))
|
|
340
|
+
throw new Error(`Invalid JSON Pointer: ${r}`);
|
|
358
341
|
let a;
|
|
359
|
-
if (
|
|
360
|
-
throw new Error(`Invalid JSON Pointer (empty part): ${
|
|
361
|
-
if (
|
|
342
|
+
if (r === "/" ? a = [] : a = r.substring(1).split("/"), a.some((s) => s.length === 0))
|
|
343
|
+
throw new Error(`Invalid JSON Pointer (empty part): ${r}`);
|
|
344
|
+
if (t != null && t.mutate) {
|
|
362
345
|
a.unshift("root");
|
|
363
346
|
const s = { root: e };
|
|
364
|
-
await
|
|
347
|
+
await j(s, a, 0, o), X(e, s.root);
|
|
365
348
|
} else
|
|
366
349
|
return await F(e, a, 0, o);
|
|
367
350
|
}
|
|
368
|
-
async function
|
|
369
|
-
const o = t
|
|
370
|
-
if (await V(e, o, n),
|
|
351
|
+
async function j(e, r, t, n) {
|
|
352
|
+
const o = r[t];
|
|
353
|
+
if (await V(e, o, n), t != r.length - 1) {
|
|
371
354
|
if (e[o] === null || typeof e[o] != "object")
|
|
372
355
|
throw new Error(
|
|
373
|
-
`Cannot resolve path, encountered non-object at part '${
|
|
356
|
+
`Cannot resolve path, encountered non-object at part '${r.slice(1).join("/")}', index ${t - 1}'`
|
|
374
357
|
);
|
|
375
|
-
return await
|
|
358
|
+
return await j(e[o], r, t + 1, n);
|
|
376
359
|
}
|
|
377
360
|
}
|
|
378
|
-
async function V(e,
|
|
379
|
-
l("resolveObjectMutate:", e,
|
|
380
|
-
let n = e[
|
|
381
|
-
const o = await g(n,
|
|
382
|
-
o !== void 0 && (e[
|
|
361
|
+
async function V(e, r, t) {
|
|
362
|
+
l("resolveObjectMutate:", e, r);
|
|
363
|
+
let n = e[r];
|
|
364
|
+
const o = await g(n, t);
|
|
365
|
+
o !== void 0 && (e[r] = o);
|
|
383
366
|
}
|
|
384
|
-
async function F(e,
|
|
385
|
-
if (
|
|
367
|
+
async function F(e, r, t, n) {
|
|
368
|
+
if (t === r.length)
|
|
386
369
|
return await g(e, n);
|
|
387
370
|
if (e === null || typeof e != "object")
|
|
388
371
|
throw new Error(
|
|
389
|
-
`Cannot resolve path, encountered non-object at part '${
|
|
372
|
+
`Cannot resolve path, encountered non-object at part '${r.join("/")}', index ${t}'`
|
|
390
373
|
);
|
|
391
|
-
const o = t
|
|
374
|
+
const o = r[t];
|
|
392
375
|
let a = e[o];
|
|
393
|
-
return a === void 0 && (a = (await g(e, n))[o]), await F(a,
|
|
376
|
+
return a === void 0 && (a = (await g(e, n))[o]), await F(a, r, t + 1, n);
|
|
394
377
|
}
|
|
395
|
-
async function g(e,
|
|
378
|
+
async function g(e, r) {
|
|
396
379
|
l("resolveObject:", e);
|
|
397
|
-
let
|
|
380
|
+
let t = e;
|
|
398
381
|
do {
|
|
399
|
-
if (typeof
|
|
400
|
-
return
|
|
401
|
-
const n =
|
|
382
|
+
if (typeof t != "object" || t === null || !("$ref" in t))
|
|
383
|
+
return t;
|
|
384
|
+
const n = H.filter((a) => M(a, t.$ref));
|
|
402
385
|
if (n.length === 0) {
|
|
403
|
-
if (
|
|
404
|
-
throw new Error(`No resolver found for ref: ${
|
|
405
|
-
return d(
|
|
386
|
+
if (t.$ref)
|
|
387
|
+
throw new Error(`No resolver found for ref: ${t.$ref}`);
|
|
388
|
+
return d(t), t;
|
|
406
389
|
}
|
|
407
390
|
if (n.length > 1)
|
|
408
|
-
throw new Error(`Multiple resolvers can resolve ref: ${
|
|
409
|
-
const o = await Z(n[0],
|
|
410
|
-
|
|
391
|
+
throw new Error(`Multiple resolvers can resolve ref: ${t.$ref}`);
|
|
392
|
+
const o = await Z(n[0], t.$ref, r);
|
|
393
|
+
t = Q(o, t);
|
|
411
394
|
} while (!0);
|
|
412
395
|
}
|
|
413
|
-
async function Z(e,
|
|
414
|
-
if (!M(e,
|
|
415
|
-
throw new Error(`Unexpected ref: ${
|
|
416
|
-
return e.resolveRef(
|
|
396
|
+
async function Z(e, r, t) {
|
|
397
|
+
if (!M(e, r))
|
|
398
|
+
throw new Error(`Unexpected ref: ${r}`);
|
|
399
|
+
return e.resolveRef(r, t);
|
|
417
400
|
}
|
|
418
|
-
function M(e,
|
|
401
|
+
function M(e, r) {
|
|
419
402
|
if (e.canResolve)
|
|
420
|
-
return e.canResolve(
|
|
403
|
+
return e.canResolve(r);
|
|
421
404
|
if (e.schema)
|
|
422
|
-
return K(
|
|
405
|
+
return K(r, e.schema);
|
|
423
406
|
throw new Error("Resolver is missing canResolve method and schema property");
|
|
424
407
|
}
|
|
425
|
-
function K(e,
|
|
426
|
-
const
|
|
427
|
-
for (const n of
|
|
408
|
+
function K(e, r) {
|
|
409
|
+
const t = [`${r}+`, `${r}:`];
|
|
410
|
+
for (const n of t)
|
|
428
411
|
if (e.startsWith(n))
|
|
429
412
|
return !0;
|
|
430
413
|
return !1;
|
|
@@ -432,39 +415,39 @@ function K(e, t) {
|
|
|
432
415
|
function p(e) {
|
|
433
416
|
if (e.startsWith("http://") || e.startsWith("https://"))
|
|
434
417
|
return e;
|
|
435
|
-
const
|
|
436
|
-
if (t !== -1)
|
|
437
|
-
return e.substring(t + 1);
|
|
418
|
+
const r = e.indexOf("+http://"), t = e.indexOf("+https://");
|
|
438
419
|
if (r !== -1)
|
|
439
420
|
return e.substring(r + 1);
|
|
421
|
+
if (t !== -1)
|
|
422
|
+
return e.substring(t + 1);
|
|
440
423
|
const n = e.indexOf(":");
|
|
441
424
|
if (n !== -1)
|
|
442
425
|
return e.substring(n + 1);
|
|
443
426
|
throw new Error(`Error getting URL from: ${e}, no valid prefix found`);
|
|
444
427
|
}
|
|
445
|
-
typeof window < "u" && (window.__debugResolve = async function(
|
|
428
|
+
typeof window < "u" && (window.__debugResolve = async function(r, t, n) {
|
|
446
429
|
let o, a, s;
|
|
447
|
-
return typeof
|
|
430
|
+
return typeof r == "string" ? (o = window.__lastResolveObject, a = r, s = t) : (o = r, a = t, s = n), await R(o, a, s);
|
|
448
431
|
});
|
|
449
432
|
function b(e) {
|
|
450
|
-
return async (
|
|
433
|
+
return async (r, ...t) => {
|
|
451
434
|
try {
|
|
452
|
-
const a = (await import(await R(
|
|
453
|
-
return a(
|
|
435
|
+
const a = (await import(await R(r, "/runtime/entry")))[e];
|
|
436
|
+
return a(r, ...t);
|
|
454
437
|
} catch (n) {
|
|
455
438
|
throw console.error("efp-loader", `Error when trying to import and call "${e}":`, n), n;
|
|
456
439
|
}
|
|
457
440
|
};
|
|
458
441
|
}
|
|
459
442
|
function l(...e) {
|
|
460
|
-
console.debug("efp-loader", ...e);
|
|
443
|
+
globalThis.__EFP_LOADER_DEBUG__ && console.debug("efp-loader", ...e);
|
|
461
444
|
}
|
|
462
445
|
function d(e) {
|
|
463
446
|
if (e === null || typeof e != "object") return e;
|
|
464
447
|
Object.freeze(e);
|
|
465
|
-
for (const
|
|
466
|
-
const
|
|
467
|
-
typeof
|
|
448
|
+
for (const r of Object.keys(e)) {
|
|
449
|
+
const t = e[r];
|
|
450
|
+
typeof t == "object" && t !== null && !Object.isFrozen(t) && d(t);
|
|
468
451
|
}
|
|
469
452
|
return e;
|
|
470
453
|
}
|
|
@@ -473,71 +456,71 @@ function k(e) {
|
|
|
473
456
|
}
|
|
474
457
|
function q(e) {
|
|
475
458
|
if (typeof document > "u") return;
|
|
476
|
-
const
|
|
477
|
-
|
|
459
|
+
const r = document.createElement("link");
|
|
460
|
+
r.rel = "preconnect", r.href = e, r.crossOrigin = "anonymous", document.head.appendChild(r);
|
|
478
461
|
}
|
|
479
|
-
function Q(e,
|
|
480
|
-
if (e ===
|
|
481
|
-
if (
|
|
462
|
+
function Q(e, r) {
|
|
463
|
+
if (e === r) return;
|
|
464
|
+
if (r === null || typeof r != "object")
|
|
482
465
|
throw new Error("Cannot merge non-object source");
|
|
483
|
-
if (Array.isArray(
|
|
466
|
+
if (Array.isArray(r))
|
|
484
467
|
throw new Error("Cannot merge arrays");
|
|
485
|
-
const
|
|
486
|
-
if (
|
|
468
|
+
const t = Object.keys(r).filter((o) => o !== "$ref");
|
|
469
|
+
if (t.length === 0) return k(e);
|
|
487
470
|
if (Array.isArray(e))
|
|
488
471
|
throw new Error("Cannot merge into arrays");
|
|
489
472
|
if (e === null || typeof e != "object")
|
|
490
473
|
throw new Error("Cannot merge into non-object target");
|
|
491
474
|
const n = k({ ...e });
|
|
492
|
-
for (const o of
|
|
493
|
-
n[o] =
|
|
475
|
+
for (const o of t)
|
|
476
|
+
n[o] = r[o];
|
|
494
477
|
return n;
|
|
495
478
|
}
|
|
496
|
-
function X(e,
|
|
497
|
-
if (e !==
|
|
498
|
-
if (
|
|
479
|
+
function X(e, r) {
|
|
480
|
+
if (e !== r) {
|
|
481
|
+
if (r === null || typeof r != "object")
|
|
499
482
|
throw new Error("Cannot replace with non-object source");
|
|
500
483
|
if (e === null || typeof e != "object")
|
|
501
484
|
throw new Error("Cannot replace non-object target");
|
|
502
485
|
if (Array.isArray(e)) {
|
|
503
|
-
if (!Array.isArray(
|
|
486
|
+
if (!Array.isArray(r))
|
|
504
487
|
throw new Error("replaceObjectFields does not support mixing arrays and objects");
|
|
505
488
|
e.length = 0;
|
|
506
|
-
for (const
|
|
507
|
-
e.push(
|
|
489
|
+
for (const t of r)
|
|
490
|
+
e.push(t);
|
|
508
491
|
return;
|
|
509
492
|
}
|
|
510
|
-
for (const
|
|
511
|
-
|
|
512
|
-
for (const
|
|
513
|
-
e[
|
|
493
|
+
for (const t of Object.keys(e))
|
|
494
|
+
t in r || delete e[t];
|
|
495
|
+
for (const t of Object.keys(r))
|
|
496
|
+
e[t] = r[t];
|
|
514
497
|
}
|
|
515
498
|
}
|
|
516
|
-
async function Y(e,
|
|
517
|
-
if (
|
|
499
|
+
async function Y(e, r, t) {
|
|
500
|
+
if (t || (t = { refCache: /* @__PURE__ */ new Map(), mutate: !0 }), !t.mutate)
|
|
518
501
|
throw new Error("resolveContext.mutate must be true for mutateManifest");
|
|
519
|
-
for (const n of
|
|
520
|
-
await R(e, n,
|
|
502
|
+
for (const n of r)
|
|
503
|
+
await R(e, n, t);
|
|
521
504
|
}
|
|
522
505
|
typeof window < "u" && (window.__debugMutateManifest = Y);
|
|
523
506
|
async function x(e) {
|
|
524
|
-
const { makeOfflineBundle:
|
|
525
|
-
return await
|
|
507
|
+
const { makeOfflineBundle: r } = await import("./makeOfflineBundle-BXfViegK.js");
|
|
508
|
+
return await r(e);
|
|
526
509
|
}
|
|
527
510
|
async function ee(e) {
|
|
528
|
-
const { downloadZip:
|
|
529
|
-
return await
|
|
511
|
+
const { downloadZip: r } = await import("./downloadZip-CKCMYGtc.js");
|
|
512
|
+
return await r(e);
|
|
530
513
|
}
|
|
531
|
-
async function
|
|
532
|
-
const { makeOffline:
|
|
533
|
-
for await (const n of (await
|
|
514
|
+
async function re(e) {
|
|
515
|
+
const { makeOffline: r } = await import("./makeOffline-CttQujH7.js"), t = await r(e);
|
|
516
|
+
for await (const n of (await t).files)
|
|
534
517
|
"data" in n ? console.info(`🗳️ Put ${n.targetFilePath} <=`, n.data) : "url" in n && console.info(`🗳️ Download ${n.targetFilePath} <= ${n.url}`);
|
|
535
|
-
console.info("Offline data: ",
|
|
518
|
+
console.info("Offline data: ", t.manifest);
|
|
536
519
|
}
|
|
537
|
-
typeof window < "u" && (window.__debugDownloadZip = ee, window.__debugMakeOfflineBundle = x, window.__debugLogOfflineManifestFiles =
|
|
538
|
-
const
|
|
539
|
-
async function ae(e,
|
|
540
|
-
return await b(e)(
|
|
520
|
+
typeof window < "u" && (window.__debugDownloadZip = ee, window.__debugMakeOfflineBundle = x, window.__debugLogOfflineManifestFiles = re);
|
|
521
|
+
const te = b("mount"), ne = b("load"), oe = b("initialize");
|
|
522
|
+
async function ae(e, r, ...t) {
|
|
523
|
+
return await b(e)(r, ...t);
|
|
541
524
|
}
|
|
542
525
|
q("https://efp-runtime.expofp.com/");
|
|
543
526
|
export {
|
|
@@ -551,10 +534,10 @@ export {
|
|
|
551
534
|
l,
|
|
552
535
|
ne as load,
|
|
553
536
|
x as makeOfflineBundle,
|
|
554
|
-
|
|
537
|
+
te as mount,
|
|
555
538
|
Y as mutateManifest,
|
|
556
539
|
p,
|
|
557
|
-
|
|
540
|
+
H as r,
|
|
558
541
|
R as resolve
|
|
559
542
|
};
|
|
560
543
|
//# sourceMappingURL=index.js.map
|
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/mutateManifest.ts","../src/offline/index.ts","../src/index.ts"],"sourcesContent":["import { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport function resolveAssetRefSync(ref: string): string {\n log('assetResolver resolveRef:', ref);\n // if (!assetResolver.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n return parseRefValue(ref);\n}\n\nexport const assetResolver = {\n schema: 'asset',\n resolveRef: async (ref: string) => resolveAssetRefSync(ref),\n offlineMethod: 'localizeRef',\n} satisfies Resolver;\n\n// async *makeOfflineRef(ref: string) {\n// log('assetResolver makeOfflineRef:', ref);\n// if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return { $ref: `asset:${targetFilePath}`, [STOP_RESOLVING]: true };\n// },\n// async *makeOfflineRef2(ref: string) {\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return `asset:${targetFilePath}`;\n// },\n","import { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA_PREFIX_BASE = 'bundle-assets';\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, context: ResolveContextInternal) {\n log('bundleAssetsResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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, type ResolveContextInternal } 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\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n async resolveRef(ref, context) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(ref, 'json');\n // options.assetCallback(ref, data)\n const data = await response.json();\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n context.refCache?.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, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n // canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('legacyDataResolver resolveRef:', ref);\n\n if (context.refCache?.has(ref)) {\n return context.refCache.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 const versionUrl = `${dataUrlBase}version.js`;\n await loadAndWaitGlobal(versionUrl);\n context.fetchCallback?.(versionUrl, '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 const filesUrl = `${dataUrlBase}files.json?v=${version}`;\n const dataUrl = `${dataUrlBase}data.js?v=${version}`;\n await Promise.all([\n (async function fetchFiles() {\n const response = await fetch(filesUrl);\n if (response.ok) {\n files = await response.json();\n } else\n throw new Error(`Could not load files.json from ${dataUrlBase}files.json?v=${version}`);\n })(),\n loadAndWaitGlobal(dataUrl, { globalVar: '__data' }),\n // injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),\n // injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),\n ]);\n context.fetchCallback?.(filesUrl, 'json');\n context.fetchCallback?.(dataUrl, 'js');\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 context.refCache?.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 {\n createMergedObjectWithOverridenNonRefProps,\n deepFreeze,\n log,\n replaceObjectFields,\n} from './shared';\nimport type { Resolver } from './types';\n\nexport interface ResolveContextInternal {\n refCache?: Map<string, Promise<any>>;\n /**\n * Callback invoked when a URL is fetched.\n */\n fetchCallback?: (url: string, type: 'json' | 'js') => void;\n}\n\nexport interface ResolveOptions extends Omit<ResolveContextInternal, 'refCache'> {\n /**\n * A cache for resolved references. Can be:\n * - A Map to use as the cache\n * - 'global' to use a global shared cache (default)\n * - 'temp' to use a temporary cache for this resolution only\n * - 'disable' to not use any cache\n */\n refCache?: Map<string, Promise<any>> | 'global' | 'temp' | 'disable';\n /**\n * Mutate original object during resolution.\n */\n mutate?: boolean;\n}\n\nconst globalResolveCache = new Map<string, Promise<any>>();\n\n/**\n * Resolves a value from an object using a JSON Pointer RFC 6901.\n *\n * @param object - The object to resolve the value from\n * @param jsonPointer - A JSON Pointer string that must start with '/'\n * @param options - Optional context for resolution, including cache and fetch callback\n * @returns A promise that resolves to the value at the specified JSON Pointer path\n * @throws {Error} If the JSON Pointer is not valid or if a $ref cannot be resolved\n *\n * @example\n * ```typescript\n * const obj = { foo: { bar: 'baz' } };\n * const result = await resolve(obj, '/foo/bar');\n * // result === 'baz'\n * ```\n */\nexport async function resolve(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n): Promise<any> {\n log('Resolving:', jsonPointer);\n if (typeof window !== 'undefined') {\n (window as any)['__lastResolveObject'] = object;\n }\n\n let refCache: Map<string, Promise<any>> | undefined;\n if (!options || options.refCache === 'global') {\n refCache = globalResolveCache;\n } else if (options?.refCache === 'temp') {\n refCache = new Map<string, Promise<any>>();\n } else if (options?.refCache === 'disable') {\n refCache = undefined;\n } else {\n refCache = options?.refCache;\n }\n\n const resolveContext: ResolveContextInternal = {\n refCache,\n fetchCallback: options?.fetchCallback,\n };\n\n if (typeof jsonPointer !== 'string') {\n throw new Error(`Invalid JSON Pointer (not a string): ${jsonPointer}`);\n }\n if (!jsonPointer.startsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n if (jsonPointer.length > 1 && jsonPointer.endsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n // if (jsonPointer === '/') {\n // const result = await resolveObject(object, resolveContext);\n // if (options?.mutate) {\n // replaceObjectFields(object, result);\n // }\n // return result;\n // }\n\n let parts: string[];\n if (jsonPointer === '/') {\n parts = [];\n } else {\n parts = jsonPointer.substring(1).split('/');\n }\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n if (options?.mutate) {\n // prepend parts with 'root'\n parts.unshift('root');\n const target = { root: object };\n await resovlePartsRecursiveMutate(target, parts, 0, resolveContext);\n replaceObjectFields(object, target.root);\n } else {\n return await resovlePartsRecursive(object, parts, 0, resolveContext);\n }\n // prepend parts with 'root'\n // parts.unshift('root');\n // // if (parts.some((part) => part.length === 0))\n // // throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n // const target = { root: object };\n // const value = await resovlePartsRecursiveMutate(\n // target,\n // // 'root',\n // parts,\n // 0,\n // resolveContext\n // );\n // if (options?.mutate) {\n // replaceObjectFields(object, target.root);\n // }\n // log(`Resolved ${jsonPointer}:`, value);\n // return value;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursiveMutate(\n node: any,\n // key: string,\n parts: string[],\n partsIndex: number,\n context: ResolveContextInternal\n): Promise<void> {\n const key = parts[partsIndex];\n // console.warn('in', key);\n\n await resolveObjectMutate(node, key, context);\n if (partsIndex == parts.length - 1) return;\n\n if (node[key] === null || typeof node[key] !== 'object') {\n // console.error('Cannot resolve path, encountered non-object:', node, key);\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.slice(1).join('/')}', index ${\n partsIndex - 1\n }'`\n );\n }\n return await resovlePartsRecursiveMutate(node[key], parts, partsIndex + 1, context);\n}\n\nasync function resolveObjectMutate(\n node: any,\n key: string,\n context: ResolveContextInternal\n): Promise<void> {\n log('resolveObjectMutate:', node, key);\n let obj = node[key];\n const result = await resolveObject(obj, context);\n if (result !== undefined) node[key] = result;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursive(\n object: any,\n parts: string[],\n index: number,\n context: ResolveContextInternal\n): Promise<any> {\n // should return undefined if last part not found\n // if not last part found - throw error\n // do not resolve object if its children are not needed (needed part exist as key)\n if (index === parts.length) {\n // console.warn('Resolving last part:', object);\n return await resolveObject(object, context);\n }\n if (object === null || typeof object !== 'object') {\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n );\n }\n const part = parts[index];\n let child = object[part];\n if (child === undefined) {\n // console.warn('Resolving, part not found during resolve:', part, object);\n const resolvedObject = await resolveObject(object, context);\n child = resolvedObject[part];\n }\n return await resovlePartsRecursive(child, parts, index + 1, context);\n}\n\nasync function resolveObject(object: any, context: ResolveContextInternal): Promise<any> {\n log('resolveObject:', object);\n let obj = object;\n\n do {\n if (typeof obj !== 'object' || obj === null || !('$ref' in obj)) {\n return obj;\n }\n const resolversToUse = resolvers.filter((r) => canResolve(r, obj.$ref));\n if (resolversToUse.length === 0) {\n if (obj.$ref) {\n throw new Error(`No resolver found for ref: ${obj.$ref}`);\n }\n deepFreeze(obj);\n return obj;\n }\n if (resolversToUse.length > 1) {\n throw new Error(`Multiple resolvers can resolve ref: ${obj.$ref}`);\n }\n\n const data = await resolverResolve(resolversToUse[0], obj.$ref, context);\n\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(\n resolver: Resolver,\n ref: string,\n context: ResolveContextInternal\n): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref, context);\n}\n\nexport function canResolve(resolver: Resolver, ref: string): boolean {\n if (resolver.canResolve) {\n return resolver.canResolve(ref);\n }\n if (resolver.schema) {\n return canResolveRefSchema(ref, resolver.schema);\n }\n throw new Error('Resolver is missing canResolve method and schema property');\n}\n\nexport function canResolveRefSchema(ref: string, prefixBase: string): boolean {\n const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n for (const prefix of prefixes) {\n if (ref.startsWith(prefix)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseRefValue(ref: string): string {\n // look for anything before \":\" or before +https:// or before +http://\n // https://www -> https://www\n // so some+base+https://www -> https://www\n // base+https://www -> https://www\n // base:abc -> abc\n // \"some-base\" can contain only non-:\n if (ref.startsWith('http://') || ref.startsWith('https://')) {\n return ref;\n }\n // if it is something+http:// or something+https://\n const plusHttpIndex = ref.indexOf('+http://');\n const plusHttpsIndex = ref.indexOf('+https://');\n if (plusHttpIndex !== -1) {\n return ref.substring(plusHttpIndex + 1);\n }\n if (plusHttpsIndex !== -1) {\n return ref.substring(plusHttpsIndex + 1);\n }\n // if it is something:abc\n const colonIndex = ref.indexOf(':');\n if (colonIndex !== -1) {\n return ref.substring(colonIndex + 1);\n }\n\n throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n}\n\n// export function parseRefValue(ref: string): string {\n// // look for anything before \":\" or before +https:// or before +http://\n// // https://www -> https://www\n// // so some+base+https://www -> https://www\n// // base+https://www -> https://www\n// // base:abc -> abc\n// // \"some-base\" can contain only non-:\n// if (ref.startsWith('http://') || ref.startsWith('https://')) {\n// return ref;\n// }\n// // if it is something+http:// or something+https://\n// const plusHttpIndex = ref.indexOf('+http://');\n// const plusHttpsIndex = ref.indexOf('+https://');\n// if (plusHttpIndex !== -1) {\n// return ref.substring(plusHttpIndex + 1);\n// }\n// if (plusHttpsIndex !== -1) {\n// return ref.substring(plusHttpsIndex + 1);\n// }\n// // if it is something:abc\n// const colonIndex = ref.indexOf(':');\n// if (colonIndex !== -1) {\n// return ref.substring(colonIndex + 1);\n// }\n\n// throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n\n// // const prefixBase = ref.split('+')[0].split(':')[0];\n// // if (!prefixBase) {\n// // throw new Error(`Invalid ref, missing prefix: ${ref}`);\n// // }\n// // return ref.substring(prefixBase.length + 1);\n\n// // const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// // for (const prefix of prefixes) {\n// // if (ref.startsWith(prefix)) {\n// // const url = ref.substring(prefix.length);\n// // if (!url) {\n// // throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// // }\n// // return url;\n// // }\n// // }\n\n// // throw new Error(\n// // `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// // );\n// }\n\n// export function parseRefValue(ref: string, prefixBase: string): string {\n// const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// for (const prefix of prefixes) {\n// if (ref.startsWith(prefix)) {\n// const url = ref.substring(prefix.length);\n// if (!url) {\n// throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// }\n// return url;\n// }\n// }\n\n// throw new Error(\n// `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// );\n// }\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = async function debugResolve(\n objectOrRef: any,\n refOrContext: any,\n context?: any\n ) {\n let object: any;\n let ref: string;\n let resolveContext: ResolveOptions | undefined;\n if (typeof objectOrRef === 'string') {\n object = (window as any)['__lastResolveObject'];\n ref = objectOrRef;\n resolveContext = refOrContext;\n } else {\n object = objectOrRef;\n ref = refOrContext;\n resolveContext = context;\n }\n return await resolve(object, ref, resolveContext);\n };\n}\n\n// if (index === parts.length - 1) {\n// return await resolveObject(object, context);\n// }\n// if (object === null || typeof object !== 'object') {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n// );\n// }\n// if (!(parts[0] in object)) {\n// return undefined;\n// }\n// let partIndex = 0;\n// let currentObject = await resolveObject(object, context);\n// while (partIndex < parts.length) {\n// const part = parts[partIndex];\n// if (typeof currentObject !== 'object' || currentObject === null) {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join(\n// '/'\n// )}, index ${partIndex}'`\n// );\n// }\n// // console.info(\n// // 'resolvePath currentObject:',\n// // part,\n// // JSON.stringify(currentObject, null, 2),\n// // currentObject[part]\n// // );\n// // debugger;\n// const child = currentObject[part];\n// currentObject = await resolveObject(child, context);\n// partIndex++;\n// }\n// return currentObject;\n","import { resolve } from './resolve';\n\n// export const NOT_APPLICABLE = Symbol('not-applicable');\n// export const STOP_RESOLVING = Symbol('STOP_RESOLVING');\n\nexport function createFunction(name: string) {\n return async (manifest: unknown, ...args: IArguments[]) => {\n try {\n const runtimeEntryPoint = await resolve(manifest, '/runtime/entry');\n const moduleExports = await import(/* @vite-ignore */ runtimeEntryPoint);\n const functionToCall = moduleExports[name];\n return functionToCall(manifest, ...args);\n } catch (error) {\n console.error('efp-loader', `Error when trying to import and call \"${name}\":`, error);\n throw error;\n }\n };\n}\n\nexport function log(...args: any[]) {\n console.debug('efp-loader', ...args);\n}\n\nexport function deepFreeze(obj: any) {\n if (obj === null || typeof obj !== 'object') return obj;\n\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const val = obj[key];\n if (typeof val === 'object' && val !== null && !Object.isFrozen(val)) {\n deepFreeze(val);\n }\n }\n\n return obj;\n}\n\nexport function deepClone<T>(obj: T): T {\n if ('structuredClone' in globalThis) {\n return (globalThis as any).structuredClone(obj);\n }\n return JSON.parse(JSON.stringify(obj));\n}\n\nexport function preloadJson(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preload';\n link.as = 'fetch';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n\nexport function preconnectUrl(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preconnect';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n// export function hashString(str: string): string {\n// let hash = 0;\n\n// for (let i = 0; i < str.length; i++) {\n// const chr = str.charCodeAt(i);\n// hash = (hash << 5) - hash + chr;\n// hash |= 0; // force 32-bit int\n// }\n\n// // >>> 0 makes it unsigned (no '-' in front)\n// return (hash >>> 0).toString(16); // hex, [0-9a-f]\n// }\n\n// Deterministic ID\n// export async function hashString(str: string): Promise<string> {\n// const encoder = new TextEncoder();\n// const data = encoder.encode(str);\n\n// const digest = await crypto.subtle.digest('SHA-1', data);\n// return bufferToHex(digest);\n// }\n\n// murmur32\n// export function hashString(str: string): string {\n// let h = 0x811c9dc5;\n\n// for (let i = 0; i < str.length; i++) {\n// h ^= str.charCodeAt(i);\n// h = Math.imul(h, 0x01000193);\n// }\n\n// return (h >>> 0).toString(16).padStart(24, '0');\n// }\n\n// function bufferToHex(buffer: ArrayBuffer): string {\n// const bytes = new Uint8Array(buffer);\n// let hex = '';\n// for (let i = 0; i < bytes.length; i++) {\n// const byteHex = bytes[i].toString(16).padStart(2, '0');\n// hex += byteHex;\n// }\n// return hex;\n// }\n\n// export function mergeNonRefFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonRefFields does not support merging arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonRefFields does not support merging into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function mergeNonExitingFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonExitingFields does not support merging arrays');\n// }\n\n// const keys = Object.keys(source);\n// if (keys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonExitingFields does not support merging into arrays');\n// }\n\n// for (const key of Object.keys(source)) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// if (!(key in target)) {\n// target[key] = source[key];\n// }\n// }\n// }\n\n// export function replaceObjectFields(target: any, source: any) {\n// if (target === source) {\n// throw new Error('Cannot replace object with itself');\n// }\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object') {\n// throw new Error('Cannot replace with non-object source');\n// }\n// // throw if any is array\n// if (Array.isArray(target) || Array.isArray(source)) {\n// throw new Error('replaceObjectFields does not support arrays');\n// }\n\n// // delete keys in target that are not in source\n// for (const key of Object.keys(target)) {\n// if (!(key in source)) {\n// delete target[key];\n// }\n// }\n\n// // copy keys from source to target\n// for (const key of Object.keys(source)) {\n// target[key] = source[key];\n// }\n// }\n\n// export function isObject(v: any): boolean {\n// return v !== null && typeof v === 'object' && !Array.isArray(v);\n// }\n\n// export function mergeOriginalFieldsIntoResolvedObject(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function createMergedObject(target: any, source: any) {\n// if (target === source) return; //throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return target;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// if (target === null || typeof target !== 'object') {\n// throw new Error('Cannot merge into non-object target');\n// }\n\n// const result = { ...target };\n// for (const key of nonRefKeys) {\n// result[key] = source[key];\n// }\n// deepFreeze(result);\n// return result;\n// }\n\nexport function createMergedObjectWithOverridenNonRefProps(target: any, source: any) {\n if (target === source) return; //throw new Error('Cannot merge object with itself');\n // if source is primitive, throw\n if (source === null || typeof source !== 'object')\n throw new Error('Cannot merge non-object source');\n if (Array.isArray(source)) {\n throw new Error('Cannot merge arrays');\n }\n const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n if (nonRefKeys.length === 0) return deepClone(target);\n\n // throw if any is array\n if (Array.isArray(target)) {\n throw new Error('Cannot merge into arrays');\n }\n\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot merge into non-object target');\n }\n\n const result = deepClone({ ...target });\n for (const key of nonRefKeys) {\n result[key] = source[key];\n }\n // deepFreeze(result);\n return result;\n}\n\nexport function replaceObjectFields(target: any, source: any): void {\n if (target === source) {\n return;\n // throw new Error('Cannot replace object with itself');\n }\n // if source is primitive, throw\n if (source === null || typeof source !== 'object') {\n throw new Error('Cannot replace with non-object source');\n }\n // if target is primitive, throw\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot replace non-object target');\n }\n\n if (Array.isArray(target)) {\n if (!Array.isArray(source)) {\n throw new Error('replaceObjectFields does not support mixing arrays and objects');\n }\n // both are arrays - replace contents\n target.length = 0;\n for (const item of source) {\n target.push(item);\n }\n return;\n }\n\n // delete keys in target that are not in source\n for (const key of Object.keys(target)) {\n if (!(key in source)) {\n delete target[key];\n }\n }\n\n // copy keys from source to target\n for (const key of Object.keys(source)) {\n target[key] = source[key];\n }\n}\n","import { resolve } from './resolve';\nimport type { ResolveOptions } from './resolve';\n\nexport async function mutateManifest(\n manifest: any,\n paths: string[],\n resolveContext?: ResolveOptions\n): Promise<void> {\n if (!resolveContext) {\n resolveContext = { refCache: new Map<string, Promise<any>>(), mutate: true };\n }\n if (!resolveContext.mutate) {\n throw new Error('resolveContext.mutate must be true for mutateManifest');\n }\n for (const path of paths) {\n await resolve(manifest, path, resolveContext);\n }\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugMutateManifest'] = mutateManifest;\n}\n","export async function makeOfflineBundle(manifest: unknown) {\n const { makeOfflineBundle } = await import('./makeOfflineBundle');\n return await makeOfflineBundle(manifest);\n}\n\nexport async function downloadZip(manifest: unknown) {\n const { downloadZip } = await import('./downloadZip');\n return await downloadZip(manifest);\n}\n\nasync function debugLogOfflineManifestFiles(manifest: unknown): Promise<void> {\n // console.log('Offline files:');\n const { makeOffline } = await import('./makeOffline');\n const result = await makeOffline(manifest);\n // const allFiles = [];\n for await (const file of (await result).files) {\n if ('data' in file) {\n console.info(`🗳️ Put ${file.targetFilePath} <=`, file.data);\n } else if ('url' in file) {\n console.info(`🗳️ Download ${file.targetFilePath} <= ${file.url}`);\n }\n // allFiles.push(file);\n }\n console.info('Offline data: ', result.manifest);\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugDownloadZip'] = downloadZip;\n (window as any)['__debugMakeOfflineBundle'] = makeOfflineBundle;\n (window as any)['__debugLogOfflineManifestFiles'] = debugLogOfflineManifestFiles;\n}\n","import { createFunction, preconnectUrl } from './shared';\n\nexport const mount = createFunction('mount');\nexport const load = createFunction('load');\nexport const initialize = createFunction('initialize');\n\n// extra\n// export const createFloorPlan = createFunction('createFloorPlan');\n// export const rewriteManifestToLocalFiles = createFunction('rewriteManifestToLocalFiles');\n\nexport async function callFunction_Experimental(\n name: string,\n manifest: unknown,\n ...args: IArguments[]\n) {\n const fn = createFunction(name);\n return await fn(manifest, ...args);\n}\n\nexport { resolve } from './resolve';\nexport { mutateManifest } from './mutateManifest';\nexport { makeOfflineBundle, downloadZip } from './offline';\n\n// preloadJson('https://efp-runtime.expofp.com/branches/main.json');\npreconnectUrl('https://efp-runtime.expofp.com/');\n"],"names":["resolveAssetRefSync","ref","log","parseRefValue","assetResolver","bundleAssetsResolver","context","_a","_b","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","_c","dataUrlBase","versionUrl","version","filesUrl","dataUrl","dataFilesAssets","map","manifest","populateDataJsAssetsMap","links","addLink","link","img","resolvers","globalResolveCache","object","jsonPointer","refCache","resolveContext","parts","part","target","resovlePartsRecursiveMutate","replaceObjectFields","resovlePartsRecursive","node","partsIndex","key","resolveObjectMutate","obj","result","resolveObject","index","child","resolversToUse","r","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","objectOrRef","refOrContext","createFunction","args","functionToCall","error","val","deepClone","preconnectUrl","source","nonRefKeys","item","mutateManifest","paths","path","makeOfflineBundle","downloadZip","debugLogOfflineManifestFiles","makeOffline","mount","load","initialize","callFunction_Experimental"],"mappings":"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"}
|
|
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/mutateManifest.ts","../src/offline/index.ts","../src/index.ts"],"sourcesContent":["import { parseRefValue } from '../resolve';\nimport { log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport function resolveAssetRefSync(ref: string): string {\n log('assetResolver resolveRef:', ref);\n // if (!assetResolver.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n\n return parseRefValue(ref);\n}\n\nexport const assetResolver = {\n schema: 'asset',\n resolveRef: async (ref: string) => resolveAssetRefSync(ref),\n offlineMethod: 'localizeRef',\n} satisfies Resolver;\n\n// async *makeOfflineRef(ref: string) {\n// log('assetResolver makeOfflineRef:', ref);\n// if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return { $ref: `asset:${targetFilePath}`, [STOP_RESOLVING]: true };\n// },\n// async *makeOfflineRef2(ref: string) {\n// const url = parseRefValue(ref);\n// const targetFilePath = makeTargetPathFromUrl(url);\n// yield { url, targetFilePath };\n// return `asset:${targetFilePath}`;\n// },\n","import { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA_PREFIX_BASE = 'bundle-assets';\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, context: ResolveContextInternal) {\n log('bundleAssetsResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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, type ResolveContextInternal } 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\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n // canResolve(ref: string) {\n // return canResolveRefSchema(ref, SCHEMA);\n // },\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n // if (!this.canResolve(ref)) throw new Error(`Unexpected ref: ${ref}`);\n if (context.refCache?.has(ref)) {\n return context.refCache.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 context.fetchCallback?.(url, 'json');\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 context.refCache?.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\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n async resolveRef(ref, context) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n\n if (context.refCache?.has(ref)) {\n return context.refCache.get(ref);\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 context.fetchCallback?.(ref, 'json');\n // options.assetCallback(ref, data)\n const data = await response.json();\n // deep freeze the data\n deepFreeze(data);\n return data;\n });\n context.refCache?.set(ref, promise);\n return promise;\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, type ResolveContextInternal } from '../resolve';\nimport { deepFreeze, log } from '../shared';\nimport type { Resolver } from '../types';\n\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n // canResolve: (ref: string) => canResolveRefSchema(ref, 'legacy-data-js'),\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('legacyDataResolver resolveRef:', ref);\n\n if (context.refCache?.has(ref)) {\n return context.refCache.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 const versionUrl = `${dataUrlBase}version.js`;\n await loadAndWaitGlobal(versionUrl);\n context.fetchCallback?.(versionUrl, 'script');\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 const filesUrl = `${dataUrlBase}files.json?v=${version}`;\n const dataUrl = `${dataUrlBase}data.js?v=${version}`;\n await Promise.all([\n (async function fetchFiles() {\n const response = await fetch(filesUrl);\n if (response.ok) {\n files = await response.json();\n } else\n throw new Error(`Could not load files.json from ${dataUrlBase}files.json?v=${version}`);\n })(),\n loadAndWaitGlobal(dataUrl, { globalVar: '__data' }),\n // injectAndWaitForGlobal(`${dataUrlBase}data.js?v=${version}`, '__data'),\n // injectAndWaitForGlobal(`${dataUrlBase}fp.svg.js?v=${version}`, '__fp'),\n ]);\n context.fetchCallback?.(filesUrl, 'json');\n context.fetchCallback?.(dataUrl, 'script');\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 context.refCache?.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 {\n createMergedObjectWithOverridenNonRefProps,\n deepFreeze,\n log,\n replaceObjectFields,\n} from './shared';\nimport type { Resolver } from './types';\n\nexport interface ResolveContextInternal {\n refCache?: Map<string, Promise<any>>;\n /**\n * Callback invoked when a URL is fetched.\n */\n fetchCallback?: (url: string, type: 'json' | 'script') => void;\n}\n\nexport interface ResolveOptions extends Omit<ResolveContextInternal, 'refCache'> {\n /**\n * A cache for resolved references. Can be:\n * - A Map to use as the cache\n * - 'global' to use a global shared cache (default)\n * - 'temp' to use a temporary cache for this resolution only\n * - 'disable' to not use any cache\n */\n refCache?: Map<string, Promise<any>> | 'global' | 'temp' | 'disable';\n /**\n * Mutate original object during resolution.\n */\n mutate?: boolean;\n}\n\nconst globalResolveCache = new Map<string, Promise<any>>();\n\n/**\n * Resolves a value from an object using a JSON Pointer RFC 6901.\n *\n * @param object - The object to resolve the value from\n * @param jsonPointer - A JSON Pointer string that must start with '/'\n * @param options - Optional context for resolution, including cache and fetch callback\n * @returns A promise that resolves to the value at the specified JSON Pointer path\n * @throws {Error} If the JSON Pointer is not valid or if a $ref cannot be resolved\n *\n * @example\n * ```typescript\n * const obj = { foo: { bar: 'baz' } };\n * const result = await resolve(obj, '/foo/bar');\n * // result === 'baz'\n * ```\n */\nexport async function resolve(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n): Promise<any> {\n log('Resolving:', jsonPointer);\n if (typeof window !== 'undefined') {\n (window as any)['__lastResolveObject'] = object;\n }\n\n let refCache: Map<string, Promise<any>> | undefined;\n if (!options || options.refCache === 'global') {\n refCache = globalResolveCache;\n } else if (options?.refCache === 'temp') {\n refCache = new Map<string, Promise<any>>();\n } else if (options?.refCache === 'disable') {\n refCache = undefined;\n } else {\n refCache = options?.refCache;\n }\n\n const resolveContext: ResolveContextInternal = {\n refCache,\n fetchCallback: options?.fetchCallback,\n };\n\n if (typeof jsonPointer !== 'string') {\n throw new Error(`Invalid JSON Pointer (not a string): ${jsonPointer}`);\n }\n if (!jsonPointer.startsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n if (jsonPointer.length > 1 && jsonPointer.endsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n // if (jsonPointer === '/') {\n // const result = await resolveObject(object, resolveContext);\n // if (options?.mutate) {\n // replaceObjectFields(object, result);\n // }\n // return result;\n // }\n\n let parts: string[];\n if (jsonPointer === '/') {\n parts = [];\n } else {\n parts = jsonPointer.substring(1).split('/');\n }\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n if (options?.mutate) {\n // prepend parts with 'root'\n parts.unshift('root');\n const target = { root: object };\n await resovlePartsRecursiveMutate(target, parts, 0, resolveContext);\n replaceObjectFields(object, target.root);\n } else {\n return await resovlePartsRecursive(object, parts, 0, resolveContext);\n }\n // prepend parts with 'root'\n // parts.unshift('root');\n // // if (parts.some((part) => part.length === 0))\n // // throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n // const target = { root: object };\n // const value = await resovlePartsRecursiveMutate(\n // target,\n // // 'root',\n // parts,\n // 0,\n // resolveContext\n // );\n // if (options?.mutate) {\n // replaceObjectFields(object, target.root);\n // }\n // log(`Resolved ${jsonPointer}:`, value);\n // return value;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursiveMutate(\n node: any,\n // key: string,\n parts: string[],\n partsIndex: number,\n context: ResolveContextInternal\n): Promise<void> {\n const key = parts[partsIndex];\n // console.warn('in', key);\n\n await resolveObjectMutate(node, key, context);\n if (partsIndex == parts.length - 1) return;\n\n if (node[key] === null || typeof node[key] !== 'object') {\n // console.error('Cannot resolve path, encountered non-object:', node, key);\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.slice(1).join('/')}', index ${\n partsIndex - 1\n }'`\n );\n }\n return await resovlePartsRecursiveMutate(node[key], parts, partsIndex + 1, context);\n}\n\nasync function resolveObjectMutate(\n node: any,\n key: string,\n context: ResolveContextInternal\n): Promise<void> {\n log('resolveObjectMutate:', node, key);\n let obj = node[key];\n const result = await resolveObject(obj, context);\n if (result !== undefined) node[key] = result;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursive(\n object: any,\n parts: string[],\n index: number,\n context: ResolveContextInternal\n): Promise<any> {\n // should return undefined if last part not found\n // if not last part found - throw error\n // do not resolve object if its children are not needed (needed part exist as key)\n if (index === parts.length) {\n // console.warn('Resolving last part:', object);\n return await resolveObject(object, context);\n }\n if (object === null || typeof object !== 'object') {\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n );\n }\n const part = parts[index];\n let child = object[part];\n if (child === undefined) {\n // console.warn('Resolving, part not found during resolve:', part, object);\n const resolvedObject = await resolveObject(object, context);\n child = resolvedObject[part];\n }\n return await resovlePartsRecursive(child, parts, index + 1, context);\n}\n\nasync function resolveObject(object: any, context: ResolveContextInternal): Promise<any> {\n log('resolveObject:', object);\n let obj = object;\n\n do {\n if (typeof obj !== 'object' || obj === null || !('$ref' in obj)) {\n return obj;\n }\n const resolversToUse = resolvers.filter((r) => canResolve(r, obj.$ref));\n if (resolversToUse.length === 0) {\n if (obj.$ref) {\n throw new Error(`No resolver found for ref: ${obj.$ref}`);\n }\n deepFreeze(obj);\n return obj;\n }\n if (resolversToUse.length > 1) {\n throw new Error(`Multiple resolvers can resolve ref: ${obj.$ref}`);\n }\n\n const data = await resolverResolve(resolversToUse[0], obj.$ref, context);\n\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(\n resolver: Resolver,\n ref: string,\n context: ResolveContextInternal\n): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref, context);\n}\n\nexport function canResolve(resolver: Resolver, ref: string): boolean {\n if (resolver.canResolve) {\n return resolver.canResolve(ref);\n }\n if (resolver.schema) {\n return canResolveRefSchema(ref, resolver.schema);\n }\n throw new Error('Resolver is missing canResolve method and schema property');\n}\n\nexport function canResolveRefSchema(ref: string, prefixBase: string): boolean {\n const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n for (const prefix of prefixes) {\n if (ref.startsWith(prefix)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseRefValue(ref: string): string {\n // look for anything before \":\" or before +https:// or before +http://\n // https://www -> https://www\n // so some+base+https://www -> https://www\n // base+https://www -> https://www\n // base:abc -> abc\n // \"some-base\" can contain only non-:\n if (ref.startsWith('http://') || ref.startsWith('https://')) {\n return ref;\n }\n // if it is something+http:// or something+https://\n const plusHttpIndex = ref.indexOf('+http://');\n const plusHttpsIndex = ref.indexOf('+https://');\n if (plusHttpIndex !== -1) {\n return ref.substring(plusHttpIndex + 1);\n }\n if (plusHttpsIndex !== -1) {\n return ref.substring(plusHttpsIndex + 1);\n }\n // if it is something:abc\n const colonIndex = ref.indexOf(':');\n if (colonIndex !== -1) {\n return ref.substring(colonIndex + 1);\n }\n\n throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n}\n\n// export function parseRefValue(ref: string): string {\n// // look for anything before \":\" or before +https:// or before +http://\n// // https://www -> https://www\n// // so some+base+https://www -> https://www\n// // base+https://www -> https://www\n// // base:abc -> abc\n// // \"some-base\" can contain only non-:\n// if (ref.startsWith('http://') || ref.startsWith('https://')) {\n// return ref;\n// }\n// // if it is something+http:// or something+https://\n// const plusHttpIndex = ref.indexOf('+http://');\n// const plusHttpsIndex = ref.indexOf('+https://');\n// if (plusHttpIndex !== -1) {\n// return ref.substring(plusHttpIndex + 1);\n// }\n// if (plusHttpsIndex !== -1) {\n// return ref.substring(plusHttpsIndex + 1);\n// }\n// // if it is something:abc\n// const colonIndex = ref.indexOf(':');\n// if (colonIndex !== -1) {\n// return ref.substring(colonIndex + 1);\n// }\n\n// throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n\n// // const prefixBase = ref.split('+')[0].split(':')[0];\n// // if (!prefixBase) {\n// // throw new Error(`Invalid ref, missing prefix: ${ref}`);\n// // }\n// // return ref.substring(prefixBase.length + 1);\n\n// // const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// // for (const prefix of prefixes) {\n// // if (ref.startsWith(prefix)) {\n// // const url = ref.substring(prefix.length);\n// // if (!url) {\n// // throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// // }\n// // return url;\n// // }\n// // }\n\n// // throw new Error(\n// // `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// // );\n// }\n\n// export function parseRefValue(ref: string, prefixBase: string): string {\n// const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// for (const prefix of prefixes) {\n// if (ref.startsWith(prefix)) {\n// const url = ref.substring(prefix.length);\n// if (!url) {\n// throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// }\n// return url;\n// }\n// }\n\n// throw new Error(\n// `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// );\n// }\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = async function debugResolve(\n objectOrRef: any,\n refOrContext: any,\n context?: any\n ) {\n let object: any;\n let ref: string;\n let resolveContext: ResolveOptions | undefined;\n if (typeof objectOrRef === 'string') {\n object = (window as any)['__lastResolveObject'];\n ref = objectOrRef;\n resolveContext = refOrContext;\n } else {\n object = objectOrRef;\n ref = refOrContext;\n resolveContext = context;\n }\n return await resolve(object, ref, resolveContext);\n };\n}\n\n// if (index === parts.length - 1) {\n// return await resolveObject(object, context);\n// }\n// if (object === null || typeof object !== 'object') {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n// );\n// }\n// if (!(parts[0] in object)) {\n// return undefined;\n// }\n// let partIndex = 0;\n// let currentObject = await resolveObject(object, context);\n// while (partIndex < parts.length) {\n// const part = parts[partIndex];\n// if (typeof currentObject !== 'object' || currentObject === null) {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join(\n// '/'\n// )}, index ${partIndex}'`\n// );\n// }\n// // console.info(\n// // 'resolvePath currentObject:',\n// // part,\n// // JSON.stringify(currentObject, null, 2),\n// // currentObject[part]\n// // );\n// // debugger;\n// const child = currentObject[part];\n// currentObject = await resolveObject(child, context);\n// partIndex++;\n// }\n// return currentObject;\n","import { resolve } from './resolve';\n\n// export const NOT_APPLICABLE = Symbol('not-applicable');\n// export const STOP_RESOLVING = Symbol('STOP_RESOLVING');\n\nexport function createFunction(name: string) {\n return async (manifest: unknown, ...args: IArguments[]) => {\n try {\n const runtimeEntryPoint = await resolve(manifest, '/runtime/entry');\n const moduleExports = await import(/* @vite-ignore */ runtimeEntryPoint);\n const functionToCall = moduleExports[name];\n return functionToCall(manifest, ...args);\n } catch (error) {\n console.error('efp-loader', `Error when trying to import and call \"${name}\":`, error);\n throw error;\n }\n };\n}\n\nexport function log(...args: any[]) {\n if (!(globalThis as any).__EFP_LOADER_DEBUG__) return;\n console.debug('efp-loader', ...args);\n}\n\nexport function deepFreeze(obj: any) {\n if (obj === null || typeof obj !== 'object') return obj;\n\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const val = obj[key];\n if (typeof val === 'object' && val !== null && !Object.isFrozen(val)) {\n deepFreeze(val);\n }\n }\n\n return obj;\n}\n\nexport function deepClone<T>(obj: T): T {\n if ('structuredClone' in globalThis) {\n return (globalThis as any).structuredClone(obj);\n }\n return JSON.parse(JSON.stringify(obj));\n}\n\nexport function preloadJson(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preload';\n link.as = 'fetch';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n\nexport function preconnectUrl(url: string) {\n if (typeof document === 'undefined') return; // SSR / Node\n\n const link = document.createElement('link');\n link.rel = 'preconnect';\n link.href = url;\n link.crossOrigin = 'anonymous';\n document.head.appendChild(link);\n}\n// export function hashString(str: string): string {\n// let hash = 0;\n\n// for (let i = 0; i < str.length; i++) {\n// const chr = str.charCodeAt(i);\n// hash = (hash << 5) - hash + chr;\n// hash |= 0; // force 32-bit int\n// }\n\n// // >>> 0 makes it unsigned (no '-' in front)\n// return (hash >>> 0).toString(16); // hex, [0-9a-f]\n// }\n\n// Deterministic ID\n// export async function hashString(str: string): Promise<string> {\n// const encoder = new TextEncoder();\n// const data = encoder.encode(str);\n\n// const digest = await crypto.subtle.digest('SHA-1', data);\n// return bufferToHex(digest);\n// }\n\n// murmur32\n// export function hashString(str: string): string {\n// let h = 0x811c9dc5;\n\n// for (let i = 0; i < str.length; i++) {\n// h ^= str.charCodeAt(i);\n// h = Math.imul(h, 0x01000193);\n// }\n\n// return (h >>> 0).toString(16).padStart(24, '0');\n// }\n\n// function bufferToHex(buffer: ArrayBuffer): string {\n// const bytes = new Uint8Array(buffer);\n// let hex = '';\n// for (let i = 0; i < bytes.length; i++) {\n// const byteHex = bytes[i].toString(16).padStart(2, '0');\n// hex += byteHex;\n// }\n// return hex;\n// }\n\n// export function mergeNonRefFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonRefFields does not support merging arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonRefFields does not support merging into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function mergeNonExitingFields(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('mergeNonExitingFields does not support merging arrays');\n// }\n\n// const keys = Object.keys(source);\n// if (keys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('mergeNonExitingFields does not support merging into arrays');\n// }\n\n// for (const key of Object.keys(source)) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// if (!(key in target)) {\n// target[key] = source[key];\n// }\n// }\n// }\n\n// export function replaceObjectFields(target: any, source: any) {\n// if (target === source) {\n// throw new Error('Cannot replace object with itself');\n// }\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object') {\n// throw new Error('Cannot replace with non-object source');\n// }\n// // throw if any is array\n// if (Array.isArray(target) || Array.isArray(source)) {\n// throw new Error('replaceObjectFields does not support arrays');\n// }\n\n// // delete keys in target that are not in source\n// for (const key of Object.keys(target)) {\n// if (!(key in source)) {\n// delete target[key];\n// }\n// }\n\n// // copy keys from source to target\n// for (const key of Object.keys(source)) {\n// target[key] = source[key];\n// }\n// }\n\n// export function isObject(v: any): boolean {\n// return v !== null && typeof v === 'object' && !Array.isArray(v);\n// }\n\n// export function mergeOriginalFieldsIntoResolvedObject(target: any, source: any) {\n// if (target === source) throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// for (const key of nonRefKeys) {\n// // if target is primitive, throw\n// if (target === null || typeof target !== 'object')\n// throw new Error('Cannot merge into non-object target');\n// target[key] = source[key];\n// }\n// }\n\n// export function createMergedObject(target: any, source: any) {\n// if (target === source) return; //throw new Error('Cannot merge object with itself');\n// // if source is primitive, throw\n// if (source === null || typeof source !== 'object')\n// throw new Error('Cannot merge non-object source');\n// if (Array.isArray(source)) {\n// throw new Error('Cannot merge arrays');\n// }\n// const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n// if (nonRefKeys.length === 0) return target;\n\n// // throw if any is array\n// if (Array.isArray(target)) {\n// throw new Error('Cannot merge into arrays');\n// }\n\n// if (target === null || typeof target !== 'object') {\n// throw new Error('Cannot merge into non-object target');\n// }\n\n// const result = { ...target };\n// for (const key of nonRefKeys) {\n// result[key] = source[key];\n// }\n// deepFreeze(result);\n// return result;\n// }\n\nexport function createMergedObjectWithOverridenNonRefProps(target: any, source: any) {\n if (target === source) return; //throw new Error('Cannot merge object with itself');\n // if source is primitive, throw\n if (source === null || typeof source !== 'object')\n throw new Error('Cannot merge non-object source');\n if (Array.isArray(source)) {\n throw new Error('Cannot merge arrays');\n }\n const nonRefKeys = Object.keys(source).filter((key) => key !== '$ref');\n if (nonRefKeys.length === 0) return deepClone(target);\n\n // throw if any is array\n if (Array.isArray(target)) {\n throw new Error('Cannot merge into arrays');\n }\n\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot merge into non-object target');\n }\n\n const result = deepClone({ ...target });\n for (const key of nonRefKeys) {\n result[key] = source[key];\n }\n // deepFreeze(result);\n return result;\n}\n\nexport function replaceObjectFields(target: any, source: any): void {\n if (target === source) {\n return;\n // throw new Error('Cannot replace object with itself');\n }\n // if source is primitive, throw\n if (source === null || typeof source !== 'object') {\n throw new Error('Cannot replace with non-object source');\n }\n // if target is primitive, throw\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot replace non-object target');\n }\n\n if (Array.isArray(target)) {\n if (!Array.isArray(source)) {\n throw new Error('replaceObjectFields does not support mixing arrays and objects');\n }\n // both are arrays - replace contents\n target.length = 0;\n for (const item of source) {\n target.push(item);\n }\n return;\n }\n\n // delete keys in target that are not in source\n for (const key of Object.keys(target)) {\n if (!(key in source)) {\n delete target[key];\n }\n }\n\n // copy keys from source to target\n for (const key of Object.keys(source)) {\n target[key] = source[key];\n }\n}\n","import { resolve } from './resolve';\nimport type { ResolveOptions } from './resolve';\n\nexport async function mutateManifest(\n manifest: any,\n paths: string[],\n resolveContext?: ResolveOptions\n): Promise<void> {\n if (!resolveContext) {\n resolveContext = { refCache: new Map<string, Promise<any>>(), mutate: true };\n }\n if (!resolveContext.mutate) {\n throw new Error('resolveContext.mutate must be true for mutateManifest');\n }\n for (const path of paths) {\n await resolve(manifest, path, resolveContext);\n }\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugMutateManifest'] = mutateManifest;\n}\n","export async function makeOfflineBundle(manifest: unknown) {\n const { makeOfflineBundle } = await import('./makeOfflineBundle');\n return await makeOfflineBundle(manifest);\n}\n\nexport async function downloadZip(manifest: unknown) {\n const { downloadZip } = await import('./downloadZip');\n return await downloadZip(manifest);\n}\n\nasync function debugLogOfflineManifestFiles(manifest: unknown): Promise<void> {\n // console.log('Offline files:');\n const { makeOffline } = await import('./makeOffline');\n const result = await makeOffline(manifest);\n // const allFiles = [];\n for await (const file of (await result).files) {\n if ('data' in file) {\n console.info(`🗳️ Put ${file.targetFilePath} <=`, file.data);\n } else if ('url' in file) {\n console.info(`🗳️ Download ${file.targetFilePath} <= ${file.url}`);\n }\n // allFiles.push(file);\n }\n console.info('Offline data: ', result.manifest);\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugDownloadZip'] = downloadZip;\n (window as any)['__debugMakeOfflineBundle'] = makeOfflineBundle;\n (window as any)['__debugLogOfflineManifestFiles'] = debugLogOfflineManifestFiles;\n}\n","import { createFunction, preconnectUrl } from './shared';\n\nexport const mount = createFunction('mount');\nexport const load = createFunction('load');\nexport const initialize = createFunction('initialize');\n\n// extra\n// export const createFloorPlan = createFunction('createFloorPlan');\n// export const rewriteManifestToLocalFiles = createFunction('rewriteManifestToLocalFiles');\n\nexport async function callFunction_Experimental(\n name: string,\n manifest: unknown,\n ...args: IArguments[]\n) {\n const fn = createFunction(name);\n return await fn(manifest, ...args);\n}\n\nexport { resolve } from './resolve';\nexport { mutateManifest } from './mutateManifest';\nexport { makeOfflineBundle, downloadZip } from './offline';\n\n// preloadJson('https://efp-runtime.expofp.com/branches/main.json');\npreconnectUrl('https://efp-runtime.expofp.com/');\n"],"names":["resolveAssetRefSync","ref","log","parseRefValue","assetResolver","bundleAssetsResolver","context","_a","_b","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","_c","dataUrlBase","versionUrl","version","filesUrl","dataUrl","dataFilesAssets","map","manifest","populateDataJsAssetsMap","links","addLink","link","img","resolvers","globalResolveCache","object","jsonPointer","refCache","resolveContext","parts","part","target","resovlePartsRecursiveMutate","replaceObjectFields","resovlePartsRecursive","node","partsIndex","key","resolveObjectMutate","obj","result","resolveObject","index","child","resolversToUse","r","canResolve","resolverResolve","createMergedObjectWithOverridenNonRefProps","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","objectOrRef","refOrContext","createFunction","args","functionToCall","error","val","deepClone","preconnectUrl","source","nonRefKeys","item","mutateManifest","paths","path","makeOfflineBundle","downloadZip","debugLogOfflineManifestFiles","makeOffline","mount","load","initialize","callFunction_Experimental"],"mappings":"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"}
|
package/dist/resolve.d.ts
CHANGED
|
@@ -4,7 +4,7 @@ export interface ResolveContextInternal {
|
|
|
4
4
|
/**
|
|
5
5
|
* Callback invoked when a URL is fetched.
|
|
6
6
|
*/
|
|
7
|
-
fetchCallback?: (url: string, type: 'json' | '
|
|
7
|
+
fetchCallback?: (url: string, type: 'json' | 'script') => void;
|
|
8
8
|
}
|
|
9
9
|
export interface ResolveOptions extends Omit<ResolveContextInternal, 'refCache'> {
|
|
10
10
|
/**
|