@bleedingdev/modern-js-runtime 3.2.0-ultramodern.1 → 3.2.0-ultramodern.100
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/boundary-debugger/index.js +299 -0
- package/dist/cjs/cli/ssr/index.js +5 -15
- package/dist/cjs/cli/template.server.js +1 -0
- package/dist/cjs/core/context/serverPayload/index.js +1 -1
- package/dist/cjs/core/plugin/index.js +3 -2
- package/dist/cjs/core/react/wrapper.js +9 -3
- package/dist/cjs/core/server/federatedCss.js +47 -0
- package/dist/cjs/core/server/helmet.js +8 -2
- package/dist/cjs/core/server/scriptOrder.js +59 -0
- package/dist/cjs/core/server/stream/afterTemplate.js +13 -5
- package/dist/cjs/core/server/stream/beforeTemplate.js +13 -20
- package/dist/cjs/core/server/stream/beforeTemplate.worker.js +98 -0
- package/dist/cjs/core/server/stream/createReadableStream.js +7 -2
- package/dist/cjs/core/server/stream/createReadableStream.worker.js +4 -2
- package/dist/cjs/core/server/stream/shared.js +3 -1
- package/dist/cjs/core/server/string/index.js +16 -9
- package/dist/cjs/core/server/string/loadable.js +74 -10
- package/dist/cjs/exports/head.js +196 -5
- package/dist/cjs/exports/loadable.js +34 -4
- package/dist/cjs/exports/tanstack-router.js +311 -54
- package/dist/cjs/router/cli/code/tanstackTypes.js +116 -51
- package/dist/cjs/router/cli/code/templates.js +15 -9
- package/dist/cjs/router/runtime/tanstack/hydrationBoundary.js +44 -0
- package/dist/cjs/router/runtime/tanstack/outlet.js +54 -0
- package/dist/cjs/router/runtime/tanstack/plugin.js +190 -88
- package/dist/cjs/router/runtime/tanstack/plugin.node.js +4 -14
- package/dist/cjs/router/runtime/tanstack/routeTree.js +64 -12
- package/dist/cjs/rsc/server.worker.js +58 -0
- package/dist/cjs/ssr/serverRender/renderToString/entry.js +9 -8
- package/dist/esm/boundary-debugger/index.mjs +263 -0
- package/dist/esm/cli/ssr/index.mjs +5 -15
- package/dist/esm/cli/template.server.mjs +1 -0
- package/dist/esm/core/context/serverPayload/index.mjs +1 -1
- package/dist/esm/core/plugin/index.mjs +3 -2
- package/dist/esm/core/react/wrapper.mjs +9 -3
- package/dist/esm/core/server/federatedCss.mjs +13 -0
- package/dist/esm/core/server/helmet.mjs +5 -2
- package/dist/esm/core/server/scriptOrder.mjs +25 -0
- package/dist/esm/core/server/stream/afterTemplate.mjs +14 -6
- package/dist/esm/core/server/stream/beforeTemplate.mjs +14 -11
- package/dist/esm/core/server/stream/beforeTemplate.worker.mjs +64 -0
- package/dist/esm/core/server/stream/createReadableStream.mjs +7 -2
- package/dist/esm/core/server/stream/createReadableStream.worker.mjs +4 -2
- package/dist/esm/core/server/stream/shared.mjs +3 -1
- package/dist/esm/core/server/string/index.mjs +17 -9
- package/dist/esm/core/server/string/loadable.mjs +70 -9
- package/dist/esm/exports/head.mjs +189 -4
- package/dist/esm/exports/loadable.mjs +20 -3
- package/dist/esm/exports/tanstack-router.mjs +2 -1
- package/dist/esm/router/cli/code/tanstackTypes.mjs +116 -51
- package/dist/esm/router/cli/code/templates.mjs +15 -9
- package/dist/esm/router/runtime/tanstack/hydrationBoundary.mjs +10 -0
- package/dist/esm/router/runtime/tanstack/outlet.mjs +17 -0
- package/dist/esm/router/runtime/tanstack/plugin.mjs +193 -91
- package/dist/esm/router/runtime/tanstack/plugin.node.mjs +5 -15
- package/dist/esm/router/runtime/tanstack/routeTree.mjs +65 -13
- package/dist/esm/rsc/server.worker.mjs +1 -0
- package/dist/esm/ssr/serverRender/renderToString/entry.mjs +9 -6
- package/dist/esm-node/boundary-debugger/index.mjs +264 -0
- package/dist/esm-node/cli/ssr/index.mjs +5 -15
- package/dist/esm-node/cli/template.server.mjs +1 -0
- package/dist/esm-node/core/context/serverPayload/index.mjs +1 -1
- package/dist/esm-node/core/plugin/index.mjs +3 -2
- package/dist/esm-node/core/react/wrapper.mjs +9 -3
- package/dist/esm-node/core/server/federatedCss.mjs +14 -0
- package/dist/esm-node/core/server/helmet.mjs +5 -2
- package/dist/esm-node/core/server/scriptOrder.mjs +26 -0
- package/dist/esm-node/core/server/stream/afterTemplate.mjs +14 -6
- package/dist/esm-node/core/server/stream/beforeTemplate.mjs +14 -11
- package/dist/esm-node/core/server/stream/beforeTemplate.worker.mjs +65 -0
- package/dist/esm-node/core/server/stream/createReadableStream.mjs +7 -2
- package/dist/esm-node/core/server/stream/createReadableStream.worker.mjs +4 -2
- package/dist/esm-node/core/server/stream/shared.mjs +3 -1
- package/dist/esm-node/core/server/string/index.mjs +17 -9
- package/dist/esm-node/core/server/string/loadable.mjs +70 -9
- package/dist/esm-node/exports/head.mjs +189 -4
- package/dist/esm-node/exports/loadable.mjs +20 -3
- package/dist/esm-node/exports/tanstack-router.mjs +2 -1
- package/dist/esm-node/router/cli/code/tanstackTypes.mjs +116 -51
- package/dist/esm-node/router/cli/code/templates.mjs +15 -9
- package/dist/esm-node/router/runtime/tanstack/hydrationBoundary.mjs +11 -0
- package/dist/esm-node/router/runtime/tanstack/outlet.mjs +18 -0
- package/dist/esm-node/router/runtime/tanstack/plugin.mjs +193 -91
- package/dist/esm-node/router/runtime/tanstack/plugin.node.mjs +5 -15
- package/dist/esm-node/router/runtime/tanstack/routeTree.mjs +65 -13
- package/dist/esm-node/rsc/server.worker.mjs +2 -0
- package/dist/esm-node/ssr/serverRender/renderToString/entry.mjs +9 -6
- package/dist/types/boundary-debugger/index.d.ts +28 -0
- package/dist/types/cache/index.d.ts +1 -0
- package/dist/types/cli/alias.d.ts +7 -0
- package/dist/types/cli/code.d.ts +3 -0
- package/dist/types/cli/constants.d.ts +9 -0
- package/dist/types/cli/entry.d.ts +2 -0
- package/dist/types/cli/index.d.ts +11 -0
- package/dist/types/cli/ssr/index.d.ts +6 -0
- package/dist/types/cli/ssr/loadable-bundler-plugin.d.ts +31 -0
- package/dist/types/cli/ssr/mode.d.ts +15 -0
- package/dist/types/cli/template.d.ts +50 -0
- package/dist/types/cli/template.server.d.ts +20 -0
- package/dist/types/common.d.ts +8 -0
- package/dist/types/core/browser/hydrate.d.ts +5 -0
- package/dist/types/core/browser/index.d.ts +9 -0
- package/dist/types/core/browser/withCallback.d.ts +5 -0
- package/dist/types/core/compat/hooks.d.ts +4 -0
- package/dist/types/core/compat/index.d.ts +2 -0
- package/dist/types/core/compat/requestContext.d.ts +5 -0
- package/dist/types/core/config.d.ts +6 -0
- package/dist/types/core/constants.d.ts +6 -0
- package/dist/types/core/context/index.d.ts +50 -0
- package/dist/types/core/context/monitors/default.d.ts +2 -0
- package/dist/types/core/context/monitors/index.d.ts +1 -0
- package/dist/types/core/context/monitors/index.server.d.ts +2 -0
- package/dist/types/core/context/request/index.d.ts +1 -0
- package/dist/types/core/context/request/index.server.d.ts +1 -0
- package/dist/types/core/context/response/index.d.ts +4 -0
- package/dist/types/core/context/response/index.server.d.ts +4 -0
- package/dist/types/core/context/runtime.d.ts +46 -0
- package/dist/types/core/context/serverPayload/index.d.ts +4 -0
- package/dist/types/core/context/serverPayload/index.server.d.ts +31 -0
- package/dist/types/core/index.d.ts +5 -0
- package/dist/types/core/plugin/index.d.ts +5 -0
- package/dist/types/core/plugin/types.d.ts +10 -0
- package/dist/types/core/react/index.d.ts +2 -0
- package/dist/types/core/react/wrapper.d.ts +3 -0
- package/dist/types/core/server/constants.d.ts +4 -0
- package/dist/types/core/server/federatedCss.d.ts +5 -0
- package/dist/types/core/server/helmet.d.ts +5 -0
- package/dist/types/core/server/index.d.ts +4 -0
- package/dist/types/core/server/react/index.d.ts +2 -0
- package/dist/types/core/server/react/no-ssr-cache/index.d.ts +2 -0
- package/dist/types/core/server/react/nossr/index.d.ts +4 -0
- package/dist/types/core/server/requestHandler.d.ts +13 -0
- package/dist/types/core/server/scriptOrder.d.ts +1 -0
- package/dist/types/core/server/server.d.ts +4 -0
- package/dist/types/core/server/shared.d.ts +8 -0
- package/dist/types/core/server/stream/afterTemplate.d.ts +13 -0
- package/dist/types/core/server/stream/beforeTemplate.d.ts +10 -0
- package/dist/types/core/server/stream/beforeTemplate.worker.d.ts +10 -0
- package/dist/types/core/server/stream/createReadableStream.d.ts +2 -0
- package/dist/types/core/server/stream/createReadableStream.worker.d.ts +2 -0
- package/dist/types/core/server/stream/deferredScript.d.ts +15 -0
- package/dist/types/core/server/stream/index.d.ts +1 -0
- package/dist/types/core/server/stream/shared.d.ts +41 -0
- package/dist/types/core/server/stream/template.d.ts +9 -0
- package/dist/types/core/server/string/index.d.ts +2 -0
- package/dist/types/core/server/string/loadable.d.ts +47 -0
- package/dist/types/core/server/string/ssrData.d.ts +20 -0
- package/dist/types/core/server/string/types.d.ts +12 -0
- package/dist/types/core/server/tracer.d.ts +17 -0
- package/dist/types/core/server/utils.d.ts +19 -0
- package/dist/types/core/types.d.ts +49 -0
- package/dist/types/document/Body.d.ts +2 -0
- package/dist/types/document/Comment.d.ts +5 -0
- package/dist/types/document/DocumentContext.d.ts +13 -0
- package/dist/types/document/DocumentStructureContext.d.ts +12 -0
- package/dist/types/document/Head.d.ts +5 -0
- package/dist/types/document/Html.d.ts +4 -0
- package/dist/types/document/Links.d.ts +2 -0
- package/dist/types/document/Root.d.ts +7 -0
- package/dist/types/document/Script.d.ts +4 -0
- package/dist/types/document/Scripts.d.ts +2 -0
- package/dist/types/document/Style.d.ts +5 -0
- package/dist/types/document/Title.d.ts +1 -0
- package/dist/types/document/cli/index.d.ts +5 -0
- package/dist/types/document/constants.d.ts +25 -0
- package/dist/types/document/index.d.ts +12 -0
- package/dist/types/exports/config-routes.d.ts +9 -0
- package/dist/types/exports/head.d.ts +11 -0
- package/dist/types/exports/loadable.d.ts +10 -0
- package/dist/types/exports/tanstack-router.d.ts +7 -0
- package/dist/types/index.d.ts +10 -0
- package/dist/types/internal.d.ts +2 -0
- package/dist/types/react-server.d.ts +3 -0
- package/dist/types/router/cli/code/getClientRoutes/getRoutes.d.ts +8 -0
- package/dist/types/router/cli/code/getClientRoutes/index.d.ts +1 -0
- package/dist/types/router/cli/code/getClientRoutes/utils.d.ts +4 -0
- package/dist/types/router/cli/code/index.d.ts +12 -0
- package/dist/types/router/cli/code/inspect.d.ts +22 -0
- package/dist/types/router/cli/code/makeLegalIdentifier.d.ts +1 -0
- package/dist/types/router/cli/code/nestedRoutes.d.ts +13 -0
- package/dist/types/router/cli/code/tanstackTypes.d.ts +10 -0
- package/dist/types/router/cli/code/templates.d.ts +28 -0
- package/dist/types/router/cli/code/utils.d.ts +12 -0
- package/dist/types/router/cli/config-routes/converter.d.ts +15 -0
- package/dist/types/router/cli/config-routes/parseRouteConfig.d.ts +32 -0
- package/dist/types/router/cli/constants.d.ts +31 -0
- package/dist/types/router/cli/entry.d.ts +18 -0
- package/dist/types/router/cli/handler.d.ts +28 -0
- package/dist/types/router/cli/index.d.ts +5 -0
- package/dist/types/router/index.d.ts +1 -0
- package/dist/types/router/internal.d.ts +2 -0
- package/dist/types/router/runtime/CSSLinks.d.ts +9 -0
- package/dist/types/router/runtime/DefaultNotFound.d.ts +2 -0
- package/dist/types/router/runtime/DeferredDataScripts.d.ts +2 -0
- package/dist/types/router/runtime/DeferredDataScripts.node.d.ts +11 -0
- package/dist/types/router/runtime/PrefetchLink.d.ts +27 -0
- package/dist/types/router/runtime/constants.d.ts +146 -0
- package/dist/types/router/runtime/hooks.d.ts +18 -0
- package/dist/types/router/runtime/index.d.ts +7 -0
- package/dist/types/router/runtime/internal.d.ts +11 -0
- package/dist/types/router/runtime/lifecycle.d.ts +25 -0
- package/dist/types/router/runtime/plugin.d.ts +9 -0
- package/dist/types/router/runtime/plugin.node.d.ts +7 -0
- package/dist/types/router/runtime/routerHelper.d.ts +5 -0
- package/dist/types/router/runtime/rsc-router.d.ts +20 -0
- package/dist/types/router/runtime/rsc.d.ts +1 -0
- package/dist/types/router/runtime/server.d.ts +1 -0
- package/dist/types/router/runtime/tanstack/basepathRewrite.d.ts +8 -0
- package/dist/types/router/runtime/tanstack/dataMutation.d.ts +29 -0
- package/dist/types/router/runtime/tanstack/hydrationBoundary.d.ts +2 -0
- package/dist/types/router/runtime/tanstack/outlet.d.ts +2 -0
- package/dist/types/router/runtime/tanstack/plugin.d.ts +6 -0
- package/dist/types/router/runtime/tanstack/plugin.node.d.ts +6 -0
- package/dist/types/router/runtime/tanstack/prefetchLink.d.ts +11 -0
- package/dist/types/router/runtime/tanstack/routeTree.d.ts +8 -0
- package/dist/types/router/runtime/tanstack/rsc/ClientSlot.d.ts +5 -0
- package/dist/types/router/runtime/tanstack/rsc/CompositeComponent.d.ts +3 -0
- package/dist/types/router/runtime/tanstack/rsc/ReplayableStream.d.ts +24 -0
- package/dist/types/router/runtime/tanstack/rsc/RscNodeRenderer.d.ts +5 -0
- package/dist/types/router/runtime/tanstack/rsc/SlotContext.d.ts +11 -0
- package/dist/types/router/runtime/tanstack/rsc/client.d.ts +11 -0
- package/dist/types/router/runtime/tanstack/rsc/createRscProxy.d.ts +7 -0
- package/dist/types/router/runtime/tanstack/rsc/index.d.ts +2 -0
- package/dist/types/router/runtime/tanstack/rsc/server.d.ts +14 -0
- package/dist/types/router/runtime/tanstack/rsc/slotUsageSanitizer.d.ts +2 -0
- package/dist/types/router/runtime/tanstack/rsc/symbols.d.ts +46 -0
- package/dist/types/router/runtime/types.d.ts +119 -0
- package/dist/types/router/runtime/utils.d.ts +48 -0
- package/dist/types/router/runtime/withRouter.d.ts +10 -0
- package/dist/types/rsc/client.d.ts +2 -0
- package/dist/types/rsc/server.d.ts +1 -0
- package/dist/types/rsc/server.worker.d.ts +1 -0
- package/package.json +24 -18
|
@@ -0,0 +1,299 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
default: ()=>boundary_debugger,
|
|
28
|
+
ultramodernBoundaryDebuggerPlugin: ()=>ultramodernBoundaryDebuggerPlugin
|
|
29
|
+
});
|
|
30
|
+
const jsx_runtime_namespaceObject = require("react/jsx-runtime");
|
|
31
|
+
const external_react_namespaceObject = require("react");
|
|
32
|
+
const defaultStorageKey = 'modernjs:boundary-debugger:enabled';
|
|
33
|
+
const queryParamName = 'modern-boundaries';
|
|
34
|
+
const boundarySelector = '[data-modern-boundary-id]';
|
|
35
|
+
const defaultLabels = {
|
|
36
|
+
cs: {
|
|
37
|
+
toggle: 'zobrazit hranice týmů'
|
|
38
|
+
},
|
|
39
|
+
en: {
|
|
40
|
+
toggle: 'show team boundaries'
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const palette = [
|
|
44
|
+
'#ff5a5f',
|
|
45
|
+
'#30e27a',
|
|
46
|
+
'#f6cf45',
|
|
47
|
+
'#7c8cff',
|
|
48
|
+
'#29b6f6'
|
|
49
|
+
];
|
|
50
|
+
const readStoredEnabled = (storageKey, fallback)=>{
|
|
51
|
+
if ("u" < typeof window) return fallback;
|
|
52
|
+
try {
|
|
53
|
+
const stored = window.localStorage.getItem(storageKey);
|
|
54
|
+
return null === stored ? fallback : 'true' === stored;
|
|
55
|
+
} catch {
|
|
56
|
+
return fallback;
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
const writeStoredEnabled = (storageKey, enabled)=>{
|
|
60
|
+
if ("u" < typeof window) return;
|
|
61
|
+
try {
|
|
62
|
+
window.localStorage.setItem(storageKey, String(enabled));
|
|
63
|
+
} catch {}
|
|
64
|
+
};
|
|
65
|
+
const parseEnabledOverride = (value)=>{
|
|
66
|
+
if (null === value) return;
|
|
67
|
+
const normalized = value.toLowerCase();
|
|
68
|
+
if ('1' === normalized || 'true' === normalized) return true;
|
|
69
|
+
if ('0' === normalized || 'false' === normalized) return false;
|
|
70
|
+
};
|
|
71
|
+
const readQueryEnabledOverride = ()=>{
|
|
72
|
+
if ("u" < typeof window) return;
|
|
73
|
+
try {
|
|
74
|
+
return parseEnabledOverride(new URLSearchParams(window.location.search).get(queryParamName));
|
|
75
|
+
} catch {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
const detectLanguage = ()=>{
|
|
80
|
+
if ("u" < typeof document) return 'en';
|
|
81
|
+
const htmlLanguage = document.documentElement.lang;
|
|
82
|
+
if (htmlLanguage) return htmlLanguage.split('-')[0] || 'en';
|
|
83
|
+
if ("u" < typeof window) return 'en';
|
|
84
|
+
return window.location.pathname.split('/').filter(Boolean)[0] || 'en';
|
|
85
|
+
};
|
|
86
|
+
const hashBoundaryId = (id)=>{
|
|
87
|
+
let hash = 0;
|
|
88
|
+
for(let index = 0; index < id.length; index++)hash = 31 * hash + id.charCodeAt(index) >>> 0;
|
|
89
|
+
return hash;
|
|
90
|
+
};
|
|
91
|
+
const formatRectKey = (rect)=>[
|
|
92
|
+
Math.round(100 * rect.left) / 100,
|
|
93
|
+
Math.round(100 * rect.top) / 100,
|
|
94
|
+
Math.round(100 * rect.width) / 100,
|
|
95
|
+
Math.round(100 * rect.height) / 100
|
|
96
|
+
].join(':');
|
|
97
|
+
const getBoundaryId = (element)=>element.dataset.modernBoundaryId ?? element.dataset.mfRemote ?? element.getAttribute('data-mf-remote') ?? void 0;
|
|
98
|
+
const collectBoundaryElements = (legacySelector)=>{
|
|
99
|
+
const elements = new Set();
|
|
100
|
+
for (const element of document.querySelectorAll(boundarySelector))elements.add(element);
|
|
101
|
+
if (!legacySelector) return Array.from(elements);
|
|
102
|
+
try {
|
|
103
|
+
for (const element of document.querySelectorAll(legacySelector))elements.add(element);
|
|
104
|
+
} catch {}
|
|
105
|
+
return Array.from(elements);
|
|
106
|
+
};
|
|
107
|
+
function BoundaryDebugger({ controlMode = 'visible', enabledByDefault = false, labels = defaultLabels, legacySelector, metadata, storageKey = defaultStorageKey }) {
|
|
108
|
+
const [mounted, setMounted] = (0, external_react_namespaceObject.useState)(false);
|
|
109
|
+
const [enabled, setEnabled] = (0, external_react_namespaceObject.useState)(false);
|
|
110
|
+
const [boxes, setBoxes] = (0, external_react_namespaceObject.useState)([]);
|
|
111
|
+
const boundaries = (0, external_react_namespaceObject.useMemo)(()=>new Map(metadata.boundaries.map((entry, index)=>[
|
|
112
|
+
entry.mfName,
|
|
113
|
+
{
|
|
114
|
+
...entry,
|
|
115
|
+
color: entry.color ?? palette[index % palette.length],
|
|
116
|
+
label: entry.label ?? entry.appId
|
|
117
|
+
}
|
|
118
|
+
])), [
|
|
119
|
+
metadata
|
|
120
|
+
]);
|
|
121
|
+
const language = mounted ? detectLanguage() : 'en';
|
|
122
|
+
const toggleLabel = labels[language]?.toggle ?? labels.en?.toggle ?? defaultLabels.en?.toggle ?? 'show team boundaries';
|
|
123
|
+
(0, external_react_namespaceObject.useEffect)(()=>{
|
|
124
|
+
setMounted(true);
|
|
125
|
+
const queryOverride = readQueryEnabledOverride();
|
|
126
|
+
setEnabled(queryOverride ?? readStoredEnabled(storageKey, enabledByDefault));
|
|
127
|
+
}, [
|
|
128
|
+
enabledByDefault,
|
|
129
|
+
storageKey
|
|
130
|
+
]);
|
|
131
|
+
(0, external_react_namespaceObject.useEffect)(()=>{
|
|
132
|
+
if (!mounted) return;
|
|
133
|
+
writeStoredEnabled(storageKey, enabled);
|
|
134
|
+
}, [
|
|
135
|
+
enabled,
|
|
136
|
+
mounted,
|
|
137
|
+
storageKey
|
|
138
|
+
]);
|
|
139
|
+
(0, external_react_namespaceObject.useEffect)(()=>{
|
|
140
|
+
if (!enabled) return void setBoxes([]);
|
|
141
|
+
const readBoxes = ()=>{
|
|
142
|
+
const seenBoxes = new Set();
|
|
143
|
+
const nextBoxes = collectBoundaryElements(legacySelector).map((element)=>{
|
|
144
|
+
const boundaryId = getBoundaryId(element);
|
|
145
|
+
if (!boundaryId) return;
|
|
146
|
+
const rect = element.getBoundingClientRect();
|
|
147
|
+
if (rect.width <= 0 || rect.height <= 0) return;
|
|
148
|
+
const rectKey = formatRectKey(rect);
|
|
149
|
+
const boxKey = `${boundaryId}:${rectKey}`;
|
|
150
|
+
if (seenBoxes.has(boxKey)) return;
|
|
151
|
+
seenBoxes.add(boxKey);
|
|
152
|
+
const boundary = boundaries.get(boundaryId);
|
|
153
|
+
const color = boundary?.color ?? palette[hashBoundaryId(boundaryId) % palette.length];
|
|
154
|
+
const label = boundary?.label ?? boundary?.appId ?? boundaryId;
|
|
155
|
+
const expose = element.dataset.modernMfExpose;
|
|
156
|
+
const detail = expose && expose !== label && expose !== boundaryId ? expose : void 0;
|
|
157
|
+
const box = {
|
|
158
|
+
color,
|
|
159
|
+
height: rect.height,
|
|
160
|
+
id: boxKey,
|
|
161
|
+
label,
|
|
162
|
+
left: rect.left,
|
|
163
|
+
top: rect.top,
|
|
164
|
+
width: rect.width
|
|
165
|
+
};
|
|
166
|
+
if (detail) box.detail = detail;
|
|
167
|
+
return box;
|
|
168
|
+
}).filter((box)=>void 0 !== box);
|
|
169
|
+
setBoxes(nextBoxes);
|
|
170
|
+
};
|
|
171
|
+
readBoxes();
|
|
172
|
+
const resizeObserver = "u" < typeof ResizeObserver ? void 0 : new ResizeObserver(readBoxes);
|
|
173
|
+
for (const element of collectBoundaryElements(legacySelector))resizeObserver?.observe(element);
|
|
174
|
+
const mutationObserver = new MutationObserver(readBoxes);
|
|
175
|
+
mutationObserver.observe(document.body, {
|
|
176
|
+
childList: true,
|
|
177
|
+
subtree: true
|
|
178
|
+
});
|
|
179
|
+
window.addEventListener('resize', readBoxes);
|
|
180
|
+
window.addEventListener('scroll', readBoxes, true);
|
|
181
|
+
return ()=>{
|
|
182
|
+
mutationObserver.disconnect();
|
|
183
|
+
resizeObserver?.disconnect();
|
|
184
|
+
window.removeEventListener('resize', readBoxes);
|
|
185
|
+
window.removeEventListener('scroll', readBoxes, true);
|
|
186
|
+
};
|
|
187
|
+
}, [
|
|
188
|
+
boundaries,
|
|
189
|
+
enabled,
|
|
190
|
+
legacySelector
|
|
191
|
+
]);
|
|
192
|
+
if (!mounted) return null;
|
|
193
|
+
const shouldRenderToggle = 'visible' === controlMode || 'hidden-when-off' === controlMode && enabled;
|
|
194
|
+
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)(jsx_runtime_namespaceObject.Fragment, {
|
|
195
|
+
children: [
|
|
196
|
+
shouldRenderToggle ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)("label", {
|
|
197
|
+
style: {
|
|
198
|
+
alignItems: 'center',
|
|
199
|
+
background: 'rgba(255, 255, 255, 0.96)',
|
|
200
|
+
border: '1px solid rgba(0, 0, 0, 0.1)',
|
|
201
|
+
borderRadius: 10,
|
|
202
|
+
boxShadow: '0 10px 28px rgba(0, 0, 0, 0.14)',
|
|
203
|
+
color: '#111827',
|
|
204
|
+
display: 'flex',
|
|
205
|
+
font: '600 13px/1.2 system-ui, sans-serif',
|
|
206
|
+
gap: 8,
|
|
207
|
+
left: 'max(12px, env(safe-area-inset-left))',
|
|
208
|
+
maxWidth: 'calc(100vw - 24px)',
|
|
209
|
+
padding: '9px 11px',
|
|
210
|
+
position: 'fixed',
|
|
211
|
+
top: 'max(12px, env(safe-area-inset-top))',
|
|
212
|
+
zIndex: 2147483000
|
|
213
|
+
},
|
|
214
|
+
children: [
|
|
215
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("input", {
|
|
216
|
+
checked: enabled,
|
|
217
|
+
onChange: (event)=>setEnabled(event.currentTarget.checked),
|
|
218
|
+
type: "checkbox"
|
|
219
|
+
}),
|
|
220
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("span", {
|
|
221
|
+
children: toggleLabel
|
|
222
|
+
})
|
|
223
|
+
]
|
|
224
|
+
}) : null,
|
|
225
|
+
enabled ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
226
|
+
"aria-hidden": "true",
|
|
227
|
+
children: boxes.map((box)=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("div", {
|
|
228
|
+
style: {
|
|
229
|
+
border: `2px solid ${box.color}`,
|
|
230
|
+
borderRadius: 8,
|
|
231
|
+
boxShadow: `0 0 0 1px rgba(255,255,255,.72), 0 6px 20px color-mix(in srgb, ${box.color} 20%, transparent)`,
|
|
232
|
+
height: box.height,
|
|
233
|
+
left: box.left,
|
|
234
|
+
pointerEvents: 'none',
|
|
235
|
+
position: 'fixed',
|
|
236
|
+
top: box.top,
|
|
237
|
+
width: box.width,
|
|
238
|
+
zIndex: 2147482999
|
|
239
|
+
},
|
|
240
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)("span", {
|
|
241
|
+
style: {
|
|
242
|
+
background: box.color,
|
|
243
|
+
borderRadius: 999,
|
|
244
|
+
color: '#111827',
|
|
245
|
+
display: 'grid',
|
|
246
|
+
font: '800 11px/1.1 system-ui, sans-serif',
|
|
247
|
+
gap: 3,
|
|
248
|
+
maxWidth: 'min(280px, calc(100vw - 24px))',
|
|
249
|
+
padding: '5px 8px',
|
|
250
|
+
position: 'absolute',
|
|
251
|
+
right: 4,
|
|
252
|
+
top: 4,
|
|
253
|
+
whiteSpace: 'nowrap'
|
|
254
|
+
},
|
|
255
|
+
children: [
|
|
256
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("span", {
|
|
257
|
+
children: box.label
|
|
258
|
+
}),
|
|
259
|
+
box.detail ? /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)("span", {
|
|
260
|
+
style: {
|
|
261
|
+
font: '700 10px/1.1 system-ui, sans-serif',
|
|
262
|
+
opacity: 0.82,
|
|
263
|
+
overflow: 'hidden',
|
|
264
|
+
textOverflow: 'ellipsis'
|
|
265
|
+
},
|
|
266
|
+
children: box.detail
|
|
267
|
+
}) : null
|
|
268
|
+
]
|
|
269
|
+
})
|
|
270
|
+
}, box.id))
|
|
271
|
+
}) : null
|
|
272
|
+
]
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
const ultramodernBoundaryDebuggerPlugin = (options)=>({
|
|
276
|
+
name: '@modern-js/runtime/boundary-debugger',
|
|
277
|
+
setup: (api)=>{
|
|
278
|
+
api.wrapRoot((App)=>(props)=>/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsxs)(jsx_runtime_namespaceObject.Fragment, {
|
|
279
|
+
children: [
|
|
280
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(App, {
|
|
281
|
+
...props
|
|
282
|
+
}),
|
|
283
|
+
/*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(BoundaryDebugger, {
|
|
284
|
+
...options
|
|
285
|
+
})
|
|
286
|
+
]
|
|
287
|
+
}));
|
|
288
|
+
}
|
|
289
|
+
});
|
|
290
|
+
const boundary_debugger = ultramodernBoundaryDebuggerPlugin;
|
|
291
|
+
exports["default"] = __webpack_exports__["default"];
|
|
292
|
+
exports.ultramodernBoundaryDebuggerPlugin = __webpack_exports__.ultramodernBoundaryDebuggerPlugin;
|
|
293
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
294
|
+
"default",
|
|
295
|
+
"ultramodernBoundaryDebuggerPlugin"
|
|
296
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
297
|
+
Object.defineProperty(exports, '__esModule', {
|
|
298
|
+
value: true
|
|
299
|
+
});
|
|
@@ -125,30 +125,20 @@ const ssrBuilderPlugin = (modernAPI, outputModule, exportLoadablePath)=>({
|
|
|
125
125
|
const hasServerRendering = hasServerRenderingConfig(userConfig);
|
|
126
126
|
const hasModuleFederationRuntimeMarker = hasServerRendering && shouldUseModuleFederationNodeOutput(config);
|
|
127
127
|
const hasExplicitMfSsrFlag = isModuleFederationAppSSREnabled(userConfig);
|
|
128
|
+
const isCloudflareWorkerSSR = 'workerSSR' === name && userConfig.deploy?.target === 'cloudflare';
|
|
128
129
|
const requireExplicitMfSsrFlag = 'true' === process.env.MODERN_MF_APP_SSR_REQUIRE_EXPLICIT;
|
|
129
130
|
if (hasServerRendering && hasModuleFederationRuntimeMarker && !hasExplicitMfSsrFlag) {
|
|
130
131
|
const warningMessage = '[modernjs][mf-ssr] Module Federation SSR was auto-detected from runtime markers. Set server.ssr.moduleFederationAppSSR=true explicitly in host and remotes to avoid heuristic drift.';
|
|
131
132
|
if (requireExplicitMfSsrFlag) throw new Error(`${warningMessage} (enforced by MODERN_MF_APP_SSR_REQUIRE_EXPLICIT=true)`);
|
|
132
133
|
console.warn(warningMessage);
|
|
133
134
|
}
|
|
134
|
-
const isModuleFederationAppSSR = hasServerRendering && hasExplicitMfSsrFlag;
|
|
135
|
-
const useModuleFederationNodeOutput = hasServerRendering && isModuleFederationAppSSR && isNodeEnvironmentTarget(config.output.target);
|
|
135
|
+
const isModuleFederationAppSSR = hasServerRendering && hasExplicitMfSsrFlag && !isCloudflareWorkerSSR;
|
|
136
136
|
const ssrEnv = userConfig.deploy?.worker?.ssr || userConfig.server?.rsc ? 'edge' : 'node';
|
|
137
137
|
const appContext = modernAPI.getAppContext();
|
|
138
138
|
const { appDirectory, entrypoints } = appContext;
|
|
139
|
-
const serverBundlerChain = useModuleFederationNodeOutput ? (chain)=>{
|
|
140
|
-
chain.target('async-node');
|
|
141
|
-
chain.output.module(false);
|
|
142
|
-
chain.output.chunkFormat('commonjs');
|
|
143
|
-
chain.output.chunkLoading('async-node');
|
|
144
|
-
chain.output.library({
|
|
145
|
-
...chain.output.get('library') || {},
|
|
146
|
-
type: 'commonjs-module'
|
|
147
|
-
});
|
|
148
|
-
} : void 0;
|
|
149
139
|
const useLoadablePlugin = (0, utils_namespaceObject.isUseSSRBundle)(userConfig) && !isServerEnvironment && checkUseStringSSR(userConfig, appDirectory, entrypoints);
|
|
150
140
|
const outputConfig = {
|
|
151
|
-
module: isServerEnvironment &&
|
|
141
|
+
module: isServerEnvironment && (outputModule || 'workerSSR' === name && userConfig.deploy?.target === 'cloudflare')
|
|
152
142
|
};
|
|
153
143
|
const useLoadableComponents = (0, utils_namespaceObject.isUseSSRBundle)(userConfig) && checkUseStringSSR(userConfig, appDirectory, entrypoints);
|
|
154
144
|
return mergeEnvironmentConfig(config, {
|
|
@@ -161,13 +151,13 @@ const ssrBuilderPlugin = (modernAPI, outputModule, exportLoadablePath)=>({
|
|
|
161
151
|
},
|
|
162
152
|
output: outputConfig,
|
|
163
153
|
tools: {
|
|
164
|
-
bundlerChain:
|
|
154
|
+
bundlerChain: useLoadablePlugin ? (chain)=>{
|
|
165
155
|
chain.plugin('loadable').use(external_loadable_bundler_plugin_js_default(), [
|
|
166
156
|
{
|
|
167
157
|
filename: utils_namespaceObject.LOADABLE_STATS_FILE
|
|
168
158
|
}
|
|
169
159
|
]);
|
|
170
|
-
} : void 0
|
|
160
|
+
} : void 0,
|
|
171
161
|
swc: useLoadableComponents ? {
|
|
172
162
|
jsc: {
|
|
173
163
|
experimental: {
|
|
@@ -27,7 +27,7 @@ __webpack_require__.d(__webpack_exports__, {
|
|
|
27
27
|
getServerPayload: ()=>getServerPayload,
|
|
28
28
|
setServerPayload: ()=>setServerPayload
|
|
29
29
|
});
|
|
30
|
-
const getServerPayload = ()=>
|
|
30
|
+
const getServerPayload = ()=>void 0;
|
|
31
31
|
const setServerPayload = (payload)=>{};
|
|
32
32
|
exports.getServerPayload = __webpack_exports__.getServerPayload;
|
|
33
33
|
exports.setServerPayload = __webpack_exports__.setServerPayload;
|
|
@@ -45,8 +45,9 @@ function registerPlugin(internalPlugins, runtimeConfig) {
|
|
|
45
45
|
config: runtimeConfig || {},
|
|
46
46
|
handleSetupResult: hooks_js_namespaceObject.handleSetupResult
|
|
47
47
|
});
|
|
48
|
-
|
|
49
|
-
|
|
48
|
+
const internalRuntimeContext = runtimeContext;
|
|
49
|
+
(0, external_context_index_js_namespaceObject.setGlobalInternalRuntimeContext)(internalRuntimeContext);
|
|
50
|
+
return internalRuntimeContext;
|
|
50
51
|
}
|
|
51
52
|
function mergeConfig(config, ...otherConfig) {
|
|
52
53
|
return (0, merge_namespaceObject.merge)({}, config, ...otherConfig);
|
|
@@ -27,9 +27,12 @@ __webpack_require__.d(__webpack_exports__, {
|
|
|
27
27
|
wrapRuntimeContextProvider: ()=>wrapRuntimeContextProvider
|
|
28
28
|
});
|
|
29
29
|
const jsx_runtime_namespaceObject = require("react/jsx-runtime");
|
|
30
|
+
const external_react_helmet_async_namespaceObject = require("react-helmet-async");
|
|
30
31
|
const index_js_namespaceObject = require("../context/index.js");
|
|
31
32
|
function wrapRuntimeContextProvider(App, contextValue) {
|
|
32
|
-
const { isBrowser, initialData, routes, routerFramework, context, routeManifest, routerRuntime, routerInstance, routerHydrationScript, routerMatchedRouteIds, routerServerSnapshot, routerContext, unstable_getBlockNavState, ssrContext, _internalContext, _internalRouterBaseName, ...rest } = contextValue;
|
|
33
|
+
const { isBrowser, initialData, routes, routerFramework, context, routeManifest, routerRuntime, routerInstance, routerHydrationScript, routerMatchedRouteIds, routerServerSnapshot, routerContext, unstable_getBlockNavState, ssrContext, _internalContext, _internalRouterBaseName, _helmetContext, ...rest } = contextValue;
|
|
34
|
+
const internalContextValue = contextValue;
|
|
35
|
+
internalContextValue._helmetContext ??= {};
|
|
33
36
|
const runtimeContextValue = {
|
|
34
37
|
isBrowser,
|
|
35
38
|
initialData,
|
|
@@ -39,10 +42,13 @@ function wrapRuntimeContextProvider(App, contextValue) {
|
|
|
39
42
|
...rest
|
|
40
43
|
};
|
|
41
44
|
return /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(index_js_namespaceObject.InternalRuntimeContext.Provider, {
|
|
42
|
-
value:
|
|
45
|
+
value: internalContextValue,
|
|
43
46
|
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(index_js_namespaceObject.RuntimeContext.Provider, {
|
|
44
47
|
value: runtimeContextValue,
|
|
45
|
-
children:
|
|
48
|
+
children: /*#__PURE__*/ (0, jsx_runtime_namespaceObject.jsx)(external_react_helmet_async_namespaceObject.HelmetProvider, {
|
|
49
|
+
context: internalContextValue._helmetContext,
|
|
50
|
+
children: App
|
|
51
|
+
})
|
|
46
52
|
})
|
|
47
53
|
});
|
|
48
54
|
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
createFederatedCssLinks: ()=>createFederatedCssLinks
|
|
28
|
+
});
|
|
29
|
+
const external_utils_js_namespaceObject = require("./utils.js");
|
|
30
|
+
const createFederatedCssLinks = (assets, options)=>{
|
|
31
|
+
if (!assets?.length) return '';
|
|
32
|
+
const seen = new Set(options.existingAssets || []);
|
|
33
|
+
const attributes = (0, external_utils_js_namespaceObject.attributesToString)(options.attributes || {});
|
|
34
|
+
const links = [];
|
|
35
|
+
for (const asset of assets)if (!(!asset || seen.has(asset) || options.template.includes(asset))) {
|
|
36
|
+
seen.add(asset);
|
|
37
|
+
links.push(`<link${attributes} href="${asset}" rel="stylesheet" />`);
|
|
38
|
+
}
|
|
39
|
+
return links.join('');
|
|
40
|
+
};
|
|
41
|
+
exports.createFederatedCssLinks = __webpack_exports__.createFederatedCssLinks;
|
|
42
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
43
|
+
"createFederatedCssLinks"
|
|
44
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
45
|
+
Object.defineProperty(exports, '__esModule', {
|
|
46
|
+
value: true
|
|
47
|
+
});
|
|
@@ -25,15 +25,19 @@ var __webpack_exports__ = {};
|
|
|
25
25
|
__webpack_require__.r(__webpack_exports__);
|
|
26
26
|
__webpack_require__.d(__webpack_exports__, {
|
|
27
27
|
createReplaceHelemt: ()=>createReplaceHelemt,
|
|
28
|
+
getHelmetData: ()=>getHelmetData,
|
|
28
29
|
helmetReplace: ()=>helmetReplace
|
|
29
30
|
});
|
|
30
|
-
const external_os_namespaceObject = require("os");
|
|
31
31
|
const external_utils_js_namespaceObject = require("./utils.js");
|
|
32
|
+
const EOL = '\n';
|
|
32
33
|
const RE_HTML_ATTR = /<html[^>]*>/;
|
|
33
34
|
const RE_BODY_ATTR = /<body[^>]*>/;
|
|
34
35
|
const RE_LAST_IN_HEAD = /<\/head>/;
|
|
35
36
|
const RE_TITLE = /<title[^>]*>([\s\S\n\r]*?)<\/title>/;
|
|
36
37
|
const TEST_TITLE_CONTENT = /(?<=<title[^>]*>)([\s\S\n\r]*?)([.|\S])([\s\S\n\r]*?)(?=<\/title>)/;
|
|
38
|
+
function getHelmetData(runtimeContext) {
|
|
39
|
+
return runtimeContext._helmetContext?.helmet ?? void 0;
|
|
40
|
+
}
|
|
37
41
|
function createReplaceHelemt(helmetData) {
|
|
38
42
|
return helmetData ? (template)=>helmetReplace(template, helmetData) : (tempalte)=>tempalte;
|
|
39
43
|
}
|
|
@@ -61,13 +65,15 @@ function helmetReplace(content, helmetData) {
|
|
|
61
65
|
script,
|
|
62
66
|
style,
|
|
63
67
|
!existTitleTag ? title : ''
|
|
64
|
-
].reduce((pre, cur)=>pre + (cur.length > 0 ? ` ${cur}${
|
|
68
|
+
].reduce((pre, cur)=>pre + (cur.length > 0 ? ` ${cur}${EOL}` : ''), '');
|
|
65
69
|
return (0, external_utils_js_namespaceObject.safeReplace)(result, RE_LAST_IN_HEAD, `${helmetStr}</head>`);
|
|
66
70
|
}
|
|
67
71
|
exports.createReplaceHelemt = __webpack_exports__.createReplaceHelemt;
|
|
72
|
+
exports.getHelmetData = __webpack_exports__.getHelmetData;
|
|
68
73
|
exports.helmetReplace = __webpack_exports__.helmetReplace;
|
|
69
74
|
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
70
75
|
"createReplaceHelemt",
|
|
76
|
+
"getHelmetData",
|
|
71
77
|
"helmetReplace"
|
|
72
78
|
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
73
79
|
Object.defineProperty(exports, '__esModule', {
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
injectBeforeHydrationEntryScript: ()=>injectBeforeHydrationEntryScript
|
|
28
|
+
});
|
|
29
|
+
function getScriptTags(template) {
|
|
30
|
+
const scriptRegExp = /<script\b[^>]*\bsrc=(["'])(.*?)\1[^>]*><\/script>/g;
|
|
31
|
+
return Array.from(template.matchAll(scriptRegExp)).map((match)=>({
|
|
32
|
+
index: match.index ?? 0,
|
|
33
|
+
tag: match[0],
|
|
34
|
+
src: match[2]
|
|
35
|
+
}));
|
|
36
|
+
}
|
|
37
|
+
function getAssetBasename(src) {
|
|
38
|
+
const withoutQuery = src.split(/[?#]/)[0];
|
|
39
|
+
return withoutQuery.split('/').pop() || withoutQuery;
|
|
40
|
+
}
|
|
41
|
+
function isEntryScript(src, entryName, asyncEntry) {
|
|
42
|
+
const basename = getAssetBasename(src);
|
|
43
|
+
const prefix = asyncEntry ? `async-${entryName}` : entryName;
|
|
44
|
+
return basename === `${prefix}.js` || basename.startsWith(`${prefix}.`) || basename.startsWith(`${prefix}-`);
|
|
45
|
+
}
|
|
46
|
+
function injectBeforeHydrationEntryScript(template, scripts, entryName = 'index') {
|
|
47
|
+
if (!scripts) return template;
|
|
48
|
+
const scriptTags = getScriptTags(template);
|
|
49
|
+
const target = scriptTags.find((match)=>isEntryScript(match.src, entryName, false)) ?? scriptTags.find((match)=>isEntryScript(match.src, entryName, true));
|
|
50
|
+
if (!target) return template;
|
|
51
|
+
return `${template.slice(0, target.index)}${scripts}${template.slice(target.index)}`;
|
|
52
|
+
}
|
|
53
|
+
exports.injectBeforeHydrationEntryScript = __webpack_exports__.injectBeforeHydrationEntryScript;
|
|
54
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
55
|
+
"injectBeforeHydrationEntryScript"
|
|
56
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
57
|
+
Object.defineProperty(exports, '__esModule', {
|
|
58
|
+
value: true
|
|
59
|
+
});
|
|
@@ -30,6 +30,7 @@ const node_namespaceObject = require("@modern-js/runtime-utils/node");
|
|
|
30
30
|
const lifecycle_js_namespaceObject = require("../../../router/runtime/lifecycle.js");
|
|
31
31
|
const external_constants_js_namespaceObject = require("../../constants.js");
|
|
32
32
|
const external_constants_js_namespaceObject_1 = require("../constants.js");
|
|
33
|
+
const external_scriptOrder_js_namespaceObject = require("../scriptOrder.js");
|
|
33
34
|
const external_shared_js_namespaceObject = require("../shared.js");
|
|
34
35
|
const external_utils_js_namespaceObject = require("../utils.js");
|
|
35
36
|
function buildShellAfterTemplate(afterAppTemplate, options) {
|
|
@@ -50,11 +51,18 @@ function buildShellAfterTemplate(afterAppTemplate, options) {
|
|
|
50
51
|
if (!routeManifest) return template;
|
|
51
52
|
const { routeAssets } = routeManifest;
|
|
52
53
|
if (!routeAssets) return template;
|
|
53
|
-
const
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
54
|
+
const matchedRouteIds = (0, lifecycle_js_namespaceObject.getRouterMatchedRouteIds)(runtimeContext) ?? [];
|
|
55
|
+
const assetEntries = [
|
|
56
|
+
...matchedRouteIds.map((routeId)=>routeAssets[routeId]),
|
|
57
|
+
routeAssets[`async-${entryName}`]
|
|
58
|
+
].filter(Boolean);
|
|
59
|
+
const jsAssets = Array.from(new Set(assetEntries.flatMap((entry)=>(entry.assets ?? []).filter((asset)=>asset.endsWith('.js')))));
|
|
60
|
+
const nonceAttr = nonce ? ` nonce="${nonce}"` : '';
|
|
61
|
+
const jsChunkStr = jsAssets.filter((asset)=>!template.includes(asset)).map((asset)=>`<script src=${asset}${nonceAttr}></script>`).join(' ');
|
|
62
|
+
if (jsChunkStr) {
|
|
63
|
+
const withoutPlaceholder = (0, external_utils_js_namespaceObject.safeReplace)(template, '<!--<?- chunksMap.js ?>-->', '');
|
|
64
|
+
const withEarlyScripts = (0, external_scriptOrder_js_namespaceObject.injectBeforeHydrationEntryScript)(withoutPlaceholder, jsChunkStr, entryName);
|
|
65
|
+
return withEarlyScripts !== withoutPlaceholder ? withEarlyScripts : (0, external_utils_js_namespaceObject.safeReplace)(template, '<!--<?- chunksMap.js ?>-->', jsChunkStr);
|
|
58
66
|
}
|
|
59
67
|
return template;
|
|
60
68
|
}
|