@expofp/loader 1.0.78 → 1.0.91

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/dist/bundle/ImportHttpRuntime.node-B85BNHJG.js +92 -0
  2. package/dist/bundle/ImportHttpRuntime.node-B85BNHJG.js.map +1 -0
  3. package/dist/bundle/bundle.js +236 -768
  4. package/dist/bundle/bundle.js.map +1 -1
  5. package/dist/bundle/fetch-retry.umd-g1itNdNw.js +115 -0
  6. package/dist/bundle/fetch-retry.umd-g1itNdNw.js.map +1 -0
  7. package/dist/esm/ImportHttpRuntime.node.d.ts +28 -0
  8. package/dist/esm/ImportHttpRuntime.node.js +139 -0
  9. package/dist/esm/_OLD_resolveRuntimeUrl.d.ts +1 -0
  10. package/dist/esm/_OLD_resolveRuntimeUrl.js +10 -0
  11. package/dist/esm/fetch.d.ts +1 -0
  12. package/dist/esm/fetch.js +14 -0
  13. package/dist/esm/importHttpRuntime.d.ts +1 -0
  14. package/dist/esm/importHttpRuntime.js +12 -0
  15. package/dist/esm/index.d.ts +10 -7
  16. package/dist/esm/index.js +40 -19
  17. package/dist/esm/resolve.d.ts +10 -44
  18. package/dist/esm/resolve.js +91 -295
  19. package/dist/esm/types.d.ts +11 -26
  20. package/package.json +3 -1
  21. package/dist/bundle/cssTextAssetResolver.offlineFunc-CWvHnYni.js +0 -19
  22. package/dist/bundle/cssTextAssetResolver.offlineFunc-CWvHnYni.js.map +0 -1
  23. package/dist/bundle/downloadOfflineZip-CNz_lUGZ.js +0 -2344
  24. package/dist/bundle/downloadOfflineZip-CNz_lUGZ.js.map +0 -1
  25. package/dist/bundle/legacyDataUrlBaseResolver.offlineFunc-DPaSp_zV.js +0 -87
  26. package/dist/bundle/legacyDataUrlBaseResolver.offlineFunc-DPaSp_zV.js.map +0 -1
  27. package/dist/bundle/makeOffline-Dj-0o5_7.js +0 -76
  28. package/dist/bundle/makeOffline-Dj-0o5_7.js.map +0 -1
  29. package/dist/bundle/makeOfflineBundle-D8tePWGI.js +0 -70
  30. package/dist/bundle/makeOfflineBundle-D8tePWGI.js.map +0 -1
  31. package/dist/bundle/saveOfflineZip.browser-BTQeRUY_.js +0 -7
  32. package/dist/bundle/saveOfflineZip.browser-BTQeRUY_.js.map +0 -1
  33. package/dist/bundle/tools-D0u8lBvQ.js +0 -102
  34. package/dist/bundle/tools-D0u8lBvQ.js.map +0 -1
  35. package/dist/esm/_OLD_fetchWithRetry.d.ts +0 -1
  36. package/dist/esm/_OLD_fetchWithRetry.js +0 -101
  37. package/dist/esm/importJson.d.ts +0 -2
  38. package/dist/esm/importJson.js +0 -57
  39. package/dist/esm/loadScript.d.ts +0 -16
  40. package/dist/esm/loadScript.js +0 -167
  41. package/dist/esm/logger.d.ts +0 -1
  42. package/dist/esm/logger.js +0 -5
  43. package/dist/esm/mutateManifest.d.ts +0 -2
  44. package/dist/esm/mutateManifest.js +0 -10
  45. package/dist/esm/offline/downloadOfflineZip.d.ts +0 -4
  46. package/dist/esm/offline/downloadOfflineZip.js +0 -15
  47. package/dist/esm/offline/generateZip.d.ts +0 -4
  48. package/dist/esm/offline/generateZip.js +0 -41
  49. package/dist/esm/offline/hashString.d.ts +0 -1
  50. package/dist/esm/offline/hashString.js +0 -16
  51. package/dist/esm/offline/index.d.ts +0 -14
  52. package/dist/esm/offline/index.js +0 -41
  53. package/dist/esm/offline/makeOffline.d.ts +0 -2
  54. package/dist/esm/offline/makeOffline.js +0 -144
  55. package/dist/esm/offline/makeOfflineBundle.d.ts +0 -4
  56. package/dist/esm/offline/makeOfflineBundle.js +0 -92
  57. package/dist/esm/offline/saveOfflineZip.browser.d.ts +0 -1
  58. package/dist/esm/offline/saveOfflineZip.browser.js +0 -3
  59. package/dist/esm/offline/saveOfflineZip.d.ts +0 -1
  60. package/dist/esm/offline/saveOfflineZip.js +0 -16
  61. package/dist/esm/offline/slugify.d.ts +0 -1
  62. package/dist/esm/offline/slugify.js +0 -61
  63. package/dist/esm/offline/tools.d.ts +0 -3
  64. package/dist/esm/offline/tools.js +0 -85
  65. package/dist/esm/resolvers/_OLD_expoResolver.d.ts +0 -1
  66. package/dist/esm/resolvers/_OLD_expoResolver.js +0 -49
  67. package/dist/esm/resolvers/assetResolver.d.ts +0 -6
  68. package/dist/esm/resolvers/assetResolver.js +0 -26
  69. package/dist/esm/resolvers/bundleAssetsResolver.d.ts +0 -2
  70. package/dist/esm/resolvers/bundleAssetsResolver.js +0 -20
  71. package/dist/esm/resolvers/cssTextAssetResolver.d.ts +0 -8
  72. package/dist/esm/resolvers/cssTextAssetResolver.js +0 -15
  73. package/dist/esm/resolvers/cssTextAssetResolver.offlineFunc.d.ts +0 -2
  74. package/dist/esm/resolvers/cssTextAssetResolver.offlineFunc.js +0 -22
  75. package/dist/esm/resolvers/expoRuntimeBranchResolver.d.ts +0 -2
  76. package/dist/esm/resolvers/expoRuntimeBranchResolver.js +0 -20
  77. package/dist/esm/resolvers/expoRuntimeGetBranchResolver.d.ts +0 -2
  78. package/dist/esm/resolvers/expoRuntimeGetBranchResolver.js +0 -14
  79. package/dist/esm/resolvers/expoRuntimeResolver.d.ts +0 -2
  80. package/dist/esm/resolvers/expoRuntimeResolver.js +0 -39
  81. package/dist/esm/resolvers/httpResolver.d.ts +0 -5
  82. package/dist/esm/resolvers/httpResolver.js +0 -14
  83. package/dist/esm/resolvers/index.d.ts +0 -2
  84. package/dist/esm/resolvers/index.js +0 -22
  85. package/dist/esm/resolvers/legacyAssetUrlsResolver.d.ts +0 -9
  86. package/dist/esm/resolvers/legacyAssetUrlsResolver.js +0 -116
  87. package/dist/esm/resolvers/legacyDataResolver.d.ts +0 -8
  88. package/dist/esm/resolvers/legacyDataResolver.js +0 -20
  89. package/dist/esm/resolvers/legacyDataUrlBaseResolver.d.ts +0 -8
  90. package/dist/esm/resolvers/legacyDataUrlBaseResolver.js +0 -15
  91. package/dist/esm/resolvers/legacyDataUrlBaseResolver.offlineFunc.d.ts +0 -2
  92. package/dist/esm/resolvers/legacyDataUrlBaseResolver.offlineFunc.js +0 -129
  93. package/dist/esm/returnCachedRef.d.ts +0 -1
  94. package/dist/esm/returnCachedRef.js +0 -12
  95. package/dist/esm/shared.d.ts +0 -8
  96. package/dist/esm/shared.js +0 -273
