@module-federation/runtime 0.0.0-next-20240310052320 → 0.0.0-next-20240311023539
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/README.md +3 -70
- package/dist/index.cjs.js +26 -83
- package/dist/index.esm.js +28 -84
- package/dist/package.json +1 -1
- package/dist/share.cjs.js +1 -1
- package/dist/share.esm.js +2 -2
- package/dist/src/core.d.ts +0 -5
- package/dist/src/index.d.ts +0 -1
- package/dist/src/utils/load.d.ts +0 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -212,15 +212,15 @@ init({
|
|
|
212
212
|
remotes: [
|
|
213
213
|
{
|
|
214
214
|
name: '@demo/sub1',
|
|
215
|
-
entry: 'http://localhost:2001/
|
|
215
|
+
entry: 'http://localhost:2001/vmok-manifest.json',
|
|
216
216
|
},
|
|
217
217
|
{
|
|
218
218
|
name: '@demo/sub2',
|
|
219
|
-
entry: 'http://localhost:2001/
|
|
219
|
+
entry: 'http://localhost:2001/vmok-manifest.json',
|
|
220
220
|
},
|
|
221
221
|
{
|
|
222
222
|
name: '@demo/sub3',
|
|
223
|
-
entry: 'http://localhost:2001/
|
|
223
|
+
entry: 'http://localhost:2001/vmok-manifest.json',
|
|
224
224
|
},
|
|
225
225
|
],
|
|
226
226
|
});
|
|
@@ -258,73 +258,6 @@ preloadRemote([
|
|
|
258
258
|
]);
|
|
259
259
|
```
|
|
260
260
|
|
|
261
|
-
### registerRemotes
|
|
262
|
-
|
|
263
|
-
- Type: `registerRemotes(remotes: Remote[], options?: { force?: boolean }): void`
|
|
264
|
-
- Used to register remotes after init .
|
|
265
|
-
|
|
266
|
-
- Type
|
|
267
|
-
|
|
268
|
-
```typescript
|
|
269
|
-
function registerRemotes(remotes: Remote[], options?: { force?: boolean }) {}
|
|
270
|
-
|
|
271
|
-
type Remote = (RemoteWithEntry | RemoteWithVersion) & RemoteInfoCommon;
|
|
272
|
-
|
|
273
|
-
interface RemoteInfoCommon {
|
|
274
|
-
alias?: string;
|
|
275
|
-
shareScope?: string;
|
|
276
|
-
type?: RemoteEntryType;
|
|
277
|
-
entryGlobalName?: string;
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
interface RemoteWithEntry {
|
|
281
|
-
name: string;
|
|
282
|
-
entry: string;
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
interface RemoteWithVersion {
|
|
286
|
-
name: string;
|
|
287
|
-
version: string;
|
|
288
|
-
}
|
|
289
|
-
```
|
|
290
|
-
|
|
291
|
-
- Details
|
|
292
|
-
**info**: Please be careful when setting `force:true` !
|
|
293
|
-
|
|
294
|
-
If set `force: true`, it will merge remote(include loaded remote), and remove loaded remote cache , as well as console.warn to tell this action may have risks.
|
|
295
|
-
|
|
296
|
-
* Example
|
|
297
|
-
|
|
298
|
-
```ts
|
|
299
|
-
import { init, registerRemotes } from '@module-federation/runtime';
|
|
300
|
-
|
|
301
|
-
init({
|
|
302
|
-
name: '@demo/register-new-remotes',
|
|
303
|
-
remotes: [
|
|
304
|
-
{
|
|
305
|
-
name: '@demo/sub1',
|
|
306
|
-
entry: 'http://localhost:2001/mf-manifest.json',
|
|
307
|
-
}
|
|
308
|
-
],
|
|
309
|
-
});
|
|
310
|
-
|
|
311
|
-
// add new remote @demo/sub2
|
|
312
|
-
registerRemotes([
|
|
313
|
-
{
|
|
314
|
-
name: '@demo/sub2',
|
|
315
|
-
entry: 'http://localhost:2002/mf-manifest.json',
|
|
316
|
-
}
|
|
317
|
-
]);
|
|
318
|
-
|
|
319
|
-
// override previous remote @demo/sub1
|
|
320
|
-
registerRemotes([
|
|
321
|
-
{
|
|
322
|
-
name: '@demo/sub1',
|
|
323
|
-
entry: 'http://localhost:2003/mf-manifest.json',
|
|
324
|
-
}
|
|
325
|
-
]);
|
|
326
|
-
```
|
|
327
|
-
|
|
328
261
|
## hooks
|
|
329
262
|
|
|
330
263
|
Lifecycle hooks for FederationHost interaction.
|
package/dist/index.cjs.js
CHANGED
|
@@ -160,13 +160,9 @@ async function loadEntryScript({ name, globalName, entry, createScriptHook }) {
|
|
|
160
160
|
return e;
|
|
161
161
|
});
|
|
162
162
|
}
|
|
163
|
-
function getRemoteEntryUniqueKey(remoteInfo) {
|
|
164
|
-
const { entry, name } = remoteInfo;
|
|
165
|
-
return sdk.composeKeyWithSeparator(name, entry);
|
|
166
|
-
}
|
|
167
163
|
async function getRemoteEntry({ remoteEntryExports, remoteInfo, createScriptHook }) {
|
|
168
164
|
const { entry, name, type, entryGlobalName } = remoteInfo;
|
|
169
|
-
const uniqueKey =
|
|
165
|
+
const uniqueKey = sdk.composeKeyWithSeparator(name, entry);
|
|
170
166
|
if (remoteEntryExports) {
|
|
171
167
|
return remoteEntryExports;
|
|
172
168
|
}
|
|
@@ -1482,9 +1478,30 @@ class FederationHost {
|
|
|
1482
1478
|
});
|
|
1483
1479
|
const userRemotes = userOptionsRes.remotes || [];
|
|
1484
1480
|
const remotes = userRemotes.reduce((res, remote)=>{
|
|
1485
|
-
|
|
1486
|
-
|
|
1487
|
-
|
|
1481
|
+
if (!res.find((item)=>item.name === remote.name)) {
|
|
1482
|
+
if (remote.alias) {
|
|
1483
|
+
// Validate if alias equals the prefix of remote.name and remote.alias, if so, throw an error
|
|
1484
|
+
// As multi-level path references cannot guarantee unique names, alias being a prefix of remote.name is not supported
|
|
1485
|
+
const findEqual = res.find((item)=>{
|
|
1486
|
+
var _item_alias;
|
|
1487
|
+
return remote.alias && (item.name.startsWith(remote.alias) || ((_item_alias = item.alias) == null ? void 0 : _item_alias.startsWith(remote.alias)));
|
|
1488
|
+
});
|
|
1489
|
+
share.assert(!findEqual, `The alias ${remote.alias} of remote ${remote.name} is not allowed to be the prefix of ${findEqual && findEqual.name} name or alias`);
|
|
1490
|
+
}
|
|
1491
|
+
// Set the remote entry to a complete path
|
|
1492
|
+
if ('entry' in remote) {
|
|
1493
|
+
if (share.isBrowserEnv() && !remote.entry.startsWith('http')) {
|
|
1494
|
+
remote.entry = new URL(remote.entry, window.location.origin).href;
|
|
1495
|
+
}
|
|
1496
|
+
}
|
|
1497
|
+
if (!remote.shareScope) {
|
|
1498
|
+
remote.shareScope = share.DEFAULT_SCOPE;
|
|
1499
|
+
}
|
|
1500
|
+
if (!remote.type) {
|
|
1501
|
+
remote.type = share.DEFAULT_REMOTE_TYPE;
|
|
1502
|
+
}
|
|
1503
|
+
res.push(remote);
|
|
1504
|
+
}
|
|
1488
1505
|
return res;
|
|
1489
1506
|
}, globalOptionsRes.remotes);
|
|
1490
1507
|
// register shared in shareScopeMap
|
|
@@ -1564,74 +1581,6 @@ class FederationHost {
|
|
|
1564
1581
|
}
|
|
1565
1582
|
});
|
|
1566
1583
|
}
|
|
1567
|
-
removeRemote(remote) {
|
|
1568
|
-
const { name } = remote;
|
|
1569
|
-
const remoteIndex = this.options.remotes.findIndex((item)=>item.name === name);
|
|
1570
|
-
if (remoteIndex !== -1) {
|
|
1571
|
-
this.options.remotes.splice(remoteIndex, 1);
|
|
1572
|
-
}
|
|
1573
|
-
const loadedModule = this.moduleCache.get(remote.name);
|
|
1574
|
-
if (loadedModule) {
|
|
1575
|
-
const key = loadedModule.remoteInfo.entryGlobalName;
|
|
1576
|
-
if (globalThis[key]) {
|
|
1577
|
-
delete globalThis[key];
|
|
1578
|
-
}
|
|
1579
|
-
const remoteEntryUniqueKey = getRemoteEntryUniqueKey(loadedModule.remoteInfo);
|
|
1580
|
-
if (share.globalLoading[remoteEntryUniqueKey]) {
|
|
1581
|
-
delete share.globalLoading[remoteEntryUniqueKey];
|
|
1582
|
-
}
|
|
1583
|
-
this.moduleCache.delete(remote.name);
|
|
1584
|
-
}
|
|
1585
|
-
}
|
|
1586
|
-
registerRemote(remote, targetRemotes, options) {
|
|
1587
|
-
const normalizeRemote = ()=>{
|
|
1588
|
-
if (remote.alias) {
|
|
1589
|
-
// Validate if alias equals the prefix of remote.name and remote.alias, if so, throw an error
|
|
1590
|
-
// As multi-level path references cannot guarantee unique names, alias being a prefix of remote.name is not supported
|
|
1591
|
-
const findEqual = targetRemotes.find((item)=>{
|
|
1592
|
-
var _item_alias;
|
|
1593
|
-
return remote.alias && (item.name.startsWith(remote.alias) || ((_item_alias = item.alias) == null ? void 0 : _item_alias.startsWith(remote.alias)));
|
|
1594
|
-
});
|
|
1595
|
-
share.assert(!findEqual, `The alias ${remote.alias} of remote ${remote.name} is not allowed to be the prefix of ${findEqual && findEqual.name} name or alias`);
|
|
1596
|
-
}
|
|
1597
|
-
// Set the remote entry to a complete path
|
|
1598
|
-
if ('entry' in remote) {
|
|
1599
|
-
if (share.isBrowserEnv() && !remote.entry.startsWith('http')) {
|
|
1600
|
-
remote.entry = new URL(remote.entry, window.location.origin).href;
|
|
1601
|
-
}
|
|
1602
|
-
}
|
|
1603
|
-
if (!remote.shareScope) {
|
|
1604
|
-
remote.shareScope = share.DEFAULT_SCOPE;
|
|
1605
|
-
}
|
|
1606
|
-
if (!remote.type) {
|
|
1607
|
-
remote.type = share.DEFAULT_REMOTE_TYPE;
|
|
1608
|
-
}
|
|
1609
|
-
};
|
|
1610
|
-
const registeredRemote = targetRemotes.find((item)=>item.name === remote.name);
|
|
1611
|
-
if (!registeredRemote) {
|
|
1612
|
-
normalizeRemote();
|
|
1613
|
-
targetRemotes.push(remote);
|
|
1614
|
-
} else {
|
|
1615
|
-
const messages = [
|
|
1616
|
-
`The remote "${remote.name}" is already registered.`,
|
|
1617
|
-
(options == null ? void 0 : options.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".'
|
|
1618
|
-
];
|
|
1619
|
-
if (options == null ? void 0 : options.force) {
|
|
1620
|
-
// remove registered remote
|
|
1621
|
-
this.removeRemote(registeredRemote);
|
|
1622
|
-
normalizeRemote();
|
|
1623
|
-
targetRemotes.push(remote);
|
|
1624
|
-
}
|
|
1625
|
-
share.warn(messages.join(' '));
|
|
1626
|
-
}
|
|
1627
|
-
}
|
|
1628
|
-
registerRemotes(remotes, options) {
|
|
1629
|
-
remotes.forEach((remote)=>{
|
|
1630
|
-
this.registerRemote(remote, this.options.remotes, {
|
|
1631
|
-
force: options == null ? void 0 : options.force
|
|
1632
|
-
});
|
|
1633
|
-
});
|
|
1634
|
-
}
|
|
1635
1584
|
constructor(userOptions){
|
|
1636
1585
|
this.hooks = new PluginSystem({
|
|
1637
1586
|
beforeInit: new SyncWaterfallHook('beforeInit'),
|
|
@@ -1656,7 +1605,7 @@ class FederationHost {
|
|
|
1656
1605
|
// not used yet
|
|
1657
1606
|
afterPreloadRemote: new AsyncHook()
|
|
1658
1607
|
});
|
|
1659
|
-
this.version = "0.0.
|
|
1608
|
+
this.version = "0.0.15";
|
|
1660
1609
|
this.moduleCache = new Map();
|
|
1661
1610
|
this.loaderHook = new PluginSystem({
|
|
1662
1611
|
// FIXME: may not be suitable , not open to the public yet
|
|
@@ -1731,11 +1680,6 @@ function preloadRemote(...args) {
|
|
|
1731
1680
|
// eslint-disable-next-line prefer-spread
|
|
1732
1681
|
return FederationInstance.preloadRemote.apply(FederationInstance, args);
|
|
1733
1682
|
}
|
|
1734
|
-
function registerRemotes(...args) {
|
|
1735
|
-
share.assert(FederationInstance, 'Please call init first');
|
|
1736
|
-
// eslint-disable-next-line prefer-spread
|
|
1737
|
-
return FederationInstance.registerRemotes.apply(FederationInstance, args);
|
|
1738
|
-
}
|
|
1739
1683
|
// Inject for debug
|
|
1740
1684
|
share.setGlobalFederationConstructor(FederationHost);
|
|
1741
1685
|
|
|
@@ -1754,4 +1698,3 @@ exports.loadRemote = loadRemote;
|
|
|
1754
1698
|
exports.loadShare = loadShare;
|
|
1755
1699
|
exports.loadShareSync = loadShareSync;
|
|
1756
1700
|
exports.preloadRemote = preloadRemote;
|
|
1757
|
-
exports.registerRemotes = registerRemotes;
|
package/dist/index.esm.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { g as getGlobalHostPlugins, D as DEFAULT_REMOTE_TYPE, a as DEFAULT_SCOPE, b as globalLoading, c as getRemoteEntryExports, d as assert, s as safeToString, e as getFMId, i as isObject, f as error, w as warn, h as isPlainObject, j as isRemoteInfoWithEntry, k as isPureRemoteEntry, l as getRegisteredShare, m as getInfoWithoutType, n as getPreloaded, o as setPreloaded, p as getGlobalSnapshotInfoByModuleInfo, q as addGlobalSnapshot, r as setGlobalSnapshotInfoByModuleInfo, t as getGlobalSnapshot, G as Global, u as getGlobalShareScope, v as formatShareConfigs, x as
|
|
1
|
+
import { g as getGlobalHostPlugins, D as DEFAULT_REMOTE_TYPE, a as DEFAULT_SCOPE, b as globalLoading, c as getRemoteEntryExports, d as assert, s as safeToString, e as getFMId, i as isObject, f as error, w as warn, h as isPlainObject, j as isRemoteInfoWithEntry, k as isPureRemoteEntry, l as getRegisteredShare, m as getInfoWithoutType, n as getPreloaded, o as setPreloaded, p as getGlobalSnapshotInfoByModuleInfo, q as addGlobalSnapshot, r as setGlobalSnapshotInfoByModuleInfo, t as getGlobalSnapshot, G as Global, u as getGlobalShareScope, v as formatShareConfigs, x as isBrowserEnv, y as getBuilderId, z as addUniqueItem, A as setGlobalFederationConstructor, B as getGlobalFederationInstance, C as getGlobalFederationConstructor, E as setGlobalFederationInstance } from './share.esm.js';
|
|
2
2
|
export { F as registerGlobalPlugins } from './share.esm.js';
|
|
3
3
|
import { composeKeyWithSeparator, loadScriptNode, loadScript, createLink, getResourceUrl, isManifestProvider, generateSnapshotFromManifest } from '@module-federation/sdk';
|
|
4
4
|
export { loadScript, loadScriptNode } from '@module-federation/sdk';
|
|
@@ -158,13 +158,9 @@ async function loadEntryScript({ name, globalName, entry, createScriptHook }) {
|
|
|
158
158
|
return e;
|
|
159
159
|
});
|
|
160
160
|
}
|
|
161
|
-
function getRemoteEntryUniqueKey(remoteInfo) {
|
|
162
|
-
const { entry, name } = remoteInfo;
|
|
163
|
-
return composeKeyWithSeparator(name, entry);
|
|
164
|
-
}
|
|
165
161
|
async function getRemoteEntry({ remoteEntryExports, remoteInfo, createScriptHook }) {
|
|
166
162
|
const { entry, name, type, entryGlobalName } = remoteInfo;
|
|
167
|
-
const uniqueKey =
|
|
163
|
+
const uniqueKey = composeKeyWithSeparator(name, entry);
|
|
168
164
|
if (remoteEntryExports) {
|
|
169
165
|
return remoteEntryExports;
|
|
170
166
|
}
|
|
@@ -1480,9 +1476,30 @@ class FederationHost {
|
|
|
1480
1476
|
});
|
|
1481
1477
|
const userRemotes = userOptionsRes.remotes || [];
|
|
1482
1478
|
const remotes = userRemotes.reduce((res, remote)=>{
|
|
1483
|
-
|
|
1484
|
-
|
|
1485
|
-
|
|
1479
|
+
if (!res.find((item)=>item.name === remote.name)) {
|
|
1480
|
+
if (remote.alias) {
|
|
1481
|
+
// Validate if alias equals the prefix of remote.name and remote.alias, if so, throw an error
|
|
1482
|
+
// As multi-level path references cannot guarantee unique names, alias being a prefix of remote.name is not supported
|
|
1483
|
+
const findEqual = res.find((item)=>{
|
|
1484
|
+
var _item_alias;
|
|
1485
|
+
return remote.alias && (item.name.startsWith(remote.alias) || ((_item_alias = item.alias) == null ? void 0 : _item_alias.startsWith(remote.alias)));
|
|
1486
|
+
});
|
|
1487
|
+
assert(!findEqual, `The alias ${remote.alias} of remote ${remote.name} is not allowed to be the prefix of ${findEqual && findEqual.name} name or alias`);
|
|
1488
|
+
}
|
|
1489
|
+
// Set the remote entry to a complete path
|
|
1490
|
+
if ('entry' in remote) {
|
|
1491
|
+
if (isBrowserEnv() && !remote.entry.startsWith('http')) {
|
|
1492
|
+
remote.entry = new URL(remote.entry, window.location.origin).href;
|
|
1493
|
+
}
|
|
1494
|
+
}
|
|
1495
|
+
if (!remote.shareScope) {
|
|
1496
|
+
remote.shareScope = DEFAULT_SCOPE;
|
|
1497
|
+
}
|
|
1498
|
+
if (!remote.type) {
|
|
1499
|
+
remote.type = DEFAULT_REMOTE_TYPE;
|
|
1500
|
+
}
|
|
1501
|
+
res.push(remote);
|
|
1502
|
+
}
|
|
1486
1503
|
return res;
|
|
1487
1504
|
}, globalOptionsRes.remotes);
|
|
1488
1505
|
// register shared in shareScopeMap
|
|
@@ -1562,74 +1579,6 @@ class FederationHost {
|
|
|
1562
1579
|
}
|
|
1563
1580
|
});
|
|
1564
1581
|
}
|
|
1565
|
-
removeRemote(remote) {
|
|
1566
|
-
const { name } = remote;
|
|
1567
|
-
const remoteIndex = this.options.remotes.findIndex((item)=>item.name === name);
|
|
1568
|
-
if (remoteIndex !== -1) {
|
|
1569
|
-
this.options.remotes.splice(remoteIndex, 1);
|
|
1570
|
-
}
|
|
1571
|
-
const loadedModule = this.moduleCache.get(remote.name);
|
|
1572
|
-
if (loadedModule) {
|
|
1573
|
-
const key = loadedModule.remoteInfo.entryGlobalName;
|
|
1574
|
-
if (globalThis[key]) {
|
|
1575
|
-
delete globalThis[key];
|
|
1576
|
-
}
|
|
1577
|
-
const remoteEntryUniqueKey = getRemoteEntryUniqueKey(loadedModule.remoteInfo);
|
|
1578
|
-
if (globalLoading[remoteEntryUniqueKey]) {
|
|
1579
|
-
delete globalLoading[remoteEntryUniqueKey];
|
|
1580
|
-
}
|
|
1581
|
-
this.moduleCache.delete(remote.name);
|
|
1582
|
-
}
|
|
1583
|
-
}
|
|
1584
|
-
registerRemote(remote, targetRemotes, options) {
|
|
1585
|
-
const normalizeRemote = ()=>{
|
|
1586
|
-
if (remote.alias) {
|
|
1587
|
-
// Validate if alias equals the prefix of remote.name and remote.alias, if so, throw an error
|
|
1588
|
-
// As multi-level path references cannot guarantee unique names, alias being a prefix of remote.name is not supported
|
|
1589
|
-
const findEqual = targetRemotes.find((item)=>{
|
|
1590
|
-
var _item_alias;
|
|
1591
|
-
return remote.alias && (item.name.startsWith(remote.alias) || ((_item_alias = item.alias) == null ? void 0 : _item_alias.startsWith(remote.alias)));
|
|
1592
|
-
});
|
|
1593
|
-
assert(!findEqual, `The alias ${remote.alias} of remote ${remote.name} is not allowed to be the prefix of ${findEqual && findEqual.name} name or alias`);
|
|
1594
|
-
}
|
|
1595
|
-
// Set the remote entry to a complete path
|
|
1596
|
-
if ('entry' in remote) {
|
|
1597
|
-
if (isBrowserEnv() && !remote.entry.startsWith('http')) {
|
|
1598
|
-
remote.entry = new URL(remote.entry, window.location.origin).href;
|
|
1599
|
-
}
|
|
1600
|
-
}
|
|
1601
|
-
if (!remote.shareScope) {
|
|
1602
|
-
remote.shareScope = DEFAULT_SCOPE;
|
|
1603
|
-
}
|
|
1604
|
-
if (!remote.type) {
|
|
1605
|
-
remote.type = DEFAULT_REMOTE_TYPE;
|
|
1606
|
-
}
|
|
1607
|
-
};
|
|
1608
|
-
const registeredRemote = targetRemotes.find((item)=>item.name === remote.name);
|
|
1609
|
-
if (!registeredRemote) {
|
|
1610
|
-
normalizeRemote();
|
|
1611
|
-
targetRemotes.push(remote);
|
|
1612
|
-
} else {
|
|
1613
|
-
const messages = [
|
|
1614
|
-
`The remote "${remote.name}" is already registered.`,
|
|
1615
|
-
(options == null ? void 0 : options.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".'
|
|
1616
|
-
];
|
|
1617
|
-
if (options == null ? void 0 : options.force) {
|
|
1618
|
-
// remove registered remote
|
|
1619
|
-
this.removeRemote(registeredRemote);
|
|
1620
|
-
normalizeRemote();
|
|
1621
|
-
targetRemotes.push(remote);
|
|
1622
|
-
}
|
|
1623
|
-
warn(messages.join(' '));
|
|
1624
|
-
}
|
|
1625
|
-
}
|
|
1626
|
-
registerRemotes(remotes, options) {
|
|
1627
|
-
remotes.forEach((remote)=>{
|
|
1628
|
-
this.registerRemote(remote, this.options.remotes, {
|
|
1629
|
-
force: options == null ? void 0 : options.force
|
|
1630
|
-
});
|
|
1631
|
-
});
|
|
1632
|
-
}
|
|
1633
1582
|
constructor(userOptions){
|
|
1634
1583
|
this.hooks = new PluginSystem({
|
|
1635
1584
|
beforeInit: new SyncWaterfallHook('beforeInit'),
|
|
@@ -1654,7 +1603,7 @@ class FederationHost {
|
|
|
1654
1603
|
// not used yet
|
|
1655
1604
|
afterPreloadRemote: new AsyncHook()
|
|
1656
1605
|
});
|
|
1657
|
-
this.version = "0.0.
|
|
1606
|
+
this.version = "0.0.15";
|
|
1658
1607
|
this.moduleCache = new Map();
|
|
1659
1608
|
this.loaderHook = new PluginSystem({
|
|
1660
1609
|
// FIXME: may not be suitable , not open to the public yet
|
|
@@ -1729,12 +1678,7 @@ function preloadRemote(...args) {
|
|
|
1729
1678
|
// eslint-disable-next-line prefer-spread
|
|
1730
1679
|
return FederationInstance.preloadRemote.apply(FederationInstance, args);
|
|
1731
1680
|
}
|
|
1732
|
-
function registerRemotes(...args) {
|
|
1733
|
-
assert(FederationInstance, 'Please call init first');
|
|
1734
|
-
// eslint-disable-next-line prefer-spread
|
|
1735
|
-
return FederationInstance.registerRemotes.apply(FederationInstance, args);
|
|
1736
|
-
}
|
|
1737
1681
|
// Inject for debug
|
|
1738
1682
|
setGlobalFederationConstructor(FederationHost);
|
|
1739
1683
|
|
|
1740
|
-
export { FederationHost, init, loadRemote, loadShare, loadShareSync, preloadRemote
|
|
1684
|
+
export { FederationHost, init, loadRemote, loadShare, loadShareSync, preloadRemote };
|
package/dist/package.json
CHANGED
package/dist/share.cjs.js
CHANGED
|
@@ -185,7 +185,7 @@ function getGlobalFederationConstructor() {
|
|
|
185
185
|
function setGlobalFederationConstructor(FederationConstructor, isDebug = isDebugMode()) {
|
|
186
186
|
if (isDebug) {
|
|
187
187
|
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR__ = FederationConstructor;
|
|
188
|
-
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR_VERSION__ = "0.0.
|
|
188
|
+
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR_VERSION__ = "0.0.15";
|
|
189
189
|
}
|
|
190
190
|
}
|
|
191
191
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
package/dist/share.esm.js
CHANGED
|
@@ -183,7 +183,7 @@ function getGlobalFederationConstructor() {
|
|
|
183
183
|
function setGlobalFederationConstructor(FederationConstructor, isDebug = isDebugMode()) {
|
|
184
184
|
if (isDebug) {
|
|
185
185
|
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR__ = FederationConstructor;
|
|
186
|
-
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR_VERSION__ = "0.0.
|
|
186
|
+
globalThis.__FEDERATION__.__DEBUG_CONSTRUCTOR_VERSION__ = "0.0.15";
|
|
187
187
|
}
|
|
188
188
|
}
|
|
189
189
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
@@ -803,4 +803,4 @@ function getGlobalShareScope() {
|
|
|
803
803
|
return Global.__FEDERATION__.__SHARE__;
|
|
804
804
|
}
|
|
805
805
|
|
|
806
|
-
export { setGlobalFederationConstructor as A, getGlobalFederationInstance as B, getGlobalFederationConstructor as C, DEFAULT_REMOTE_TYPE as D, setGlobalFederationInstance as E, registerGlobalPlugins as F, Global as G, nativeGlobal as H, resetFederationGlobalInfo as I, getTargetSnapshotInfoByModuleInfo as J, DEFAULT_SCOPE as a, globalLoading as b, getRemoteEntryExports as c, assert as d, getFMId as e, error as f, getGlobalHostPlugins as g, isPlainObject as h, isObject as i, isRemoteInfoWithEntry as j, isPureRemoteEntry as k, getRegisteredShare as l, getInfoWithoutType as m, getPreloaded as n, setPreloaded as o, getGlobalSnapshotInfoByModuleInfo as p, addGlobalSnapshot as q, setGlobalSnapshotInfoByModuleInfo as r, safeToString as s, getGlobalSnapshot as t, getGlobalShareScope as u, formatShareConfigs as v, warn as w,
|
|
806
|
+
export { setGlobalFederationConstructor as A, getGlobalFederationInstance as B, getGlobalFederationConstructor as C, DEFAULT_REMOTE_TYPE as D, setGlobalFederationInstance as E, registerGlobalPlugins as F, Global as G, nativeGlobal as H, resetFederationGlobalInfo as I, getTargetSnapshotInfoByModuleInfo as J, DEFAULT_SCOPE as a, globalLoading as b, getRemoteEntryExports as c, assert as d, getFMId as e, error as f, getGlobalHostPlugins as g, isPlainObject as h, isObject as i, isRemoteInfoWithEntry as j, isPureRemoteEntry as k, getRegisteredShare as l, getInfoWithoutType as m, getPreloaded as n, setPreloaded as o, getGlobalSnapshotInfoByModuleInfo as p, addGlobalSnapshot as q, setGlobalSnapshotInfoByModuleInfo as r, safeToString as s, getGlobalSnapshot as t, getGlobalShareScope as u, formatShareConfigs as v, warn as w, isBrowserEnv as x, getBuilderId as y, addUniqueItem as z };
|
package/dist/src/core.d.ts
CHANGED
|
@@ -153,10 +153,5 @@ export declare class FederationHost {
|
|
|
153
153
|
private formatOptions;
|
|
154
154
|
private registerPlugins;
|
|
155
155
|
private setShared;
|
|
156
|
-
private removeRemote;
|
|
157
|
-
private registerRemote;
|
|
158
|
-
registerRemotes(remotes: Remote[], options?: {
|
|
159
|
-
force?: boolean;
|
|
160
|
-
}): void;
|
|
161
156
|
}
|
|
162
157
|
export {};
|
package/dist/src/index.d.ts
CHANGED
|
@@ -10,4 +10,3 @@ export declare function loadRemote(...args: Parameters<FederationHost['loadRemot
|
|
|
10
10
|
export declare function loadShare(...args: Parameters<FederationHost['loadShare']>): ReturnType<FederationHost['loadShare']>;
|
|
11
11
|
export declare function loadShareSync(...args: Parameters<FederationHost['loadShareSync']>): ReturnType<FederationHost['loadShareSync']>;
|
|
12
12
|
export declare function preloadRemote(...args: Parameters<FederationHost['preloadRemote']>): ReturnType<FederationHost['preloadRemote']>;
|
|
13
|
-
export declare function registerRemotes(...args: Parameters<FederationHost['registerRemotes']>): ReturnType<FederationHost['registerRemotes']>;
|
package/dist/src/utils/load.d.ts
CHANGED
|
@@ -9,7 +9,6 @@ export declare function loadEntryScript({ name, globalName, entry, createScriptH
|
|
|
9
9
|
entry: string;
|
|
10
10
|
createScriptHook?: (url: string) => HTMLScriptElement | void;
|
|
11
11
|
}): Promise<RemoteEntryExports>;
|
|
12
|
-
export declare function getRemoteEntryUniqueKey(remoteInfo: RemoteInfo): string;
|
|
13
12
|
export declare function getRemoteEntry({ remoteEntryExports, remoteInfo, createScriptHook, }: {
|
|
14
13
|
remoteInfo: RemoteInfo;
|
|
15
14
|
remoteEntryExports?: RemoteEntryExports | undefined;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@module-federation/runtime",
|
|
3
|
-
"version": "0.0.0-next-
|
|
3
|
+
"version": "0.0.0-next-20240311023539",
|
|
4
4
|
"author": "zhouxiao <codingzx@gmail.com>",
|
|
5
5
|
"main": "./dist/index.cjs",
|
|
6
6
|
"module": "./dist/index.esm.js",
|
|
@@ -45,6 +45,6 @@
|
|
|
45
45
|
}
|
|
46
46
|
},
|
|
47
47
|
"dependencies": {
|
|
48
|
-
"@module-federation/sdk": "0.0.0-next-
|
|
48
|
+
"@module-federation/sdk": "0.0.0-next-20240311023539"
|
|
49
49
|
}
|
|
50
50
|
}
|