@module-federation/bridge-vue3 0.0.0-next-20241205062623 → 0.0.0-next-20241205085800
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +5 -12
- package/dist/index.cjs.js +3 -3
- package/dist/index.es.js +622 -613
- package/package.json +4 -4
package/dist/index.es.js
CHANGED
|
@@ -2,15 +2,15 @@ import * as Vue from "vue";
|
|
|
2
2
|
import { defineComponent, ref, watch, onMounted, onBeforeUnmount, createVNode, defineAsyncComponent, h } from "vue";
|
|
3
3
|
import * as VueRouter from "vue-router";
|
|
4
4
|
import { useRoute } from "vue-router";
|
|
5
|
-
var __defProp = Object.defineProperty, __getOwnPropDesc = Object.getOwnPropertyDescriptor, __getOwnPropNames = Object.getOwnPropertyNames, __hasOwnProp = Object.prototype.hasOwnProperty, __export = (
|
|
6
|
-
for (var
|
|
7
|
-
__defProp(
|
|
8
|
-
}, __copyProps = (
|
|
5
|
+
var __defProp = Object.defineProperty, __getOwnPropDesc = Object.getOwnPropertyDescriptor, __getOwnPropNames = Object.getOwnPropertyNames, __hasOwnProp = Object.prototype.hasOwnProperty, __export = (o, t) => {
|
|
6
|
+
for (var r in t)
|
|
7
|
+
__defProp(o, r, { get: t[r], enumerable: !0 });
|
|
8
|
+
}, __copyProps = (o, t, r, n) => {
|
|
9
9
|
if (t && typeof t == "object" || typeof t == "function")
|
|
10
10
|
for (let s of __getOwnPropNames(t))
|
|
11
|
-
!__hasOwnProp.call(
|
|
12
|
-
return
|
|
13
|
-
}, __toCommonJS = (
|
|
11
|
+
!__hasOwnProp.call(o, s) && s !== r && __defProp(o, s, { get: () => t[s], enumerable: !(n = __getOwnPropDesc(t, s)) || n.enumerable });
|
|
12
|
+
return o;
|
|
13
|
+
}, __toCommonJS = (o) => __copyProps(__defProp({}, "__esModule", { value: !0 }), o), browser_exports = {};
|
|
14
14
|
__export(browser_exports, {
|
|
15
15
|
createLogger: () => createLogger2,
|
|
16
16
|
logger: () => logger$1
|
|
@@ -19,10 +19,10 @@ var browser = __toCommonJS(browser_exports), supportsSubstitutions = void 0, sup
|
|
|
19
19
|
if (typeof supportsSubstitutions < "u")
|
|
20
20
|
return supportsSubstitutions;
|
|
21
21
|
try {
|
|
22
|
-
const
|
|
22
|
+
const o = "color test", t = "color: red;", r = console.log;
|
|
23
23
|
console.log = (...n) => {
|
|
24
|
-
n[0] === `%c${
|
|
25
|
-
}, console.log(`%c${
|
|
24
|
+
n[0] === `%c${o}` && n[1] === t && (supportsSubstitutions = !0);
|
|
25
|
+
}, console.log(`%c${o}`, t), console.log = r;
|
|
26
26
|
} catch {
|
|
27
27
|
supportsSubstitutions = !1;
|
|
28
28
|
}
|
|
@@ -35,20 +35,20 @@ var browser = __toCommonJS(browser_exports), supportsSubstitutions = void 0, sup
|
|
|
35
35
|
dodgerblue: "color: dodgerblue;",
|
|
36
36
|
magenta: "color: magenta;",
|
|
37
37
|
gray: "color: gray;"
|
|
38
|
-
}, formatter = (
|
|
38
|
+
}, formatter = (o) => supportColor() ? (t) => {
|
|
39
39
|
if (Array.isArray(t)) {
|
|
40
|
-
const [
|
|
41
|
-
return [`%c${
|
|
40
|
+
const [r, n] = t;
|
|
41
|
+
return [`%c${r.replace("%c", "")}`, n ? `${ansiToCss[o]}${n}` : `${ansiToCss[o] || ""}`];
|
|
42
42
|
}
|
|
43
|
-
return [`%c${String(t).replace("%c", "")}`, ansiToCss[
|
|
43
|
+
return [`%c${String(t).replace("%c", "")}`, ansiToCss[o] || ""];
|
|
44
44
|
} : (t) => [String(t)], bold = formatter("bold"), red = formatter("red"), green = formatter("green"), orange = formatter("orange"), dodgerblue = formatter("dodgerblue"), magenta = formatter("magenta");
|
|
45
45
|
formatter("gray");
|
|
46
|
-
function getLabel(
|
|
46
|
+
function getLabel(o, t, r) {
|
|
47
47
|
let n = [""];
|
|
48
|
-
return "label" in t && (n = [o
|
|
48
|
+
return "label" in t && (n = [r[o] || t.label || ""], n = bold(t.color ? t.color(n) : n[0])), n = n.filter(Boolean), n;
|
|
49
49
|
}
|
|
50
|
-
function finalLog(
|
|
51
|
-
|
|
50
|
+
function finalLog(o, t, r, n) {
|
|
51
|
+
o.length ? Array.isArray(n) ? console.log(...o, ...n) : console.log(...o, t) : Array.isArray(n) ? console.log(...n) : console.log(t, ...r);
|
|
52
52
|
}
|
|
53
53
|
var LOG_LEVEL = {
|
|
54
54
|
error: 0,
|
|
@@ -56,8 +56,8 @@ var LOG_LEVEL = {
|
|
|
56
56
|
info: 2,
|
|
57
57
|
log: 3,
|
|
58
58
|
verbose: 4
|
|
59
|
-
}, errorStackRegExp = /at\s.*:\d+:\d+[\s\)]*$/, anonymousErrorStackRegExp = /at\s.*\(<anonymous>\)$/, isErrorStackMessage = (
|
|
60
|
-
let a =
|
|
59
|
+
}, errorStackRegExp = /at\s.*:\d+:\d+[\s\)]*$/, anonymousErrorStackRegExp = /at\s.*\(<anonymous>\)$/, isErrorStackMessage = (o) => errorStackRegExp.test(o) || anonymousErrorStackRegExp.test(o), createLogger$1 = (o = {}, { getLabel: t, handleError: r, finalLog: n, greet: s, LOG_TYPES: l }) => {
|
|
60
|
+
let a = o.level || "log", i = o.labels || {}, c = (d, p, ...m) => {
|
|
61
61
|
if (LOG_LEVEL[l[d].level] > LOG_LEVEL[a])
|
|
62
62
|
return;
|
|
63
63
|
if (p == null)
|
|
@@ -69,13 +69,13 @@ var LOG_LEVEL = {
|
|
|
69
69
|
let [g, ...E] = p.stack.split(`
|
|
70
70
|
`);
|
|
71
71
|
g.startsWith("Error: ") && (g = g.slice(7)), _ = `${g}
|
|
72
|
-
${
|
|
72
|
+
${r(E.join(`
|
|
73
73
|
`))}`;
|
|
74
74
|
} else
|
|
75
75
|
_ = p.message;
|
|
76
76
|
else
|
|
77
77
|
y.level === "error" && typeof p == "string" ? _ = p.split(`
|
|
78
|
-
`).map((E) => isErrorStackMessage(E) ?
|
|
78
|
+
`).map((E) => isErrorStackMessage(E) ? r(E) : E).join(`
|
|
79
79
|
`) : _ = `${p}`;
|
|
80
80
|
n(R, _, m, p);
|
|
81
81
|
}, u = {
|
|
@@ -97,17 +97,17 @@ ${o(E.join(`
|
|
|
97
97
|
}), u.override = (d) => {
|
|
98
98
|
Object.assign(u, d);
|
|
99
99
|
}, u;
|
|
100
|
-
}, startColor = [189, 255, 243], endColor = [74, 194, 154], isWord = (
|
|
101
|
-
function gradient(
|
|
100
|
+
}, startColor = [189, 255, 243], endColor = [74, 194, 154], isWord = (o) => !/[\s\n]/.test(o);
|
|
101
|
+
function gradient(o) {
|
|
102
102
|
if (!supportColor())
|
|
103
|
-
return [
|
|
104
|
-
const t = [...
|
|
103
|
+
return [o];
|
|
104
|
+
const t = [...o], r = t.filter(isWord), n = r.length - 1;
|
|
105
105
|
if (n === 0)
|
|
106
|
-
return console.log(`%c${
|
|
106
|
+
return console.log(`%c${o}`, `color: rgb(${startColor.join(",")}); font-weight: bold;`), [o];
|
|
107
107
|
let s = "", l = [];
|
|
108
108
|
return t.forEach((a) => {
|
|
109
109
|
if (isWord(a)) {
|
|
110
|
-
const i =
|
|
110
|
+
const i = r.indexOf(a) / n, c = Math.round(startColor[0] + (endColor[0] - startColor[0]) * i), u = Math.round(startColor[1] + (endColor[1] - startColor[1]) * i), d = Math.round(startColor[2] + (endColor[2] - startColor[2]) * i);
|
|
111
111
|
s += `%c${a}`, l.push(`color: rgb(${c},${u},${d}); font-weight: bold;`);
|
|
112
112
|
} else
|
|
113
113
|
s += a;
|
|
@@ -158,8 +158,8 @@ var LOG_TYPES = {
|
|
|
158
158
|
color: magenta
|
|
159
159
|
}
|
|
160
160
|
};
|
|
161
|
-
function createLogger2(
|
|
162
|
-
return createLogger$1(
|
|
161
|
+
function createLogger2(o = {}) {
|
|
162
|
+
return createLogger$1(o, {
|
|
163
163
|
handleError: (t) => t,
|
|
164
164
|
getLabel,
|
|
165
165
|
gradient,
|
|
@@ -171,8 +171,8 @@ function createLogger2(r = {}) {
|
|
|
171
171
|
var logger$1 = createLogger2();
|
|
172
172
|
function _extends$2() {
|
|
173
173
|
return _extends$2 = Object.assign || function(t) {
|
|
174
|
-
for (var
|
|
175
|
-
var n = arguments[
|
|
174
|
+
for (var r = 1; r < arguments.length; r++) {
|
|
175
|
+
var n = arguments[r];
|
|
176
176
|
for (var s in n)
|
|
177
177
|
Object.prototype.hasOwnProperty.call(n, s) && (t[s] = n[s]);
|
|
178
178
|
}
|
|
@@ -196,11 +196,11 @@ function isDebugMode() {
|
|
|
196
196
|
return typeof process < "u" && process.env && process.env.FEDERATION_DEBUG ? !!process.env.FEDERATION_DEBUG : typeof FEDERATION_DEBUG < "u" && FEDERATION_DEBUG ? !0 : isBrowserDebug();
|
|
197
197
|
}
|
|
198
198
|
const PREFIX = "[ Module Federation ]";
|
|
199
|
-
function setDebug(
|
|
200
|
-
isDebugMode() && (
|
|
199
|
+
function setDebug(o) {
|
|
200
|
+
isDebugMode() && (o.level = "verbose");
|
|
201
201
|
}
|
|
202
|
-
function setPrefix(
|
|
203
|
-
|
|
202
|
+
function setPrefix(o, t) {
|
|
203
|
+
o.labels = {
|
|
204
204
|
warn: `${t} Warn`,
|
|
205
205
|
error: `${t} Error`,
|
|
206
206
|
success: `${t} Success`,
|
|
@@ -209,7 +209,7 @@ function setPrefix(r, t) {
|
|
|
209
209
|
debug: `${t} Debug`
|
|
210
210
|
};
|
|
211
211
|
}
|
|
212
|
-
function createLogger(
|
|
212
|
+
function createLogger(o) {
|
|
213
213
|
const t = browser.createLogger({
|
|
214
214
|
labels: {
|
|
215
215
|
warn: `${PREFIX} Warn`,
|
|
@@ -220,29 +220,29 @@ function createLogger(r) {
|
|
|
220
220
|
debug: `${PREFIX} Debug`
|
|
221
221
|
}
|
|
222
222
|
});
|
|
223
|
-
return setDebug(t), setPrefix(t,
|
|
223
|
+
return setDebug(t), setPrefix(t, o), t;
|
|
224
224
|
}
|
|
225
225
|
createLogger(PREFIX);
|
|
226
|
-
const LOG_CATEGORY$1 = "[ Federation Runtime ]", composeKeyWithSeparator = function(...
|
|
227
|
-
return
|
|
228
|
-
}, getResourceUrl = (
|
|
229
|
-
if ("getPublicPath" in
|
|
230
|
-
let
|
|
231
|
-
return
|
|
226
|
+
const LOG_CATEGORY$1 = "[ Federation Runtime ]", composeKeyWithSeparator = function(...o) {
|
|
227
|
+
return o.length ? o.reduce((t, r) => r ? t ? `${t}${SEPARATOR}${r}` : r : t, "") : "";
|
|
228
|
+
}, getResourceUrl = (o, t) => {
|
|
229
|
+
if ("getPublicPath" in o) {
|
|
230
|
+
let r;
|
|
231
|
+
return o.getPublicPath.startsWith("function") ? r = new Function("return " + o.getPublicPath)()() : r = new Function(o.getPublicPath)(), `${r}${t}`;
|
|
232
232
|
} else
|
|
233
|
-
return "publicPath" in
|
|
234
|
-
}, warn$1 = (
|
|
235
|
-
console.warn(`${LOG_CATEGORY$1}: ${
|
|
233
|
+
return "publicPath" in o ? `${o.publicPath}${t}` : (console.warn("Cannot get resource URL. If in debug mode, please ignore.", o, t), "");
|
|
234
|
+
}, warn$1 = (o) => {
|
|
235
|
+
console.warn(`${LOG_CATEGORY$1}: ${o}`);
|
|
236
236
|
};
|
|
237
|
-
function safeToString(
|
|
237
|
+
function safeToString(o) {
|
|
238
238
|
try {
|
|
239
|
-
return JSON.stringify(
|
|
239
|
+
return JSON.stringify(o, null, 2);
|
|
240
240
|
} catch {
|
|
241
241
|
return "";
|
|
242
242
|
}
|
|
243
243
|
}
|
|
244
|
-
const simpleJoinRemoteEntry = (
|
|
245
|
-
if (!
|
|
244
|
+
const simpleJoinRemoteEntry = (o, t) => {
|
|
245
|
+
if (!o)
|
|
246
246
|
return t;
|
|
247
247
|
const n = ((s) => {
|
|
248
248
|
if (s === ".")
|
|
@@ -254,25 +254,25 @@ const simpleJoinRemoteEntry = (r, t) => {
|
|
|
254
254
|
return l.endsWith("/") ? l.slice(0, -1) : l;
|
|
255
255
|
}
|
|
256
256
|
return s;
|
|
257
|
-
})(
|
|
257
|
+
})(o);
|
|
258
258
|
return n ? n.endsWith("/") ? `${n}${t}` : `${n}/${t}` : t;
|
|
259
259
|
};
|
|
260
|
-
function inferAutoPublicPath(
|
|
261
|
-
return
|
|
260
|
+
function inferAutoPublicPath(o) {
|
|
261
|
+
return o.replace(/#.*$/, "").replace(/\?.*$/, "").replace(/\/[^\/]+$/, "/");
|
|
262
262
|
}
|
|
263
|
-
function generateSnapshotFromManifest(
|
|
264
|
-
var
|
|
263
|
+
function generateSnapshotFromManifest(o, t = {}) {
|
|
264
|
+
var r, n;
|
|
265
265
|
const { remotes: s = {}, overrides: l = {}, version: a } = t;
|
|
266
266
|
let i;
|
|
267
|
-
const c = () => "publicPath" in
|
|
267
|
+
const c = () => "publicPath" in o.metaData ? o.metaData.publicPath === "auto" && a ? inferAutoPublicPath(a) : o.metaData.publicPath : o.metaData.getPublicPath, u = Object.keys(l);
|
|
268
268
|
let d = {};
|
|
269
269
|
if (!Object.keys(s).length) {
|
|
270
270
|
var p;
|
|
271
|
-
d = ((p =
|
|
272
|
-
let
|
|
271
|
+
d = ((p = o.remotes) == null ? void 0 : p.reduce((b, $) => {
|
|
272
|
+
let w;
|
|
273
273
|
const O = $.federationContainerName;
|
|
274
|
-
return u.includes(O) ?
|
|
275
|
-
matchedVersion:
|
|
274
|
+
return u.includes(O) ? w = l[O] : "version" in $ ? w = $.version : w = $.entry, b[O] = {
|
|
275
|
+
matchedVersion: w
|
|
276
276
|
}, b;
|
|
277
277
|
}, {})) || {};
|
|
278
278
|
}
|
|
@@ -280,7 +280,7 @@ function generateSnapshotFromManifest(r, t = {}) {
|
|
|
280
280
|
// overrides will override dependencies
|
|
281
281
|
matchedVersion: u.includes(b) ? l[b] : s[b]
|
|
282
282
|
});
|
|
283
|
-
const { remoteEntry: { path: m, name: y, type: _ }, types: R, buildInfo: { buildVersion: g }, globalName: E, ssrRemoteEntry: I } =
|
|
283
|
+
const { remoteEntry: { path: m, name: y, type: _ }, types: R, buildInfo: { buildVersion: g }, globalName: E, ssrRemoteEntry: I } = o.metaData, { exposes: v } = o;
|
|
284
284
|
let S = {
|
|
285
285
|
version: a || "",
|
|
286
286
|
buildVersion: g,
|
|
@@ -291,7 +291,7 @@ function generateSnapshotFromManifest(r, t = {}) {
|
|
|
291
291
|
remoteTypesZip: R.zip || "",
|
|
292
292
|
remoteTypesAPI: R.api || "",
|
|
293
293
|
remotesInfo: d,
|
|
294
|
-
shared:
|
|
294
|
+
shared: o == null ? void 0 : o.shared.map((b) => ({
|
|
295
295
|
assets: b.assets,
|
|
296
296
|
sharedName: b.name,
|
|
297
297
|
version: b.version
|
|
@@ -302,20 +302,20 @@ function generateSnapshotFromManifest(r, t = {}) {
|
|
|
302
302
|
assets: b.assets
|
|
303
303
|
}))
|
|
304
304
|
};
|
|
305
|
-
if ((
|
|
306
|
-
const b =
|
|
305
|
+
if ((r = o.metaData) != null && r.prefetchInterface) {
|
|
306
|
+
const b = o.metaData.prefetchInterface;
|
|
307
307
|
S = _extends$2({}, S, {
|
|
308
308
|
prefetchInterface: b
|
|
309
309
|
});
|
|
310
310
|
}
|
|
311
|
-
if ((n =
|
|
312
|
-
const { path: b, name: $, type:
|
|
311
|
+
if ((n = o.metaData) != null && n.prefetchEntry) {
|
|
312
|
+
const { path: b, name: $, type: w } = o.metaData.prefetchEntry;
|
|
313
313
|
S = _extends$2({}, S, {
|
|
314
314
|
prefetchEntry: simpleJoinRemoteEntry(b, $),
|
|
315
|
-
prefetchEntryType:
|
|
315
|
+
prefetchEntryType: w
|
|
316
316
|
});
|
|
317
317
|
}
|
|
318
|
-
if ("publicPath" in
|
|
318
|
+
if ("publicPath" in o.metaData ? i = _extends$2({}, S, {
|
|
319
319
|
publicPath: c()
|
|
320
320
|
}) : i = _extends$2({}, S, {
|
|
321
321
|
getPublicPath: c()
|
|
@@ -325,43 +325,43 @@ function generateSnapshotFromManifest(r, t = {}) {
|
|
|
325
325
|
}
|
|
326
326
|
return i;
|
|
327
327
|
}
|
|
328
|
-
function isManifestProvider(
|
|
329
|
-
return !!("remoteEntry" in
|
|
328
|
+
function isManifestProvider(o) {
|
|
329
|
+
return !!("remoteEntry" in o && o.remoteEntry.includes(MANIFEST_EXT));
|
|
330
330
|
}
|
|
331
|
-
async function safeWrapper(
|
|
331
|
+
async function safeWrapper(o, t) {
|
|
332
332
|
try {
|
|
333
|
-
return await
|
|
334
|
-
} catch (
|
|
335
|
-
warn$1(
|
|
333
|
+
return await o();
|
|
334
|
+
} catch (r) {
|
|
335
|
+
warn$1(r);
|
|
336
336
|
return;
|
|
337
337
|
}
|
|
338
338
|
}
|
|
339
|
-
function isStaticResourcesEqual(
|
|
340
|
-
const
|
|
339
|
+
function isStaticResourcesEqual(o, t) {
|
|
340
|
+
const r = /^(https?:)?\/\//i, n = o.replace(r, "").replace(/\/$/, ""), s = t.replace(r, "").replace(/\/$/, "");
|
|
341
341
|
return n === s;
|
|
342
342
|
}
|
|
343
|
-
function createScript(
|
|
344
|
-
let t = null,
|
|
343
|
+
function createScript(o) {
|
|
344
|
+
let t = null, r = !0, n = 2e4, s;
|
|
345
345
|
const l = document.getElementsByTagName("script");
|
|
346
346
|
for (let i = 0; i < l.length; i++) {
|
|
347
347
|
const c = l[i], u = c.getAttribute("src");
|
|
348
|
-
if (u && isStaticResourcesEqual(u,
|
|
349
|
-
t = c,
|
|
348
|
+
if (u && isStaticResourcesEqual(u, o.url)) {
|
|
349
|
+
t = c, r = !1;
|
|
350
350
|
break;
|
|
351
351
|
}
|
|
352
352
|
}
|
|
353
353
|
if (!t) {
|
|
354
|
-
const i =
|
|
354
|
+
const i = o.attrs;
|
|
355
355
|
t = document.createElement("script"), t.type = (i == null ? void 0 : i.type) === "module" ? "module" : "text/javascript";
|
|
356
356
|
let c;
|
|
357
|
-
|
|
357
|
+
o.createScriptHook && (c = o.createScriptHook(o.url, o.attrs), c instanceof HTMLScriptElement ? t = c : typeof c == "object" && ("script" in c && c.script && (t = c.script), "timeout" in c && c.timeout && (n = c.timeout))), t.src || (t.src = o.url), i && !c && Object.keys(i).forEach((u) => {
|
|
358
358
|
t && (u === "async" || u === "defer" ? t[u] = i[u] : t.getAttribute(u) || t.setAttribute(u, i[u]));
|
|
359
359
|
});
|
|
360
360
|
}
|
|
361
361
|
const a = async (i, c) => {
|
|
362
362
|
var u;
|
|
363
363
|
if (clearTimeout(s), t && (t.onerror = null, t.onload = null, safeWrapper(() => {
|
|
364
|
-
const { needDeleteScript: m = !0 } =
|
|
364
|
+
const { needDeleteScript: m = !0 } = o;
|
|
365
365
|
m && t != null && t.parentNode && t.parentNode.removeChild(t);
|
|
366
366
|
}), i && typeof i == "function")) {
|
|
367
367
|
var d;
|
|
@@ -369,94 +369,94 @@ function createScript(r) {
|
|
|
369
369
|
if (m instanceof Promise) {
|
|
370
370
|
var p;
|
|
371
371
|
const y = await m;
|
|
372
|
-
return
|
|
372
|
+
return o == null || (p = o.cb) == null || p.call(o), y;
|
|
373
373
|
}
|
|
374
|
-
return
|
|
374
|
+
return o == null || (d = o.cb) == null || d.call(o), m;
|
|
375
375
|
}
|
|
376
|
-
|
|
376
|
+
o == null || (u = o.cb) == null || u.call(o);
|
|
377
377
|
};
|
|
378
378
|
return t.onerror = a.bind(null, t.onerror), t.onload = a.bind(null, t.onload), s = setTimeout(() => {
|
|
379
|
-
a(null, new Error(`Remote script "${
|
|
379
|
+
a(null, new Error(`Remote script "${o.url}" time-outed.`));
|
|
380
380
|
}, n), {
|
|
381
381
|
script: t,
|
|
382
|
-
needAttach:
|
|
382
|
+
needAttach: r
|
|
383
383
|
};
|
|
384
384
|
}
|
|
385
|
-
function createLink(
|
|
386
|
-
let t = null,
|
|
385
|
+
function createLink(o) {
|
|
386
|
+
let t = null, r = !0;
|
|
387
387
|
const n = document.getElementsByTagName("link");
|
|
388
388
|
for (let l = 0; l < n.length; l++) {
|
|
389
389
|
const a = n[l], i = a.getAttribute("href"), c = a.getAttribute("ref");
|
|
390
|
-
if (i && isStaticResourcesEqual(i,
|
|
391
|
-
t = a,
|
|
390
|
+
if (i && isStaticResourcesEqual(i, o.url) && c === o.attrs.ref) {
|
|
391
|
+
t = a, r = !1;
|
|
392
392
|
break;
|
|
393
393
|
}
|
|
394
394
|
}
|
|
395
395
|
if (!t) {
|
|
396
|
-
t = document.createElement("link"), t.setAttribute("href",
|
|
396
|
+
t = document.createElement("link"), t.setAttribute("href", o.url);
|
|
397
397
|
let l;
|
|
398
|
-
const a =
|
|
399
|
-
|
|
398
|
+
const a = o.attrs;
|
|
399
|
+
o.createLinkHook && (l = o.createLinkHook(o.url, a), l instanceof HTMLLinkElement && (t = l)), a && !l && Object.keys(a).forEach((i) => {
|
|
400
400
|
t && !t.getAttribute(i) && t.setAttribute(i, a[i]);
|
|
401
401
|
});
|
|
402
402
|
}
|
|
403
403
|
const s = (l, a) => {
|
|
404
404
|
if (t && (t.onerror = null, t.onload = null, safeWrapper(() => {
|
|
405
|
-
const { needDeleteLink: i = !0 } =
|
|
405
|
+
const { needDeleteLink: i = !0 } = o;
|
|
406
406
|
i && t != null && t.parentNode && t.parentNode.removeChild(t);
|
|
407
407
|
}), l)) {
|
|
408
408
|
const i = l(a);
|
|
409
|
-
return
|
|
409
|
+
return o.cb(), i;
|
|
410
410
|
}
|
|
411
|
-
|
|
411
|
+
o.cb();
|
|
412
412
|
};
|
|
413
413
|
return t.onerror = s.bind(null, t.onerror), t.onload = s.bind(null, t.onload), {
|
|
414
414
|
link: t,
|
|
415
|
-
needAttach:
|
|
415
|
+
needAttach: r
|
|
416
416
|
};
|
|
417
417
|
}
|
|
418
|
-
function loadScript(
|
|
419
|
-
const { attrs:
|
|
418
|
+
function loadScript(o, t) {
|
|
419
|
+
const { attrs: r = {}, createScriptHook: n } = t;
|
|
420
420
|
return new Promise((s, l) => {
|
|
421
421
|
const { script: a, needAttach: i } = createScript({
|
|
422
|
-
url:
|
|
422
|
+
url: o,
|
|
423
423
|
cb: s,
|
|
424
424
|
attrs: _extends$2({
|
|
425
425
|
fetchpriority: "high"
|
|
426
|
-
},
|
|
426
|
+
}, r),
|
|
427
427
|
createScriptHook: n,
|
|
428
428
|
needDeleteScript: !0
|
|
429
429
|
});
|
|
430
430
|
i && document.head.appendChild(a);
|
|
431
431
|
});
|
|
432
432
|
}
|
|
433
|
-
function importNodeModule(
|
|
434
|
-
if (!
|
|
433
|
+
function importNodeModule(o) {
|
|
434
|
+
if (!o)
|
|
435
435
|
throw new Error("import specifier is required");
|
|
436
|
-
return new Function("name", "return import(name)")(
|
|
437
|
-
throw console.error(`Error importing module ${
|
|
436
|
+
return new Function("name", "return import(name)")(o).then((r) => r).catch((r) => {
|
|
437
|
+
throw console.error(`Error importing module ${o}:`, r), r;
|
|
438
438
|
});
|
|
439
439
|
}
|
|
440
440
|
const loadNodeFetch = async () => {
|
|
441
|
-
const
|
|
442
|
-
return
|
|
443
|
-
}, lazyLoaderHookFetch = async (
|
|
444
|
-
const s = await ((l, a) =>
|
|
445
|
-
return !s || !(s instanceof Response) ? (typeof fetch > "u" ? await loadNodeFetch() : fetch)(
|
|
441
|
+
const o = await importNodeModule("node-fetch");
|
|
442
|
+
return o.default || o;
|
|
443
|
+
}, lazyLoaderHookFetch = async (o, t, r) => {
|
|
444
|
+
const s = await ((l, a) => r.lifecycle.fetch.emit(l, a))(o, t || {});
|
|
445
|
+
return !s || !(s instanceof Response) ? (typeof fetch > "u" ? await loadNodeFetch() : fetch)(o, t || {}) : s;
|
|
446
446
|
};
|
|
447
447
|
function createScriptNode(url, cb, attrs, loaderHook) {
|
|
448
448
|
if (loaderHook != null && loaderHook.createScriptHook) {
|
|
449
|
-
const
|
|
450
|
-
|
|
449
|
+
const o = loaderHook.createScriptHook(url);
|
|
450
|
+
o && typeof o == "object" && "url" in o && (url = o.url);
|
|
451
451
|
}
|
|
452
452
|
let urlObj;
|
|
453
453
|
try {
|
|
454
454
|
urlObj = new URL(url);
|
|
455
|
-
} catch (
|
|
456
|
-
console.error("Error constructing URL:",
|
|
455
|
+
} catch (o) {
|
|
456
|
+
console.error("Error constructing URL:", o), cb(new Error(`Invalid URL: ${o}`));
|
|
457
457
|
return;
|
|
458
458
|
}
|
|
459
|
-
const getFetch = async () => loaderHook != null && loaderHook.fetch ? (
|
|
459
|
+
const getFetch = async () => loaderHook != null && loaderHook.fetch ? (o, t) => lazyLoaderHookFetch(o, t, loaderHook) : typeof fetch > "u" ? loadNodeFetch() : fetch, handleScriptFetch = async (f, urlObj) => {
|
|
460
460
|
try {
|
|
461
461
|
var _vm_constants;
|
|
462
462
|
const res = await f(urlObj.href), data = await res.text(), [path, vm] = await Promise.all([
|
|
@@ -477,131 +477,131 @@ function createScriptNode(url, cb, attrs, loaderHook) {
|
|
|
477
477
|
script.runInThisContext()(scriptContext.exports, scriptContext.module, eval("require"), urlDirname, filename);
|
|
478
478
|
const exportedInterface = scriptContext.module.exports || scriptContext.exports;
|
|
479
479
|
if (attrs && exportedInterface && attrs.globalName) {
|
|
480
|
-
const
|
|
481
|
-
cb(void 0,
|
|
480
|
+
const o = exportedInterface[attrs.globalName] || exportedInterface;
|
|
481
|
+
cb(void 0, o);
|
|
482
482
|
return;
|
|
483
483
|
}
|
|
484
484
|
cb(void 0, exportedInterface);
|
|
485
|
-
} catch (
|
|
486
|
-
cb(
|
|
485
|
+
} catch (o) {
|
|
486
|
+
cb(o instanceof Error ? o : new Error(`Script execution error: ${o}`));
|
|
487
487
|
}
|
|
488
488
|
};
|
|
489
|
-
getFetch().then(async (
|
|
489
|
+
getFetch().then(async (o) => {
|
|
490
490
|
if ((attrs == null ? void 0 : attrs.type) === "esm" || (attrs == null ? void 0 : attrs.type) === "module")
|
|
491
491
|
return loadModule(urlObj.href, {
|
|
492
|
-
fetch:
|
|
492
|
+
fetch: o,
|
|
493
493
|
vm: await importNodeModule("vm")
|
|
494
494
|
}).then(async (t) => {
|
|
495
495
|
await t.evaluate(), cb(void 0, t.namespace);
|
|
496
496
|
}).catch((t) => {
|
|
497
497
|
cb(t instanceof Error ? t : new Error(`Script execution error: ${t}`));
|
|
498
498
|
});
|
|
499
|
-
handleScriptFetch(
|
|
500
|
-
}).catch((
|
|
501
|
-
cb(
|
|
499
|
+
handleScriptFetch(o, urlObj);
|
|
500
|
+
}).catch((o) => {
|
|
501
|
+
cb(o);
|
|
502
502
|
});
|
|
503
503
|
}
|
|
504
|
-
function loadScriptNode(
|
|
505
|
-
return new Promise((
|
|
506
|
-
createScriptNode(
|
|
504
|
+
function loadScriptNode(o, t) {
|
|
505
|
+
return new Promise((r, n) => {
|
|
506
|
+
createScriptNode(o, (s, l) => {
|
|
507
507
|
if (s)
|
|
508
508
|
n(s);
|
|
509
509
|
else {
|
|
510
510
|
var a, i;
|
|
511
511
|
const c = (t == null || (a = t.attrs) == null ? void 0 : a.globalName) || `__FEDERATION_${t == null || (i = t.attrs) == null ? void 0 : i.name}:custom__`, u = globalThis[c] = l;
|
|
512
|
-
|
|
512
|
+
r(u);
|
|
513
513
|
}
|
|
514
514
|
}, t.attrs, t.loaderHook);
|
|
515
515
|
});
|
|
516
516
|
}
|
|
517
|
-
async function loadModule(
|
|
518
|
-
const { fetch:
|
|
517
|
+
async function loadModule(o, t) {
|
|
518
|
+
const { fetch: r, vm: n } = t, l = await (await r(o)).text(), a = new n.SourceTextModule(l, {
|
|
519
519
|
// @ts-ignore
|
|
520
520
|
importModuleDynamically: async (i, c) => {
|
|
521
|
-
const u = new URL(i,
|
|
521
|
+
const u = new URL(i, o).href;
|
|
522
522
|
return loadModule(u, t);
|
|
523
523
|
}
|
|
524
524
|
});
|
|
525
525
|
return await a.link(async (i) => {
|
|
526
|
-
const c = new URL(i,
|
|
526
|
+
const c = new URL(i, o).href;
|
|
527
527
|
return await loadModule(c, t);
|
|
528
528
|
}), a;
|
|
529
529
|
}
|
|
530
530
|
const LoggerInstance = createLogger("[ Module Federation Bridge Vue3 ]");
|
|
531
531
|
function _extends$1() {
|
|
532
532
|
return _extends$1 = Object.assign || function(t) {
|
|
533
|
-
for (var
|
|
534
|
-
var n = arguments[
|
|
533
|
+
for (var r = 1; r < arguments.length; r++) {
|
|
534
|
+
var n = arguments[r];
|
|
535
535
|
for (var s in n)
|
|
536
536
|
Object.prototype.hasOwnProperty.call(n, s) && (t[s] = n[s]);
|
|
537
537
|
}
|
|
538
538
|
return t;
|
|
539
539
|
}, _extends$1.apply(this, arguments);
|
|
540
540
|
}
|
|
541
|
-
function _object_without_properties_loose(
|
|
542
|
-
if (
|
|
541
|
+
function _object_without_properties_loose(o, t) {
|
|
542
|
+
if (o == null)
|
|
543
543
|
return {};
|
|
544
|
-
var
|
|
544
|
+
var r = {}, n = Object.keys(o), s, l;
|
|
545
545
|
for (l = 0; l < n.length; l++)
|
|
546
|
-
s = n[l], !(t.indexOf(s) >= 0) && (
|
|
547
|
-
return
|
|
546
|
+
s = n[l], !(t.indexOf(s) >= 0) && (r[s] = o[s]);
|
|
547
|
+
return r;
|
|
548
548
|
}
|
|
549
549
|
function getBuilderId() {
|
|
550
550
|
return typeof FEDERATION_BUILD_IDENTIFIER < "u" ? FEDERATION_BUILD_IDENTIFIER : "";
|
|
551
551
|
}
|
|
552
552
|
const LOG_CATEGORY = "[ Federation Runtime ]", logger = createLogger(LOG_CATEGORY);
|
|
553
|
-
function assert(
|
|
554
|
-
|
|
553
|
+
function assert(o, t) {
|
|
554
|
+
o || error(t);
|
|
555
555
|
}
|
|
556
|
-
function error(
|
|
557
|
-
throw
|
|
556
|
+
function error(o) {
|
|
557
|
+
throw o instanceof Error ? (o.message = `${LOG_CATEGORY}: ${o.message}`, o) : new Error(`${LOG_CATEGORY}: ${o}`);
|
|
558
558
|
}
|
|
559
|
-
function warn(
|
|
560
|
-
|
|
559
|
+
function warn(o) {
|
|
560
|
+
o instanceof Error && (o.message = `${LOG_CATEGORY}: ${o.message}`), logger.warn(o);
|
|
561
561
|
}
|
|
562
|
-
function addUniqueItem(
|
|
563
|
-
return
|
|
562
|
+
function addUniqueItem(o, t) {
|
|
563
|
+
return o.findIndex((r) => r === t) === -1 && o.push(t), o;
|
|
564
564
|
}
|
|
565
|
-
function getFMId(
|
|
566
|
-
return "version" in
|
|
565
|
+
function getFMId(o) {
|
|
566
|
+
return "version" in o && o.version ? `${o.name}:${o.version}` : "entry" in o && o.entry ? `${o.name}:${o.entry}` : `${o.name}`;
|
|
567
567
|
}
|
|
568
|
-
function isRemoteInfoWithEntry(
|
|
569
|
-
return typeof
|
|
568
|
+
function isRemoteInfoWithEntry(o) {
|
|
569
|
+
return typeof o.entry < "u";
|
|
570
570
|
}
|
|
571
|
-
function isPureRemoteEntry(
|
|
572
|
-
return !
|
|
571
|
+
function isPureRemoteEntry(o) {
|
|
572
|
+
return !o.entry.includes(".json") && o.entry.includes(".js");
|
|
573
573
|
}
|
|
574
|
-
function isObject(
|
|
575
|
-
return
|
|
574
|
+
function isObject(o) {
|
|
575
|
+
return o && typeof o == "object";
|
|
576
576
|
}
|
|
577
577
|
const objectToString = Object.prototype.toString;
|
|
578
|
-
function isPlainObject(
|
|
579
|
-
return objectToString.call(
|
|
578
|
+
function isPlainObject(o) {
|
|
579
|
+
return objectToString.call(o) === "[object Object]";
|
|
580
580
|
}
|
|
581
|
-
function arrayOptions(
|
|
582
|
-
return Array.isArray(
|
|
583
|
-
|
|
581
|
+
function arrayOptions(o) {
|
|
582
|
+
return Array.isArray(o) ? o : [
|
|
583
|
+
o
|
|
584
584
|
];
|
|
585
585
|
}
|
|
586
|
-
function getRemoteEntryInfoFromSnapshot(
|
|
586
|
+
function getRemoteEntryInfoFromSnapshot(o) {
|
|
587
587
|
const t = {
|
|
588
588
|
url: "",
|
|
589
589
|
type: "global",
|
|
590
590
|
globalName: ""
|
|
591
591
|
};
|
|
592
|
-
return isBrowserEnv() ? "remoteEntry" in
|
|
593
|
-
url:
|
|
594
|
-
type:
|
|
595
|
-
globalName:
|
|
596
|
-
} : t : "ssrRemoteEntry" in
|
|
597
|
-
url:
|
|
598
|
-
type:
|
|
599
|
-
globalName:
|
|
592
|
+
return isBrowserEnv() ? "remoteEntry" in o ? {
|
|
593
|
+
url: o.remoteEntry,
|
|
594
|
+
type: o.remoteEntryType,
|
|
595
|
+
globalName: o.globalName
|
|
596
|
+
} : t : "ssrRemoteEntry" in o ? {
|
|
597
|
+
url: o.ssrRemoteEntry || t.url,
|
|
598
|
+
type: o.ssrRemoteEntryType || t.type,
|
|
599
|
+
globalName: o.globalName
|
|
600
600
|
} : t;
|
|
601
601
|
}
|
|
602
|
-
const processModuleAlias = (
|
|
603
|
-
let
|
|
604
|
-
return
|
|
602
|
+
const processModuleAlias = (o, t) => {
|
|
603
|
+
let r;
|
|
604
|
+
return o.endsWith("/") ? r = o.slice(0, -1) : r = o, t.startsWith(".") && (t = t.slice(1)), r = r + t, r;
|
|
605
605
|
}, CurrentGlobal = typeof globalThis == "object" ? globalThis : window, nativeGlobal = (() => {
|
|
606
606
|
try {
|
|
607
607
|
return document.defaultView;
|
|
@@ -609,57 +609,57 @@ const processModuleAlias = (r, t) => {
|
|
|
609
609
|
return CurrentGlobal;
|
|
610
610
|
}
|
|
611
611
|
})(), Global = nativeGlobal;
|
|
612
|
-
function definePropertyGlobalVal(
|
|
613
|
-
Object.defineProperty(
|
|
614
|
-
value:
|
|
612
|
+
function definePropertyGlobalVal(o, t, r) {
|
|
613
|
+
Object.defineProperty(o, t, {
|
|
614
|
+
value: r,
|
|
615
615
|
configurable: !1,
|
|
616
616
|
writable: !0
|
|
617
617
|
});
|
|
618
618
|
}
|
|
619
|
-
function includeOwnProperty(
|
|
620
|
-
return Object.hasOwnProperty.call(
|
|
619
|
+
function includeOwnProperty(o, t) {
|
|
620
|
+
return Object.hasOwnProperty.call(o, t);
|
|
621
621
|
}
|
|
622
622
|
includeOwnProperty(CurrentGlobal, "__GLOBAL_LOADING_REMOTE_ENTRY__") || definePropertyGlobalVal(CurrentGlobal, "__GLOBAL_LOADING_REMOTE_ENTRY__", {});
|
|
623
623
|
const globalLoading = CurrentGlobal.__GLOBAL_LOADING_REMOTE_ENTRY__;
|
|
624
|
-
function setGlobalDefaultVal(
|
|
625
|
-
var t,
|
|
626
|
-
includeOwnProperty(
|
|
624
|
+
function setGlobalDefaultVal(o) {
|
|
625
|
+
var t, r, n, s, l, a;
|
|
626
|
+
includeOwnProperty(o, "__VMOK__") && !includeOwnProperty(o, "__FEDERATION__") && definePropertyGlobalVal(o, "__FEDERATION__", o.__VMOK__), includeOwnProperty(o, "__FEDERATION__") || (definePropertyGlobalVal(o, "__FEDERATION__", {
|
|
627
627
|
__GLOBAL_PLUGIN__: [],
|
|
628
628
|
__INSTANCES__: [],
|
|
629
629
|
moduleInfo: {},
|
|
630
630
|
__SHARE__: {},
|
|
631
631
|
__MANIFEST_LOADING__: {},
|
|
632
632
|
__PRELOADED_MAP__: /* @__PURE__ */ new Map()
|
|
633
|
-
}), definePropertyGlobalVal(
|
|
633
|
+
}), definePropertyGlobalVal(o, "__VMOK__", o.__FEDERATION__));
|
|
634
634
|
var i;
|
|
635
|
-
(i = (t =
|
|
635
|
+
(i = (t = o.__FEDERATION__).__GLOBAL_PLUGIN__) != null || (t.__GLOBAL_PLUGIN__ = []);
|
|
636
636
|
var c;
|
|
637
|
-
(c = (
|
|
637
|
+
(c = (r = o.__FEDERATION__).__INSTANCES__) != null || (r.__INSTANCES__ = []);
|
|
638
638
|
var u;
|
|
639
|
-
(u = (n =
|
|
639
|
+
(u = (n = o.__FEDERATION__).moduleInfo) != null || (n.moduleInfo = {});
|
|
640
640
|
var d;
|
|
641
|
-
(d = (s =
|
|
641
|
+
(d = (s = o.__FEDERATION__).__SHARE__) != null || (s.__SHARE__ = {});
|
|
642
642
|
var p;
|
|
643
|
-
(p = (l =
|
|
643
|
+
(p = (l = o.__FEDERATION__).__MANIFEST_LOADING__) != null || (l.__MANIFEST_LOADING__ = {});
|
|
644
644
|
var m;
|
|
645
|
-
(m = (a =
|
|
645
|
+
(m = (a = o.__FEDERATION__).__PRELOADED_MAP__) != null || (a.__PRELOADED_MAP__ = /* @__PURE__ */ new Map());
|
|
646
646
|
}
|
|
647
647
|
setGlobalDefaultVal(CurrentGlobal);
|
|
648
648
|
setGlobalDefaultVal(nativeGlobal);
|
|
649
|
-
function setGlobalFederationConstructor(
|
|
650
|
-
t && (CurrentGlobal.__FEDERATION__.__DEBUG_CONSTRUCTOR__ =
|
|
649
|
+
function setGlobalFederationConstructor(o, t = isDebugMode()) {
|
|
650
|
+
t && (CurrentGlobal.__FEDERATION__.__DEBUG_CONSTRUCTOR__ = o, CurrentGlobal.__FEDERATION__.__DEBUG_CONSTRUCTOR_VERSION__ = "0.8.1");
|
|
651
651
|
}
|
|
652
|
-
function getInfoWithoutType(
|
|
652
|
+
function getInfoWithoutType(o, t) {
|
|
653
653
|
if (typeof t == "string") {
|
|
654
|
-
if (
|
|
654
|
+
if (o[t])
|
|
655
655
|
return {
|
|
656
|
-
value:
|
|
656
|
+
value: o[t],
|
|
657
657
|
key: t
|
|
658
658
|
};
|
|
659
659
|
{
|
|
660
|
-
const n = Object.keys(
|
|
660
|
+
const n = Object.keys(o);
|
|
661
661
|
for (const s of n) {
|
|
662
|
-
const [l, a] = s.split(":"), i = `${l}:${t}`, c =
|
|
662
|
+
const [l, a] = s.split(":"), i = `${l}:${t}`, c = o[i];
|
|
663
663
|
if (c)
|
|
664
664
|
return {
|
|
665
665
|
value: c,
|
|
@@ -674,121 +674,121 @@ function getInfoWithoutType(r, t) {
|
|
|
674
674
|
} else
|
|
675
675
|
throw new Error("key must be string");
|
|
676
676
|
}
|
|
677
|
-
const getGlobalSnapshot = () => nativeGlobal.__FEDERATION__.moduleInfo, getTargetSnapshotInfoByModuleInfo = (
|
|
678
|
-
const
|
|
679
|
-
if (n && !n.version && "version" in
|
|
677
|
+
const getGlobalSnapshot = () => nativeGlobal.__FEDERATION__.moduleInfo, getTargetSnapshotInfoByModuleInfo = (o, t) => {
|
|
678
|
+
const r = getFMId(o), n = getInfoWithoutType(t, r).value;
|
|
679
|
+
if (n && !n.version && "version" in o && o.version && (n.version = o.version), n)
|
|
680
680
|
return n;
|
|
681
|
-
if ("version" in
|
|
682
|
-
const { version: s } =
|
|
681
|
+
if ("version" in o && o.version) {
|
|
682
|
+
const { version: s } = o, l = _object_without_properties_loose(o, [
|
|
683
683
|
"version"
|
|
684
684
|
]), a = getFMId(l), i = getInfoWithoutType(nativeGlobal.__FEDERATION__.moduleInfo, a).value;
|
|
685
685
|
if ((i == null ? void 0 : i.version) === s)
|
|
686
686
|
return i;
|
|
687
687
|
}
|
|
688
|
-
}, getGlobalSnapshotInfoByModuleInfo = (
|
|
689
|
-
const
|
|
690
|
-
return nativeGlobal.__FEDERATION__.moduleInfo[
|
|
691
|
-
}, addGlobalSnapshot = (
|
|
692
|
-
const t = Object.keys(
|
|
693
|
-
for (const
|
|
694
|
-
delete nativeGlobal.__FEDERATION__.moduleInfo[
|
|
695
|
-
}), getRemoteEntryExports = (
|
|
696
|
-
const
|
|
688
|
+
}, getGlobalSnapshotInfoByModuleInfo = (o) => getTargetSnapshotInfoByModuleInfo(o, nativeGlobal.__FEDERATION__.moduleInfo), setGlobalSnapshotInfoByModuleInfo = (o, t) => {
|
|
689
|
+
const r = getFMId(o);
|
|
690
|
+
return nativeGlobal.__FEDERATION__.moduleInfo[r] = t, nativeGlobal.__FEDERATION__.moduleInfo;
|
|
691
|
+
}, addGlobalSnapshot = (o) => (nativeGlobal.__FEDERATION__.moduleInfo = _extends$1({}, nativeGlobal.__FEDERATION__.moduleInfo, o), () => {
|
|
692
|
+
const t = Object.keys(o);
|
|
693
|
+
for (const r of t)
|
|
694
|
+
delete nativeGlobal.__FEDERATION__.moduleInfo[r];
|
|
695
|
+
}), getRemoteEntryExports = (o, t) => {
|
|
696
|
+
const r = t || `__FEDERATION_${o}:custom__`, n = CurrentGlobal[r];
|
|
697
697
|
return {
|
|
698
|
-
remoteEntryKey:
|
|
698
|
+
remoteEntryKey: r,
|
|
699
699
|
entryExports: n
|
|
700
700
|
};
|
|
701
|
-
}, getGlobalHostPlugins = () => nativeGlobal.__FEDERATION__.__GLOBAL_PLUGIN__, getPreloaded = (
|
|
702
|
-
function parseRegex(
|
|
703
|
-
return new RegExp(
|
|
701
|
+
}, getGlobalHostPlugins = () => nativeGlobal.__FEDERATION__.__GLOBAL_PLUGIN__, getPreloaded = (o) => CurrentGlobal.__FEDERATION__.__PRELOADED_MAP__.get(o), setPreloaded = (o) => CurrentGlobal.__FEDERATION__.__PRELOADED_MAP__.set(o, !0), DEFAULT_SCOPE = "default", DEFAULT_REMOTE_TYPE = "global", buildIdentifier = "[0-9A-Za-z-]+", build = `(?:\\+(${buildIdentifier}(?:\\.${buildIdentifier})*))`, numericIdentifier = "0|[1-9]\\d*", numericIdentifierLoose = "[0-9]+", nonNumericIdentifier = "\\d*[a-zA-Z-][a-zA-Z0-9-]*", preReleaseIdentifierLoose = `(?:${numericIdentifierLoose}|${nonNumericIdentifier})`, preReleaseLoose = `(?:-?(${preReleaseIdentifierLoose}(?:\\.${preReleaseIdentifierLoose})*))`, preReleaseIdentifier = `(?:${numericIdentifier}|${nonNumericIdentifier})`, preRelease = `(?:-(${preReleaseIdentifier}(?:\\.${preReleaseIdentifier})*))`, xRangeIdentifier = `${numericIdentifier}|x|X|\\*`, xRangePlain = `[v=\\s]*(${xRangeIdentifier})(?:\\.(${xRangeIdentifier})(?:\\.(${xRangeIdentifier})(?:${preRelease})?${build}?)?)?`, hyphenRange = `^\\s*(${xRangePlain})\\s+-\\s+(${xRangePlain})\\s*$`, mainVersionLoose = `(${numericIdentifierLoose})\\.(${numericIdentifierLoose})\\.(${numericIdentifierLoose})`, loosePlain = `[v=\\s]*${mainVersionLoose}${preReleaseLoose}?${build}?`, gtlt = "((?:<|>)?=?)", comparatorTrim = `(\\s*)${gtlt}\\s*(${loosePlain}|${xRangePlain})`, loneTilde = "(?:~>?)", tildeTrim = `(\\s*)${loneTilde}\\s+`, loneCaret = "(?:\\^)", caretTrim = `(\\s*)${loneCaret}\\s+`, star = "(<|>)?=?\\s*\\*", caret = `^${loneCaret}${xRangePlain}$`, mainVersion = `(${numericIdentifier})\\.(${numericIdentifier})\\.(${numericIdentifier})`, fullPlain = `v?${mainVersion}${preRelease}?${build}?`, tilde = `^${loneTilde}${xRangePlain}$`, xRange = `^${gtlt}\\s*${xRangePlain}$`, comparator = `^${gtlt}\\s*(${fullPlain})$|^$`, gte0 = "^\\s*>=\\s*0.0.0\\s*$";
|
|
702
|
+
function parseRegex(o) {
|
|
703
|
+
return new RegExp(o);
|
|
704
704
|
}
|
|
705
|
-
function isXVersion(
|
|
706
|
-
return !
|
|
705
|
+
function isXVersion(o) {
|
|
706
|
+
return !o || o.toLowerCase() === "x" || o === "*";
|
|
707
707
|
}
|
|
708
|
-
function pipe(...
|
|
709
|
-
return (t) =>
|
|
708
|
+
function pipe(...o) {
|
|
709
|
+
return (t) => o.reduce((r, n) => n(r), t);
|
|
710
710
|
}
|
|
711
|
-
function extractComparator(
|
|
712
|
-
return
|
|
711
|
+
function extractComparator(o) {
|
|
712
|
+
return o.match(parseRegex(comparator));
|
|
713
713
|
}
|
|
714
|
-
function combineVersion(
|
|
715
|
-
const s = `${
|
|
714
|
+
function combineVersion(o, t, r, n) {
|
|
715
|
+
const s = `${o}.${t}.${r}`;
|
|
716
716
|
return n ? `${s}-${n}` : s;
|
|
717
717
|
}
|
|
718
|
-
function parseHyphen(
|
|
719
|
-
return
|
|
718
|
+
function parseHyphen(o) {
|
|
719
|
+
return o.replace(parseRegex(hyphenRange), (t, r, n, s, l, a, i, c, u, d, p, m) => (isXVersion(n) ? r = "" : isXVersion(s) ? r = `>=${n}.0.0` : isXVersion(l) ? r = `>=${n}.${s}.0` : r = `>=${r}`, isXVersion(u) ? c = "" : isXVersion(d) ? c = `<${Number(u) + 1}.0.0-0` : isXVersion(p) ? c = `<${u}.${Number(d) + 1}.0-0` : m ? c = `<=${u}.${d}.${p}-${m}` : c = `<=${c}`, `${r} ${c}`.trim()));
|
|
720
720
|
}
|
|
721
|
-
function parseComparatorTrim(
|
|
722
|
-
return
|
|
721
|
+
function parseComparatorTrim(o) {
|
|
722
|
+
return o.replace(parseRegex(comparatorTrim), "$1$2$3");
|
|
723
723
|
}
|
|
724
|
-
function parseTildeTrim(
|
|
725
|
-
return
|
|
724
|
+
function parseTildeTrim(o) {
|
|
725
|
+
return o.replace(parseRegex(tildeTrim), "$1~");
|
|
726
726
|
}
|
|
727
|
-
function parseCaretTrim(
|
|
728
|
-
return
|
|
727
|
+
function parseCaretTrim(o) {
|
|
728
|
+
return o.replace(parseRegex(caretTrim), "$1^");
|
|
729
729
|
}
|
|
730
|
-
function parseCarets(
|
|
731
|
-
return
|
|
730
|
+
function parseCarets(o) {
|
|
731
|
+
return o.trim().split(/\s+/).map((t) => t.replace(parseRegex(caret), (r, n, s, l, a) => isXVersion(n) ? "" : isXVersion(s) ? `>=${n}.0.0 <${Number(n) + 1}.0.0-0` : isXVersion(l) ? n === "0" ? `>=${n}.${s}.0 <${n}.${Number(s) + 1}.0-0` : `>=${n}.${s}.0 <${Number(n) + 1}.0.0-0` : a ? n === "0" ? s === "0" ? `>=${n}.${s}.${l}-${a} <${n}.${s}.${Number(l) + 1}-0` : `>=${n}.${s}.${l}-${a} <${n}.${Number(s) + 1}.0-0` : `>=${n}.${s}.${l}-${a} <${Number(n) + 1}.0.0-0` : n === "0" ? s === "0" ? `>=${n}.${s}.${l} <${n}.${s}.${Number(l) + 1}-0` : `>=${n}.${s}.${l} <${n}.${Number(s) + 1}.0-0` : `>=${n}.${s}.${l} <${Number(n) + 1}.0.0-0`)).join(" ");
|
|
732
732
|
}
|
|
733
|
-
function parseTildes(
|
|
734
|
-
return
|
|
733
|
+
function parseTildes(o) {
|
|
734
|
+
return o.trim().split(/\s+/).map((t) => t.replace(parseRegex(tilde), (r, n, s, l, a) => isXVersion(n) ? "" : isXVersion(s) ? `>=${n}.0.0 <${Number(n) + 1}.0.0-0` : isXVersion(l) ? `>=${n}.${s}.0 <${n}.${Number(s) + 1}.0-0` : a ? `>=${n}.${s}.${l}-${a} <${n}.${Number(s) + 1}.0-0` : `>=${n}.${s}.${l} <${n}.${Number(s) + 1}.0-0`)).join(" ");
|
|
735
735
|
}
|
|
736
|
-
function parseXRanges(
|
|
737
|
-
return
|
|
736
|
+
function parseXRanges(o) {
|
|
737
|
+
return o.split(/\s+/).map((t) => t.trim().replace(parseRegex(xRange), (r, n, s, l, a, i) => {
|
|
738
738
|
const c = isXVersion(s), u = c || isXVersion(l), d = u || isXVersion(a);
|
|
739
|
-
return n === "=" && d && (n = ""), i = "", c ? n === ">" || n === "<" ? "<0.0.0-0" : "*" : n && d ? (u && (l = 0), a = 0, n === ">" ? (n = ">=", u ? (s = Number(s) + 1, l = 0, a = 0) : (l = Number(l) + 1, a = 0)) : n === "<=" && (n = "<", u ? s = Number(s) + 1 : l = Number(l) + 1), n === "<" && (i = "-0"), `${n + s}.${l}.${a}${i}`) : u ? `>=${s}.0.0${i} <${Number(s) + 1}.0.0-0` : d ? `>=${s}.${l}.0${i} <${s}.${Number(l) + 1}.0-0` :
|
|
739
|
+
return n === "=" && d && (n = ""), i = "", c ? n === ">" || n === "<" ? "<0.0.0-0" : "*" : n && d ? (u && (l = 0), a = 0, n === ">" ? (n = ">=", u ? (s = Number(s) + 1, l = 0, a = 0) : (l = Number(l) + 1, a = 0)) : n === "<=" && (n = "<", u ? s = Number(s) + 1 : l = Number(l) + 1), n === "<" && (i = "-0"), `${n + s}.${l}.${a}${i}`) : u ? `>=${s}.0.0${i} <${Number(s) + 1}.0.0-0` : d ? `>=${s}.${l}.0${i} <${s}.${Number(l) + 1}.0-0` : r;
|
|
740
740
|
})).join(" ");
|
|
741
741
|
}
|
|
742
|
-
function parseStar(
|
|
743
|
-
return
|
|
742
|
+
function parseStar(o) {
|
|
743
|
+
return o.trim().replace(parseRegex(star), "");
|
|
744
744
|
}
|
|
745
|
-
function parseGTE0(
|
|
746
|
-
return
|
|
745
|
+
function parseGTE0(o) {
|
|
746
|
+
return o.trim().replace(parseRegex(gte0), "");
|
|
747
747
|
}
|
|
748
|
-
function compareAtom(
|
|
749
|
-
return
|
|
748
|
+
function compareAtom(o, t) {
|
|
749
|
+
return o = Number(o) || o, t = Number(t) || t, o > t ? 1 : o === t ? 0 : -1;
|
|
750
750
|
}
|
|
751
|
-
function comparePreRelease(
|
|
752
|
-
const { preRelease:
|
|
753
|
-
if (
|
|
751
|
+
function comparePreRelease(o, t) {
|
|
752
|
+
const { preRelease: r } = o, { preRelease: n } = t;
|
|
753
|
+
if (r === void 0 && n)
|
|
754
754
|
return 1;
|
|
755
|
-
if (
|
|
755
|
+
if (r && n === void 0)
|
|
756
756
|
return -1;
|
|
757
|
-
if (
|
|
757
|
+
if (r === void 0 && n === void 0)
|
|
758
758
|
return 0;
|
|
759
|
-
for (let s = 0, l =
|
|
760
|
-
const a =
|
|
759
|
+
for (let s = 0, l = r.length; s <= l; s++) {
|
|
760
|
+
const a = r[s], i = n[s];
|
|
761
761
|
if (a !== i)
|
|
762
762
|
return a === void 0 && i === void 0 ? 0 : a ? i ? compareAtom(a, i) : -1 : 1;
|
|
763
763
|
}
|
|
764
764
|
return 0;
|
|
765
765
|
}
|
|
766
|
-
function compareVersion(
|
|
767
|
-
return compareAtom(
|
|
766
|
+
function compareVersion(o, t) {
|
|
767
|
+
return compareAtom(o.major, t.major) || compareAtom(o.minor, t.minor) || compareAtom(o.patch, t.patch) || comparePreRelease(o, t);
|
|
768
768
|
}
|
|
769
|
-
function eq(
|
|
770
|
-
return
|
|
769
|
+
function eq(o, t) {
|
|
770
|
+
return o.version === t.version;
|
|
771
771
|
}
|
|
772
|
-
function compare(
|
|
773
|
-
switch (
|
|
772
|
+
function compare(o, t) {
|
|
773
|
+
switch (o.operator) {
|
|
774
774
|
case "":
|
|
775
775
|
case "=":
|
|
776
|
-
return eq(
|
|
776
|
+
return eq(o, t);
|
|
777
777
|
case ">":
|
|
778
|
-
return compareVersion(
|
|
778
|
+
return compareVersion(o, t) < 0;
|
|
779
779
|
case ">=":
|
|
780
|
-
return eq(
|
|
780
|
+
return eq(o, t) || compareVersion(o, t) < 0;
|
|
781
781
|
case "<":
|
|
782
|
-
return compareVersion(
|
|
782
|
+
return compareVersion(o, t) > 0;
|
|
783
783
|
case "<=":
|
|
784
|
-
return eq(
|
|
784
|
+
return eq(o, t) || compareVersion(o, t) > 0;
|
|
785
785
|
case void 0:
|
|
786
786
|
return !0;
|
|
787
787
|
default:
|
|
788
788
|
return !1;
|
|
789
789
|
}
|
|
790
790
|
}
|
|
791
|
-
function parseComparatorString(
|
|
791
|
+
function parseComparatorString(o) {
|
|
792
792
|
return pipe(
|
|
793
793
|
// handle caret
|
|
794
794
|
// ^ --> * (any, kinda silly)
|
|
@@ -808,9 +808,9 @@ function parseComparatorString(r) {
|
|
|
808
808
|
parseTildes,
|
|
809
809
|
parseXRanges,
|
|
810
810
|
parseStar
|
|
811
|
-
)(
|
|
811
|
+
)(o);
|
|
812
812
|
}
|
|
813
|
-
function parseRange(
|
|
813
|
+
function parseRange(o) {
|
|
814
814
|
return pipe(
|
|
815
815
|
// handle hyphenRange
|
|
816
816
|
// `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`
|
|
@@ -824,12 +824,12 @@ function parseRange(r) {
|
|
|
824
824
|
// handle trim caret
|
|
825
825
|
// `^ 1.2.3` => `^1.2.3`
|
|
826
826
|
parseCaretTrim
|
|
827
|
-
)(
|
|
827
|
+
)(o.trim()).split(/\s+/).join(" ");
|
|
828
828
|
}
|
|
829
|
-
function satisfy(
|
|
830
|
-
if (!
|
|
829
|
+
function satisfy(o, t) {
|
|
830
|
+
if (!o)
|
|
831
831
|
return !1;
|
|
832
|
-
const s = parseRange(t).split(" ").map((m) => parseComparatorString(m)).join(" ").split(/\s+/).map((m) => parseGTE0(m)), l = extractComparator(
|
|
832
|
+
const s = parseRange(t).split(" ").map((m) => parseComparatorString(m)).join(" ").split(/\s+/).map((m) => parseGTE0(m)), l = extractComparator(o);
|
|
833
833
|
if (!l)
|
|
834
834
|
return !1;
|
|
835
835
|
const [, a, , i, c, u, d] = l, p = {
|
|
@@ -857,40 +857,40 @@ function satisfy(r, t) {
|
|
|
857
857
|
}
|
|
858
858
|
return !0;
|
|
859
859
|
}
|
|
860
|
-
function formatShare(
|
|
860
|
+
function formatShare(o, t, r, n) {
|
|
861
861
|
let s;
|
|
862
|
-
"get" in
|
|
863
|
-
throw new Error(`Can not get shared '${
|
|
864
|
-
}),
|
|
862
|
+
"get" in o ? s = o.get : "lib" in o ? s = () => Promise.resolve(o.lib) : s = () => Promise.resolve(() => {
|
|
863
|
+
throw new Error(`Can not get shared '${r}'!`);
|
|
864
|
+
}), o.strategy && warn('"shared.strategy is deprecated, please set in initOptions.shareStrategy instead!"');
|
|
865
865
|
var l, a, i;
|
|
866
866
|
return _extends$1({
|
|
867
867
|
deps: [],
|
|
868
868
|
useIn: [],
|
|
869
869
|
from: t,
|
|
870
870
|
loading: null
|
|
871
|
-
},
|
|
871
|
+
}, o, {
|
|
872
872
|
shareConfig: _extends$1({
|
|
873
|
-
requiredVersion: `^${
|
|
873
|
+
requiredVersion: `^${o.version}`,
|
|
874
874
|
singleton: !1,
|
|
875
875
|
eager: !1,
|
|
876
876
|
strictVersion: !1
|
|
877
|
-
},
|
|
877
|
+
}, o.shareConfig),
|
|
878
878
|
get: s,
|
|
879
|
-
loaded:
|
|
880
|
-
version: (l =
|
|
881
|
-
scope: Array.isArray(
|
|
882
|
-
(a =
|
|
879
|
+
loaded: o != null && o.loaded || "lib" in o ? !0 : void 0,
|
|
880
|
+
version: (l = o.version) != null ? l : "0",
|
|
881
|
+
scope: Array.isArray(o.scope) ? o.scope : [
|
|
882
|
+
(a = o.scope) != null ? a : "default"
|
|
883
883
|
],
|
|
884
|
-
strategy: ((i =
|
|
884
|
+
strategy: ((i = o.strategy) != null ? i : n) || "version-first"
|
|
885
885
|
});
|
|
886
886
|
}
|
|
887
|
-
function formatShareConfigs(
|
|
888
|
-
const
|
|
889
|
-
const c = arrayOptions(
|
|
887
|
+
function formatShareConfigs(o, t) {
|
|
888
|
+
const r = t.shared || {}, n = t.name, s = Object.keys(r).reduce((a, i) => {
|
|
889
|
+
const c = arrayOptions(r[i]);
|
|
890
890
|
return a[i] = a[i] || [], c.forEach((u) => {
|
|
891
891
|
a[i].push(formatShare(u, n, i, t.shareStrategy));
|
|
892
892
|
}), a;
|
|
893
|
-
}, {}), l = _extends$1({},
|
|
893
|
+
}, {}), l = _extends$1({}, o.shared);
|
|
894
894
|
return Object.keys(s).forEach((a) => {
|
|
895
895
|
l[a] ? s[a].forEach((i) => {
|
|
896
896
|
l[a].find((u) => u.version === i.version) || l[a].push(i);
|
|
@@ -900,8 +900,8 @@ function formatShareConfigs(r, t) {
|
|
|
900
900
|
shareInfos: s
|
|
901
901
|
};
|
|
902
902
|
}
|
|
903
|
-
function versionLt(
|
|
904
|
-
const
|
|
903
|
+
function versionLt(o, t) {
|
|
904
|
+
const r = (n) => {
|
|
905
905
|
if (!Number.isNaN(Number(n))) {
|
|
906
906
|
const l = n.split(".");
|
|
907
907
|
let a = n;
|
|
@@ -911,54 +911,54 @@ function versionLt(r, t) {
|
|
|
911
911
|
}
|
|
912
912
|
return n;
|
|
913
913
|
};
|
|
914
|
-
return !!satisfy(o
|
|
914
|
+
return !!satisfy(r(o), `<=${r(t)}`);
|
|
915
915
|
}
|
|
916
|
-
const findVersion = (
|
|
917
|
-
const
|
|
916
|
+
const findVersion = (o, t) => {
|
|
917
|
+
const r = t || function(n, s) {
|
|
918
918
|
return versionLt(n, s);
|
|
919
919
|
};
|
|
920
|
-
return Object.keys(
|
|
921
|
-
}, isLoaded = (
|
|
922
|
-
function findSingletonVersionOrderByVersion(
|
|
923
|
-
const n =
|
|
920
|
+
return Object.keys(o).reduce((n, s) => !n || r(n, s) || n === "0" ? s : n, 0);
|
|
921
|
+
}, isLoaded = (o) => !!o.loaded || typeof o.lib == "function", isLoading = (o) => !!o.loading;
|
|
922
|
+
function findSingletonVersionOrderByVersion(o, t, r) {
|
|
923
|
+
const n = o[t][r], s = function(l, a) {
|
|
924
924
|
return !isLoaded(n[l]) && versionLt(l, a);
|
|
925
925
|
};
|
|
926
|
-
return findVersion(
|
|
926
|
+
return findVersion(o[t][r], s);
|
|
927
927
|
}
|
|
928
|
-
function findSingletonVersionOrderByLoaded(
|
|
929
|
-
const n =
|
|
928
|
+
function findSingletonVersionOrderByLoaded(o, t, r) {
|
|
929
|
+
const n = o[t][r], s = function(l, a) {
|
|
930
930
|
const i = (c) => isLoaded(c) || isLoading(c);
|
|
931
931
|
return i(n[a]) ? i(n[l]) ? !!versionLt(l, a) : !0 : i(n[l]) ? !1 : versionLt(l, a);
|
|
932
932
|
};
|
|
933
|
-
return findVersion(
|
|
933
|
+
return findVersion(o[t][r], s);
|
|
934
934
|
}
|
|
935
|
-
function getFindShareFunction(
|
|
936
|
-
return
|
|
935
|
+
function getFindShareFunction(o) {
|
|
936
|
+
return o === "loaded-first" ? findSingletonVersionOrderByLoaded : findSingletonVersionOrderByVersion;
|
|
937
937
|
}
|
|
938
|
-
function getRegisteredShare(
|
|
939
|
-
if (!
|
|
938
|
+
function getRegisteredShare(o, t, r, n) {
|
|
939
|
+
if (!o)
|
|
940
940
|
return;
|
|
941
|
-
const { shareConfig: s, scope: l = DEFAULT_SCOPE, strategy: a } =
|
|
941
|
+
const { shareConfig: s, scope: l = DEFAULT_SCOPE, strategy: a } = r, i = Array.isArray(l) ? l : [
|
|
942
942
|
l
|
|
943
943
|
];
|
|
944
944
|
for (const c of i)
|
|
945
|
-
if (s &&
|
|
946
|
-
const { requiredVersion: u } = s, p = getFindShareFunction(a)(
|
|
945
|
+
if (s && o[c] && o[c][t]) {
|
|
946
|
+
const { requiredVersion: u } = s, p = getFindShareFunction(a)(o, c, t), m = () => {
|
|
947
947
|
if (s.singleton) {
|
|
948
948
|
if (typeof u == "string" && !satisfy(p, u)) {
|
|
949
|
-
const R = `Version ${p} from ${p &&
|
|
949
|
+
const R = `Version ${p} from ${p && o[c][t][p].from} of shared singleton module ${t} does not satisfy the requirement of ${r.from} which needs ${u})`;
|
|
950
950
|
s.strictVersion ? error(R) : warn(R);
|
|
951
951
|
}
|
|
952
|
-
return
|
|
952
|
+
return o[c][t][p];
|
|
953
953
|
} else {
|
|
954
954
|
if (u === !1 || u === "*" || satisfy(p, u))
|
|
955
|
-
return
|
|
956
|
-
for (const [R, g] of Object.entries(
|
|
955
|
+
return o[c][t][p];
|
|
956
|
+
for (const [R, g] of Object.entries(o[c][t]))
|
|
957
957
|
if (satisfy(R, u))
|
|
958
958
|
return g;
|
|
959
959
|
}
|
|
960
960
|
}, y = {
|
|
961
|
-
shareScopeMap:
|
|
961
|
+
shareScopeMap: o,
|
|
962
962
|
scope: c,
|
|
963
963
|
pkgName: t,
|
|
964
964
|
version: p,
|
|
@@ -971,8 +971,8 @@ function getRegisteredShare(r, t, o, n) {
|
|
|
971
971
|
function getGlobalShareScope() {
|
|
972
972
|
return Global.__FEDERATION__.__SHARE__;
|
|
973
973
|
}
|
|
974
|
-
function getTargetSharedOptions(
|
|
975
|
-
const { pkgName: t, extraOptions:
|
|
974
|
+
function getTargetSharedOptions(o) {
|
|
975
|
+
const { pkgName: t, extraOptions: r, shareInfos: n } = o, s = (i) => {
|
|
976
976
|
if (!i)
|
|
977
977
|
return;
|
|
978
978
|
const c = {};
|
|
@@ -985,23 +985,23 @@ function getTargetSharedOptions(r) {
|
|
|
985
985
|
return c[d];
|
|
986
986
|
};
|
|
987
987
|
var l;
|
|
988
|
-
const a = (l =
|
|
989
|
-
return Object.assign({}, a(n[t]),
|
|
988
|
+
const a = (l = r == null ? void 0 : r.resolver) != null ? l : s;
|
|
989
|
+
return Object.assign({}, a(n[t]), r == null ? void 0 : r.customShareInfo);
|
|
990
990
|
}
|
|
991
|
-
const RUNTIME_001 = "RUNTIME-001", RUNTIME_002 = "RUNTIME-002", RUNTIME_003 = "RUNTIME-003", RUNTIME_004 = "RUNTIME-004", RUNTIME_005 = "RUNTIME-005", RUNTIME_006 = "RUNTIME-006", RUNTIME_007 = "RUNTIME-007", TYPE_001 = "TYPE-001", getDocsUrl = (
|
|
991
|
+
const RUNTIME_001 = "RUNTIME-001", RUNTIME_002 = "RUNTIME-002", RUNTIME_003 = "RUNTIME-003", RUNTIME_004 = "RUNTIME-004", RUNTIME_005 = "RUNTIME-005", RUNTIME_006 = "RUNTIME-006", RUNTIME_007 = "RUNTIME-007", TYPE_001 = "TYPE-001", getDocsUrl = (o) => `https://module-federation.io/guide/troubleshooting/${o.split("-")[0].toLowerCase()}/${o}`, getShortErrorMsg = (o, t, r, n) => {
|
|
992
992
|
const s = [
|
|
993
993
|
`${[
|
|
994
|
-
t[
|
|
995
|
-
]} #${
|
|
994
|
+
t[o]
|
|
995
|
+
]} #${o}`
|
|
996
996
|
];
|
|
997
|
-
return
|
|
997
|
+
return r && s.push(`args: ${JSON.stringify(r)}`), s.push(getDocsUrl(o)), n && s.push(`Original Error Message:
|
|
998
998
|
${n}`), s.join(`
|
|
999
999
|
`);
|
|
1000
1000
|
};
|
|
1001
1001
|
function _extends() {
|
|
1002
1002
|
return _extends = Object.assign || function(t) {
|
|
1003
|
-
for (var
|
|
1004
|
-
var n = arguments[
|
|
1003
|
+
for (var r = 1; r < arguments.length; r++) {
|
|
1004
|
+
var n = arguments[r];
|
|
1005
1005
|
for (var s in n)
|
|
1006
1006
|
Object.prototype.hasOwnProperty.call(n, s) && (t[s] = n[s]);
|
|
1007
1007
|
}
|
|
@@ -1020,80 +1020,80 @@ const runtimeDescMap = {
|
|
|
1020
1020
|
[TYPE_001]: "Failed to generate type declaration."
|
|
1021
1021
|
};
|
|
1022
1022
|
_extends({}, runtimeDescMap, typeDescMap);
|
|
1023
|
-
function matchRemoteWithNameAndExpose(
|
|
1024
|
-
for (const
|
|
1025
|
-
const n = t.startsWith(
|
|
1026
|
-
let s = t.replace(
|
|
1023
|
+
function matchRemoteWithNameAndExpose(o, t) {
|
|
1024
|
+
for (const r of o) {
|
|
1025
|
+
const n = t.startsWith(r.name);
|
|
1026
|
+
let s = t.replace(r.name, "");
|
|
1027
1027
|
if (n) {
|
|
1028
1028
|
if (s.startsWith("/")) {
|
|
1029
|
-
const i =
|
|
1029
|
+
const i = r.name;
|
|
1030
1030
|
return s = `.${s}`, {
|
|
1031
1031
|
pkgNameOrAlias: i,
|
|
1032
1032
|
expose: s,
|
|
1033
|
-
remote:
|
|
1033
|
+
remote: r
|
|
1034
1034
|
};
|
|
1035
1035
|
} else if (s === "")
|
|
1036
1036
|
return {
|
|
1037
|
-
pkgNameOrAlias:
|
|
1037
|
+
pkgNameOrAlias: r.name,
|
|
1038
1038
|
expose: ".",
|
|
1039
|
-
remote:
|
|
1039
|
+
remote: r
|
|
1040
1040
|
};
|
|
1041
1041
|
}
|
|
1042
|
-
const l =
|
|
1043
|
-
let a =
|
|
1044
|
-
if (
|
|
1042
|
+
const l = r.alias && t.startsWith(r.alias);
|
|
1043
|
+
let a = r.alias && t.replace(r.alias, "");
|
|
1044
|
+
if (r.alias && l) {
|
|
1045
1045
|
if (a && a.startsWith("/")) {
|
|
1046
|
-
const i =
|
|
1046
|
+
const i = r.alias;
|
|
1047
1047
|
return a = `.${a}`, {
|
|
1048
1048
|
pkgNameOrAlias: i,
|
|
1049
1049
|
expose: a,
|
|
1050
|
-
remote:
|
|
1050
|
+
remote: r
|
|
1051
1051
|
};
|
|
1052
1052
|
} else if (a === "")
|
|
1053
1053
|
return {
|
|
1054
|
-
pkgNameOrAlias:
|
|
1054
|
+
pkgNameOrAlias: r.alias,
|
|
1055
1055
|
expose: ".",
|
|
1056
|
-
remote:
|
|
1056
|
+
remote: r
|
|
1057
1057
|
};
|
|
1058
1058
|
}
|
|
1059
1059
|
}
|
|
1060
1060
|
}
|
|
1061
|
-
function matchRemote(
|
|
1062
|
-
for (const
|
|
1063
|
-
if (t ===
|
|
1064
|
-
return
|
|
1061
|
+
function matchRemote(o, t) {
|
|
1062
|
+
for (const r of o)
|
|
1063
|
+
if (t === r.name || r.alias && t === r.alias)
|
|
1064
|
+
return r;
|
|
1065
1065
|
}
|
|
1066
|
-
function registerPlugins$1(
|
|
1067
|
-
const
|
|
1068
|
-
return
|
|
1069
|
-
|
|
1070
|
-
}),
|
|
1066
|
+
function registerPlugins$1(o, t) {
|
|
1067
|
+
const r = getGlobalHostPlugins();
|
|
1068
|
+
return r.length > 0 && r.forEach((n) => {
|
|
1069
|
+
o != null && o.find((s) => s.name !== n.name) && o.push(n);
|
|
1070
|
+
}), o && o.length > 0 && o.forEach((n) => {
|
|
1071
1071
|
t.forEach((s) => {
|
|
1072
1072
|
s.applyPlugin(n);
|
|
1073
1073
|
});
|
|
1074
|
-
}),
|
|
1074
|
+
}), o;
|
|
1075
1075
|
}
|
|
1076
|
-
async function loadEsmEntry({ entry:
|
|
1077
|
-
return new Promise((
|
|
1076
|
+
async function loadEsmEntry({ entry: o, remoteEntryExports: t }) {
|
|
1077
|
+
return new Promise((r, n) => {
|
|
1078
1078
|
try {
|
|
1079
|
-
t ?
|
|
1080
|
-
|
|
1079
|
+
t ? r(t) : typeof FEDERATION_ALLOW_NEW_FUNCTION < "u" ? new Function("callbacks", `import("${o}").then(callbacks[0]).catch(callbacks[1])`)([
|
|
1080
|
+
r,
|
|
1081
1081
|
n
|
|
1082
1082
|
]) : import(
|
|
1083
1083
|
/* webpackIgnore: true */
|
|
1084
1084
|
/* @vite-ignore */
|
|
1085
|
-
|
|
1086
|
-
).then(
|
|
1085
|
+
o
|
|
1086
|
+
).then(r).catch(n);
|
|
1087
1087
|
} catch (s) {
|
|
1088
1088
|
n(s);
|
|
1089
1089
|
}
|
|
1090
1090
|
});
|
|
1091
1091
|
}
|
|
1092
|
-
async function loadSystemJsEntry({ entry:
|
|
1093
|
-
return new Promise((
|
|
1092
|
+
async function loadSystemJsEntry({ entry: o, remoteEntryExports: t }) {
|
|
1093
|
+
return new Promise((r, n) => {
|
|
1094
1094
|
try {
|
|
1095
|
-
t ?
|
|
1096
|
-
|
|
1095
|
+
t ? r(t) : typeof __system_context__ > "u" ? System.import(o).then(r).catch(n) : new Function("callbacks", `System.import("${o}").then(callbacks[0]).catch(callbacks[1])`)([
|
|
1096
|
+
r,
|
|
1097
1097
|
n
|
|
1098
1098
|
]);
|
|
1099
1099
|
} catch (s) {
|
|
@@ -1101,9 +1101,9 @@ async function loadSystemJsEntry({ entry: r, remoteEntryExports: t }) {
|
|
|
1101
1101
|
}
|
|
1102
1102
|
});
|
|
1103
1103
|
}
|
|
1104
|
-
async function loadEntryScript({ name:
|
|
1105
|
-
const { entryExports: s } = getRemoteEntryExports(
|
|
1106
|
-
return s || loadScript(
|
|
1104
|
+
async function loadEntryScript({ name: o, globalName: t, entry: r, loaderHook: n }) {
|
|
1105
|
+
const { entryExports: s } = getRemoteEntryExports(o, t);
|
|
1106
|
+
return s || loadScript(r, {
|
|
1107
1107
|
attrs: {},
|
|
1108
1108
|
createScriptHook: (l, a) => {
|
|
1109
1109
|
const i = n.lifecycle.createScript.emit({
|
|
@@ -1114,18 +1114,18 @@ async function loadEntryScript({ name: r, globalName: t, entry: o, loaderHook: n
|
|
|
1114
1114
|
return i;
|
|
1115
1115
|
}
|
|
1116
1116
|
}).then(() => {
|
|
1117
|
-
const { remoteEntryKey: l, entryExports: a } = getRemoteEntryExports(
|
|
1117
|
+
const { remoteEntryKey: l, entryExports: a } = getRemoteEntryExports(o, t);
|
|
1118
1118
|
return assert(a, getShortErrorMsg(RUNTIME_001, runtimeDescMap, {
|
|
1119
|
-
remoteName:
|
|
1120
|
-
remoteEntryUrl:
|
|
1119
|
+
remoteName: o,
|
|
1120
|
+
remoteEntryUrl: r,
|
|
1121
1121
|
remoteEntryKey: l
|
|
1122
1122
|
})), a;
|
|
1123
1123
|
}).catch((l) => {
|
|
1124
1124
|
throw l;
|
|
1125
1125
|
});
|
|
1126
1126
|
}
|
|
1127
|
-
async function loadEntryDom({ remoteInfo:
|
|
1128
|
-
const { entry: n, entryGlobalName: s, name: l, type: a } =
|
|
1127
|
+
async function loadEntryDom({ remoteInfo: o, remoteEntryExports: t, loaderHook: r }) {
|
|
1128
|
+
const { entry: n, entryGlobalName: s, name: l, type: a } = o;
|
|
1129
1129
|
switch (a) {
|
|
1130
1130
|
case "esm":
|
|
1131
1131
|
case "module":
|
|
@@ -1143,13 +1143,13 @@ async function loadEntryDom({ remoteInfo: r, remoteEntryExports: t, loaderHook:
|
|
|
1143
1143
|
entry: n,
|
|
1144
1144
|
globalName: s,
|
|
1145
1145
|
name: l,
|
|
1146
|
-
loaderHook:
|
|
1146
|
+
loaderHook: r
|
|
1147
1147
|
});
|
|
1148
1148
|
}
|
|
1149
1149
|
}
|
|
1150
|
-
async function loadEntryNode({ remoteInfo:
|
|
1151
|
-
const { entry:
|
|
1152
|
-
return a || loadScriptNode(
|
|
1150
|
+
async function loadEntryNode({ remoteInfo: o, loaderHook: t }) {
|
|
1151
|
+
const { entry: r, entryGlobalName: n, name: s, type: l } = o, { entryExports: a } = getRemoteEntryExports(s, n);
|
|
1152
|
+
return a || loadScriptNode(r, {
|
|
1153
1153
|
attrs: {
|
|
1154
1154
|
name: s,
|
|
1155
1155
|
globalName: n,
|
|
@@ -1169,60 +1169,68 @@ async function loadEntryNode({ remoteInfo: r, loaderHook: t }) {
|
|
|
1169
1169
|
const { remoteEntryKey: i, entryExports: c } = getRemoteEntryExports(s, n);
|
|
1170
1170
|
return assert(c, getShortErrorMsg(RUNTIME_001, runtimeDescMap, {
|
|
1171
1171
|
remoteName: s,
|
|
1172
|
-
remoteEntryUrl:
|
|
1172
|
+
remoteEntryUrl: r,
|
|
1173
1173
|
remoteEntryKey: i
|
|
1174
1174
|
})), c;
|
|
1175
1175
|
}).catch((i) => {
|
|
1176
1176
|
throw i;
|
|
1177
1177
|
});
|
|
1178
1178
|
}
|
|
1179
|
-
function getRemoteEntryUniqueKey(
|
|
1180
|
-
const { entry: t, name:
|
|
1181
|
-
return composeKeyWithSeparator(
|
|
1179
|
+
function getRemoteEntryUniqueKey(o) {
|
|
1180
|
+
const { entry: t, name: r } = o;
|
|
1181
|
+
return composeKeyWithSeparator(r, t);
|
|
1182
1182
|
}
|
|
1183
|
-
async function getRemoteEntry({ origin:
|
|
1184
|
-
const n = getRemoteEntryUniqueKey(
|
|
1183
|
+
async function getRemoteEntry({ origin: o, remoteEntryExports: t, remoteInfo: r }) {
|
|
1184
|
+
const n = getRemoteEntryUniqueKey(r);
|
|
1185
1185
|
if (t)
|
|
1186
1186
|
return t;
|
|
1187
1187
|
if (!globalLoading[n]) {
|
|
1188
|
-
const s =
|
|
1188
|
+
const s = o.remoteHandler.hooks.lifecycle.loadEntry, l = o.loaderHook;
|
|
1189
1189
|
globalLoading[n] = s.emit({
|
|
1190
1190
|
loaderHook: l,
|
|
1191
|
-
remoteInfo:
|
|
1191
|
+
remoteInfo: r,
|
|
1192
1192
|
remoteEntryExports: t
|
|
1193
1193
|
}).then((a) => a || (isBrowserEnv() ? loadEntryDom({
|
|
1194
|
-
remoteInfo:
|
|
1194
|
+
remoteInfo: r,
|
|
1195
1195
|
remoteEntryExports: t,
|
|
1196
1196
|
loaderHook: l
|
|
1197
1197
|
}) : loadEntryNode({
|
|
1198
|
-
remoteInfo:
|
|
1198
|
+
remoteInfo: r,
|
|
1199
1199
|
loaderHook: l
|
|
1200
1200
|
})));
|
|
1201
1201
|
}
|
|
1202
1202
|
return globalLoading[n];
|
|
1203
1203
|
}
|
|
1204
|
-
function getRemoteInfo(
|
|
1205
|
-
return _extends$1({},
|
|
1206
|
-
entry: "entry" in
|
|
1207
|
-
type:
|
|
1208
|
-
entryGlobalName:
|
|
1209
|
-
shareScope:
|
|
1204
|
+
function getRemoteInfo(o) {
|
|
1205
|
+
return _extends$1({}, o, {
|
|
1206
|
+
entry: "entry" in o ? o.entry : "",
|
|
1207
|
+
type: o.type || DEFAULT_REMOTE_TYPE,
|
|
1208
|
+
entryGlobalName: o.entryGlobalName || o.name,
|
|
1209
|
+
shareScope: o.shareScope || DEFAULT_SCOPE
|
|
1210
1210
|
});
|
|
1211
1211
|
}
|
|
1212
1212
|
let Module = class {
|
|
1213
1213
|
async getEntry() {
|
|
1214
1214
|
if (this.remoteEntryExports)
|
|
1215
1215
|
return this.remoteEntryExports;
|
|
1216
|
-
|
|
1216
|
+
let t;
|
|
1217
|
+
const r = getRemoteEntryUniqueKey(this.remoteInfo);
|
|
1218
|
+
return t = await this.host.loaderHook.lifecycle.getRemoteEntryExports.emit({
|
|
1219
|
+
getRemoteEntry,
|
|
1220
|
+
origin: this.host,
|
|
1221
|
+
remoteInfo: this.remoteInfo,
|
|
1222
|
+
remoteEntryExports: this.remoteEntryExports,
|
|
1223
|
+
globalLoading,
|
|
1224
|
+
uniqueKey: r
|
|
1225
|
+
}), t || (t = await getRemoteEntry({
|
|
1217
1226
|
origin: this.host,
|
|
1218
1227
|
remoteInfo: this.remoteInfo,
|
|
1219
1228
|
remoteEntryExports: this.remoteEntryExports
|
|
1220
|
-
})
|
|
1221
|
-
return assert(t, `remoteEntryExports is undefined
|
|
1229
|
+
})), assert(t, `remoteEntryExports is undefined
|
|
1222
1230
|
${safeToString(this.remoteInfo)}`), this.remoteEntryExports = t, this.remoteEntryExports;
|
|
1223
1231
|
}
|
|
1224
1232
|
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
|
|
1225
|
-
async get(t,
|
|
1233
|
+
async get(t, r, n, s) {
|
|
1226
1234
|
const { loadFactory: l = !0 } = n || {
|
|
1227
1235
|
loadFactory: !0
|
|
1228
1236
|
}, a = await this.getEntry();
|
|
@@ -1259,13 +1267,13 @@ let Module = class {
|
|
|
1259
1267
|
let i;
|
|
1260
1268
|
i = await this.host.loaderHook.lifecycle.getModuleFactory.emit({
|
|
1261
1269
|
remoteEntryExports: a,
|
|
1262
|
-
expose:
|
|
1270
|
+
expose: r,
|
|
1263
1271
|
moduleInfo: this.remoteInfo
|
|
1264
|
-
}), i || (i = await a.get(
|
|
1265
|
-
const c = processModuleAlias(this.remoteInfo.name,
|
|
1272
|
+
}), i || (i = await a.get(r)), assert(i, `${getFMId(this.remoteInfo)} remote don't export ${r}.`);
|
|
1273
|
+
const c = processModuleAlias(this.remoteInfo.name, r), u = this.wraperFactory(i, c);
|
|
1266
1274
|
return l ? await u() : u;
|
|
1267
1275
|
}
|
|
1268
|
-
wraperFactory(t,
|
|
1276
|
+
wraperFactory(t, r) {
|
|
1269
1277
|
function n(s, l) {
|
|
1270
1278
|
s && typeof s == "object" && Object.isExtensible(s) && !Object.getOwnPropertyDescriptor(s, Symbol.for("mf_module_id")) && Object.defineProperty(s, Symbol.for("mf_module_id"), {
|
|
1271
1279
|
value: l,
|
|
@@ -1274,14 +1282,14 @@ let Module = class {
|
|
|
1274
1282
|
}
|
|
1275
1283
|
return t instanceof Promise ? async () => {
|
|
1276
1284
|
const s = await t();
|
|
1277
|
-
return n(s,
|
|
1285
|
+
return n(s, r), s;
|
|
1278
1286
|
} : () => {
|
|
1279
1287
|
const s = t();
|
|
1280
|
-
return n(s,
|
|
1288
|
+
return n(s, r), s;
|
|
1281
1289
|
};
|
|
1282
1290
|
}
|
|
1283
|
-
constructor({ remoteInfo: t, host:
|
|
1284
|
-
this.inited = !1, this.lib = void 0, this.remoteInfo = t, this.host =
|
|
1291
|
+
constructor({ remoteInfo: t, host: r }) {
|
|
1292
|
+
this.inited = !1, this.lib = void 0, this.remoteInfo = t, this.host = r;
|
|
1285
1293
|
}
|
|
1286
1294
|
};
|
|
1287
1295
|
class SyncHook {
|
|
@@ -1289,16 +1297,16 @@ class SyncHook {
|
|
|
1289
1297
|
typeof t == "function" && this.listeners.add(t);
|
|
1290
1298
|
}
|
|
1291
1299
|
once(t) {
|
|
1292
|
-
const
|
|
1300
|
+
const r = this;
|
|
1293
1301
|
this.on(function n(...s) {
|
|
1294
|
-
return
|
|
1302
|
+
return r.remove(n), t.apply(null, s);
|
|
1295
1303
|
});
|
|
1296
1304
|
}
|
|
1297
1305
|
emit(...t) {
|
|
1298
|
-
let
|
|
1306
|
+
let r;
|
|
1299
1307
|
return this.listeners.size > 0 && this.listeners.forEach((n) => {
|
|
1300
|
-
|
|
1301
|
-
}),
|
|
1308
|
+
r = n(...t);
|
|
1309
|
+
}), r;
|
|
1302
1310
|
}
|
|
1303
1311
|
remove(t) {
|
|
1304
1312
|
this.listeners.delete(t);
|
|
@@ -1312,22 +1320,22 @@ class SyncHook {
|
|
|
1312
1320
|
}
|
|
1313
1321
|
class AsyncHook extends SyncHook {
|
|
1314
1322
|
emit(...t) {
|
|
1315
|
-
let
|
|
1323
|
+
let r;
|
|
1316
1324
|
const n = Array.from(this.listeners);
|
|
1317
1325
|
if (n.length > 0) {
|
|
1318
1326
|
let s = 0;
|
|
1319
1327
|
const l = (a) => a === !1 ? !1 : s < n.length ? Promise.resolve(n[s++].apply(null, t)).then(l) : a;
|
|
1320
|
-
|
|
1328
|
+
r = l();
|
|
1321
1329
|
}
|
|
1322
|
-
return Promise.resolve(
|
|
1330
|
+
return Promise.resolve(r);
|
|
1323
1331
|
}
|
|
1324
1332
|
}
|
|
1325
|
-
function checkReturnData(
|
|
1333
|
+
function checkReturnData(o, t) {
|
|
1326
1334
|
if (!isObject(t))
|
|
1327
1335
|
return !1;
|
|
1328
|
-
if (
|
|
1329
|
-
for (const
|
|
1330
|
-
if (!(
|
|
1336
|
+
if (o !== t) {
|
|
1337
|
+
for (const r in o)
|
|
1338
|
+
if (!(r in t))
|
|
1331
1339
|
return !1;
|
|
1332
1340
|
}
|
|
1333
1341
|
return !0;
|
|
@@ -1335,9 +1343,9 @@ function checkReturnData(r, t) {
|
|
|
1335
1343
|
class SyncWaterfallHook extends SyncHook {
|
|
1336
1344
|
emit(t) {
|
|
1337
1345
|
isObject(t) || error(`The data for the "${this.type}" hook should be an object.`);
|
|
1338
|
-
for (const
|
|
1346
|
+
for (const r of this.listeners)
|
|
1339
1347
|
try {
|
|
1340
|
-
const n =
|
|
1348
|
+
const n = r(t);
|
|
1341
1349
|
if (checkReturnData(t, n))
|
|
1342
1350
|
t = n;
|
|
1343
1351
|
else {
|
|
@@ -1356,14 +1364,14 @@ class SyncWaterfallHook extends SyncHook {
|
|
|
1356
1364
|
class AsyncWaterfallHook extends SyncHook {
|
|
1357
1365
|
emit(t) {
|
|
1358
1366
|
isObject(t) || error(`The response data for the "${this.type}" hook must be an object.`);
|
|
1359
|
-
const
|
|
1360
|
-
if (
|
|
1367
|
+
const r = Array.from(this.listeners);
|
|
1368
|
+
if (r.length > 0) {
|
|
1361
1369
|
let n = 0;
|
|
1362
1370
|
const s = (a) => (warn(a), this.onerror(a), t), l = (a) => {
|
|
1363
1371
|
if (checkReturnData(t, a)) {
|
|
1364
|
-
if (t = a, n <
|
|
1372
|
+
if (t = a, n < r.length)
|
|
1365
1373
|
try {
|
|
1366
|
-
return Promise.resolve(
|
|
1374
|
+
return Promise.resolve(r[n++](t)).then(l, s);
|
|
1367
1375
|
} catch (i) {
|
|
1368
1376
|
return s(i);
|
|
1369
1377
|
}
|
|
@@ -1382,59 +1390,59 @@ class AsyncWaterfallHook extends SyncHook {
|
|
|
1382
1390
|
class PluginSystem {
|
|
1383
1391
|
applyPlugin(t) {
|
|
1384
1392
|
assert(isPlainObject(t), "Plugin configuration is invalid.");
|
|
1385
|
-
const
|
|
1386
|
-
assert(
|
|
1393
|
+
const r = t.name;
|
|
1394
|
+
assert(r, "A name must be provided by the plugin."), this.registerPlugins[r] || (this.registerPlugins[r] = t, Object.keys(this.lifecycle).forEach((n) => {
|
|
1387
1395
|
const s = t[n];
|
|
1388
1396
|
s && this.lifecycle[n].on(s);
|
|
1389
1397
|
}));
|
|
1390
1398
|
}
|
|
1391
1399
|
removePlugin(t) {
|
|
1392
1400
|
assert(t, "A name is required.");
|
|
1393
|
-
const
|
|
1394
|
-
assert(
|
|
1395
|
-
n !== "name" && this.lifecycle[n].remove(
|
|
1401
|
+
const r = this.registerPlugins[t];
|
|
1402
|
+
assert(r, `The plugin "${t}" is not registered.`), Object.keys(r).forEach((n) => {
|
|
1403
|
+
n !== "name" && this.lifecycle[n].remove(r[n]);
|
|
1396
1404
|
});
|
|
1397
1405
|
}
|
|
1398
1406
|
// eslint-disable-next-line @typescript-eslint/no-shadow
|
|
1399
|
-
inherit({ lifecycle: t, registerPlugins:
|
|
1407
|
+
inherit({ lifecycle: t, registerPlugins: r }) {
|
|
1400
1408
|
Object.keys(t).forEach((n) => {
|
|
1401
1409
|
assert(!this.lifecycle[n], `The hook "${n}" has a conflict and cannot be inherited.`), this.lifecycle[n] = t[n];
|
|
1402
|
-
}), Object.keys(
|
|
1403
|
-
assert(!this.registerPlugins[n], `The plugin "${n}" has a conflict and cannot be inherited.`), this.applyPlugin(
|
|
1410
|
+
}), Object.keys(r).forEach((n) => {
|
|
1411
|
+
assert(!this.registerPlugins[n], `The plugin "${n}" has a conflict and cannot be inherited.`), this.applyPlugin(r[n]);
|
|
1404
1412
|
});
|
|
1405
1413
|
}
|
|
1406
1414
|
constructor(t) {
|
|
1407
1415
|
this.registerPlugins = {}, this.lifecycle = t, this.lifecycleKeys = Object.keys(t);
|
|
1408
1416
|
}
|
|
1409
1417
|
}
|
|
1410
|
-
function defaultPreloadArgs(
|
|
1418
|
+
function defaultPreloadArgs(o) {
|
|
1411
1419
|
return _extends$1({
|
|
1412
1420
|
resourceCategory: "sync",
|
|
1413
1421
|
share: !0,
|
|
1414
1422
|
depsRemote: !0,
|
|
1415
1423
|
prefetchInterface: !1
|
|
1416
|
-
},
|
|
1424
|
+
}, o);
|
|
1417
1425
|
}
|
|
1418
|
-
function formatPreloadArgs(
|
|
1419
|
-
return t.map((
|
|
1420
|
-
const n = matchRemote(
|
|
1421
|
-
return assert(n, `Unable to preload ${
|
|
1426
|
+
function formatPreloadArgs(o, t) {
|
|
1427
|
+
return t.map((r) => {
|
|
1428
|
+
const n = matchRemote(o, r.nameOrAlias);
|
|
1429
|
+
return assert(n, `Unable to preload ${r.nameOrAlias} as it is not included in ${!n && safeToString({
|
|
1422
1430
|
remoteInfo: n,
|
|
1423
|
-
remotes:
|
|
1431
|
+
remotes: o
|
|
1424
1432
|
})}`), {
|
|
1425
1433
|
remote: n,
|
|
1426
|
-
preloadConfig: defaultPreloadArgs(
|
|
1434
|
+
preloadConfig: defaultPreloadArgs(r)
|
|
1427
1435
|
};
|
|
1428
1436
|
});
|
|
1429
1437
|
}
|
|
1430
|
-
function normalizePreloadExposes(
|
|
1431
|
-
return
|
|
1438
|
+
function normalizePreloadExposes(o) {
|
|
1439
|
+
return o ? o.map((t) => t === "." ? t : t.startsWith("./") ? t.replace("./", "") : t) : [];
|
|
1432
1440
|
}
|
|
1433
|
-
function preloadAssets(
|
|
1434
|
-
const { cssAssets: s, jsAssetsWithoutEntry: l, entryAssets: a } =
|
|
1441
|
+
function preloadAssets(o, t, r, n = !0) {
|
|
1442
|
+
const { cssAssets: s, jsAssetsWithoutEntry: l, entryAssets: a } = r;
|
|
1435
1443
|
if (t.options.inBrowser) {
|
|
1436
1444
|
if (a.forEach((i) => {
|
|
1437
|
-
const { moduleInfo: c } = i, u = t.moduleCache.get(
|
|
1445
|
+
const { moduleInfo: c } = i, u = t.moduleCache.get(o.name);
|
|
1438
1446
|
getRemoteEntry(u ? {
|
|
1439
1447
|
origin: t,
|
|
1440
1448
|
remoteInfo: c,
|
|
@@ -1515,7 +1523,7 @@ function preloadAssets(r, t, o, n = !0) {
|
|
|
1515
1523
|
} else {
|
|
1516
1524
|
const i = {
|
|
1517
1525
|
fetchpriority: "high",
|
|
1518
|
-
type: (
|
|
1526
|
+
type: (o == null ? void 0 : o.type) === "module" ? "module" : "text/javascript"
|
|
1519
1527
|
};
|
|
1520
1528
|
l.forEach((c) => {
|
|
1521
1529
|
const { script: u, needAttach: d } = createScript({
|
|
@@ -1538,24 +1546,24 @@ function preloadAssets(r, t, o, n = !0) {
|
|
|
1538
1546
|
}
|
|
1539
1547
|
}
|
|
1540
1548
|
}
|
|
1541
|
-
function assignRemoteInfo(
|
|
1542
|
-
const
|
|
1543
|
-
|
|
1544
|
-
let n = getResourceUrl(t,
|
|
1545
|
-
!isBrowserEnv() && !n.startsWith("http") && (n = `https:${n}`),
|
|
1549
|
+
function assignRemoteInfo(o, t) {
|
|
1550
|
+
const r = getRemoteEntryInfoFromSnapshot(t);
|
|
1551
|
+
r.url || error(`The attribute remoteEntry of ${o.name} must not be undefined.`);
|
|
1552
|
+
let n = getResourceUrl(t, r.url);
|
|
1553
|
+
!isBrowserEnv() && !n.startsWith("http") && (n = `https:${n}`), o.type = r.type, o.entryGlobalName = r.globalName, o.entry = n, o.version = t.version, o.buildVersion = t.buildVersion;
|
|
1546
1554
|
}
|
|
1547
1555
|
function snapshotPlugin() {
|
|
1548
1556
|
return {
|
|
1549
1557
|
name: "snapshot-plugin",
|
|
1550
|
-
async afterResolve(
|
|
1551
|
-
const { remote: t, pkgNameOrAlias:
|
|
1558
|
+
async afterResolve(o) {
|
|
1559
|
+
const { remote: t, pkgNameOrAlias: r, expose: n, origin: s, remoteInfo: l } = o;
|
|
1552
1560
|
if (!isRemoteInfoWithEntry(t) || !isPureRemoteEntry(t)) {
|
|
1553
1561
|
const { remoteSnapshot: a, globalSnapshot: i } = await s.snapshotHandler.loadRemoteSnapshotInfo(t);
|
|
1554
1562
|
assignRemoteInfo(l, a);
|
|
1555
1563
|
const c = {
|
|
1556
1564
|
remote: t,
|
|
1557
1565
|
preloadConfig: {
|
|
1558
|
-
nameOrAlias:
|
|
1566
|
+
nameOrAlias: r,
|
|
1559
1567
|
exposes: [
|
|
1560
1568
|
n
|
|
1561
1569
|
],
|
|
@@ -1571,16 +1579,16 @@ function snapshotPlugin() {
|
|
|
1571
1579
|
remoteSnapshot: a,
|
|
1572
1580
|
globalSnapshot: i
|
|
1573
1581
|
});
|
|
1574
|
-
return u && preloadAssets(l, s, u, !1), _extends$1({},
|
|
1582
|
+
return u && preloadAssets(l, s, u, !1), _extends$1({}, o, {
|
|
1575
1583
|
remoteSnapshot: a
|
|
1576
1584
|
});
|
|
1577
1585
|
}
|
|
1578
|
-
return
|
|
1586
|
+
return o;
|
|
1579
1587
|
}
|
|
1580
1588
|
};
|
|
1581
1589
|
}
|
|
1582
|
-
function splitId(
|
|
1583
|
-
const t =
|
|
1590
|
+
function splitId(o) {
|
|
1591
|
+
const t = o.split(":");
|
|
1584
1592
|
return t.length === 1 ? {
|
|
1585
1593
|
name: t[0],
|
|
1586
1594
|
version: void 0
|
|
@@ -1592,30 +1600,30 @@ function splitId(r) {
|
|
|
1592
1600
|
version: t[2]
|
|
1593
1601
|
};
|
|
1594
1602
|
}
|
|
1595
|
-
function traverseModuleInfo(
|
|
1596
|
-
const a = getFMId(t), { value: i } = getInfoWithoutType(
|
|
1597
|
-
if (c && !isManifestProvider(c) && (
|
|
1603
|
+
function traverseModuleInfo(o, t, r, n, s = {}, l) {
|
|
1604
|
+
const a = getFMId(t), { value: i } = getInfoWithoutType(o, a), c = l || i;
|
|
1605
|
+
if (c && !isManifestProvider(c) && (r(c, t, n), c.remotesInfo)) {
|
|
1598
1606
|
const u = Object.keys(c.remotesInfo);
|
|
1599
1607
|
for (const d of u) {
|
|
1600
1608
|
if (s[d])
|
|
1601
1609
|
continue;
|
|
1602
1610
|
s[d] = !0;
|
|
1603
1611
|
const p = splitId(d), m = c.remotesInfo[d];
|
|
1604
|
-
traverseModuleInfo(
|
|
1612
|
+
traverseModuleInfo(o, {
|
|
1605
1613
|
name: p.name,
|
|
1606
1614
|
version: m.matchedVersion
|
|
1607
|
-
},
|
|
1615
|
+
}, r, !1, s, void 0);
|
|
1608
1616
|
}
|
|
1609
1617
|
}
|
|
1610
1618
|
}
|
|
1611
|
-
function generatePreloadAssets(
|
|
1612
|
-
const l = [], a = [], i = [], c = /* @__PURE__ */ new Set(), u = /* @__PURE__ */ new Set(), { options: d } =
|
|
1613
|
-
if (traverseModuleInfo(n,
|
|
1619
|
+
function generatePreloadAssets(o, t, r, n, s) {
|
|
1620
|
+
const l = [], a = [], i = [], c = /* @__PURE__ */ new Set(), u = /* @__PURE__ */ new Set(), { options: d } = o, { preloadConfig: p } = t, { depsRemote: m } = p;
|
|
1621
|
+
if (traverseModuleInfo(n, r, (g, E, I) => {
|
|
1614
1622
|
let v;
|
|
1615
1623
|
if (I)
|
|
1616
1624
|
v = p;
|
|
1617
1625
|
else if (Array.isArray(m)) {
|
|
1618
|
-
const T = m.find((
|
|
1626
|
+
const T = m.find((A) => A.nameOrAlias === E.name || A.nameOrAlias === E.alias);
|
|
1619
1627
|
if (!T)
|
|
1620
1628
|
return;
|
|
1621
1629
|
v = defaultPreloadArgs(T);
|
|
@@ -1639,30 +1647,30 @@ function generatePreloadAssets(r, t, o, n, s) {
|
|
|
1639
1647
|
let b = "modules" in g ? g.modules : [];
|
|
1640
1648
|
const $ = normalizePreloadExposes(v.exposes);
|
|
1641
1649
|
if ($.length && "modules" in g) {
|
|
1642
|
-
var
|
|
1643
|
-
b = g == null || (
|
|
1650
|
+
var w;
|
|
1651
|
+
b = g == null || (w = g.modules) == null ? void 0 : w.reduce((T, A) => (($ == null ? void 0 : $.indexOf(A.moduleName)) !== -1 && T.push(A), T), []);
|
|
1644
1652
|
}
|
|
1645
1653
|
function O(T) {
|
|
1646
|
-
const
|
|
1647
|
-
return v.filter ?
|
|
1654
|
+
const A = T.map((P) => getResourceUrl(g, P));
|
|
1655
|
+
return v.filter ? A.filter(v.filter) : A;
|
|
1648
1656
|
}
|
|
1649
1657
|
if (b) {
|
|
1650
1658
|
const T = b.length;
|
|
1651
|
-
for (let
|
|
1652
|
-
const P = b[
|
|
1653
|
-
|
|
1659
|
+
for (let A = 0; A < T; A++) {
|
|
1660
|
+
const P = b[A], M = `${E.name}/${P.moduleName}`;
|
|
1661
|
+
o.remoteHandler.hooks.lifecycle.handlePreloadModule.emit({
|
|
1654
1662
|
id: P.moduleName === "." ? E.name : M,
|
|
1655
1663
|
name: E.name,
|
|
1656
1664
|
remoteSnapshot: g,
|
|
1657
1665
|
preloadConfig: v,
|
|
1658
1666
|
remote: E,
|
|
1659
|
-
origin:
|
|
1667
|
+
origin: o
|
|
1660
1668
|
}), !getPreloaded(M) && (v.resourceCategory === "all" ? (l.push(...O(P.assets.css.async)), l.push(...O(P.assets.css.sync)), a.push(...O(P.assets.js.async)), a.push(...O(P.assets.js.sync))) : (v.resourceCategory = "sync") && (l.push(...O(P.assets.css.sync)), a.push(...O(P.assets.js.sync))), setPreloaded(M));
|
|
1661
1669
|
}
|
|
1662
1670
|
}
|
|
1663
1671
|
}, !0, {}, s), s.shared) {
|
|
1664
1672
|
const g = (E, I) => {
|
|
1665
|
-
const v = getRegisteredShare(
|
|
1673
|
+
const v = getRegisteredShare(o.shareScopeMap, I.sharedName, E, o.sharedHandler.hooks.lifecycle.resolveShare);
|
|
1666
1674
|
v && typeof v.lib == "function" && (I.assets.js.sync.forEach((S) => {
|
|
1667
1675
|
c.add(S);
|
|
1668
1676
|
}), I.assets.css.sync.forEach((S) => {
|
|
@@ -1692,8 +1700,8 @@ function generatePreloadAssets(r, t, o, n, s) {
|
|
|
1692
1700
|
const generatePreloadAssetsPlugin = function() {
|
|
1693
1701
|
return {
|
|
1694
1702
|
name: "generate-preload-assets-plugin",
|
|
1695
|
-
async generatePreloadAssets(
|
|
1696
|
-
const { origin: t, preloadOptions:
|
|
1703
|
+
async generatePreloadAssets(o) {
|
|
1704
|
+
const { origin: t, preloadOptions: r, remoteInfo: n, remote: s, globalSnapshot: l, remoteSnapshot: a } = o;
|
|
1697
1705
|
return isRemoteInfoWithEntry(s) && isPureRemoteEntry(s) ? {
|
|
1698
1706
|
cssAssets: [],
|
|
1699
1707
|
jsAssetsWithoutEntry: [],
|
|
@@ -1710,35 +1718,35 @@ const generatePreloadAssetsPlugin = function() {
|
|
|
1710
1718
|
}
|
|
1711
1719
|
}
|
|
1712
1720
|
]
|
|
1713
|
-
} : (assignRemoteInfo(n, a), generatePreloadAssets(t,
|
|
1721
|
+
} : (assignRemoteInfo(n, a), generatePreloadAssets(t, r, n, l, a));
|
|
1714
1722
|
}
|
|
1715
1723
|
};
|
|
1716
1724
|
};
|
|
1717
|
-
function getGlobalRemoteInfo(
|
|
1718
|
-
const
|
|
1725
|
+
function getGlobalRemoteInfo(o, t) {
|
|
1726
|
+
const r = getGlobalSnapshotInfoByModuleInfo({
|
|
1719
1727
|
name: t.options.name,
|
|
1720
1728
|
version: t.options.version
|
|
1721
|
-
}), n =
|
|
1729
|
+
}), n = r && "remotesInfo" in r && r.remotesInfo && getInfoWithoutType(r.remotesInfo, o.name).value;
|
|
1722
1730
|
return n && n.matchedVersion ? {
|
|
1723
|
-
hostGlobalSnapshot:
|
|
1731
|
+
hostGlobalSnapshot: r,
|
|
1724
1732
|
globalSnapshot: getGlobalSnapshot(),
|
|
1725
1733
|
remoteSnapshot: getGlobalSnapshotInfoByModuleInfo({
|
|
1726
|
-
name:
|
|
1734
|
+
name: o.name,
|
|
1727
1735
|
version: n.matchedVersion
|
|
1728
1736
|
})
|
|
1729
1737
|
} : {
|
|
1730
1738
|
hostGlobalSnapshot: void 0,
|
|
1731
1739
|
globalSnapshot: getGlobalSnapshot(),
|
|
1732
1740
|
remoteSnapshot: getGlobalSnapshotInfoByModuleInfo({
|
|
1733
|
-
name:
|
|
1734
|
-
version: "version" in
|
|
1741
|
+
name: o.name,
|
|
1742
|
+
version: "version" in o ? o.version : void 0
|
|
1735
1743
|
})
|
|
1736
1744
|
};
|
|
1737
1745
|
}
|
|
1738
1746
|
class SnapshotHandler {
|
|
1739
1747
|
async loadSnapshot(t) {
|
|
1740
|
-
const { options:
|
|
1741
|
-
options:
|
|
1748
|
+
const { options: r } = this.HostInstance, { hostGlobalSnapshot: n, remoteSnapshot: s, globalSnapshot: l } = this.getGlobalRemoteInfo(t), { remoteSnapshot: a, globalSnapshot: i } = await this.hooks.lifecycle.loadSnapshot.emit({
|
|
1749
|
+
options: r,
|
|
1742
1750
|
moduleInfo: t,
|
|
1743
1751
|
hostGlobalSnapshot: n,
|
|
1744
1752
|
remoteSnapshot: s,
|
|
@@ -1751,9 +1759,9 @@ class SnapshotHandler {
|
|
|
1751
1759
|
}
|
|
1752
1760
|
// eslint-disable-next-line max-lines-per-function
|
|
1753
1761
|
async loadRemoteSnapshotInfo(t) {
|
|
1754
|
-
const { options:
|
|
1762
|
+
const { options: r } = this.HostInstance;
|
|
1755
1763
|
await this.hooks.lifecycle.beforeLoadRemoteSnapshot.emit({
|
|
1756
|
-
options:
|
|
1764
|
+
options: r,
|
|
1757
1765
|
moduleInfo: t
|
|
1758
1766
|
});
|
|
1759
1767
|
let n = getGlobalSnapshotInfoByModuleInfo({
|
|
@@ -1772,7 +1780,7 @@ class SnapshotHandler {
|
|
|
1772
1780
|
}
|
|
1773
1781
|
}));
|
|
1774
1782
|
const { hostGlobalSnapshot: s, remoteSnapshot: l, globalSnapshot: a } = this.getGlobalRemoteInfo(t), { remoteSnapshot: i, globalSnapshot: c } = await this.hooks.lifecycle.loadSnapshot.emit({
|
|
1775
|
-
options:
|
|
1783
|
+
options: r,
|
|
1776
1784
|
moduleInfo: t,
|
|
1777
1785
|
hostGlobalSnapshot: s,
|
|
1778
1786
|
remoteSnapshot: l,
|
|
@@ -1811,7 +1819,7 @@ class SnapshotHandler {
|
|
|
1811
1819
|
globalSnapshot: JSON.stringify(c)
|
|
1812
1820
|
}));
|
|
1813
1821
|
return await this.hooks.lifecycle.afterLoadSnapshot.emit({
|
|
1814
|
-
options:
|
|
1822
|
+
options: r,
|
|
1815
1823
|
moduleInfo: t,
|
|
1816
1824
|
remoteSnapshot: u
|
|
1817
1825
|
}), {
|
|
@@ -1822,7 +1830,7 @@ class SnapshotHandler {
|
|
|
1822
1830
|
getGlobalRemoteInfo(t) {
|
|
1823
1831
|
return getGlobalRemoteInfo(t, this.HostInstance);
|
|
1824
1832
|
}
|
|
1825
|
-
async getManifestJson(t,
|
|
1833
|
+
async getManifestJson(t, r, n) {
|
|
1826
1834
|
const s = async () => {
|
|
1827
1835
|
let a = this.manifestCache.get(t);
|
|
1828
1836
|
if (a)
|
|
@@ -1833,7 +1841,7 @@ class SnapshotHandler {
|
|
|
1833
1841
|
} catch (i) {
|
|
1834
1842
|
delete this.manifestLoading[t], error(getShortErrorMsg(RUNTIME_003, runtimeDescMap, {
|
|
1835
1843
|
manifestUrl: t,
|
|
1836
|
-
moduleName:
|
|
1844
|
+
moduleName: r.name
|
|
1837
1845
|
}, `${i}`));
|
|
1838
1846
|
}
|
|
1839
1847
|
}, l = async () => {
|
|
@@ -1841,7 +1849,7 @@ class SnapshotHandler {
|
|
|
1841
1849
|
version: t
|
|
1842
1850
|
}), { remoteSnapshot: c } = await this.hooks.lifecycle.loadRemoteSnapshot.emit({
|
|
1843
1851
|
options: this.HostInstance.options,
|
|
1844
|
-
moduleInfo:
|
|
1852
|
+
moduleInfo: r,
|
|
1845
1853
|
manifestJson: a,
|
|
1846
1854
|
remoteSnapshot: i,
|
|
1847
1855
|
manifestUrl: t,
|
|
@@ -1862,8 +1870,8 @@ class SnapshotHandler {
|
|
|
1862
1870
|
}
|
|
1863
1871
|
class SharedHandler {
|
|
1864
1872
|
// register shared in shareScopeMap
|
|
1865
|
-
registerShared(t,
|
|
1866
|
-
const { shareInfos: n, shared: s } = formatShareConfigs(t,
|
|
1873
|
+
registerShared(t, r) {
|
|
1874
|
+
const { shareInfos: n, shared: s } = formatShareConfigs(t, r);
|
|
1867
1875
|
return Object.keys(n).forEach((a) => {
|
|
1868
1876
|
n[a].forEach((c) => {
|
|
1869
1877
|
!getRegisteredShare(this.shareScopeMap, a, c, this.hooks.lifecycle.resolveShare) && c && c.lib && this.setShared({
|
|
@@ -1872,7 +1880,7 @@ class SharedHandler {
|
|
|
1872
1880
|
get: c.get,
|
|
1873
1881
|
loaded: !0,
|
|
1874
1882
|
shared: c,
|
|
1875
|
-
from:
|
|
1883
|
+
from: r.name
|
|
1876
1884
|
});
|
|
1877
1885
|
});
|
|
1878
1886
|
}), {
|
|
@@ -1880,10 +1888,10 @@ class SharedHandler {
|
|
|
1880
1888
|
shared: s
|
|
1881
1889
|
};
|
|
1882
1890
|
}
|
|
1883
|
-
async loadShare(t,
|
|
1891
|
+
async loadShare(t, r) {
|
|
1884
1892
|
const { host: n } = this, s = getTargetSharedOptions({
|
|
1885
1893
|
pkgName: t,
|
|
1886
|
-
extraOptions:
|
|
1894
|
+
extraOptions: r,
|
|
1887
1895
|
shareInfos: n.options.shared
|
|
1888
1896
|
});
|
|
1889
1897
|
s != null && s.scope && await Promise.all(s.scope.map(async (u) => {
|
|
@@ -1922,7 +1930,7 @@ class SharedHandler {
|
|
|
1922
1930
|
loading: d
|
|
1923
1931
|
}), d;
|
|
1924
1932
|
} else {
|
|
1925
|
-
if (
|
|
1933
|
+
if (r != null && r.customShareInfo)
|
|
1926
1934
|
return !1;
|
|
1927
1935
|
const d = (async () => {
|
|
1928
1936
|
const p = await a.get();
|
|
@@ -1946,9 +1954,9 @@ class SharedHandler {
|
|
|
1946
1954
|
* If the share scope does not exist, it creates one.
|
|
1947
1955
|
*/
|
|
1948
1956
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
1949
|
-
initializeSharing(t = DEFAULT_SCOPE,
|
|
1950
|
-
const { host: n } = this, s =
|
|
1951
|
-
let a =
|
|
1957
|
+
initializeSharing(t = DEFAULT_SCOPE, r) {
|
|
1958
|
+
const { host: n } = this, s = r == null ? void 0 : r.from, l = r == null ? void 0 : r.strategy;
|
|
1959
|
+
let a = r == null ? void 0 : r.initScope;
|
|
1952
1960
|
const i = [];
|
|
1953
1961
|
if (s !== "build") {
|
|
1954
1962
|
const { initTokens: _ } = this;
|
|
@@ -2000,10 +2008,10 @@ class SharedHandler {
|
|
|
2000
2008
|
// 1. If the loaded shared already exists globally, then it will be reused
|
|
2001
2009
|
// 2. If lib exists in local shared, it will be used directly
|
|
2002
2010
|
// 3. If the local get returns something other than Promise, then it will be used directly
|
|
2003
|
-
loadShareSync(t,
|
|
2011
|
+
loadShareSync(t, r) {
|
|
2004
2012
|
const { host: n } = this, s = getTargetSharedOptions({
|
|
2005
2013
|
pkgName: t,
|
|
2006
|
-
extraOptions:
|
|
2014
|
+
extraOptions: r,
|
|
2007
2015
|
shareInfos: n.options.shared
|
|
2008
2016
|
});
|
|
2009
2017
|
s != null && s.scope && s.scope.forEach((i) => {
|
|
@@ -2034,7 +2042,7 @@ class SharedHandler {
|
|
|
2034
2042
|
if (s.get) {
|
|
2035
2043
|
const i = s.get();
|
|
2036
2044
|
if (i instanceof Promise) {
|
|
2037
|
-
const c = (
|
|
2045
|
+
const c = (r == null ? void 0 : r.from) === "build" ? RUNTIME_005 : RUNTIME_006;
|
|
2038
2046
|
throw new Error(getShortErrorMsg(c, runtimeDescMap, {
|
|
2039
2047
|
hostName: n.options.name,
|
|
2040
2048
|
sharedPkgName: t
|
|
@@ -2053,18 +2061,18 @@ class SharedHandler {
|
|
|
2053
2061
|
sharedPkgName: t
|
|
2054
2062
|
}));
|
|
2055
2063
|
}
|
|
2056
|
-
initShareScopeMap(t,
|
|
2064
|
+
initShareScopeMap(t, r, n = {}) {
|
|
2057
2065
|
const { host: s } = this;
|
|
2058
|
-
this.shareScopeMap[t] =
|
|
2059
|
-
shareScope:
|
|
2066
|
+
this.shareScopeMap[t] = r, this.hooks.lifecycle.initContainerShareScopeMap.emit({
|
|
2067
|
+
shareScope: r,
|
|
2060
2068
|
options: s.options,
|
|
2061
2069
|
origin: s,
|
|
2062
2070
|
scopeName: t,
|
|
2063
2071
|
hostShareScopeMap: n.hostShareScopeMap
|
|
2064
2072
|
});
|
|
2065
2073
|
}
|
|
2066
|
-
setShared({ pkgName: t, shared:
|
|
2067
|
-
const { version: c, scope: u = "default" } =
|
|
2074
|
+
setShared({ pkgName: t, shared: r, from: n, lib: s, loading: l, loaded: a, get: i }) {
|
|
2075
|
+
const { version: c, scope: u = "default" } = r, d = _object_without_properties_loose(r, [
|
|
2068
2076
|
"version",
|
|
2069
2077
|
"scope"
|
|
2070
2078
|
]);
|
|
@@ -2089,8 +2097,8 @@ class SharedHandler {
|
|
|
2089
2097
|
});
|
|
2090
2098
|
}
|
|
2091
2099
|
_setGlobalShareScopeMap(t) {
|
|
2092
|
-
const
|
|
2093
|
-
n && !
|
|
2100
|
+
const r = getGlobalShareScope(), n = t.id || t.name;
|
|
2101
|
+
n && !r[n] && (r[n] = this.shareScopeMap);
|
|
2094
2102
|
}
|
|
2095
2103
|
constructor(t) {
|
|
2096
2104
|
this.hooks = new PluginSystem({
|
|
@@ -2105,13 +2113,13 @@ class SharedHandler {
|
|
|
2105
2113
|
}
|
|
2106
2114
|
}
|
|
2107
2115
|
class RemoteHandler {
|
|
2108
|
-
formatAndRegisterRemote(t,
|
|
2109
|
-
return (
|
|
2116
|
+
formatAndRegisterRemote(t, r) {
|
|
2117
|
+
return (r.remotes || []).reduce((s, l) => (this.registerRemote(l, s, {
|
|
2110
2118
|
force: !1
|
|
2111
2119
|
}), s), t.remotes);
|
|
2112
2120
|
}
|
|
2113
|
-
setIdToRemoteMap(t,
|
|
2114
|
-
const { remote: n, expose: s } =
|
|
2121
|
+
setIdToRemoteMap(t, r) {
|
|
2122
|
+
const { remote: n, expose: s } = r, { name: l, alias: a } = n;
|
|
2115
2123
|
if (this.idToRemoteMap[t] = {
|
|
2116
2124
|
name: n.name,
|
|
2117
2125
|
expose: s
|
|
@@ -2133,14 +2141,14 @@ class RemoteHandler {
|
|
|
2133
2141
|
}
|
|
2134
2142
|
// eslint-disable-next-line max-lines-per-function
|
|
2135
2143
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
2136
|
-
async loadRemote(t,
|
|
2144
|
+
async loadRemote(t, r) {
|
|
2137
2145
|
const { host: n } = this;
|
|
2138
2146
|
try {
|
|
2139
|
-
const { loadFactory: s = !0 } =
|
|
2147
|
+
const { loadFactory: s = !0 } = r || {
|
|
2140
2148
|
loadFactory: !0
|
|
2141
2149
|
}, { module: l, moduleOptions: a, remoteMatchInfo: i } = await this.getRemoteModuleAndOptions({
|
|
2142
2150
|
id: t
|
|
2143
|
-
}), { pkgNameOrAlias: c, remote: u, expose: d, id: p, remoteSnapshot: m } = i, y = await l.get(p, d,
|
|
2151
|
+
}), { pkgNameOrAlias: c, remote: u, expose: d, id: p, remoteSnapshot: m } = i, y = await l.get(p, d, r, m), _ = await this.hooks.lifecycle.onLoad.emit({
|
|
2144
2152
|
id: p,
|
|
2145
2153
|
pkgNameOrAlias: c,
|
|
2146
2154
|
expose: d,
|
|
@@ -2153,7 +2161,7 @@ class RemoteHandler {
|
|
|
2153
2161
|
});
|
|
2154
2162
|
return this.setIdToRemoteMap(t, i), typeof _ == "function" ? _ : y;
|
|
2155
2163
|
} catch (s) {
|
|
2156
|
-
const { from: l = "runtime" } =
|
|
2164
|
+
const { from: l = "runtime" } = r || {
|
|
2157
2165
|
from: "runtime"
|
|
2158
2166
|
}, a = await this.hooks.lifecycle.errorLoadRemote.emit({
|
|
2159
2167
|
id: t,
|
|
@@ -2169,81 +2177,81 @@ class RemoteHandler {
|
|
|
2169
2177
|
}
|
|
2170
2178
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
2171
2179
|
async preloadRemote(t) {
|
|
2172
|
-
const { host:
|
|
2180
|
+
const { host: r } = this;
|
|
2173
2181
|
await this.hooks.lifecycle.beforePreloadRemote.emit({
|
|
2174
2182
|
preloadOps: t,
|
|
2175
|
-
options:
|
|
2176
|
-
origin:
|
|
2183
|
+
options: r.options,
|
|
2184
|
+
origin: r
|
|
2177
2185
|
});
|
|
2178
|
-
const n = formatPreloadArgs(
|
|
2186
|
+
const n = formatPreloadArgs(r.options.remotes, t);
|
|
2179
2187
|
await Promise.all(n.map(async (s) => {
|
|
2180
|
-
const { remote: l } = s, a = getRemoteInfo(l), { globalSnapshot: i, remoteSnapshot: c } = await
|
|
2181
|
-
origin:
|
|
2188
|
+
const { remote: l } = s, a = getRemoteInfo(l), { globalSnapshot: i, remoteSnapshot: c } = await r.snapshotHandler.loadRemoteSnapshotInfo(l), u = await this.hooks.lifecycle.generatePreloadAssets.emit({
|
|
2189
|
+
origin: r,
|
|
2182
2190
|
preloadOptions: s,
|
|
2183
2191
|
remote: l,
|
|
2184
2192
|
remoteInfo: a,
|
|
2185
2193
|
globalSnapshot: i,
|
|
2186
2194
|
remoteSnapshot: c
|
|
2187
2195
|
});
|
|
2188
|
-
u && preloadAssets(a,
|
|
2196
|
+
u && preloadAssets(a, r, u);
|
|
2189
2197
|
}));
|
|
2190
2198
|
}
|
|
2191
|
-
registerRemotes(t,
|
|
2199
|
+
registerRemotes(t, r) {
|
|
2192
2200
|
const { host: n } = this;
|
|
2193
2201
|
t.forEach((s) => {
|
|
2194
2202
|
this.registerRemote(s, n.options.remotes, {
|
|
2195
|
-
force:
|
|
2203
|
+
force: r == null ? void 0 : r.force
|
|
2196
2204
|
});
|
|
2197
2205
|
});
|
|
2198
2206
|
}
|
|
2199
2207
|
async getRemoteModuleAndOptions(t) {
|
|
2200
|
-
const { host:
|
|
2208
|
+
const { host: r } = this, { id: n } = t;
|
|
2201
2209
|
let s;
|
|
2202
2210
|
try {
|
|
2203
2211
|
s = await this.hooks.lifecycle.beforeRequest.emit({
|
|
2204
2212
|
id: n,
|
|
2205
|
-
options:
|
|
2206
|
-
origin:
|
|
2213
|
+
options: r.options,
|
|
2214
|
+
origin: r
|
|
2207
2215
|
});
|
|
2208
2216
|
} catch (_) {
|
|
2209
2217
|
if (s = await this.hooks.lifecycle.errorLoadRemote.emit({
|
|
2210
2218
|
id: n,
|
|
2211
|
-
options:
|
|
2212
|
-
origin:
|
|
2219
|
+
options: r.options,
|
|
2220
|
+
origin: r,
|
|
2213
2221
|
from: "runtime",
|
|
2214
2222
|
error: _,
|
|
2215
2223
|
lifecycle: "beforeRequest"
|
|
2216
2224
|
}), !s)
|
|
2217
2225
|
throw _;
|
|
2218
2226
|
}
|
|
2219
|
-
const { id: l } = s, a = matchRemoteWithNameAndExpose(
|
|
2227
|
+
const { id: l } = s, a = matchRemoteWithNameAndExpose(r.options.remotes, l);
|
|
2220
2228
|
assert(a, getShortErrorMsg(RUNTIME_004, runtimeDescMap, {
|
|
2221
|
-
hostName:
|
|
2229
|
+
hostName: r.options.name,
|
|
2222
2230
|
requestId: l
|
|
2223
2231
|
}));
|
|
2224
|
-
const { remote: i } = a, c = getRemoteInfo(i), u = await
|
|
2232
|
+
const { remote: i } = a, c = getRemoteInfo(i), u = await r.sharedHandler.hooks.lifecycle.afterResolve.emit(_extends$1({
|
|
2225
2233
|
id: l
|
|
2226
2234
|
}, a, {
|
|
2227
|
-
options:
|
|
2228
|
-
origin:
|
|
2235
|
+
options: r.options,
|
|
2236
|
+
origin: r,
|
|
2229
2237
|
remoteInfo: c
|
|
2230
2238
|
})), { remote: d, expose: p } = u;
|
|
2231
2239
|
assert(d && p, `The 'beforeRequest' hook was executed, but it failed to return the correct 'remote' and 'expose' values while loading ${l}.`);
|
|
2232
|
-
let m =
|
|
2240
|
+
let m = r.moduleCache.get(d.name);
|
|
2233
2241
|
const y = {
|
|
2234
|
-
host:
|
|
2242
|
+
host: r,
|
|
2235
2243
|
remoteInfo: c
|
|
2236
2244
|
};
|
|
2237
|
-
return m || (m = new Module(y),
|
|
2245
|
+
return m || (m = new Module(y), r.moduleCache.set(d.name, m)), {
|
|
2238
2246
|
module: m,
|
|
2239
2247
|
moduleOptions: y,
|
|
2240
2248
|
remoteMatchInfo: u
|
|
2241
2249
|
};
|
|
2242
2250
|
}
|
|
2243
|
-
registerRemote(t,
|
|
2251
|
+
registerRemote(t, r, n) {
|
|
2244
2252
|
const { host: s } = this, l = () => {
|
|
2245
2253
|
if (t.alias) {
|
|
2246
|
-
const i =
|
|
2254
|
+
const i = r.find((c) => {
|
|
2247
2255
|
var u;
|
|
2248
2256
|
return t.alias && (c.name.startsWith(t.alias) || ((u = c.alias) == null ? void 0 : u.startsWith(t.alias)));
|
|
2249
2257
|
});
|
|
@@ -2255,9 +2263,9 @@ class RemoteHandler {
|
|
|
2255
2263
|
remote: t,
|
|
2256
2264
|
origin: s
|
|
2257
2265
|
});
|
|
2258
|
-
const a =
|
|
2266
|
+
const a = r.find((i) => i.name === t.name);
|
|
2259
2267
|
if (!a)
|
|
2260
|
-
l(),
|
|
2268
|
+
l(), r.push(t), this.hooks.lifecycle.registerRemote.emit({
|
|
2261
2269
|
remote: t,
|
|
2262
2270
|
origin: s
|
|
2263
2271
|
});
|
|
@@ -2266,7 +2274,7 @@ class RemoteHandler {
|
|
|
2266
2274
|
`The remote "${t.name}" is already registered.`,
|
|
2267
2275
|
n != null && n.force ? "Hope you have known that OVERRIDE it may have some unexpected errors" : 'If you want to merge the remote, you can set "force: true".'
|
|
2268
2276
|
];
|
|
2269
|
-
n != null && n.force && (this.removeRemote(a), l(),
|
|
2277
|
+
n != null && n.force && (this.removeRemote(a), l(), r.push(t), this.hooks.lifecycle.registerRemote.emit({
|
|
2270
2278
|
remote: t,
|
|
2271
2279
|
origin: s
|
|
2272
2280
|
})), warn$1(i.join(" "));
|
|
@@ -2280,8 +2288,8 @@ class RemoteHandler {
|
|
|
2280
2288
|
if (a) {
|
|
2281
2289
|
const i = a.remoteInfo, c = i.entryGlobalName;
|
|
2282
2290
|
if (CurrentGlobal[c]) {
|
|
2283
|
-
var
|
|
2284
|
-
(
|
|
2291
|
+
var r;
|
|
2292
|
+
(r = Object.getOwnPropertyDescriptor(CurrentGlobal, c)) != null && r.configurable ? delete CurrentGlobal[c] : CurrentGlobal[c] = void 0;
|
|
2285
2293
|
}
|
|
2286
2294
|
const u = getRemoteEntryUniqueKey(a.remoteInfo);
|
|
2287
2295
|
globalLoading[u] && delete globalLoading[u], n.snapshotHandler.manifestCache.delete(i.entry);
|
|
@@ -2299,25 +2307,25 @@ class RemoteHandler {
|
|
|
2299
2307
|
const S = I[v];
|
|
2300
2308
|
S && Object.keys(S).forEach((b) => {
|
|
2301
2309
|
const $ = S[b];
|
|
2302
|
-
$ && Object.keys($).forEach((
|
|
2303
|
-
const O = $[
|
|
2310
|
+
$ && Object.keys($).forEach((w) => {
|
|
2311
|
+
const O = $[w];
|
|
2304
2312
|
O && typeof O == "object" && O.from === i.name && (O.loaded || O.loading ? (O.useIn = O.useIn.filter((T) => T !== i.name), O.useIn.length ? R = !1 : g.push([
|
|
2305
2313
|
E,
|
|
2306
2314
|
v,
|
|
2307
2315
|
b,
|
|
2308
|
-
|
|
2316
|
+
w
|
|
2309
2317
|
])) : g.push([
|
|
2310
2318
|
E,
|
|
2311
2319
|
v,
|
|
2312
2320
|
b,
|
|
2313
|
-
|
|
2321
|
+
w
|
|
2314
2322
|
]));
|
|
2315
2323
|
});
|
|
2316
2324
|
});
|
|
2317
2325
|
});
|
|
2318
2326
|
}), R && (y.shareScopeMap = {}, delete _[d]), g.forEach(([E, I, v, S]) => {
|
|
2319
|
-
var b, $,
|
|
2320
|
-
(
|
|
2327
|
+
var b, $, w;
|
|
2328
|
+
(w = _[E]) == null || ($ = w[I]) == null || (b = $[v]) == null || delete b[S];
|
|
2321
2329
|
}), CurrentGlobal.__FEDERATION__.__INSTANCES__.splice(p, 1);
|
|
2322
2330
|
}
|
|
2323
2331
|
const { hostGlobalSnapshot: m } = getGlobalRemoteInfo(t, n);
|
|
@@ -2350,26 +2358,26 @@ class RemoteHandler {
|
|
|
2350
2358
|
class FederationHost {
|
|
2351
2359
|
initOptions(t) {
|
|
2352
2360
|
this.registerPlugins(t.plugins);
|
|
2353
|
-
const
|
|
2354
|
-
return this.options =
|
|
2361
|
+
const r = this.formatOptions(this.options, t);
|
|
2362
|
+
return this.options = r, r;
|
|
2355
2363
|
}
|
|
2356
|
-
async loadShare(t,
|
|
2357
|
-
return this.sharedHandler.loadShare(t,
|
|
2364
|
+
async loadShare(t, r) {
|
|
2365
|
+
return this.sharedHandler.loadShare(t, r);
|
|
2358
2366
|
}
|
|
2359
2367
|
// The lib function will only be available if the shared set by eager or runtime init is set or the shared is successfully loaded.
|
|
2360
2368
|
// 1. If the loaded shared already exists globally, then it will be reused
|
|
2361
2369
|
// 2. If lib exists in local shared, it will be used directly
|
|
2362
2370
|
// 3. If the local get returns something other than Promise, then it will be used directly
|
|
2363
|
-
loadShareSync(t,
|
|
2364
|
-
return this.sharedHandler.loadShareSync(t,
|
|
2371
|
+
loadShareSync(t, r) {
|
|
2372
|
+
return this.sharedHandler.loadShareSync(t, r);
|
|
2365
2373
|
}
|
|
2366
|
-
initializeSharing(t = DEFAULT_SCOPE,
|
|
2367
|
-
return this.sharedHandler.initializeSharing(t,
|
|
2374
|
+
initializeSharing(t = DEFAULT_SCOPE, r) {
|
|
2375
|
+
return this.sharedHandler.initializeSharing(t, r);
|
|
2368
2376
|
}
|
|
2369
|
-
initRawContainer(t,
|
|
2377
|
+
initRawContainer(t, r, n) {
|
|
2370
2378
|
const s = getRemoteInfo({
|
|
2371
2379
|
name: t,
|
|
2372
|
-
entry:
|
|
2380
|
+
entry: r
|
|
2373
2381
|
}), l = new Module({
|
|
2374
2382
|
host: this,
|
|
2375
2383
|
remoteInfo: s
|
|
@@ -2378,20 +2386,20 @@ class FederationHost {
|
|
|
2378
2386
|
}
|
|
2379
2387
|
// eslint-disable-next-line max-lines-per-function
|
|
2380
2388
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
2381
|
-
async loadRemote(t,
|
|
2382
|
-
return this.remoteHandler.loadRemote(t,
|
|
2389
|
+
async loadRemote(t, r) {
|
|
2390
|
+
return this.remoteHandler.loadRemote(t, r);
|
|
2383
2391
|
}
|
|
2384
2392
|
// eslint-disable-next-line @typescript-eslint/member-ordering
|
|
2385
2393
|
async preloadRemote(t) {
|
|
2386
2394
|
return this.remoteHandler.preloadRemote(t);
|
|
2387
2395
|
}
|
|
2388
|
-
initShareScopeMap(t,
|
|
2389
|
-
this.sharedHandler.initShareScopeMap(t,
|
|
2396
|
+
initShareScopeMap(t, r, n = {}) {
|
|
2397
|
+
this.sharedHandler.initShareScopeMap(t, r, n);
|
|
2390
2398
|
}
|
|
2391
|
-
formatOptions(t,
|
|
2392
|
-
const { shared: n } = formatShareConfigs(t,
|
|
2399
|
+
formatOptions(t, r) {
|
|
2400
|
+
const { shared: n } = formatShareConfigs(t, r), { userOptions: s, options: l } = this.hooks.lifecycle.beforeInit.emit({
|
|
2393
2401
|
origin: this,
|
|
2394
|
-
userOptions:
|
|
2402
|
+
userOptions: r,
|
|
2395
2403
|
options: t,
|
|
2396
2404
|
shareInfo: n
|
|
2397
2405
|
}), a = this.remoteHandler.formatAndRegisterRemote(l, s), { shared: i } = this.sharedHandler.registerShared(l, s), c = [
|
|
@@ -2400,7 +2408,7 @@ class FederationHost {
|
|
|
2400
2408
|
s.plugins && s.plugins.forEach((d) => {
|
|
2401
2409
|
c.includes(d) || c.push(d);
|
|
2402
2410
|
});
|
|
2403
|
-
const u = _extends$1({}, t,
|
|
2411
|
+
const u = _extends$1({}, t, r, {
|
|
2404
2412
|
plugins: c,
|
|
2405
2413
|
remotes: a,
|
|
2406
2414
|
shared: i
|
|
@@ -2411,7 +2419,7 @@ class FederationHost {
|
|
|
2411
2419
|
}), u;
|
|
2412
2420
|
}
|
|
2413
2421
|
registerPlugins(t) {
|
|
2414
|
-
const
|
|
2422
|
+
const r = registerPlugins$1(t, [
|
|
2415
2423
|
this.hooks,
|
|
2416
2424
|
this.remoteHandler.hooks,
|
|
2417
2425
|
this.sharedHandler.hooks,
|
|
@@ -2419,10 +2427,10 @@ class FederationHost {
|
|
|
2419
2427
|
this.loaderHook,
|
|
2420
2428
|
this.bridgeHook
|
|
2421
2429
|
]);
|
|
2422
|
-
this.options.plugins = this.options.plugins.reduce((n, s) => (s && n && !n.find((l) => l.name === s.name) && n.push(s), n),
|
|
2430
|
+
this.options.plugins = this.options.plugins.reduce((n, s) => (s && n && !n.find((l) => l.name === s.name) && n.push(s), n), r || []);
|
|
2423
2431
|
}
|
|
2424
|
-
registerRemotes(t,
|
|
2425
|
-
return this.remoteHandler.registerRemotes(t,
|
|
2432
|
+
registerRemotes(t, r) {
|
|
2433
|
+
return this.remoteHandler.registerRemotes(t, r);
|
|
2426
2434
|
}
|
|
2427
2435
|
constructor(t) {
|
|
2428
2436
|
this.hooks = new PluginSystem({
|
|
@@ -2432,13 +2440,14 @@ class FederationHost {
|
|
|
2432
2440
|
beforeInitContainer: new AsyncWaterfallHook("beforeInitContainer"),
|
|
2433
2441
|
// maybe will change, temporarily for internal use only
|
|
2434
2442
|
initContainer: new AsyncWaterfallHook("initContainer")
|
|
2435
|
-
}), this.version = "0.8.
|
|
2443
|
+
}), this.version = "0.8.1", this.moduleCache = /* @__PURE__ */ new Map(), this.loaderHook = new PluginSystem({
|
|
2436
2444
|
// FIXME: may not be suitable , not open to the public yet
|
|
2437
2445
|
getModuleInfo: new SyncHook(),
|
|
2438
2446
|
createScript: new SyncHook(),
|
|
2439
2447
|
createLink: new SyncHook(),
|
|
2440
2448
|
// only work for manifest , so not open to the public yet
|
|
2441
2449
|
fetch: new AsyncHook(),
|
|
2450
|
+
getRemoteEntryExports: new AsyncHook(),
|
|
2442
2451
|
getModuleFactory: new AsyncHook()
|
|
2443
2452
|
}), this.bridgeHook = new PluginSystem({
|
|
2444
2453
|
beforeBridgeRender: new SyncHook(),
|
|
@@ -2446,7 +2455,7 @@ class FederationHost {
|
|
|
2446
2455
|
beforeBridgeDestroy: new SyncHook(),
|
|
2447
2456
|
afterBridgeDestroy: new SyncHook()
|
|
2448
2457
|
});
|
|
2449
|
-
const
|
|
2458
|
+
const r = {
|
|
2450
2459
|
id: getBuilderId(),
|
|
2451
2460
|
name: t.name,
|
|
2452
2461
|
plugins: [
|
|
@@ -2457,47 +2466,47 @@ class FederationHost {
|
|
|
2457
2466
|
shared: {},
|
|
2458
2467
|
inBrowser: isBrowserEnv()
|
|
2459
2468
|
};
|
|
2460
|
-
this.name = t.name, this.options =
|
|
2461
|
-
...
|
|
2469
|
+
this.name = t.name, this.options = r, this.snapshotHandler = new SnapshotHandler(this), this.sharedHandler = new SharedHandler(this), this.remoteHandler = new RemoteHandler(this), this.shareScopeMap = this.sharedHandler.shareScopeMap, this.registerPlugins([
|
|
2470
|
+
...r.plugins,
|
|
2462
2471
|
...t.plugins || []
|
|
2463
|
-
]), this.options = this.formatOptions(
|
|
2472
|
+
]), this.options = this.formatOptions(r, t);
|
|
2464
2473
|
}
|
|
2465
2474
|
}
|
|
2466
2475
|
setGlobalFederationConstructor(FederationHost);
|
|
2467
|
-
function createBridgeComponent(
|
|
2476
|
+
function createBridgeComponent(o) {
|
|
2468
2477
|
const t = /* @__PURE__ */ new Map();
|
|
2469
2478
|
return () => ({
|
|
2470
|
-
__APP_VERSION__: "0.8.
|
|
2471
|
-
render(
|
|
2472
|
-
LoggerInstance.log("createBridgeComponent render Info",
|
|
2473
|
-
const n = Vue.createApp(
|
|
2474
|
-
t.set(
|
|
2475
|
-
const s = {}, l = s && typeof s == "object" && (s != null && s.extraProps) ? s == null ? void 0 : s.extraProps : {}, a =
|
|
2476
|
-
basename:
|
|
2477
|
-
memoryRoute:
|
|
2479
|
+
__APP_VERSION__: "0.8.1",
|
|
2480
|
+
render(r) {
|
|
2481
|
+
LoggerInstance.log("createBridgeComponent render Info", r);
|
|
2482
|
+
const n = Vue.createApp(o.rootComponent);
|
|
2483
|
+
t.set(r.dom, n);
|
|
2484
|
+
const s = {}, l = s && typeof s == "object" && (s != null && s.extraProps) ? s == null ? void 0 : s.extraProps : {}, a = o.appOptions({
|
|
2485
|
+
basename: r.basename,
|
|
2486
|
+
memoryRoute: r.memoryRoute,
|
|
2478
2487
|
...l
|
|
2479
|
-
}), i =
|
|
2488
|
+
}), i = r.memoryRoute ? VueRouter.createMemoryHistory(r.basename) : VueRouter.createWebHistory(r.basename), c = VueRouter.createRouter({
|
|
2480
2489
|
...a.router.options,
|
|
2481
2490
|
history: i,
|
|
2482
2491
|
routes: a.router.getRoutes()
|
|
2483
2492
|
});
|
|
2484
2493
|
LoggerInstance.log("createBridgeComponent render router info>>>", {
|
|
2485
|
-
name:
|
|
2494
|
+
name: r.moduleName,
|
|
2486
2495
|
router: c
|
|
2487
|
-
}),
|
|
2488
|
-
n.use(c), n.mount(
|
|
2489
|
-
}) : (n.use(c), n.mount(
|
|
2496
|
+
}), r.memoryRoute ? c.push(r.memoryRoute.entryPath).then(() => {
|
|
2497
|
+
n.use(c), n.mount(r.dom);
|
|
2498
|
+
}) : (n.use(c), n.mount(r.dom));
|
|
2490
2499
|
},
|
|
2491
|
-
destroy(
|
|
2492
|
-
LoggerInstance.log("createBridgeComponent destroy Info",
|
|
2493
|
-
const n = t.get(
|
|
2500
|
+
destroy(r) {
|
|
2501
|
+
LoggerInstance.log("createBridgeComponent destroy Info", r);
|
|
2502
|
+
const n = t.get(r == null ? void 0 : r.dom);
|
|
2494
2503
|
n == null || n.unmount();
|
|
2495
2504
|
}
|
|
2496
2505
|
});
|
|
2497
2506
|
}
|
|
2498
2507
|
function e() {
|
|
2499
|
-
const
|
|
2500
|
-
window.dispatchEvent(
|
|
2508
|
+
const o = new PopStateEvent("popstate", { state: window.history.state });
|
|
2509
|
+
window.dispatchEvent(o);
|
|
2501
2510
|
}
|
|
2502
2511
|
const RemoteApp = /* @__PURE__ */ defineComponent({
|
|
2503
2512
|
name: "RemoteApp",
|
|
@@ -2507,16 +2516,16 @@ const RemoteApp = /* @__PURE__ */ defineComponent({
|
|
|
2507
2516
|
memoryRoute: Object,
|
|
2508
2517
|
providerInfo: Function
|
|
2509
2518
|
},
|
|
2510
|
-
setup(
|
|
2511
|
-
const t = ref(null),
|
|
2519
|
+
setup(o) {
|
|
2520
|
+
const t = ref(null), r = ref(null), n = ref(""), s = useRoute(), l = () => {
|
|
2512
2521
|
var d;
|
|
2513
|
-
const i = (d =
|
|
2514
|
-
|
|
2522
|
+
const i = (d = o.providerInfo) == null ? void 0 : d.call(o);
|
|
2523
|
+
r.value = i;
|
|
2515
2524
|
let c = {
|
|
2516
|
-
name:
|
|
2525
|
+
name: o.moduleName,
|
|
2517
2526
|
dom: t.value,
|
|
2518
|
-
basename:
|
|
2519
|
-
memoryRoute:
|
|
2527
|
+
basename: o.basename,
|
|
2528
|
+
memoryRoute: o.memoryRoute
|
|
2520
2529
|
};
|
|
2521
2530
|
LoggerInstance.log("createRemoteComponent LazyComponent render >>>", c), c = {
|
|
2522
2531
|
...c,
|
|
@@ -2524,7 +2533,7 @@ const RemoteApp = /* @__PURE__ */ defineComponent({
|
|
|
2524
2533
|
}, i.render(c);
|
|
2525
2534
|
}, a = watch(() => s.path, (i) => {
|
|
2526
2535
|
i !== s.path && l(), n.value !== "" && n.value !== i && (LoggerInstance.log("createRemoteComponent dispatchPopstateEnv >>>", {
|
|
2527
|
-
...
|
|
2536
|
+
...o,
|
|
2528
2537
|
pathname: s.path
|
|
2529
2538
|
}), e()), n.value = i;
|
|
2530
2539
|
});
|
|
@@ -2533,8 +2542,8 @@ const RemoteApp = /* @__PURE__ */ defineComponent({
|
|
|
2533
2542
|
}), onBeforeUnmount(() => {
|
|
2534
2543
|
var i;
|
|
2535
2544
|
LoggerInstance.log("createRemoteComponent LazyComponent destroy >>>", {
|
|
2536
|
-
...
|
|
2537
|
-
}), a(), (i =
|
|
2545
|
+
...o
|
|
2546
|
+
}), a(), (i = r.value) == null || i.destroy({
|
|
2538
2547
|
dom: t.value
|
|
2539
2548
|
});
|
|
2540
2549
|
}), () => createVNode("div", {
|
|
@@ -2542,33 +2551,33 @@ const RemoteApp = /* @__PURE__ */ defineComponent({
|
|
|
2542
2551
|
}, null);
|
|
2543
2552
|
}
|
|
2544
2553
|
});
|
|
2545
|
-
function createRemoteComponent(
|
|
2554
|
+
function createRemoteComponent(o) {
|
|
2546
2555
|
return defineAsyncComponent({
|
|
2547
|
-
__APP_VERSION__: "0.8.
|
|
2548
|
-
...
|
|
2556
|
+
__APP_VERSION__: "0.8.1",
|
|
2557
|
+
...o.asyncComponentOptions,
|
|
2549
2558
|
//@ts-ignore
|
|
2550
2559
|
loader: async () => {
|
|
2551
2560
|
var c;
|
|
2552
2561
|
const t = useRoute();
|
|
2553
|
-
let
|
|
2562
|
+
let r = "/";
|
|
2554
2563
|
const n = (c = t.matched[0]) == null ? void 0 : c.path;
|
|
2555
|
-
n && (n.endsWith("/:pathMatch(.*)*") ?
|
|
2556
|
-
const s = (
|
|
2564
|
+
n && (n.endsWith("/:pathMatch(.*)*") ? r = n.replace("/:pathMatch(.*)*", "") : r = t.matched[0].path);
|
|
2565
|
+
const s = (o == null ? void 0 : o.export) || "default";
|
|
2557
2566
|
LoggerInstance.log("createRemoteComponent LazyComponent create >>>", {
|
|
2558
|
-
basename:
|
|
2559
|
-
info:
|
|
2567
|
+
basename: r,
|
|
2568
|
+
info: o
|
|
2560
2569
|
});
|
|
2561
|
-
const l = await
|
|
2570
|
+
const l = await o.loader(), a = l && l[Symbol.for("mf_module_id")], i = l[s];
|
|
2562
2571
|
if (LoggerInstance.log(
|
|
2563
2572
|
"createRemoteComponent LazyComponent loadRemote info >>>",
|
|
2564
|
-
{ name: a, module: l, exportName: s, basename:
|
|
2573
|
+
{ name: a, module: l, exportName: s, basename: r, route: t }
|
|
2565
2574
|
), s in l && typeof i == "function")
|
|
2566
2575
|
return {
|
|
2567
2576
|
render() {
|
|
2568
2577
|
return h(RemoteApp, {
|
|
2569
2578
|
moduleName: a,
|
|
2570
2579
|
providerInfo: i,
|
|
2571
|
-
basename:
|
|
2580
|
+
basename: r
|
|
2572
2581
|
});
|
|
2573
2582
|
}
|
|
2574
2583
|
};
|