@@ -1 +1 @@
1
- {"version":3,"file":"bundle.js","sources":["../../node_modules/.pnpm/ms@2.1.3/node_modules/ms/index.js","../../node_modules/.pnpm/debug@4.4.3/node_modules/debug/src/common.js","../../node_modules/.pnpm/debug@4.4.3/node_modules/debug/src/browser.js","../../src/logger.ts","../../src/resolvers/assetResolver.ts","../../src/importJson.ts","../../src/returnCachedRef.ts","../../src/resolvers/bundleAssetsResolver.ts","../../src/resolvers/cssTextAssetResolver.ts","../../src/resolvers/expoRuntimeBranchResolver.ts","../../src/resolvers/expoRuntimeGetBranchResolver.ts","../../src/resolvers/expoRuntimeResolver.ts","../../src/resolvers/httpResolver.ts","../../node_modules/.pnpm/fetch-retry@6.0.0/node_modules/fetch-retry/dist/fetch-retry.umd.js","../../src/loadScript.ts","../../src/resolvers/legacyAssetUrlsResolver.ts","../../src/resolvers/legacyDataResolver.ts","../../src/resolvers/legacyDataUrlBaseResolver.ts","../../src/resolvers/index.ts","../../src/resolve.ts","../../src/shared.ts","../../src/mutateManifest.ts","../../src/offline/index.ts","../../src/index.ts"],"sourcesContent":["/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '')\n\t\t\t.trim()\n\t\t\t.replace(/\\s+/g, ',')\n\t\t\t.split(',')\n\t\t\t.filter(Boolean);\n\n\t\tfor (const ns of split) {\n\t\t\tif (ns[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(ns.slice(1));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(ns);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the given string matches a namespace template, honoring\n\t * asterisks as wildcards.\n\t *\n\t * @param {String} search\n\t * @param {String} template\n\t * @return {Boolean}\n\t */\n\tfunction matchesTemplate(search, template) {\n\t\tlet searchIndex = 0;\n\t\tlet templateIndex = 0;\n\t\tlet starIndex = -1;\n\t\tlet matchIndex = 0;\n\n\t\twhile (searchIndex < search.length) {\n\t\t\tif (templateIndex < template.length && (template[templateIndex] === search[searchIndex] || template[templateIndex] === '*')) {\n\t\t\t\t// Match character or proceed with wildcard\n\t\t\t\tif (template[templateIndex] === '*') {\n\t\t\t\t\tstarIndex = templateIndex;\n\t\t\t\t\tmatchIndex = searchIndex;\n\t\t\t\t\ttemplateIndex++; // Skip the '*'\n\t\t\t\t} else {\n\t\t\t\t\tsearchIndex++;\n\t\t\t\t\ttemplateIndex++;\n\t\t\t\t}\n\t\t\t} else if (starIndex !== -1) { // eslint-disable-line no-negated-condition\n\t\t\t\t// Backtrack to the last '*' and try to match more characters\n\t\t\t\ttemplateIndex = starIndex + 1;\n\t\t\t\tmatchIndex++;\n\t\t\t\tsearchIndex = matchIndex;\n\t\t\t} else {\n\t\t\t\treturn false; // No match\n\t\t\t}\n\t\t}\n\n\t\t// Handle trailing '*' in template\n\t\twhile (templateIndex < template.length && template[templateIndex] === '*') {\n\t\t\ttemplateIndex++;\n\t\t}\n\n\t\treturn templateIndex === template.length;\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names,\n\t\t\t...createDebug.skips.map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tfor (const skip of createDebug.skips) {\n\t\t\tif (matchesTemplate(name, skip)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (const ns of createDebug.names) {\n\t\t\tif (matchesTemplate(name, ns)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug') || exports.storage.getItem('DEBUG') ;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","import debug from 'debug';\n\nconst logger = debug('efp:loader');\n\nexport function log(...args: any[]) {\n logger(...(args as [any?, ...any[]]));\n}\n","import { parseRefValue } from '../resolve';\nimport { log } from '../logger';\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 offlineFunc: '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 { log } from './logger';\nimport type { ResolveContextInternal } from './resolve';\nimport { deepFreeze } from './shared';\n\nlet importJsonNotAvailable: boolean | undefined;\nconst jsonFrozen = new WeakSet<any>();\n\n// ET: this is a workaround for Vite that analyzes dynamic imports and removes 'with' option\n// to be removed when Vite supports it properly\n// Cons: can have CSP issues in some environments\nconst importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n url: string\n) => Promise<any>;\n\nexport async function importJson<T = any>(\n url: string,\n resolveContext: ResolveContextInternal\n): Promise<T> {\n if (resolveContext.preResolvedRefs?.has(url)) {\n log('importJson: using preResolvedRefs for', url);\n return resolveContext.preResolvedRefs.get(url);\n }\n // console.warn('importJson:', resolveContext.forceFetch);\n if (importJsonNotAvailable === undefined && !resolveContext.forceFetch) {\n try {\n await importJsonNative(url);\n importJsonNotAvailable = false;\n } catch {\n log('importJson: dynamic import not available, falling back to fetch');\n importJsonNotAvailable = true;\n }\n }\n let result: any = undefined;\n if (!importJsonNotAvailable && !resolveContext.forceFetch) {\n const module = await importJsonNative(url);\n result = module.default;\n resolveContext.importCallback?.(url, 'json');\n } else {\n log('importJson: fetch', url);\n result = await loadJson(url, resolveContext.refCache, resolveContext.signal || null);\n resolveContext.importCallback?.(url, 'json');\n }\n if (!jsonFrozen.has(result)) {\n deepFreeze(result);\n // jsonFrozen.add(result);\n }\n return result;\n}\n\n// const fetchCache = new Map<string, Promise<any>>();\n\nasync function loadJson(\n url: string,\n fetchCache: Map<string, Promise<any>>,\n signal: AbortSignal | null\n): Promise<any> {\n const key = '__loadJson__' + url;\n if (fetchCache.has(key)) {\n return fetchCache.get(key)!;\n }\n\n const dataPromise = (async function loadJsonInner() {\n const response = await fetch(url, { signal });\n if (!response.ok) {\n throw new Error(`Failed to fetch JSON from ${url}`);\n }\n return await response.json();\n })();\n\n fetchCache.set(key, dataPromise);\n return dataPromise;\n}\n","import { deepFreeze } from './shared';\n\nexport async function returnCachedRef(\n ref: string,\n refCache: Map<string, Promise<any>>,\n factory: () => Promise<any>\n) {\n if (refCache.has(ref)) {\n return refCache.get(ref);\n }\n const promise = factory().then((data) => {\n deepFreeze(data);\n return data;\n });\n refCache.set(ref, promise);\n return promise;\n}\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../logger';\nimport type { Resolver } from '../types';\n\nexport const bundleAssetsResolver: Resolver = {\n schema: 'bundle-assets',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('bundleAssetsResolver resolveRef:', ref);\n\n const url = parseRefValue(ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const files = await importJson(url, context);\n const baseUrl = url.substring(0, url.lastIndexOf('/') + 1);\n\n const assets = files.map((file: string) => ({\n $ref: `asset+${baseUrl}${file}`,\n }));\n return assets;\n });\n },\n offlineFunc: 'localizeRef',\n};\n","import debug from 'debug';\nimport { parseRefValue } from '../resolve';\nimport type { Resolver } from '../types';\n\nexport const log = debug('efp:loader:resolver:cssTextAsset');\nexport const SCHEMA = 'css-text-asset';\n\nexport const cssTextAssetResolver = {\n schema: SCHEMA,\n resolveRef(ref: string) {\n log('cssTextAssetResolver resolveRef:', ref);\n return Promise.resolve(parseRefValue(ref));\n },\n offlineFunc: async function* (ref, _context) {\n const { offlineFunc } = await import('./cssTextAssetResolver.offlineFunc');\n return yield* offlineFunc(ref, _context);\n },\n} satisfies Resolver;\n","import { importJson } from '../importJson';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../logger';\nimport type { Resolver } from '../types';\n\nconst BASE_URL = 'https://efp-runtime.expofp.com/';\n\nexport const expoRuntimeBranchResolver: Resolver = {\n schema: 'expo-runtime-branch',\n async resolveRef(ref: string, context: ResolveContextInternal) {\n log('expoRuntimeBranchResolver resolveRef:', ref);\n\n const branch = parseRefValue(ref);\n const branchUrl = `${BASE_URL}branches/${branch}.json`;\n\n return returnCachedRef(ref, context.refCache, async () => {\n const { release } = await importJson(branchUrl, context);\n return {\n $ref: `expo-runtime+https://efp-runtime.expofp.com/releases/${release}/`,\n };\n });\n },\n\n offlineFunc: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { parseRefValue } from '../resolve';\nimport { log } from '../logger';\nimport type { Resolver } from '../types';\n\n// const SCHEMA = 'expo-runtime-get-branch';\n\nexport const expoRuntimeGetBranchResolver: Resolver = {\n schema: 'expo-runtime-get-branch',\n async resolveRef(ref, context) {\n log('expoRuntimeGetBranchResolver resolveRef:', ref);\n\n const expo = parseRefValue(ref);\n const url = `https://${expo}.expofp.com/get-branch`;\n return importJson(url, context);\n },\n offlineFunc: 'resolveRef',\n};\n","import { log } from '../logger';\nimport { parseRefValue } from '../resolve';\nimport { deepFreeze } 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 offlineFunc: 'resolveRef',\n};\n","import { importJson } from '../importJson';\nimport { log } from '../logger';\nimport { type Resolver } from '../types';\n\nexport const httpResolver = {\n canResolve(ref) {\n return ref.startsWith('http://') || ref.startsWith('https://') || ref.startsWith('./');\n },\n resolveRef(ref, context) {\n log('httpResolver resolveRef:', ref);\n if (!this.canResolve!(ref)) throw new Error(`Unexpected ref in httpResolver: ${ref}`);\n\n return importJson(ref, context);\n },\n offlineFunc: 'resolveRef',\n} satisfies Resolver;\n","(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.fetchRetry = factory());\n})(this, (function () { 'use strict';\n\n var fetchRetry = function (fetch, defaults) {\n defaults = defaults || {};\n if (typeof fetch !== 'function') {\n throw new ArgumentError('fetch must be a function');\n }\n\n if (typeof defaults !== 'object') {\n throw new ArgumentError('defaults must be an object');\n }\n\n if (defaults.retries !== undefined && !isPositiveInteger(defaults.retries)) {\n throw new ArgumentError('retries must be a positive integer');\n }\n\n if (defaults.retryDelay !== undefined && !isPositiveInteger(defaults.retryDelay) && typeof defaults.retryDelay !== 'function') {\n throw new ArgumentError('retryDelay must be a positive integer or a function returning a positive integer');\n }\n\n if (defaults.retryOn !== undefined && !Array.isArray(defaults.retryOn) && typeof defaults.retryOn !== 'function') {\n throw new ArgumentError('retryOn property expects an array or function');\n }\n\n var baseDefaults = {\n retries: 3,\n retryDelay: 1000,\n retryOn: [],\n };\n\n defaults = Object.assign(baseDefaults, defaults);\n\n return function fetchRetry(input, init) {\n var retries = defaults.retries;\n var retryDelay = defaults.retryDelay;\n var retryOn = defaults.retryOn;\n\n if (init && init.retries !== undefined) {\n if (isPositiveInteger(init.retries)) {\n retries = init.retries;\n } else {\n throw new ArgumentError('retries must be a positive integer');\n }\n }\n\n if (init && init.retryDelay !== undefined) {\n if (isPositiveInteger(init.retryDelay) || (typeof init.retryDelay === 'function')) {\n retryDelay = init.retryDelay;\n } else {\n throw new ArgumentError('retryDelay must be a positive integer or a function returning a positive integer');\n }\n }\n\n if (init && init.retryOn) {\n if (Array.isArray(init.retryOn) || (typeof init.retryOn === 'function')) {\n retryOn = init.retryOn;\n } else {\n throw new ArgumentError('retryOn property expects an array or function');\n }\n }\n\n // eslint-disable-next-line no-undef\n return new Promise(function (resolve, reject) {\n var wrappedFetch = function (attempt) {\n // As of node 18, this is no longer needed since node comes with native support for fetch:\n /* istanbul ignore next */\n var _input =\n typeof Request !== 'undefined' && input instanceof Request\n ? input.clone()\n : input;\n fetch(_input, init)\n .then(function (response) {\n if (Array.isArray(retryOn) && retryOn.indexOf(response.status) === -1) {\n resolve(response);\n } else if (typeof retryOn === 'function') {\n try {\n // eslint-disable-next-line no-undef\n return Promise.resolve(retryOn(attempt, null, response))\n .then(function (retryOnResponse) {\n if(retryOnResponse) {\n retry(attempt, null, response);\n } else {\n resolve(response);\n }\n }).catch(reject);\n } catch (error) {\n reject(error);\n }\n } else {\n if (attempt < retries) {\n retry(attempt, null, response);\n } else {\n resolve(response);\n }\n }\n })\n .catch(function (error) {\n if (typeof retryOn === 'function') {\n try {\n // eslint-disable-next-line no-undef\n Promise.resolve(retryOn(attempt, error, null))\n .then(function (retryOnResponse) {\n if(retryOnResponse) {\n retry(attempt, error, null);\n } else {\n reject(error);\n }\n })\n .catch(function(error) {\n reject(error);\n });\n } catch(error) {\n reject(error);\n }\n } else if (attempt < retries) {\n retry(attempt, error, null);\n } else {\n reject(error);\n }\n });\n };\n\n function retry(attempt, error, response) {\n var delay = (typeof retryDelay === 'function') ?\n retryDelay(attempt, error, response) : retryDelay;\n setTimeout(function () {\n wrappedFetch(++attempt);\n }, delay);\n }\n\n wrappedFetch(0);\n });\n };\n };\n\n function isPositiveInteger(value) {\n return Number.isInteger(value) && value >= 0;\n }\n\n function ArgumentError(message) {\n this.name = 'ArgumentError';\n this.message = message;\n }\n\n return fetchRetry;\n\n}));\n","import debug from 'debug';\nimport fetchRetry from 'fetch-retry';\n\nconst fetchWithRetry = fetchRetry(fetch);\n\nconst log = debug('efp:loader:loadScript');\n\nexport interface LoadAndWaitOptions {\n /** Name of the global variable to wait for */\n globalVar?: string;\n /** How long to wait for the global (ms) */\n timeoutMs?: number;\n /** Poll interval (ms) */\n pollIntervalMs?: number;\n signal: AbortSignal | null;\n}\n\n/**\n * @deprecated Use loadScript directly instead.\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 if (globalVar && (window as any)[globalVar] !== undefined) {\n delete (window as any)[globalVar];\n }\n await loadInBrowser(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (window as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n } else {\n if (globalVar && (globalThis as any)[globalVar] !== undefined) {\n delete (globalThis as any)[globalVar];\n }\n await loadInNode(scriptUrl, options.signal);\n if (globalVar) {\n await waitForGlobal(\n () => (globalThis as any)[globalVar],\n globalVar,\n timeoutMs,\n pollIntervalMs,\n options.signal\n );\n }\n }\n}\n\nfunction isBrowser(): boolean {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n\nexport async function loadScript(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n log('Loading', scriptUrl);\n if (isBrowser()) {\n await loadInBrowser(scriptUrl, signal);\n } else {\n await loadInNode(scriptUrl, signal);\n }\n}\n\n/* -------------------- Browser implementation -------------------- */\n\nfunction loadInBrowser(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n return new Promise((resolve, reject) => {\n const script = document.createElement('script');\n script.src = scriptUrl;\n script.async = true;\n\n const cleanup = () => {\n script.onload = null;\n script.onerror = null;\n script.remove();\n };\n\n const onAbort = () => {\n cleanup();\n reject(new Error('Script load aborted'));\n };\n\n if (signal?.aborted) {\n cleanup();\n reject(new Error('Script load aborted'));\n return;\n }\n\n signal?.addEventListener('abort', onAbort, { once: true });\n\n script.onload = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n resolve();\n };\n\n script.onerror = () => {\n signal?.removeEventListener('abort', onAbort);\n cleanup();\n reject(new Error(`Failed to load script: ${scriptUrl}`));\n };\n\n document.head.appendChild(script);\n });\n}\n\n/* -------------------- Node implementation -------------------- */\n\nasync function loadInNode(scriptUrl: string, signal: AbortSignal | null): Promise<void> {\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let res: Response;\n\n try {\n res = await fetchWithRetry(scriptUrl, { signal });\n } catch (err: any) {\n // Node / WHATWG fetch uses AbortError on abort\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (!res.ok) {\n throw new Error(`Failed to load script in Node (HTTP ${res.status}): ${scriptUrl}`);\n }\n\n // If it was aborted between headers and body:\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n let code: string;\n try {\n code = await res.text();\n } catch (err: any) {\n if (err && err.name === 'AbortError') {\n throw new Error('Script load aborted');\n }\n throw err;\n }\n\n if (signal?.aborted) {\n throw new Error('Script load aborted');\n }\n\n // TEMPORARILY expose window for browser-style UMDs that expect it\n const g = globalThis as any;\n const prevWindow = g.window;\n\n g.window = g;\n\n try {\n // Indirect eval -> global scope in Node\n // Assumes the loaded script attaches itself to globalThis/window/global.\n (0, eval)(code);\n } finally {\n // Restore previous window (if any)\n if (prevWindow === undefined) {\n delete g.window;\n } else {\n g.window = prevWindow;\n }\n }\n}\n\n/* -------------------- Shared helper -------------------- */\n\nfunction waitForGlobal(\n getter: () => any,\n name: string,\n timeoutMs: number,\n pollIntervalMs: number,\n abortSignal: AbortSignal | null\n): Promise<void> {\n return new Promise((resolve, reject) => {\n const start = Date.now();\n\n const onAbort = () => {\n reject(new Error('Wait for global aborted'));\n };\n\n if (abortSignal?.aborted) {\n reject(new Error('Wait for global aborted'));\n return;\n }\n\n abortSignal?.addEventListener('abort', onAbort, { once: true });\n\n const check = () => {\n if (abortSignal?.aborted) {\n return reject(new Error('Wait for global aborted'));\n }\n\n try {\n if (getter() !== undefined) {\n abortSignal?.removeEventListener('abort', onAbort);\n // log(`loadAndWaitGlobal: global \"${name}\" is now available`);\n return resolve();\n }\n } catch {\n // ignore access errors and keep polling\n }\n\n if (Date.now() - start >= timeoutMs) {\n abortSignal?.removeEventListener('abort', onAbort);\n // console.error(`loadAndWaitGlobal: timed out waiting for global \"${name}\"`);\n return reject(new Error(`Timed out after ${timeoutMs} ms waiting for global \"${name}\"`));\n }\n\n setTimeout(check, pollIntervalMs);\n };\n\n check();\n });\n}\n","import { loadAndWaitGlobal } from '../loadScript';\nimport { parseRefValue, type ResolveContextInternal } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../logger';\nimport type { Resolver } from '../types';\n\n/**\n * @deprecated Use legacyDataUrlBaseResolver instead\n */\nexport const legacyAssetUrlsResolver = {\n schema: 'legacy-asset-urls',\n resolveRef(ref: string, context: ResolveContextInternal) {\n log('legacyAssetUrlsResolver resolveRef:', ref);\n const signal = context.signal;\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n // load version.js - it will contain \"window.__fpDataVersion = \"20251129003330106\";\"\n const versionUrl = `${dataUrlBase}version.js`;\n try {\n await loadAndWaitGlobal(versionUrl, {\n globalVar: '__fpDataVersion',\n timeoutMs: 30_000,\n signal,\n });\n context.importCallback?.(versionUrl, 'script');\n } catch {\n console.warn(`Could not load version.js at ${versionUrl}, proceeding without it`);\n }\n const version = (globalThis as any).__fpDataVersion || (+new Date()).toString();\n\n // const filesUrl = `${dataUrlBase}files.json?v=${version}`;\n const dataUrl = `${dataUrlBase}data.js?v=${version}`;\n // const filesPromise = importJson<string[]>(filesUrl, context).catch(() => {\n // console.warn(`Could not load files.json at ${filesUrl}, proceeding without it`);\n // return [];\n // });\n\n // data.js\n const dataLoadPromise = loadAndWaitGlobal(dataUrl, {\n globalVar: '__data',\n signal,\n });\n context.importCallback?.(dataUrl, 'script');\n\n // wf.data.js\n const wfDataUrl = `${dataUrlBase}wf.data.js?v=${version}`;\n const wfDataLoadPromise = loadAndWaitGlobal(wfDataUrl, {\n globalVar: '__wfData',\n signal,\n })\n .then(() => {\n context.importCallback?.(wfDataUrl, 'script');\n })\n .catch(() => {\n console.warn(`Could not load wf.data.js at ${wfDataUrl}, proceeding without it`);\n });\n\n // fp.svg.js\n delete (globalThis as any).__fpLayers;\n const fpSvgUrl = `${dataUrlBase}fp.svg.js?v=${version}`;\n const fpSvgLoadPromise = loadAndWaitGlobal(fpSvgUrl, {\n globalVar: '__fp',\n signal,\n });\n context.importCallback?.(fpSvgUrl, 'script');\n\n await Promise.all([dataLoadPromise, wfDataLoadPromise, fpSvgLoadPromise]);\n\n const __fpLayers = ((globalThis as any).__fpLayers ?? []) as Array<{ name: string }>;\n const fpLayerFiles = __fpLayers.map((x) => `fp.svg.${x.name}.js`);\n for (const layerFile of fpLayerFiles) {\n const layerUrl = `${dataUrlBase}${layerFile}?v=${version}`;\n context.importCallback?.(layerUrl, 'script');\n }\n\n // const files = await filesPromise;...files,\n\n const data = (globalThis as any).__data || {};\n const dataFiles = ['data.js', 'wf.data.js', 'fp.svg.js', ...fpLayerFiles];\n const dataFilesAssets = dataFiles.reduce((map, file) => {\n map[file] = { $ref: `asset+${dataUrlBase}${file}?v=${version}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n\n // return {};\n return { ...dataFilesAssets, ...populateDataJsAssetsMap(dataUrlBase, data) };\n });\n },\n offlineFunc: '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 // add same files but with __small and __tiny suffixes\n if (e.logo) {\n const dotIndex = e.logo.lastIndexOf('.');\n if (dotIndex !== -1) {\n const name = e.logo.substring(0, dotIndex);\n const ext = e.logo.substring(dotIndex);\n addLink(`${name}__small${ext}`);\n addLink(`${name}__tiny${ext}`);\n }\n }\n e.gallery?.forEach((img: string) => addLink(img));\n });\n\n data.events?.forEach((e: any) => {\n addLink(e.logoFile);\n e.speakers?.forEach((s: any) => {\n addLink(s.photoFile);\n });\n });\n\n return Array.from(links).reduce((map, link) => {\n map[link] = { $ref: `asset+${dataUrlBase}${link}` };\n return map;\n }, {} as Record<string, { $ref: string }>);\n}\n","import { parseRefValue } from '../resolve';\nimport { returnCachedRef } from '../returnCachedRef';\nimport { log } from '../logger';\nimport type { Resolver } from '../types';\n\n/**\n * @deprecated Use legacyDataUrlBaseResolver instead\n */\nexport const legacyDataResolver = {\n schema: 'legacy-data',\n resolveRef(ref: string, context) {\n log('legacyDataResolver resolveRef:', ref);\n\n return returnCachedRef(ref, context.refCache, async () => {\n const dataUrlBase = parseRefValue(ref);\n\n return {\n _to_remove_for_offline_to_work_dataUrlBase: dataUrlBase,\n legacyAssetUrls: { $ref: `legacy-asset-urls+${dataUrlBase}` },\n };\n });\n },\n offlineFunc: 'resolveRef',\n} satisfies Resolver;\n","import debug from 'debug';\nimport { parseRefValue } from '../resolve';\nimport type { Resolver } from '../types';\n\nexport const log = debug('efp:loader:resolver:legacyDataUrlBase');\nexport const SCHEMA = 'legacy-data-url-base';\n\nexport const legacyDataUrlBaseResolver = {\n schema: SCHEMA,\n resolveRef(ref: string) {\n log('legacyDataResolver resolveRef:', ref);\n return Promise.resolve(parseRefValue(ref));\n },\n offlineFunc: async function* (ref, _context) {\n const { offlineFunc } = await import('./legacyDataUrlBaseResolver.offlineFunc');\n return yield* offlineFunc(ref, _context);\n },\n} satisfies Resolver;\n","import type { Resolver } from '../types';\nimport { assetResolver } from './assetResolver';\nimport { bundleAssetsResolver } from './bundleAssetsResolver';\nimport { cssTextAssetResolver } from './cssTextAssetResolver';\nimport { expoRuntimeBranchResolver } from './expoRuntimeBranchResolver';\nimport { expoRuntimeGetBranchResolver } from './expoRuntimeGetBranchResolver';\nimport { expoRuntimeResolver } from './expoRuntimeResolver';\nimport { httpResolver } from './httpResolver';\nimport { legacyAssetUrlsResolver } from './legacyAssetUrlsResolver';\nimport { legacyDataResolver } from './legacyDataResolver';\nimport { legacyDataUrlBaseResolver } from './legacyDataUrlBaseResolver';\n\nexport const resolvers: Resolver[] = [\n httpResolver,\n bundleAssetsResolver,\n assetResolver,\n expoRuntimeResolver,\n expoRuntimeBranchResolver,\n expoRuntimeGetBranchResolver,\n cssTextAssetResolver,\n legacyDataResolver,\n legacyAssetUrlsResolver,\n legacyDataUrlBaseResolver,\n];\n","import { log } from './logger';\nimport { resolvers } from './resolvers';\nimport {\n createMergedObjectWithOverridenNonRefProps,\n deepFreeze,\n replaceObjectFields,\n} from './shared';\nimport type { Resolver } from './types';\n\nconst globalRefCache = new Map<string, Promise<any>>();\n\nexport interface ResolveContextInternal {\n forceFetch: boolean;\n refCache: Map<string, Promise<any>>;\n /**\n * Callback invoked when a URL is fetched or imported.\n */\n importCallback?: (url: string, type: 'json' | 'script') => void;\n signal: AbortSignal | null;\n preResolvedRefs?: Map<string, any>;\n}\n\ninterface ResolveOptionsNotMutate extends Partial<ResolveContextInternal> {\n mutate?: false;\n signal?: AbortSignal;\n}\n\ninterface ResolveOptionMutate extends Omit<ResolveOptionsNotMutate, 'mutate'> {\n /**\n * Mutate original object during resolution.\n */\n mutate: true;\n}\n\nexport type ResolveOptions = ResolveOptionsNotMutate | ResolveOptionMutate;\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 */\n\nexport async function resolve(\n object: any,\n jsonPointer: string,\n options: ResolveOptionMutate\n): Promise<void>;\n\nexport async function resolve<T = any>(\n object: any,\n jsonPointer: string,\n options?: ResolveOptionsNotMutate\n): Promise<T>;\n\nexport async function resolve<T = any>(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n): Promise<T | void> {\n log('Resolving:', jsonPointer, 'of', object, options);\n // if (typeof window !== 'undefined') {\n // (window as any)['__lastResolveObject'] = object;\n // }\n\n const resolveContext: ResolveContextInternal = {\n importCallback: options?.importCallback,\n refCache: options?.refCache || globalRefCache,\n forceFetch: !!options?.forceFetch,\n signal: options?.signal || null,\n preResolvedRefs: options?.preResolvedRefs,\n };\n\n if (typeof jsonPointer !== 'string') {\n throw new Error(`Invalid JSON Pointer (not a string): ${jsonPointer}`);\n }\n if (!jsonPointer.startsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n if (jsonPointer.length > 1 && jsonPointer.endsWith('/')) {\n throw new Error(`Invalid JSON Pointer: ${jsonPointer}`);\n }\n // if (jsonPointer === '/') {\n // const result = await resolveObject(object, resolveContext);\n // if (options?.mutate) {\n // replaceObjectFields(object, result);\n // }\n // return result;\n // }\n\n let parts: string[];\n if (jsonPointer === '/') {\n parts = [];\n } else {\n parts = jsonPointer.substring(1).split('/');\n }\n if (parts.some((part) => part.length === 0))\n throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n if (options?.mutate) {\n // prepend parts with 'root'\n parts.unshift('root');\n const target = { root: object };\n await resovlePartsRecursiveMutate(target, parts, 0, resolveContext);\n replaceObjectFields(object, target.root);\n } else {\n return await resovlePartsRecursive(object, parts, 0, resolveContext);\n }\n // prepend parts with 'root'\n // parts.unshift('root');\n // // if (parts.some((part) => part.length === 0))\n // // throw new Error(`Invalid JSON Pointer (empty part): ${jsonPointer}`);\n // const target = { root: object };\n // const value = await resovlePartsRecursiveMutate(\n // target,\n // // 'root',\n // parts,\n // 0,\n // resolveContext\n // );\n // if (options?.mutate) {\n // replaceObjectFields(object, target.root);\n // }\n // log(`Resolved ${jsonPointer}:`, value);\n // return value;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursiveMutate(\n node: any,\n // key: string,\n parts: string[],\n partsIndex: number,\n context: ResolveContextInternal\n): Promise<void> {\n const key = parts[partsIndex];\n // console.warn('in', key);\n\n await resolveObjectMutate(node, key, context);\n if (partsIndex == parts.length - 1) return;\n\n if (node[key] === null || typeof node[key] !== 'object') {\n // console.error('Cannot resolve path, encountered non-object:', node, key);\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.slice(1).join('/')}', index ${\n partsIndex - 1\n }'`\n );\n }\n return await resovlePartsRecursiveMutate(node[key], parts, partsIndex + 1, context);\n}\n\nasync function resolveObjectMutate(\n node: any,\n key: string,\n context: ResolveContextInternal\n): Promise<void> {\n log('resolveObjectMutate:', node, key);\n let obj = node[key];\n const result = await resolveObject(obj, context);\n if (result !== undefined) node[key] = result;\n}\n\n// TODO: use library for JSON Pointer resolution\nasync function resovlePartsRecursive(\n object: any,\n parts: string[],\n index: number,\n context: ResolveContextInternal\n): Promise<any> {\n // should return undefined if last part not found\n // if not last part found - throw error\n // do not resolve object if its children are not needed (needed part exist as key)\n if (index === parts.length) {\n // console.warn('Resolving last part:', object);\n return await resolveObject(object, context);\n }\n if (object === null || typeof object !== 'object') {\n throw new Error(\n `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n );\n }\n const part = parts[index];\n let child = object[part];\n if (child === undefined) {\n // console.warn('Resolving, part not found during resolve:', part, object);\n const resolvedObject = await resolveObject(object, context);\n child = resolvedObject[part];\n }\n return await resovlePartsRecursive(child, parts, index + 1, context);\n}\n\nasync function resolveObject(object: any, context: ResolveContextInternal): Promise<any> {\n log('resolveObject:', object);\n let obj = object;\n\n do {\n if (typeof obj !== 'object' || obj === null || !('$ref' in obj)) {\n return obj;\n }\n const resolversToUse = resolvers.filter((r) => canResolve(r, obj.$ref));\n if (resolversToUse.length === 0) {\n if (obj.$ref) {\n throw new Error(`No resolver found for ref: ${obj.$ref}`);\n }\n deepFreeze(obj);\n return obj;\n }\n if (resolversToUse.length > 1) {\n throw new Error(`Multiple resolvers can resolve ref: ${obj.$ref}`);\n }\n\n const data = await resolverResolve(resolversToUse[0], obj.$ref, context);\n\n obj = createMergedObjectWithOverridenNonRefProps(data, obj);\n } while (true);\n}\n\nexport async function resolverResolve(\n resolver: Resolver,\n ref: string,\n context: ResolveContextInternal\n): Promise<any> {\n if (!canResolve(resolver, ref)) {\n throw new Error(`Unexpected ref: ${ref}`);\n }\n return resolver.resolveRef(ref, context);\n}\n\nexport function canResolve(resolver: Resolver, ref: string): boolean {\n if (resolver.canResolve) {\n return resolver.canResolve(ref);\n }\n if (resolver.schema) {\n return canResolveRefSchema(ref, resolver.schema);\n }\n throw new Error('Resolver is missing canResolve method and schema property');\n}\n\nexport function canResolveRefSchema(ref: string, prefixBase: string): boolean {\n const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n for (const prefix of prefixes) {\n if (ref.startsWith(prefix)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseRefValue(ref: string): string {\n // look for anything before \":\" or before +https:// or before +http://\n // https://www -> https://www\n // so some+base+https://www -> https://www\n // base+https://www -> https://www\n // base:abc -> abc\n // \"some-base\" can contain only non-:\n if (ref.startsWith('http://') || ref.startsWith('https://')) {\n return ref;\n }\n // if it is something+http:// or something+https://\n const plusHttpIndex = ref.indexOf('+http://');\n const plusHttpsIndex = ref.indexOf('+https://');\n if (plusHttpIndex !== -1) {\n return ref.substring(plusHttpIndex + 1);\n }\n if (plusHttpsIndex !== -1) {\n return ref.substring(plusHttpsIndex + 1);\n }\n // if it is something:abc\n const colonIndex = ref.indexOf(':');\n if (colonIndex !== -1) {\n return ref.substring(colonIndex + 1);\n }\n\n throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n}\n\n// export function parseRefValue(ref: string): string {\n// // look for anything before \":\" or before +https:// or before +http://\n// // https://www -> https://www\n// // so some+base+https://www -> https://www\n// // base+https://www -> https://www\n// // base:abc -> abc\n// // \"some-base\" can contain only non-:\n// if (ref.startsWith('http://') || ref.startsWith('https://')) {\n// return ref;\n// }\n// // if it is something+http:// or something+https://\n// const plusHttpIndex = ref.indexOf('+http://');\n// const plusHttpsIndex = ref.indexOf('+https://');\n// if (plusHttpIndex !== -1) {\n// return ref.substring(plusHttpIndex + 1);\n// }\n// if (plusHttpsIndex !== -1) {\n// return ref.substring(plusHttpsIndex + 1);\n// }\n// // if it is something:abc\n// const colonIndex = ref.indexOf(':');\n// if (colonIndex !== -1) {\n// return ref.substring(colonIndex + 1);\n// }\n\n// throw new Error(`Error getting URL from: ${ref}, no valid prefix found`);\n\n// // const prefixBase = ref.split('+')[0].split(':')[0];\n// // if (!prefixBase) {\n// // throw new Error(`Invalid ref, missing prefix: ${ref}`);\n// // }\n// // return ref.substring(prefixBase.length + 1);\n\n// // const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// // for (const prefix of prefixes) {\n// // if (ref.startsWith(prefix)) {\n// // const url = ref.substring(prefix.length);\n// // if (!url) {\n// // throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// // }\n// // return url;\n// // }\n// // }\n\n// // throw new Error(\n// // `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// // );\n// }\n\n// export function parseRefValue(ref: string, prefixBase: string): string {\n// const prefixes = [`${prefixBase}+`, `${prefixBase}:`];\n// for (const prefix of prefixes) {\n// if (ref.startsWith(prefix)) {\n// const url = ref.substring(prefix.length);\n// if (!url) {\n// throw new Error(`Invalid ref, missing URL after prefix \"${prefix}\": ${ref}`);\n// }\n// return url;\n// }\n// }\n\n// throw new Error(\n// `Error getting URL from: ${ref}, none of the prefixes matched: ${prefixes.join(', ')}`\n// );\n// }\n\n// const importJsonNative = new Function('url', 'return import(url, { with: { type: \"json\" } });') as (\n// url: string\n// ) => Promise<any>;\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugResolve'] = async function debugResolve<T>(\n object: any,\n jsonPointer: string,\n options?: ResolveOptions\n ) {\n return await resolve<T>(object, jsonPointer, options as any);\n };\n\n // (window as any)['__dd'] = async function dd() {\n // const url = 'https://demo.expofp.com/manifest.json';\n // // const imp = import;\n // const zz = (await importJsonNative(url)).default;\n // console.warn('debugResolve demo manifest:', zz);\n // // let object: any;\n // // let ref: string;\n // // let resolveContext: ResolveOptions | undefined;\n // // if (typeof objectOrRef === 'string') {\n // // object = (window as any)['__lastResolveObject'];\n // // ref = objectOrRef;\n // // resolveContext = refOrContext;\n // // } else {\n // // object = objectOrRef;\n // // ref = refOrContext;\n // // resolveContext = context;\n // // }\n // // return await resolve(object, ref, resolveContext);\n // };\n}\n\n// if (index === parts.length - 1) {\n// return await resolveObject(object, context);\n// }\n// if (object === null || typeof object !== 'object') {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join('/')}', index ${index}'`\n// );\n// }\n// if (!(parts[0] in object)) {\n// return undefined;\n// }\n// let partIndex = 0;\n// let currentObject = await resolveObject(object, context);\n// while (partIndex < parts.length) {\n// const part = parts[partIndex];\n// if (typeof currentObject !== 'object' || currentObject === null) {\n// throw new Error(\n// `Cannot resolve path, encountered non-object at part '${parts.join(\n// '/'\n// )}, index ${partIndex}'`\n// );\n// }\n// // console.info(\n// // 'resolvePath currentObject:',\n// // part,\n// // JSON.stringify(currentObject, null, 2),\n// // currentObject[part]\n// // );\n// // debugger;\n// const child = currentObject[part];\n// currentObject = await resolveObject(child, context);\n// partIndex++;\n// }\n// return currentObject;\n","import { resolve } from './resolve';\n\n// export const NOT_APPLICABLE = Symbol('not-applicable');\n// export const STOP_RESOLVING = Symbol('STOP_RESOLVING');\n\nexport function createFunction(name: string) {\n return async (manifest: unknown, ...args: IArguments[]) => {\n try {\n const runtimeEntryPoint = await resolve(manifest, '/runtime/entry');\n const moduleExports = await import(/* @vite-ignore */ runtimeEntryPoint);\n const functionToCall = moduleExports[name];\n return functionToCall(manifest, ...args);\n } catch (error) {\n console.error('efp-loader', `Error when trying to import and call \"${name}\":`, error);\n throw error;\n }\n };\n}\n\nexport function 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 shallowClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') return obj;\n if (Array.isArray(obj)) {\n return obj.slice() as any;\n }\n return { ...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 shallowClone(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 };//deepClone({ ...target });\n for (const key of nonRefKeys) {\n result[key] = source[key];\n }\n // deepFreeze(result);\n return result;\n}\n\nexport function replaceObjectFields(target: any, source: any): void {\n if (target === source) {\n return;\n // throw new Error('Cannot replace object with itself');\n }\n // if source is primitive, throw\n if (source === null || typeof source !== 'object') {\n throw new Error('Cannot replace with non-object source');\n }\n // if target is primitive, throw\n if (target === null || typeof target !== 'object') {\n throw new Error('Cannot replace non-object target');\n }\n\n if (Array.isArray(target)) {\n if (!Array.isArray(source)) {\n throw new Error('replaceObjectFields does not support mixing arrays and objects');\n }\n // both are arrays - replace contents\n target.length = 0;\n for (const item of source) {\n target.push(item);\n }\n return;\n }\n\n // delete keys in target that are not in source\n for (const key of Object.keys(target)) {\n if (!(key in source)) {\n delete target[key];\n }\n }\n\n // copy keys from source to target\n for (const key of Object.keys(source)) {\n target[key] = source[key];\n }\n}\n","import { resolve } from './resolve';\nimport type { ResolveOptions } from './resolve';\n\nexport async function mutateManifest(\n manifest: any,\n paths: string[],\n resolveContext?: Omit<ResolveOptions, 'mutate'>\n): Promise<void> {\n resolveContext = resolveContext || {};\n\n for (const path of paths) {\n await resolve(manifest, path, { ...resolveContext, mutate: true });\n }\n}\n\nif (typeof window !== 'undefined') {\n (window as any)['__debugMutateManifest'] = mutateManifest;\n}\n","export async function makeOffline(manifest: unknown) {\n const { makeOffline } = await import('./makeOffline');\n return await makeOffline(manifest);\n}\n\nexport async function makeOfflineBundle(manifest: unknown) {\n const { makeOfflineBundle } = await import('./makeOfflineBundle');\n return await makeOfflineBundle(manifest);\n}\n\nexport async function generateZip(\n manifest: unknown,\n extraFiles?: Array<{ path: string; data: Uint8Array }>\n) {\n const { generateZip } = await import('./generateZip');\n return await generateZip(manifest, extraFiles);\n}\n\nexport async function downloadOfflineZip(\n manifest: unknown,\n extraFiles?: Array<{ path: string; data: Uint8Array }>\n) {\n const { downloadOfflineZip } = await import('./downloadOfflineZip');\n return await downloadOfflineZip(manifest, extraFiles);\n}\n\nexport async function saveOfflineZip(manifest: unknown, path: string) {\n const { saveOfflineZip } = await import('./saveOfflineZip');\n return await saveOfflineZip(manifest, path);\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)['__debugDownloadOfflineZip'] = downloadOfflineZip;\n (window as any)['__debugMakeOfflineBundle'] = makeOfflineBundle;\n (window as any)['__debugLogOfflineManifestFiles'] = debugLogOfflineManifestFiles;\n}\n","import { log } from './logger';\nimport { createFunction } from './shared';\n\nconst info = (globalThis as any).__efpLoaderBuildInfo as\n | [version: string, builtAt: string]\n | undefined;\n\nif (info) {\n log('Initialized', { version: info[0], builtAt: info[1] });\n} else {\n log('Initialized');\n}\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 { mutateManifest } from './mutateManifest';\nexport { downloadOfflineZip, makeOfflineBundle, saveOfflineZip, makeOffline } from './offline';\nexport { resolve } from './resolve';\n\n// preloadJson('https://efp-runtime.expofp.com/branches/main.json');\n// preconnectUrl('https://efp-runtime.expofp.com/');\n"],"names":["hasRequiredMs","s","m","h","d","w","ms","val","options","type","parse","fmtLong","fmtShort","str","match","n","y","msAbs","plural","name","isPlural","hasRequiredCommon","setup","env","createDebug","coerce","disable","enable","enabled","requireMs","key","selectColor","namespace","i","hash","prevTime","enableOverride","namespacesCache","debug","args","curr","self","index","format","formatter","enabledCache","v","delimiter","newDebug","namespaces","split","ns","matchesTemplate","search","template","searchIndex","templateIndex","starIndex","matchIndex","skip","destroy","module","exports","formatArgs","save","load","localstorage","warned","useColors","c","lastC","r","formatters","error","logger","log$3","resolveAssetRefSync","ref","parseRefValue","assetResolver","importJsonNotAvailable","jsonFrozen","importJsonNative","url","resolveContext","log","result","_b","loadJson","_c","deepFreeze","signal","fetchCache","dataPromise","response","returnCachedRef","refCache","factory","promise","data","bundleAssetsResolver","context","files","importJson","baseUrl","file","SCHEMA","SCHEMA$1","cssTextAssetResolver","log$2","_context","offlineFunc","BASE_URL","expoRuntimeBranchResolver","branch","branchUrl","release","expoRuntimeGetBranchResolver","expoRuntimeResolver","httpResolver","global","this","fetchRetry","fetch","defaults","ArgumentError","baseDefaults","input","init","retries","retryDelay","isPositiveInteger","retryOn","resolve","reject","wrappedFetch","attempt","_input","retry","delay","value","message","log$1","loadAndWaitGlobal","scriptUrl","globalVar","timeoutMs","pollIntervalMs","isBrowser","waitForGlobal","loadScript","loadInBrowser","loadInNode","script","cleanup","onAbort","res","fetchWithRetry","err","code","g","prevWindow","getter","abortSignal","start","check","legacyAssetUrlsResolver","dataUrlBase","versionUrl","_a","version","dataUrl","dataLoadPromise","wfDataUrl","wfDataLoadPromise","fpSvgUrl","fpSvgLoadPromise","fpLayerFiles","_d","x","layerFile","_e","layerUrl","map","populateDataJsAssetsMap","links","addLink","link","e","dotIndex","ext","img","legacyDataResolver","legacyDataUrlBaseResolver","resolvers","globalRefCache","object","jsonPointer","parts","part","target","replaceObjectFields","resovlePartsRecursive","resovlePartsRecursiveMutate","node","partsIndex","resolveObjectMutate","obj","resolveObject","child","resolversToUse","canResolve","resolverResolve","resolver","canResolveRefSchema","prefixBase","prefixes","prefix","plusHttpIndex","plusHttpsIndex","colonIndex","createFunction","manifest","functionToCall","deepClone","shallowClone","createMergedObjectWithOverridenNonRefProps","source","nonRefKeys","item","mutateManifest","paths","path","makeOffline","makeOffline2","makeOfflineBundle","makeOfflineBundle2","downloadOfflineZip","downloadOfflineZip2","extraFiles","saveOfflineZip","saveOfflineZip2","debugLogOfflineManifestFiles","info","mount","initialize","callFunction_Experimental"],"mappings":"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","x_google_ignoreList":[0,1,2,13]}
1
+ {"version":3,"file":"bundle.js","sources":["../../node_modules/.pnpm/ms@2.1.3/node_modules/ms/index.js","../../node_modules/.pnpm/debug@4.4.3/node_modules/debug/src/common.js","../../node_modules/.pnpm/debug@4.4.3/node_modules/debug/src/browser.js","../../src/fetch.ts","../../src/importHttpRuntime.ts","../../src/resolve.ts","../../src/index.ts"],"sourcesContent":["/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '')\n\t\t\t.trim()\n\t\t\t.replace(/\\s+/g, ',')\n\t\t\t.split(',')\n\t\t\t.filter(Boolean);\n\n\t\tfor (const ns of split) {\n\t\t\tif (ns[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(ns.slice(1));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(ns);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Checks if the given string matches a namespace template, honoring\n\t * asterisks as wildcards.\n\t *\n\t * @param {String} search\n\t * @param {String} template\n\t * @return {Boolean}\n\t */\n\tfunction matchesTemplate(search, template) {\n\t\tlet searchIndex = 0;\n\t\tlet templateIndex = 0;\n\t\tlet starIndex = -1;\n\t\tlet matchIndex = 0;\n\n\t\twhile (searchIndex < search.length) {\n\t\t\tif (templateIndex < template.length && (template[templateIndex] === search[searchIndex] || template[templateIndex] === '*')) {\n\t\t\t\t// Match character or proceed with wildcard\n\t\t\t\tif (template[templateIndex] === '*') {\n\t\t\t\t\tstarIndex = templateIndex;\n\t\t\t\t\tmatchIndex = searchIndex;\n\t\t\t\t\ttemplateIndex++; // Skip the '*'\n\t\t\t\t} else {\n\t\t\t\t\tsearchIndex++;\n\t\t\t\t\ttemplateIndex++;\n\t\t\t\t}\n\t\t\t} else if (starIndex !== -1) { // eslint-disable-line no-negated-condition\n\t\t\t\t// Backtrack to the last '*' and try to match more characters\n\t\t\t\ttemplateIndex = starIndex + 1;\n\t\t\t\tmatchIndex++;\n\t\t\t\tsearchIndex = matchIndex;\n\t\t\t} else {\n\t\t\t\treturn false; // No match\n\t\t\t}\n\t\t}\n\n\t\t// Handle trailing '*' in template\n\t\twhile (templateIndex < template.length && template[templateIndex] === '*') {\n\t\t\ttemplateIndex++;\n\t\t}\n\n\t\treturn templateIndex === template.length;\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names,\n\t\t\t...createDebug.skips.map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tfor (const skip of createDebug.skips) {\n\t\t\tif (matchesTemplate(name, skip)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (const ns of createDebug.names) {\n\t\t\tif (matchesTemplate(name, ns)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\tlet m;\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\t// eslint-disable-next-line no-return-assign\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && (m = navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/)) && parseInt(m[1], 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug') || exports.storage.getItem('DEBUG') ;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","let fn: typeof fetch;\nexport const fetch = async function fetch(\n ...args: Parameters<typeof window.fetch>\n): ReturnType<typeof window.fetch> {\n if (!fn) {\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n fn = window.fetch.bind(window);\n } else {\n const fr = await import('fetch-retry');\n const fetchWithRetry = fr.default(globalThis.fetch);\n fn = fetchWithRetry;\n }\n }\n return fn.apply(null, args);\n};\n","import { fetch } from './fetch';\n\nexport async function importHttpRuntime<TModule = any>(runtime: string): Promise<TModule> {\n // if browser, use dynamic import\n if (typeof window !== 'undefined' && typeof document !== 'undefined') {\n const module = await import(/* @vite-ignore */ runtime);\n return module as TModule;\n } else {\n const { nodeImportHttpRuntime } = await import('./ImportHttpRuntime.node');\n return nodeImportHttpRuntime<TModule>(runtime, { fetchImpl: fetch });\n }\n}\n","// resolveHttpRefToString.ts\n// Follows $ref chains until finding a value without $ref.\n//\n// Rules:\n// - If value is an object with {$ref: string} -> follow it (fetch if http/https URL)\n// - Otherwise -> return the value as-is\n//\n// Browser: tries `import(url, { with: { type: 'json' } })` first, falls back to fetch.\n// Node: uses fetch (Node 18+ has global fetch).\n\nimport debug from 'debug';\nimport { fetch } from './fetch';\n\nconst log = debug('efp:loader:resolve');\n\nexport type ResolveOptions = {\n maxHops?: number;\n signal?: AbortSignal;\n // Hook if you want to observe each hop (debug/log/preload metrics)\n onHop?: (info: { hop: number; ref: string; via: 'import' | 'fetch' }) => void;\n fetchCallback?: (ref: string) => void;\n};\n\nexport async function resolve<T>(input: unknown, options: ResolveOptions = {}): Promise<T> {\n const maxHops = options.maxHops ?? 32;\n const seen = new Set<string>();\n\n let cur: unknown = input;\n\n for (let hop = 0; hop < maxHops; hop++) {\n // If it's an object with $ref, follow it\n if (cur && typeof cur === 'object' && '$ref' in cur) {\n const obj = cur as any;\n const ref = obj.$ref;\n\n if (typeof ref !== 'string') {\n throw new Error(`$ref must be a string, got: ${typeof ref}`);\n }\n\n // If it's an http/https URL, fetch it\n if (isHttpUrl(ref)) {\n if (seen.has(ref)) {\n throw new Error(`Circular $ref detected at: ${ref}`);\n }\n seen.add(ref);\n log('Loading JSON ref:', ref);\n options.fetchCallback?.(ref);\n const json = await loadJson(ref, options.signal);\n options.onHop?.({ hop, ref, via: json.__via });\n cur = json.value;\n continue;\n }\n\n // Non-http $ref (e.g., relative, custom schema) - return the object as-is\n // (caller is responsible for handling these)\n return cur as T;\n }\n\n // No $ref found - return current value\n return cur as T;\n }\n\n throw new Error(`Too many ref hops (>${maxHops}). Possible loop or unexpectedly deep chain.`);\n}\n\nfunction isHttpUrl(s: string): boolean {\n return s.startsWith('http://') || s.startsWith('https://');\n}\n\nasync function loadJson(\n url: string,\n signal?: AbortSignal\n): Promise<{ value: unknown; __via: 'import' | 'fetch' }> {\n // Try import() JSON first (browser-friendly; depends on runtime/bundler support + CORS)\n const imported = await tryImportJson(url);\n if (imported.ok) return { value: imported.value, __via: 'import' };\n\n // Fallback to fetch\n const res = await fetch(url, {\n method: 'GET',\n signal,\n headers: {\n // Helps some CDNs/content negotiation setups\n Accept: 'application/json, text/plain;q=0.9, */*;q=0.1',\n },\n });\n\n if (!res.ok) {\n throw new Error(`Failed to fetch JSON ref: ${url} (${res.status} ${res.statusText})`);\n }\n\n // Prefer JSON; if server mislabels, fallback to text->JSON parse.\n const ct = res.headers.get('content-type') || '';\n if (ct.includes('application/json') || ct.includes('+json')) {\n return { value: await res.json(), __via: 'fetch' };\n }\n\n const text = await res.text();\n try {\n return { value: JSON.parse(text), __via: 'fetch' };\n } catch {\n // If the endpoint literally returns a plain string (not JSON), accept it.\n return { value: text, __via: 'fetch' };\n }\n}\n\nasync function tryImportJson(\n url: string\n): Promise<{ ok: true; value: unknown } | { ok: false; error: unknown }> {\n // `with: { type: 'json' }` is the modern import assertion form.\n // Some environments still only accept `assert: { type: 'json' }`.\n try {\n //// @ts-expect-error - TS lib definitions differ across versions\n const mod = await import(/* @vite-ignore */ url, { with: { type: 'json' } });\n log('Imported JSON via import():', url);\n return { ok: true, value: mod?.default ?? mod };\n } catch (e1) {\n try {\n //// @ts-expect-error - fallback for older assertion syntax\n const mod = await import(/* @vite-ignore */ url, { assert: { type: 'json' } });\n return { ok: true, value: mod?.default ?? mod };\n } catch (e2) {\n return { ok: false, error: e2 ?? e1 };\n }\n }\n}\n","import debug from 'debug';\nimport { importHttpRuntime } from './importHttpRuntime';\nimport { resolve } from './resolve';\nimport { LoaderApi, Manifest, Ref } from './types';\n\nconst log = debug('efp:loader');\n\ndeclare global {\n const __efpLoaderBuildInfo: [version: string, builtAt: string] | undefined;\n}\n\nif (typeof __efpLoaderBuildInfo !== 'undefined') {\n log('Initialized', { version: __efpLoaderBuildInfo[0], builtAt: __efpLoaderBuildInfo[1] });\n} else {\n log('Initialized');\n}\n\nexport async function loadApi(\n manifest: Manifest | Ref | string,\n options?: {\n fetchCallback?: (ref: string) => void;\n }\n): Promise<LoaderApi> {\n log('Loading manifest:', manifest);\n if (typeof manifest === 'string') {\n manifest = { $ref: manifest };\n }\n manifest = await resolve<Manifest>(manifest, { fetchCallback: options?.fetchCallback });\n const runtime = await resolve<string>(manifest.runtime, {\n fetchCallback: options?.fetchCallback,\n });\n\n log('Resolved runtime URL:', runtime);\n if (typeof runtime !== 'string') {\n throw new Error('Resolved runtime is not a string ');\n }\n\n const api = await importHttpRuntime(runtime);\n api.meta = { runtime };\n return api; //{ ...api, runtime } as LoaderApi;\n}\n\n// allow calling api functions directly from here\nconst api: LoaderApi = new Proxy(\n {},\n {\n get: (_, prop: string) => {\n return async (...args: any[]) => {\n const manifest = args[0];\n const runtimeApi = await loadApi(manifest);\n const fn = runtimeApi[prop];\n if (typeof fn !== 'function') {\n throw new Error(`API has no function named '${prop}'`);\n }\n return fn.apply(runtimeApi, args as any);\n };\n },\n }\n);\n\nexport async function load(manifest: Manifest | Ref | string, ...args: unknown[]) {\n return api.load!(manifest, ...args);\n}\n\nexport default api;\n"],"names":["hasRequiredMs","s","m","h","d","w","ms","val","options","type","parse","fmtLong","fmtShort","str","match","n","y","msAbs","plural","name","isPlural","hasRequiredCommon","setup","env","createDebug","coerce","disable","enable","enabled","requireMs","key","selectColor","namespace","i","hash","prevTime","enableOverride","namespacesCache","debug","args","curr","self","index","format","formatter","enabledCache","v","delimiter","newDebug","namespaces","split","ns","matchesTemplate","search","template","searchIndex","templateIndex","starIndex","matchIndex","skip","destroy","module","exports","formatArgs","save","load","localstorage","warned","useColors","c","lastC","r","formatters","error","fn","fetch","importHttpRuntime","runtime","nodeImportHttpRuntime","log$1","resolve","maxHops","_a","seen","cur","input","hop","ref","log","_b","json","loadJson","_c","isHttpUrl","signal","imported","url","res","ct","text","tryImportJson","mod","e1","e2","__efpLoaderBuildInfo","loadApi","manifest","api","api2","_","prop","runtimeApi"],"mappings":"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","x_google_ignoreList":[0,1,2]}
@@ -0,0 +1,115 @@
1
+ import { g as x } from "./bundle.js";
2
+ function R(s, g) {
3
+ for (var c = 0; c < g.length; c++) {
4
+ const o = g[c];
5
+ if (typeof o != "string" && !Array.isArray(o)) {
6
+ for (const n in o)
7
+ if (n !== "default" && !(n in s)) {
8
+ const i = Object.getOwnPropertyDescriptor(o, n);
9
+ i && Object.defineProperty(s, n, i.get ? i : {
10
+ enumerable: !0,
11
+ get: () => o[n]
12
+ });
13
+ }
14
+ }
15
+ }
16
+ return Object.freeze(Object.defineProperty(s, Symbol.toStringTag, { value: "Module" }));
17
+ }
18
+ var p = { exports: {} }, A = p.exports, d;
19
+ function P() {
20
+ return d || (d = 1, (function(s, g) {
21
+ (function(c, o) {
22
+ s.exports = o();
23
+ })(A, (function() {
24
+ var c = function(i, e) {
25
+ if (e = e || {}, typeof i != "function")
26
+ throw new n("fetch must be a function");
27
+ if (typeof e != "object")
28
+ throw new n("defaults must be an object");
29
+ if (e.retries !== void 0 && !o(e.retries))
30
+ throw new n("retries must be a positive integer");
31
+ if (e.retryDelay !== void 0 && !o(e.retryDelay) && typeof e.retryDelay != "function")
32
+ throw new n("retryDelay must be a positive integer or a function returning a positive integer");
33
+ if (e.retryOn !== void 0 && !Array.isArray(e.retryOn) && typeof e.retryOn != "function")
34
+ throw new n("retryOn property expects an array or function");
35
+ var _ = {
36
+ retries: 3,
37
+ retryDelay: 1e3,
38
+ retryOn: []
39
+ };
40
+ return e = Object.assign(_, e), function(m, r) {
41
+ var v = e.retries, l = e.retryDelay, u = e.retryOn;
42
+ if (r && r.retries !== void 0)
43
+ if (o(r.retries))
44
+ v = r.retries;
45
+ else
46
+ throw new n("retries must be a positive integer");
47
+ if (r && r.retryDelay !== void 0)
48
+ if (o(r.retryDelay) || typeof r.retryDelay == "function")
49
+ l = r.retryDelay;
50
+ else
51
+ throw new n("retryDelay must be a positive integer or a function returning a positive integer");
52
+ if (r && r.retryOn)
53
+ if (Array.isArray(r.retryOn) || typeof r.retryOn == "function")
54
+ u = r.retryOn;
55
+ else
56
+ throw new n("retryOn property expects an array or function");
57
+ return new Promise(function(w, a) {
58
+ var b = function(f) {
59
+ var O = typeof Request < "u" && m instanceof Request ? m.clone() : m;
60
+ i(O, r).then(function(t) {
61
+ if (Array.isArray(u) && u.indexOf(t.status) === -1)
62
+ w(t);
63
+ else if (typeof u == "function")
64
+ try {
65
+ return Promise.resolve(u(f, null, t)).then(function(y) {
66
+ y ? h(f, null, t) : w(t);
67
+ }).catch(a);
68
+ } catch (y) {
69
+ a(y);
70
+ }
71
+ else
72
+ f < v ? h(f, null, t) : w(t);
73
+ }).catch(function(t) {
74
+ if (typeof u == "function")
75
+ try {
76
+ Promise.resolve(u(f, t, null)).then(function(y) {
77
+ y ? h(f, t, null) : a(t);
78
+ }).catch(function(y) {
79
+ a(y);
80
+ });
81
+ } catch (y) {
82
+ a(y);
83
+ }
84
+ else f < v ? h(f, t, null) : a(t);
85
+ });
86
+ };
87
+ function h(f, O, t) {
88
+ var y = typeof l == "function" ? l(f, O, t) : l;
89
+ setTimeout(function() {
90
+ b(++f);
91
+ }, y);
92
+ }
93
+ b(0);
94
+ });
95
+ };
96
+ };
97
+ function o(i) {
98
+ return Number.isInteger(i) && i >= 0;
99
+ }
100
+ function n(i) {
101
+ this.name = "ArgumentError", this.message = i;
102
+ }
103
+ return c;
104
+ }));
105
+ })(p)), p.exports;
106
+ }
107
+ var D = P();
108
+ const q = /* @__PURE__ */ x(D), j = /* @__PURE__ */ R({
109
+ __proto__: null,
110
+ default: q
111
+ }, [D]);
112
+ export {
113
+ j as f
114
+ };
115
+ //# sourceMappingURL=fetch-retry.umd-g1itNdNw.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fetch-retry.umd-g1itNdNw.js","sources":["../../node_modules/.pnpm/fetch-retry@6.0.0/node_modules/fetch-retry/dist/fetch-retry.umd.js"],"sourcesContent":["(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.fetchRetry = factory());\n})(this, (function () { 'use strict';\n\n var fetchRetry = function (fetch, defaults) {\n defaults = defaults || {};\n if (typeof fetch !== 'function') {\n throw new ArgumentError('fetch must be a function');\n }\n\n if (typeof defaults !== 'object') {\n throw new ArgumentError('defaults must be an object');\n }\n\n if (defaults.retries !== undefined && !isPositiveInteger(defaults.retries)) {\n throw new ArgumentError('retries must be a positive integer');\n }\n\n if (defaults.retryDelay !== undefined && !isPositiveInteger(defaults.retryDelay) && typeof defaults.retryDelay !== 'function') {\n throw new ArgumentError('retryDelay must be a positive integer or a function returning a positive integer');\n }\n\n if (defaults.retryOn !== undefined && !Array.isArray(defaults.retryOn) && typeof defaults.retryOn !== 'function') {\n throw new ArgumentError('retryOn property expects an array or function');\n }\n\n var baseDefaults = {\n retries: 3,\n retryDelay: 1000,\n retryOn: [],\n };\n\n defaults = Object.assign(baseDefaults, defaults);\n\n return function fetchRetry(input, init) {\n var retries = defaults.retries;\n var retryDelay = defaults.retryDelay;\n var retryOn = defaults.retryOn;\n\n if (init && init.retries !== undefined) {\n if (isPositiveInteger(init.retries)) {\n retries = init.retries;\n } else {\n throw new ArgumentError('retries must be a positive integer');\n }\n }\n\n if (init && init.retryDelay !== undefined) {\n if (isPositiveInteger(init.retryDelay) || (typeof init.retryDelay === 'function')) {\n retryDelay = init.retryDelay;\n } else {\n throw new ArgumentError('retryDelay must be a positive integer or a function returning a positive integer');\n }\n }\n\n if (init && init.retryOn) {\n if (Array.isArray(init.retryOn) || (typeof init.retryOn === 'function')) {\n retryOn = init.retryOn;\n } else {\n throw new ArgumentError('retryOn property expects an array or function');\n }\n }\n\n // eslint-disable-next-line no-undef\n return new Promise(function (resolve, reject) {\n var wrappedFetch = function (attempt) {\n // As of node 18, this is no longer needed since node comes with native support for fetch:\n /* istanbul ignore next */\n var _input =\n typeof Request !== 'undefined' && input instanceof Request\n ? input.clone()\n : input;\n fetch(_input, init)\n .then(function (response) {\n if (Array.isArray(retryOn) && retryOn.indexOf(response.status) === -1) {\n resolve(response);\n } else if (typeof retryOn === 'function') {\n try {\n // eslint-disable-next-line no-undef\n return Promise.resolve(retryOn(attempt, null, response))\n .then(function (retryOnResponse) {\n if(retryOnResponse) {\n retry(attempt, null, response);\n } else {\n resolve(response);\n }\n }).catch(reject);\n } catch (error) {\n reject(error);\n }\n } else {\n if (attempt < retries) {\n retry(attempt, null, response);\n } else {\n resolve(response);\n }\n }\n })\n .catch(function (error) {\n if (typeof retryOn === 'function') {\n try {\n // eslint-disable-next-line no-undef\n Promise.resolve(retryOn(attempt, error, null))\n .then(function (retryOnResponse) {\n if(retryOnResponse) {\n retry(attempt, error, null);\n } else {\n reject(error);\n }\n })\n .catch(function(error) {\n reject(error);\n });\n } catch(error) {\n reject(error);\n }\n } else if (attempt < retries) {\n retry(attempt, error, null);\n } else {\n reject(error);\n }\n });\n };\n\n function retry(attempt, error, response) {\n var delay = (typeof retryDelay === 'function') ?\n retryDelay(attempt, error, response) : retryDelay;\n setTimeout(function () {\n wrappedFetch(++attempt);\n }, delay);\n }\n\n wrappedFetch(0);\n });\n };\n };\n\n function isPositiveInteger(value) {\n return Number.isInteger(value) && value >= 0;\n }\n\n function ArgumentError(message) {\n this.name = 'ArgumentError';\n this.message = message;\n }\n\n return fetchRetry;\n\n}));\n"],"names":["global","factory","module","this","fetchRetry","fetch","defaults","ArgumentError","isPositiveInteger","baseDefaults","input","init","retries","retryDelay","retryOn","resolve","reject","wrappedFetch","attempt","_input","response","retryOnResponse","retry","error","delay","value","message"],"mappings":"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","x_google_ignoreList":[0]}
@@ -0,0 +1,28 @@
1
+ export type ImportHttpRuntimeOptions = {
2
+ /**
3
+ * Where to store downloaded runtime bundles.
4
+ * Default: <os.tmpdir()>/efp-loader
5
+ */
6
+ cacheRootDir?: string;
7
+ /**
8
+ * Max parallel downloads.
9
+ * Default: 8
10
+ */
11
+ concurrency?: number;
12
+ /**
13
+ * If true, will re-download files even if already present.
14
+ * Default: false
15
+ */
16
+ forceRedownload?: boolean;
17
+ /**
18
+ * Pass a custom fetch (useful for tests / node < 18).
19
+ * Default: global fetch
20
+ */
21
+ fetchImpl?: typeof fetch;
22
+ };
23
+ /**
24
+ * Downloads an HTTP runtime bundle (bundle.json + all referenced files)
25
+ * into a stable temp folder hashed by the runtime directory URL,
26
+ * then imports expofp.js locally via file://.
27
+ */
28
+ export declare function nodeImportHttpRuntime<TModule = any>(runtime: string, opts?: ImportHttpRuntimeOptions): Promise<TModule>;