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