@bleedingdev/modern-js-runtime 3.2.0-ultramodern.11 → 3.2.0-ultramodern.111
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 +303 -0
- package/dist/cjs/cache/index.js +9 -5
- package/dist/cjs/cli/alias.js +9 -5
- package/dist/cjs/cli/code.js +9 -5
- package/dist/cjs/cli/constants.js +20 -16
- package/dist/cjs/cli/entry.js +9 -5
- package/dist/cjs/cli/index.js +9 -5
- package/dist/cjs/cli/ssr/index.js +14 -20
- package/dist/cjs/cli/ssr/loadable-bundler-plugin.js +9 -5
- package/dist/cjs/cli/ssr/mode.js +12 -8
- package/dist/cjs/cli/template.js +9 -5
- package/dist/cjs/cli/template.server.js +10 -5
- package/dist/cjs/common.js +14 -10
- package/dist/cjs/core/browser/hydrate.js +9 -5
- package/dist/cjs/core/browser/index.js +9 -5
- package/dist/cjs/core/browser/withCallback.js +9 -5
- package/dist/cjs/core/compat/hooks.js +14 -10
- package/dist/cjs/core/compat/index.js +9 -5
- package/dist/cjs/core/compat/requestContext.js +13 -9
- package/dist/cjs/core/config.js +12 -8
- package/dist/cjs/core/constants.js +15 -10
- package/dist/cjs/core/context/index.js +9 -5
- package/dist/cjs/core/context/monitors/default.js +12 -8
- package/dist/cjs/core/context/monitors/index.js +9 -5
- package/dist/cjs/core/context/monitors/index.server.js +9 -5
- package/dist/cjs/core/context/request/index.js +12 -8
- package/dist/cjs/core/context/request/index.server.js +9 -5
- package/dist/cjs/core/context/response/index.js +15 -11
- package/dist/cjs/core/context/response/index.server.js +9 -5
- package/dist/cjs/core/context/runtime.js +9 -5
- package/dist/cjs/core/context/serverPayload/index.js +13 -9
- package/dist/cjs/core/context/serverPayload/index.server.js +9 -5
- package/dist/cjs/core/index.js +9 -5
- package/dist/cjs/core/plugin/index.js +9 -5
- package/dist/cjs/core/react/index.js +9 -5
- package/dist/cjs/core/react/wrapper.js +18 -8
- package/dist/cjs/core/server/constants.js +15 -11
- package/dist/cjs/core/server/federatedCss.js +51 -0
- package/dist/cjs/core/server/helmet.js +17 -7
- package/dist/cjs/core/server/index.js +9 -5
- package/dist/cjs/core/server/react/index.js +9 -5
- package/dist/cjs/core/server/react/no-ssr-cache/index.js +9 -5
- package/dist/cjs/core/server/react/nossr/index.js +9 -5
- package/dist/cjs/core/server/requestHandler.js +9 -5
- package/dist/cjs/core/server/scriptOrder.js +63 -0
- package/dist/cjs/core/server/server.js +9 -5
- package/dist/cjs/core/server/shared.js +12 -8
- package/dist/cjs/core/server/stream/afterTemplate.js +22 -10
- package/dist/cjs/core/server/stream/beforeTemplate.js +22 -25
- package/dist/cjs/core/server/stream/beforeTemplate.worker.js +102 -0
- package/dist/cjs/core/server/stream/createReadableStream.js +16 -7
- package/dist/cjs/core/server/stream/createReadableStream.worker.js +13 -7
- package/dist/cjs/core/server/stream/deferredScript.js +9 -5
- package/dist/cjs/core/server/stream/index.js +9 -5
- package/dist/cjs/core/server/stream/shared.js +12 -6
- package/dist/cjs/core/server/stream/template.js +9 -5
- package/dist/cjs/core/server/string/index.js +25 -14
- package/dist/cjs/core/server/string/loadable.js +83 -15
- package/dist/cjs/core/server/string/ssrData.js +9 -5
- package/dist/cjs/core/server/tracer.js +13 -9
- package/dist/cjs/core/server/utils.js +9 -5
- package/dist/cjs/document/Body.js +9 -5
- package/dist/cjs/document/Comment.js +9 -5
- package/dist/cjs/document/DocumentContext.js +9 -5
- package/dist/cjs/document/DocumentStructureContext.js +9 -5
- package/dist/cjs/document/Head.js +9 -5
- package/dist/cjs/document/Html.js +9 -5
- package/dist/cjs/document/Links.js +9 -5
- package/dist/cjs/document/Root.js +9 -5
- package/dist/cjs/document/Script.js +9 -5
- package/dist/cjs/document/Scripts.js +9 -5
- package/dist/cjs/document/Style.js +9 -5
- package/dist/cjs/document/Title.js +9 -5
- package/dist/cjs/document/cli/index.js +12 -6
- package/dist/cjs/document/constants.js +9 -5
- package/dist/cjs/document/index.js +9 -5
- package/dist/cjs/exports/config-routes.js +12 -8
- package/dist/cjs/exports/head.js +209 -10
- package/dist/cjs/exports/loadable.js +51 -12
- package/dist/cjs/exports/tanstack-router.js +320 -59
- package/dist/cjs/index.js +9 -5
- package/dist/cjs/internal.js +9 -5
- package/dist/cjs/react-server.js +9 -5
- package/dist/cjs/router/cli/code/getClientRoutes/getRoutes.js +9 -5
- package/dist/cjs/router/cli/code/getClientRoutes/index.js +9 -5
- package/dist/cjs/router/cli/code/getClientRoutes/utils.js +9 -5
- package/dist/cjs/router/cli/code/index.js +9 -5
- package/dist/cjs/router/cli/code/inspect.js +9 -5
- package/dist/cjs/router/cli/code/makeLegalIdentifier.js +12 -8
- package/dist/cjs/router/cli/code/nestedRoutes.js +9 -5
- package/dist/cjs/router/cli/code/tanstackTypes.js +125 -56
- package/dist/cjs/router/cli/code/templates.js +24 -14
- package/dist/cjs/router/cli/code/utils.js +9 -5
- package/dist/cjs/router/cli/config-routes/converter.js +9 -5
- package/dist/cjs/router/cli/config-routes/parseRouteConfig.js +9 -5
- package/dist/cjs/router/cli/constants.js +23 -19
- package/dist/cjs/router/cli/entry.js +9 -5
- package/dist/cjs/router/cli/handler.js +9 -5
- package/dist/cjs/router/cli/index.js +9 -5
- package/dist/cjs/router/index.js +9 -5
- package/dist/cjs/router/internal.js +12 -8
- package/dist/cjs/router/runtime/CSSLinks.js +9 -5
- package/dist/cjs/router/runtime/DefaultNotFound.js +9 -5
- package/dist/cjs/router/runtime/DeferredDataScripts.js +12 -8
- package/dist/cjs/router/runtime/DeferredDataScripts.node.js +9 -5
- package/dist/cjs/router/runtime/PrefetchLink.js +162 -26
- package/dist/cjs/router/runtime/constants.js +9 -5
- package/dist/cjs/router/runtime/hooks.js +9 -5
- package/dist/cjs/router/runtime/index.js +15 -10
- package/dist/cjs/router/runtime/internal.js +9 -5
- package/dist/cjs/router/runtime/lifecycle.js +18 -14
- package/dist/cjs/router/runtime/plugin.js +9 -5
- package/dist/cjs/router/runtime/plugin.node.js +9 -5
- package/dist/cjs/router/runtime/routerHelper.js +9 -5
- package/dist/cjs/router/runtime/rsc-router.js +9 -5
- package/dist/cjs/router/runtime/rsc.js +9 -5
- package/dist/cjs/router/runtime/server.js +9 -5
- package/dist/cjs/router/runtime/tanstack/basepathRewrite.js +12 -8
- package/dist/cjs/router/runtime/tanstack/dataMutation.js +9 -5
- package/dist/cjs/router/runtime/tanstack/hydrationBoundary.js +48 -0
- package/dist/cjs/router/runtime/tanstack/outlet.js +58 -0
- package/dist/cjs/router/runtime/tanstack/plugin.js +199 -96
- package/dist/cjs/router/runtime/tanstack/plugin.node.js +13 -19
- package/dist/cjs/router/runtime/tanstack/prefetchLink.js +10 -6
- package/dist/cjs/router/runtime/tanstack/routeTree.js +73 -17
- package/dist/cjs/router/runtime/tanstack/rsc/ClientSlot.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/CompositeComponent.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/ReplayableStream.js +14 -9
- package/dist/cjs/router/runtime/tanstack/rsc/RscNodeRenderer.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/SlotContext.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/client.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/createRscProxy.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/index.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/server.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/slotUsageSanitizer.js +9 -5
- package/dist/cjs/router/runtime/tanstack/rsc/symbols.js +20 -15
- package/dist/cjs/router/runtime/utils.js +9 -5
- package/dist/cjs/router/runtime/withRouter.js +9 -5
- package/dist/cjs/rsc/client.js +12 -8
- package/dist/cjs/rsc/server.js +9 -5
- package/dist/cjs/rsc/server.worker.js +62 -0
- package/dist/cjs/ssr/index.node.js +13 -9
- package/dist/cjs/ssr/serverRender/renderToStream/buildTemplate.after.js +9 -5
- package/dist/cjs/ssr/serverRender/renderToString/entry.js +18 -13
- package/dist/cjs/ssr/serverRender/types.js +9 -5
- 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/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/document/cli/index.mjs +3 -1
- package/dist/esm/exports/head.mjs +193 -4
- package/dist/esm/exports/loadable.mjs +26 -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/PrefetchLink.mjs +153 -21
- 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 -94
- package/dist/esm/router/runtime/tanstack/plugin.node.mjs +5 -15
- package/dist/esm/router/runtime/tanstack/prefetchLink.mjs +1 -1
- 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/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/document/cli/index.mjs +3 -1
- package/dist/esm-node/exports/head.mjs +193 -4
- package/dist/esm-node/exports/loadable.mjs +26 -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/PrefetchLink.mjs +153 -21
- 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 -94
- package/dist/esm-node/router/runtime/tanstack/plugin.node.mjs +5 -15
- package/dist/esm-node/router/runtime/tanstack/prefetchLink.mjs +1 -1
- 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/cli/entry.d.ts +2 -2
- package/dist/types/core/context/response/index.server.d.ts +4 -1
- package/dist/types/core/context/runtime.d.ts +4 -0
- package/dist/types/core/plugin/index.d.ts +1 -1
- package/dist/types/core/server/federatedCss.d.ts +5 -0
- package/dist/types/core/server/helmet.d.ts +5 -3
- package/dist/types/core/server/scriptOrder.d.ts +1 -0
- package/dist/types/core/server/stream/beforeTemplate.d.ts +1 -0
- package/dist/types/core/server/stream/beforeTemplate.worker.d.ts +10 -0
- package/dist/types/core/server/stream/shared.d.ts +8 -0
- package/dist/types/core/server/string/loadable.d.ts +11 -0
- package/dist/types/core/server/utils.d.ts +11 -1
- package/dist/types/document/constants.d.ts +3 -1
- package/dist/types/exports/head.d.ts +10 -3
- package/dist/types/exports/loadable.d.ts +8 -1
- package/dist/types/exports/tanstack-router.d.ts +3 -1
- package/dist/types/router/cli/code/utils.d.ts +1 -1
- package/dist/types/router/cli/entry.d.ts +1 -1
- package/dist/types/router/runtime/PrefetchLink.d.ts +5 -1
- 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/rsc/server.worker.d.ts +1 -0
- package/package.json +31 -25
|
@@ -5,11 +5,12 @@ import { time } from "@modern-js/runtime-utils/time";
|
|
|
5
5
|
import { LOADER_REPORTER_NAME } from "@modern-js/utils/universal/constants";
|
|
6
6
|
import { RouterProvider, createMemoryHistory, createRouter } from "@tanstack/react-router";
|
|
7
7
|
import { attachRouterServerSsrUtils } from "@tanstack/react-router/ssr/server";
|
|
8
|
-
import {
|
|
8
|
+
import { useContext } from "react";
|
|
9
9
|
import { InternalRuntimeContext, getGlobalEnableRsc, getGlobalLayoutApp, getGlobalRoutes } from "../../../core/context/index.mjs";
|
|
10
10
|
import { applyRouterServerPrepareResult, createRouterServerSnapshot } from "../lifecycle.mjs";
|
|
11
11
|
import { createRouteObjectsFromConfig, urlJoin } from "../utils.mjs";
|
|
12
12
|
import { createModernBasepathRewrite } from "./basepathRewrite.mjs";
|
|
13
|
+
import { wrapTanstackSsrHydrationBoundary } from "./hydrationBoundary.mjs";
|
|
13
14
|
import { createRouteTreeFromRouteObjects, getModernRouteIdsFromMatches } from "./routeTree.mjs";
|
|
14
15
|
function isPreloadableRouteComponent(component) {
|
|
15
16
|
if (!component || 'function' != typeof component) return false;
|
|
@@ -37,13 +38,6 @@ async function preloadMatchedRouteComponents(tanstackRouter) {
|
|
|
37
38
|
]);
|
|
38
39
|
}));
|
|
39
40
|
}
|
|
40
|
-
async function waitForRouterSerialization(tanstackRouter) {
|
|
41
|
-
const serverSsr = tanstackRouter.serverSsr;
|
|
42
|
-
if (!serverSsr || 'function' != typeof serverSsr.onSerializationFinished || serverSsr.isSerializationFinished?.()) return;
|
|
43
|
-
await new Promise((resolve)=>{
|
|
44
|
-
serverSsr.onSerializationFinished?.(resolve);
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
41
|
function htmlEscapeAttr(value) {
|
|
48
42
|
return value.replace(/&/g, '&').replace(/"/g, '"');
|
|
49
43
|
}
|
|
@@ -189,7 +183,6 @@ const tanstackRouterPlugin = (userConfig = {})=>({
|
|
|
189
183
|
await preloadMatchedRouteComponents(serverRouter);
|
|
190
184
|
context.ssrContext?.response.status(tanstackRouter.state.statusCode);
|
|
191
185
|
await serverRouter.serverSsr?.dehydrate?.();
|
|
192
|
-
await waitForRouterSerialization(serverRouter);
|
|
193
186
|
const ssrScriptTags = serverRouter.serverSsr?.takeBufferedScripts?.();
|
|
194
187
|
const hydrationScripts = routerManagedTagsToHtml(ssrScriptTags);
|
|
195
188
|
const matchedRouteIds = getModernRouteIdsFromMatches(serverRouter);
|
|
@@ -227,12 +220,9 @@ const tanstackRouterPlugin = (userConfig = {})=>({
|
|
|
227
220
|
if (!router) return App ? /*#__PURE__*/ jsx(App, {
|
|
228
221
|
...props
|
|
229
222
|
}) : null;
|
|
230
|
-
const routerWrapper = /*#__PURE__*/ jsx(
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
router: router
|
|
234
|
-
})
|
|
235
|
-
});
|
|
223
|
+
const routerWrapper = wrapTanstackSsrHydrationBoundary(/*#__PURE__*/ jsx(RouterProvider, {
|
|
224
|
+
router: router
|
|
225
|
+
}), true);
|
|
236
226
|
return App ? /*#__PURE__*/ jsx(App, {
|
|
237
227
|
children: routerWrapper
|
|
238
228
|
}) : routerWrapper;
|
|
@@ -4,7 +4,7 @@ function resolvePreloadFromPrefetch(prefetch, preload) {
|
|
|
4
4
|
if (void 0 !== preload) return preload;
|
|
5
5
|
if ('none' === prefetch) return false;
|
|
6
6
|
if ('intent' === prefetch || 'render' === prefetch || 'viewport' === prefetch) return prefetch;
|
|
7
|
-
return
|
|
7
|
+
return 'viewport';
|
|
8
8
|
}
|
|
9
9
|
const LinkComponentImpl = (props)=>{
|
|
10
10
|
const { prefetch, preload, ...rest } = props;
|
|
@@ -1,11 +1,17 @@
|
|
|
1
|
-
import { createRootRoute, createRoute, notFound, redirect } from "@tanstack/react-router";
|
|
1
|
+
import { createRootRoute, createRoute, notFound, redirect, rootRouteId } from "@tanstack/react-router";
|
|
2
|
+
import { createElement } from "react";
|
|
2
3
|
import { DefaultNotFound } from "../DefaultNotFound.mjs";
|
|
4
|
+
import { withModernRouteMatchContext } from "./outlet.mjs";
|
|
3
5
|
function createTanstackRoute(options) {
|
|
4
6
|
return createRoute(options);
|
|
5
7
|
}
|
|
6
8
|
function createTanstackRootRoute(options) {
|
|
7
9
|
return createRootRoute(options);
|
|
8
10
|
}
|
|
11
|
+
function wrapRouteComponentWithModernContext(route, component, routeId) {
|
|
12
|
+
const routeMatchId = routeId || route.id;
|
|
13
|
+
if (component && routeMatchId) route.options.component = withModernRouteMatchContext(component, routeMatchId);
|
|
14
|
+
}
|
|
9
15
|
function toTanstackPath(pathname) {
|
|
10
16
|
return pathname.split('/').map((segment)=>{
|
|
11
17
|
if (!segment) return segment;
|
|
@@ -43,6 +49,40 @@ function isModernDeferredData(value) {
|
|
|
43
49
|
function normalizeModernLoaderResult(result) {
|
|
44
50
|
return isModernDeferredData(result) ? result.data : result;
|
|
45
51
|
}
|
|
52
|
+
function pickRouteModuleComponent(routeModule, seen = new Set()) {
|
|
53
|
+
if ('function' == typeof routeModule || routeModule && 'object' == typeof routeModule && '$$typeof' in routeModule) return routeModule;
|
|
54
|
+
if (!routeModule || 'object' != typeof routeModule) return;
|
|
55
|
+
if (seen.has(routeModule)) return;
|
|
56
|
+
seen.add(routeModule);
|
|
57
|
+
const module = routeModule;
|
|
58
|
+
for (const candidate of [
|
|
59
|
+
module.default,
|
|
60
|
+
module.Component
|
|
61
|
+
]){
|
|
62
|
+
const component = pickRouteModuleComponent(candidate, seen);
|
|
63
|
+
if (component) return component;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
function createServerLazyImportComponent(lazyImport, fallbackComponent) {
|
|
67
|
+
if ("u" > typeof document) return fallbackComponent;
|
|
68
|
+
let resolvedComponent;
|
|
69
|
+
let pendingLoad;
|
|
70
|
+
const load = async ()=>{
|
|
71
|
+
if (resolvedComponent) return resolvedComponent;
|
|
72
|
+
const routeModule = await lazyImport();
|
|
73
|
+
const component = pickRouteModuleComponent(routeModule);
|
|
74
|
+
if (component) resolvedComponent = component;
|
|
75
|
+
return resolvedComponent;
|
|
76
|
+
};
|
|
77
|
+
const Component = (props)=>{
|
|
78
|
+
if (resolvedComponent) return createElement(resolvedComponent, props);
|
|
79
|
+
pendingLoad ||= load();
|
|
80
|
+
throw pendingLoad;
|
|
81
|
+
};
|
|
82
|
+
Component.load = load;
|
|
83
|
+
Component.preload = load;
|
|
84
|
+
return Component;
|
|
85
|
+
}
|
|
46
86
|
function throwTanstackRedirect(location) {
|
|
47
87
|
const target = location || '/';
|
|
48
88
|
try {
|
|
@@ -111,7 +151,7 @@ function wrapModernLoader(modernRoute, modernLoader, revalidationState) {
|
|
|
111
151
|
const signal = ctx?.abortController?.signal || ctx?.signal || new AbortController().signal;
|
|
112
152
|
const baseRequest = ctx?.context?.request instanceof Request ? ctx.context.request : void 0;
|
|
113
153
|
const href = 'string' == typeof ctx?.location ? ctx.location : ctx?.location?.publicHref || ctx?.location?.href || ctx?.location?.url?.href || '';
|
|
114
|
-
const request = baseRequest ? new Request(baseRequest, {
|
|
154
|
+
const request = void 0 !== baseRequest ? new Request(baseRequest, {
|
|
115
155
|
signal
|
|
116
156
|
}) : createModernRequest(href, signal);
|
|
117
157
|
const params = mapParamsForModernLoader({
|
|
@@ -174,7 +214,7 @@ function wrapRouteObjectLoader(route, revalidationState) {
|
|
|
174
214
|
const signal = ctx?.abortController?.signal || ctx?.signal || new AbortController().signal;
|
|
175
215
|
const baseRequest = ctx?.context?.request instanceof Request ? ctx.context.request : void 0;
|
|
176
216
|
const href = 'string' == typeof ctx?.location ? ctx.location : ctx?.location?.publicHref || ctx?.location?.href || ctx?.location?.url?.href || '';
|
|
177
|
-
const request = baseRequest ? new Request(baseRequest, {
|
|
217
|
+
const request = void 0 !== baseRequest ? new Request(baseRequest, {
|
|
178
218
|
signal
|
|
179
219
|
}) : createModernRequest(href, signal);
|
|
180
220
|
const params = mapParamsForRouteObjectLoader({
|
|
@@ -209,10 +249,18 @@ function wrapRouteObjectLoader(route, revalidationState) {
|
|
|
209
249
|
}
|
|
210
250
|
function toRouteComponent(routeObject) {
|
|
211
251
|
const route = routeObject;
|
|
252
|
+
const lazyImport = 'function' == typeof route.lazyImport ? route.lazyImport : void 0;
|
|
253
|
+
const fallbackComponent = route.Component ? route.Component : route.element ? ()=>route.element : void 0;
|
|
254
|
+
if (lazyImport && fallbackComponent) return createServerLazyImportComponent(lazyImport, fallbackComponent);
|
|
212
255
|
if (route.Component) return route.Component;
|
|
213
256
|
const element = route.element;
|
|
214
257
|
if (element) return ()=>element;
|
|
215
258
|
}
|
|
259
|
+
function toModernRouteComponent(route) {
|
|
260
|
+
const component = route.component || void 0;
|
|
261
|
+
if ('function' == typeof route.lazyImport && component) return createServerLazyImportComponent(route.lazyImport, component);
|
|
262
|
+
return component;
|
|
263
|
+
}
|
|
216
264
|
function toErrorComponent(routeObject) {
|
|
217
265
|
const route = routeObject;
|
|
218
266
|
if (route.ErrorBoundary) return route.ErrorBoundary;
|
|
@@ -250,12 +298,12 @@ function createRouteFromRouteObject(opts) {
|
|
|
250
298
|
const shouldRevalidate = modernRouteObject.shouldRevalidate;
|
|
251
299
|
const shouldReload = createModernShouldReload(shouldRevalidate, revalidationState);
|
|
252
300
|
const stableFallbackId = routeObject.id || modernRouteObject.file || routeObject.path || 'pathless';
|
|
301
|
+
const component = toRouteComponent(routeObject);
|
|
253
302
|
const base = {
|
|
254
303
|
getParentRoute: ()=>parent,
|
|
255
|
-
component
|
|
304
|
+
component,
|
|
256
305
|
pendingComponent: toPendingComponent(routeObject),
|
|
257
306
|
errorComponent: toErrorComponent(routeObject),
|
|
258
|
-
wrapInSuspense: true,
|
|
259
307
|
staticData: createRouteStaticData({
|
|
260
308
|
modernRouteId: routeObject.id,
|
|
261
309
|
modernRouteAction: modernRouteObject.action,
|
|
@@ -274,6 +322,7 @@ function createRouteFromRouteObject(opts) {
|
|
|
274
322
|
if (isRouteObjectPathlessLayout(routeObject)) base.id = stableFallbackId;
|
|
275
323
|
else base.path = routeObject.index ? '/' : toTanstackPath(routeObject.path || '');
|
|
276
324
|
const route = createTanstackRoute(base);
|
|
325
|
+
wrapRouteComponentWithModernContext(route, component, routeObject.id);
|
|
277
326
|
const children = routeObject.children;
|
|
278
327
|
if (children && children.length > 0) {
|
|
279
328
|
const childRoutes = children.map((child)=>createRouteFromRouteObject({
|
|
@@ -292,7 +341,7 @@ function createRouteFromModernRoute(opts) {
|
|
|
292
341
|
const stableFallbackId = modernId || route._component || route.filename || route.data || ('function' == typeof route.loader ? route.id : void 0);
|
|
293
342
|
const pendingComponent = route.loading || route.pendingComponent;
|
|
294
343
|
const errorComponent = route.error || route.errorComponent;
|
|
295
|
-
const component = route
|
|
344
|
+
const component = toModernRouteComponent(route);
|
|
296
345
|
const modernLoader = route.loader;
|
|
297
346
|
const modernAction = route.action;
|
|
298
347
|
const modernShouldRevalidate = route.shouldRevalidate;
|
|
@@ -304,7 +353,6 @@ function createRouteFromModernRoute(opts) {
|
|
|
304
353
|
component: component || void 0,
|
|
305
354
|
pendingComponent: pendingComponent || void 0,
|
|
306
355
|
errorComponent: errorComponent || void 0,
|
|
307
|
-
wrapInSuspense: true,
|
|
308
356
|
staticData: createRouteStaticData({
|
|
309
357
|
modernRouteId: modernId,
|
|
310
358
|
modernRouteAction: modernAction,
|
|
@@ -326,6 +374,7 @@ function createRouteFromModernRoute(opts) {
|
|
|
326
374
|
base.path = isIndexRoute ? '/' : toTanstackPath(rawPath || '');
|
|
327
375
|
}
|
|
328
376
|
const tanstackRoute = createTanstackRoute(base);
|
|
377
|
+
wrapRouteComponentWithModernContext(tanstackRoute, component, modernId);
|
|
329
378
|
const children = route.children;
|
|
330
379
|
if (children && children.length > 0) {
|
|
331
380
|
const childRoutes = children.map((child)=>createRouteFromModernRoute({
|
|
@@ -338,7 +387,7 @@ function createRouteFromModernRoute(opts) {
|
|
|
338
387
|
}
|
|
339
388
|
function createRouteTreeFromModernRoutes(routes) {
|
|
340
389
|
const rootModern = routes.find((r)=>r && 'nested' === r.type && r.isRoot);
|
|
341
|
-
const rootComponent = rootModern
|
|
390
|
+
const rootComponent = rootModern ? toModernRouteComponent(rootModern) : void 0;
|
|
342
391
|
const pendingComponent = rootModern?.loading;
|
|
343
392
|
const errorComponent = rootModern?.error;
|
|
344
393
|
const rootLoader = rootModern?.loader;
|
|
@@ -351,7 +400,6 @@ function createRouteTreeFromModernRoutes(routes) {
|
|
|
351
400
|
component: rootComponent || void 0,
|
|
352
401
|
pendingComponent: pendingComponent || void 0,
|
|
353
402
|
errorComponent: errorComponent || void 0,
|
|
354
|
-
wrapInSuspense: true,
|
|
355
403
|
notFoundComponent: DefaultNotFound,
|
|
356
404
|
staticData: createRouteStaticData({
|
|
357
405
|
modernRouteId: rootModernId,
|
|
@@ -369,6 +417,7 @@ function createRouteTreeFromModernRoutes(routes) {
|
|
|
369
417
|
if (rootShouldReload) rootRouteOptions.shouldReload = rootShouldReload;
|
|
370
418
|
if (rootModern?.inValidSSRRoute) rootRouteOptions.ssr = false;
|
|
371
419
|
const rootRoute = createTanstackRootRoute(rootRouteOptions);
|
|
420
|
+
if (rootComponent) rootRoute.options.component = withModernRouteMatchContext(rootComponent, rootRouteId);
|
|
372
421
|
const topLevel = rootModern ? rootModern.children || [] : routes;
|
|
373
422
|
const childRoutes = topLevel.map((child)=>createRouteFromModernRoute({
|
|
374
423
|
parent: rootRoute,
|
|
@@ -385,11 +434,11 @@ function createRouteTreeFromRouteObjects(routes) {
|
|
|
385
434
|
const rootRevalidationState = {};
|
|
386
435
|
const rootShouldRevalidate = rootLikeRoute?.shouldRevalidate;
|
|
387
436
|
const rootShouldReload = createModernShouldReload(rootShouldRevalidate, rootRevalidationState);
|
|
437
|
+
const rootComponent = rootLikeRoute ? toRouteComponent(rootLikeRoute) : void 0;
|
|
388
438
|
const rootRouteOptions = {
|
|
389
|
-
component:
|
|
439
|
+
component: rootComponent,
|
|
390
440
|
pendingComponent: rootLikeRoute ? toPendingComponent(rootLikeRoute) : void 0,
|
|
391
441
|
errorComponent: rootLikeRoute ? toErrorComponent(rootLikeRoute) : void 0,
|
|
392
|
-
wrapInSuspense: true,
|
|
393
442
|
notFoundComponent: DefaultNotFound,
|
|
394
443
|
staticData: createRouteStaticData({
|
|
395
444
|
modernRouteId: rootLikeRoute?.id,
|
|
@@ -407,6 +456,7 @@ function createRouteTreeFromRouteObjects(routes) {
|
|
|
407
456
|
if (rootShouldReload) rootRouteOptions.shouldReload = rootShouldReload;
|
|
408
457
|
if (rootLikeRoute?.inValidSSRRoute) rootRouteOptions.ssr = false;
|
|
409
458
|
const rootRoute = createTanstackRootRoute(rootRouteOptions);
|
|
459
|
+
if (rootComponent) rootRoute.options.component = withModernRouteMatchContext(rootComponent, rootRouteId);
|
|
410
460
|
const topLevel = rootLikeRoute ? [
|
|
411
461
|
...rootLikeRoute.children || [],
|
|
412
462
|
...routes.filter((route)=>route !== rootLikeRoute)
|
|
@@ -420,9 +470,11 @@ function createRouteTreeFromRouteObjects(routes) {
|
|
|
420
470
|
}
|
|
421
471
|
function getModernRouteIdsFromMatches(router) {
|
|
422
472
|
const matches = router.state.matches || [];
|
|
473
|
+
const routesById = router.routesById;
|
|
423
474
|
const ids = matches.map((match)=>{
|
|
424
|
-
const
|
|
425
|
-
|
|
475
|
+
const normalizedMatch = match;
|
|
476
|
+
const routeId = 'string' == typeof normalizedMatch.routeId ? normalizedMatch.routeId : void 0;
|
|
477
|
+
return normalizedMatch.route?.options?.staticData?.modernRouteId ?? (routeId ? routesById?.[routeId]?.options?.staticData?.modernRouteId : void 0);
|
|
426
478
|
}).filter((id)=>'string' == typeof id);
|
|
427
479
|
return Array.from(new Set(ids));
|
|
428
480
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "@modern-js/render/rsc-worker";
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { sanitizeSSRPayload, serializeJson } from "@modern-js/runtime-utils/node";
|
|
2
2
|
import { time } from "@modern-js/runtime-utils/time";
|
|
3
3
|
import react from "react";
|
|
4
|
-
import
|
|
4
|
+
import { HelmetProvider } from "react-helmet-async";
|
|
5
|
+
import { getHelmetData, helmetReplace } from "../../../core/server/helmet.mjs";
|
|
5
6
|
import { serializeErrors } from "../../../router/runtime/utils.mjs";
|
|
6
7
|
import prefetch from "../../prefetch";
|
|
7
|
-
import helmet from "../helmet";
|
|
8
8
|
import { SSRErrors, SSRTimings } from "../tracker";
|
|
9
9
|
import { RenderLevel } from "../types.mjs";
|
|
10
10
|
import { ROUTER_DATA_JSON_ID, SSR_DATA_JSON_ID, attributesToString } from "../utils";
|
|
@@ -60,8 +60,8 @@ class Entry {
|
|
|
60
60
|
createReplaceSSRDataScript(ssrDataScripts),
|
|
61
61
|
...this.htmlModifiers
|
|
62
62
|
]);
|
|
63
|
-
const helmetData =
|
|
64
|
-
return helmetData ?
|
|
63
|
+
const helmetData = getHelmetData(context);
|
|
64
|
+
return helmetData ? helmetReplace(html, helmetData) : html;
|
|
65
65
|
}
|
|
66
66
|
async prefetch(context) {
|
|
67
67
|
let prefetchData;
|
|
@@ -82,11 +82,14 @@ class Entry {
|
|
|
82
82
|
const end = time();
|
|
83
83
|
const { ssrContext } = context;
|
|
84
84
|
try {
|
|
85
|
-
const
|
|
85
|
+
const helmetContext = context._helmetContext ??= {};
|
|
86
|
+
const App = react.createElement(HelmetProvider, {
|
|
87
|
+
context: helmetContext
|
|
88
|
+
}, react.createElement(this.App, {
|
|
86
89
|
context: Object.assign(context, {
|
|
87
90
|
ssr: true
|
|
88
91
|
})
|
|
89
|
-
});
|
|
92
|
+
}));
|
|
90
93
|
html = await createRender(App).addCollector(createStyledCollector(this.result)).addCollector(createLoadableCollector({
|
|
91
94
|
stats: ssrContext.loadableStats,
|
|
92
95
|
result: this.result,
|
|
@@ -0,0 +1,264 @@
|
|
|
1
|
+
import "node:module";
|
|
2
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useEffect, useMemo, useState } from "react";
|
|
4
|
+
const defaultStorageKey = 'modernjs:boundary-debugger:enabled';
|
|
5
|
+
const queryParamName = 'modern-boundaries';
|
|
6
|
+
const boundarySelector = '[data-modern-boundary-id]';
|
|
7
|
+
const defaultLabels = {
|
|
8
|
+
cs: {
|
|
9
|
+
toggle: 'zobrazit hranice týmů'
|
|
10
|
+
},
|
|
11
|
+
en: {
|
|
12
|
+
toggle: 'show team boundaries'
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
const palette = [
|
|
16
|
+
'#ff5a5f',
|
|
17
|
+
'#30e27a',
|
|
18
|
+
'#f6cf45',
|
|
19
|
+
'#7c8cff',
|
|
20
|
+
'#29b6f6'
|
|
21
|
+
];
|
|
22
|
+
const readStoredEnabled = (storageKey, fallback)=>{
|
|
23
|
+
if ("u" < typeof window) return fallback;
|
|
24
|
+
try {
|
|
25
|
+
const stored = window.localStorage.getItem(storageKey);
|
|
26
|
+
return null === stored ? fallback : 'true' === stored;
|
|
27
|
+
} catch {
|
|
28
|
+
return fallback;
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const writeStoredEnabled = (storageKey, enabled)=>{
|
|
32
|
+
if ("u" < typeof window) return;
|
|
33
|
+
try {
|
|
34
|
+
window.localStorage.setItem(storageKey, String(enabled));
|
|
35
|
+
} catch {}
|
|
36
|
+
};
|
|
37
|
+
const parseEnabledOverride = (value)=>{
|
|
38
|
+
if (null === value) return;
|
|
39
|
+
const normalized = value.toLowerCase();
|
|
40
|
+
if ('1' === normalized || 'true' === normalized) return true;
|
|
41
|
+
if ('0' === normalized || 'false' === normalized) return false;
|
|
42
|
+
};
|
|
43
|
+
const readQueryEnabledOverride = ()=>{
|
|
44
|
+
if ("u" < typeof window) return;
|
|
45
|
+
try {
|
|
46
|
+
return parseEnabledOverride(new URLSearchParams(window.location.search).get(queryParamName));
|
|
47
|
+
} catch {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
const detectLanguage = ()=>{
|
|
52
|
+
if ("u" < typeof document) return 'en';
|
|
53
|
+
const htmlLanguage = document.documentElement.lang;
|
|
54
|
+
if ('' !== htmlLanguage) return htmlLanguage.split('-')[0] || 'en';
|
|
55
|
+
if ("u" < typeof window) return 'en';
|
|
56
|
+
return window.location.pathname.split('/').filter(Boolean)[0] || 'en';
|
|
57
|
+
};
|
|
58
|
+
const hashBoundaryId = (id)=>{
|
|
59
|
+
let hash = 0;
|
|
60
|
+
for(let index = 0; index < id.length; index++)hash = 31 * hash + id.charCodeAt(index) >>> 0;
|
|
61
|
+
return hash;
|
|
62
|
+
};
|
|
63
|
+
const formatRectKey = (rect)=>[
|
|
64
|
+
Math.round(100 * rect.left) / 100,
|
|
65
|
+
Math.round(100 * rect.top) / 100,
|
|
66
|
+
Math.round(100 * rect.width) / 100,
|
|
67
|
+
Math.round(100 * rect.height) / 100
|
|
68
|
+
].join(':');
|
|
69
|
+
const getBoundaryId = (element)=>element.dataset.modernBoundaryId ?? element.dataset.mfRemote ?? element.getAttribute('data-mf-remote') ?? void 0;
|
|
70
|
+
const collectBoundaryElements = (legacySelector)=>{
|
|
71
|
+
const elements = new Set();
|
|
72
|
+
for (const element of document.querySelectorAll(boundarySelector))elements.add(element);
|
|
73
|
+
if (void 0 === legacySelector || '' === legacySelector) return Array.from(elements);
|
|
74
|
+
try {
|
|
75
|
+
for (const element of document.querySelectorAll(legacySelector))elements.add(element);
|
|
76
|
+
} catch {}
|
|
77
|
+
return Array.from(elements);
|
|
78
|
+
};
|
|
79
|
+
function BoundaryDebugger({ controlMode = 'visible', enabledByDefault = false, labels = defaultLabels, legacySelector, metadata, storageKey = defaultStorageKey }) {
|
|
80
|
+
const [mounted, setMounted] = useState(false);
|
|
81
|
+
const [enabled, setEnabled] = useState(false);
|
|
82
|
+
const [boxes, setBoxes] = useState([]);
|
|
83
|
+
const boundaries = useMemo(()=>new Map(metadata.boundaries.map((entry, index)=>[
|
|
84
|
+
entry.mfName,
|
|
85
|
+
{
|
|
86
|
+
...entry,
|
|
87
|
+
color: entry.color ?? palette[index % palette.length],
|
|
88
|
+
label: entry.label ?? entry.appId
|
|
89
|
+
}
|
|
90
|
+
])), [
|
|
91
|
+
metadata
|
|
92
|
+
]);
|
|
93
|
+
const language = mounted ? detectLanguage() : 'en';
|
|
94
|
+
const toggleLabel = labels[language]?.toggle ?? labels.en?.toggle ?? defaultLabels.en?.toggle ?? 'show team boundaries';
|
|
95
|
+
useEffect(()=>{
|
|
96
|
+
setMounted(true);
|
|
97
|
+
const queryOverride = readQueryEnabledOverride();
|
|
98
|
+
setEnabled(queryOverride ?? readStoredEnabled(storageKey, enabledByDefault));
|
|
99
|
+
}, [
|
|
100
|
+
enabledByDefault,
|
|
101
|
+
storageKey
|
|
102
|
+
]);
|
|
103
|
+
useEffect(()=>{
|
|
104
|
+
if (!mounted) return;
|
|
105
|
+
writeStoredEnabled(storageKey, enabled);
|
|
106
|
+
}, [
|
|
107
|
+
enabled,
|
|
108
|
+
mounted,
|
|
109
|
+
storageKey
|
|
110
|
+
]);
|
|
111
|
+
useEffect(()=>{
|
|
112
|
+
if (!enabled) return void setBoxes([]);
|
|
113
|
+
const readBoxes = ()=>{
|
|
114
|
+
const seenBoxes = new Set();
|
|
115
|
+
const nextBoxes = collectBoundaryElements(legacySelector).map((element)=>{
|
|
116
|
+
const boundaryId = getBoundaryId(element);
|
|
117
|
+
if (void 0 === boundaryId || '' === boundaryId) return;
|
|
118
|
+
const rect = element.getBoundingClientRect();
|
|
119
|
+
if (rect.width <= 0 || rect.height <= 0) return;
|
|
120
|
+
const rectKey = formatRectKey(rect);
|
|
121
|
+
const boxKey = `${boundaryId}:${rectKey}`;
|
|
122
|
+
if (seenBoxes.has(boxKey)) return;
|
|
123
|
+
seenBoxes.add(boxKey);
|
|
124
|
+
const boundary = boundaries.get(boundaryId);
|
|
125
|
+
const color = boundary?.color ?? palette[hashBoundaryId(boundaryId) % palette.length];
|
|
126
|
+
const label = boundary?.label ?? boundary?.appId ?? boundaryId;
|
|
127
|
+
const expose = element.dataset.modernMfExpose;
|
|
128
|
+
const detail = void 0 !== expose && '' !== expose && expose !== label && expose !== boundaryId ? expose : void 0;
|
|
129
|
+
const box = {
|
|
130
|
+
color,
|
|
131
|
+
height: rect.height,
|
|
132
|
+
id: boxKey,
|
|
133
|
+
label,
|
|
134
|
+
left: rect.left,
|
|
135
|
+
top: rect.top,
|
|
136
|
+
width: rect.width
|
|
137
|
+
};
|
|
138
|
+
if (void 0 !== detail) box.detail = detail;
|
|
139
|
+
return box;
|
|
140
|
+
}).filter((box)=>void 0 !== box);
|
|
141
|
+
setBoxes(nextBoxes);
|
|
142
|
+
};
|
|
143
|
+
readBoxes();
|
|
144
|
+
const resizeObserver = "u" < typeof ResizeObserver ? void 0 : new ResizeObserver(readBoxes);
|
|
145
|
+
for (const element of collectBoundaryElements(legacySelector))resizeObserver?.observe(element);
|
|
146
|
+
const mutationObserver = new MutationObserver(readBoxes);
|
|
147
|
+
mutationObserver.observe(document.body, {
|
|
148
|
+
childList: true,
|
|
149
|
+
subtree: true
|
|
150
|
+
});
|
|
151
|
+
window.addEventListener('resize', readBoxes);
|
|
152
|
+
window.addEventListener('scroll', readBoxes, true);
|
|
153
|
+
return ()=>{
|
|
154
|
+
mutationObserver.disconnect();
|
|
155
|
+
resizeObserver?.disconnect();
|
|
156
|
+
window.removeEventListener('resize', readBoxes);
|
|
157
|
+
window.removeEventListener('scroll', readBoxes, true);
|
|
158
|
+
};
|
|
159
|
+
}, [
|
|
160
|
+
boundaries,
|
|
161
|
+
enabled,
|
|
162
|
+
legacySelector
|
|
163
|
+
]);
|
|
164
|
+
if (!mounted) return null;
|
|
165
|
+
const shouldRenderToggle = 'visible' === controlMode || 'hidden-when-off' === controlMode && enabled;
|
|
166
|
+
return /*#__PURE__*/ jsxs(Fragment, {
|
|
167
|
+
children: [
|
|
168
|
+
shouldRenderToggle ? /*#__PURE__*/ jsxs("label", {
|
|
169
|
+
style: {
|
|
170
|
+
alignItems: 'center',
|
|
171
|
+
background: 'rgba(255, 255, 255, 0.96)',
|
|
172
|
+
border: '1px solid rgba(0, 0, 0, 0.1)',
|
|
173
|
+
borderRadius: 10,
|
|
174
|
+
boxShadow: '0 10px 28px rgba(0, 0, 0, 0.14)',
|
|
175
|
+
color: '#111827',
|
|
176
|
+
display: 'flex',
|
|
177
|
+
font: '600 13px/1.2 system-ui, sans-serif',
|
|
178
|
+
gap: 8,
|
|
179
|
+
left: 'max(12px, env(safe-area-inset-left))',
|
|
180
|
+
maxWidth: 'calc(100vw - 24px)',
|
|
181
|
+
padding: '9px 11px',
|
|
182
|
+
position: 'fixed',
|
|
183
|
+
top: 'max(12px, env(safe-area-inset-top))',
|
|
184
|
+
zIndex: 2147483000
|
|
185
|
+
},
|
|
186
|
+
children: [
|
|
187
|
+
/*#__PURE__*/ jsx("input", {
|
|
188
|
+
checked: enabled,
|
|
189
|
+
onChange: (event)=>setEnabled(event.currentTarget.checked),
|
|
190
|
+
type: "checkbox"
|
|
191
|
+
}),
|
|
192
|
+
/*#__PURE__*/ jsx("span", {
|
|
193
|
+
children: toggleLabel
|
|
194
|
+
})
|
|
195
|
+
]
|
|
196
|
+
}) : null,
|
|
197
|
+
enabled ? /*#__PURE__*/ jsx("div", {
|
|
198
|
+
"aria-hidden": "true",
|
|
199
|
+
children: boxes.map((box)=>/*#__PURE__*/ jsx("div", {
|
|
200
|
+
style: {
|
|
201
|
+
border: `2px solid ${box.color}`,
|
|
202
|
+
borderRadius: 8,
|
|
203
|
+
boxShadow: `0 0 0 1px rgba(255,255,255,.72), 0 6px 20px color-mix(in srgb, ${box.color} 20%, transparent)`,
|
|
204
|
+
height: box.height,
|
|
205
|
+
left: box.left,
|
|
206
|
+
pointerEvents: 'none',
|
|
207
|
+
position: 'fixed',
|
|
208
|
+
top: box.top,
|
|
209
|
+
width: box.width,
|
|
210
|
+
zIndex: 2147482999
|
|
211
|
+
},
|
|
212
|
+
children: /*#__PURE__*/ jsxs("span", {
|
|
213
|
+
style: {
|
|
214
|
+
background: box.color,
|
|
215
|
+
borderRadius: 999,
|
|
216
|
+
color: '#111827',
|
|
217
|
+
display: 'grid',
|
|
218
|
+
font: '800 11px/1.1 system-ui, sans-serif',
|
|
219
|
+
gap: 3,
|
|
220
|
+
maxWidth: 'min(280px, calc(100vw - 24px))',
|
|
221
|
+
padding: '5px 8px',
|
|
222
|
+
position: 'absolute',
|
|
223
|
+
right: 4,
|
|
224
|
+
top: 4,
|
|
225
|
+
whiteSpace: 'nowrap'
|
|
226
|
+
},
|
|
227
|
+
children: [
|
|
228
|
+
/*#__PURE__*/ jsx("span", {
|
|
229
|
+
children: box.label
|
|
230
|
+
}),
|
|
231
|
+
void 0 !== box.detail && '' !== box.detail ? /*#__PURE__*/ jsx("span", {
|
|
232
|
+
style: {
|
|
233
|
+
font: '700 10px/1.1 system-ui, sans-serif',
|
|
234
|
+
opacity: 0.82,
|
|
235
|
+
overflow: 'hidden',
|
|
236
|
+
textOverflow: 'ellipsis'
|
|
237
|
+
},
|
|
238
|
+
children: box.detail
|
|
239
|
+
}) : null
|
|
240
|
+
]
|
|
241
|
+
})
|
|
242
|
+
}, box.id))
|
|
243
|
+
}) : null
|
|
244
|
+
]
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
const ultramodernBoundaryDebuggerPlugin = (options)=>({
|
|
248
|
+
name: '@modern-js/runtime/boundary-debugger',
|
|
249
|
+
setup: (api)=>{
|
|
250
|
+
api.wrapRoot((App)=>(props)=>/*#__PURE__*/ jsxs(Fragment, {
|
|
251
|
+
children: [
|
|
252
|
+
/*#__PURE__*/ jsx(App, {
|
|
253
|
+
...props
|
|
254
|
+
}),
|
|
255
|
+
/*#__PURE__*/ jsx(BoundaryDebugger, {
|
|
256
|
+
...options
|
|
257
|
+
})
|
|
258
|
+
]
|
|
259
|
+
}));
|
|
260
|
+
}
|
|
261
|
+
});
|
|
262
|
+
const boundary_debugger = ultramodernBoundaryDebuggerPlugin;
|
|
263
|
+
export default boundary_debugger;
|
|
264
|
+
export { ultramodernBoundaryDebuggerPlugin };
|
|
@@ -86,30 +86,20 @@ const ssrBuilderPlugin = (modernAPI, outputModule, exportLoadablePath)=>({
|
|
|
86
86
|
const hasServerRendering = hasServerRenderingConfig(userConfig);
|
|
87
87
|
const hasModuleFederationRuntimeMarker = hasServerRendering && shouldUseModuleFederationNodeOutput(config);
|
|
88
88
|
const hasExplicitMfSsrFlag = isModuleFederationAppSSREnabled(userConfig);
|
|
89
|
+
const isCloudflareWorkerSSR = 'workerSSR' === name && userConfig.deploy?.target === 'cloudflare';
|
|
89
90
|
const requireExplicitMfSsrFlag = 'true' === process.env.MODERN_MF_APP_SSR_REQUIRE_EXPLICIT;
|
|
90
91
|
if (hasServerRendering && hasModuleFederationRuntimeMarker && !hasExplicitMfSsrFlag) {
|
|
91
92
|
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.';
|
|
92
93
|
if (requireExplicitMfSsrFlag) throw new Error(`${warningMessage} (enforced by MODERN_MF_APP_SSR_REQUIRE_EXPLICIT=true)`);
|
|
93
94
|
console.warn(warningMessage);
|
|
94
95
|
}
|
|
95
|
-
const isModuleFederationAppSSR = hasServerRendering && hasExplicitMfSsrFlag;
|
|
96
|
-
const useModuleFederationNodeOutput = hasServerRendering && isModuleFederationAppSSR && isNodeEnvironmentTarget(config.output.target);
|
|
96
|
+
const isModuleFederationAppSSR = hasServerRendering && hasExplicitMfSsrFlag && !isCloudflareWorkerSSR;
|
|
97
97
|
const ssrEnv = userConfig.deploy?.worker?.ssr || userConfig.server?.rsc ? 'edge' : 'node';
|
|
98
98
|
const appContext = modernAPI.getAppContext();
|
|
99
99
|
const { appDirectory, entrypoints } = appContext;
|
|
100
|
-
const serverBundlerChain = useModuleFederationNodeOutput ? (chain)=>{
|
|
101
|
-
chain.target('async-node');
|
|
102
|
-
chain.output.module(false);
|
|
103
|
-
chain.output.chunkFormat('commonjs');
|
|
104
|
-
chain.output.chunkLoading('async-node');
|
|
105
|
-
chain.output.library({
|
|
106
|
-
...chain.output.get('library') || {},
|
|
107
|
-
type: 'commonjs-module'
|
|
108
|
-
});
|
|
109
|
-
} : void 0;
|
|
110
100
|
const useLoadablePlugin = isUseSSRBundle(userConfig) && !isServerEnvironment && checkUseStringSSR(userConfig, appDirectory, entrypoints);
|
|
111
101
|
const outputConfig = {
|
|
112
|
-
module: isServerEnvironment &&
|
|
102
|
+
module: isServerEnvironment && (outputModule || 'workerSSR' === name && userConfig.deploy?.target === 'cloudflare')
|
|
113
103
|
};
|
|
114
104
|
const useLoadableComponents = isUseSSRBundle(userConfig) && checkUseStringSSR(userConfig, appDirectory, entrypoints);
|
|
115
105
|
return mergeEnvironmentConfig(config, {
|
|
@@ -122,13 +112,13 @@ const ssrBuilderPlugin = (modernAPI, outputModule, exportLoadablePath)=>({
|
|
|
122
112
|
},
|
|
123
113
|
output: outputConfig,
|
|
124
114
|
tools: {
|
|
125
|
-
bundlerChain:
|
|
115
|
+
bundlerChain: useLoadablePlugin ? (chain)=>{
|
|
126
116
|
chain.plugin('loadable').use(loadable_bundler_plugin, [
|
|
127
117
|
{
|
|
128
118
|
filename: LOADABLE_STATS_FILE
|
|
129
119
|
}
|
|
130
120
|
]);
|
|
131
|
-
} : void 0
|
|
121
|
+
} : void 0,
|
|
132
122
|
swc: useLoadableComponents ? {
|
|
133
123
|
jsc: {
|
|
134
124
|
experimental: {
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import "node:module";
|
|
2
2
|
import { jsx } from "react/jsx-runtime";
|
|
3
|
+
import { HelmetProvider } from "react-helmet-async";
|
|
3
4
|
import { InternalRuntimeContext, RuntimeContext } from "../context/index.mjs";
|
|
4
5
|
function wrapRuntimeContextProvider(App, contextValue) {
|
|
5
|
-
const { isBrowser, initialData, routes, routerFramework, context, routeManifest, routerRuntime, routerInstance, routerHydrationScript, routerMatchedRouteIds, routerServerSnapshot, routerContext, unstable_getBlockNavState, ssrContext, _internalContext, _internalRouterBaseName, ...rest } = contextValue;
|
|
6
|
+
const { isBrowser, initialData, routes, routerFramework, context, routeManifest, routerRuntime, routerInstance, routerHydrationScript, routerMatchedRouteIds, routerServerSnapshot, routerContext, unstable_getBlockNavState, ssrContext, _internalContext, _internalRouterBaseName, _helmetContext, ...rest } = contextValue;
|
|
7
|
+
const internalContextValue = contextValue;
|
|
8
|
+
internalContextValue._helmetContext ??= {};
|
|
6
9
|
const runtimeContextValue = {
|
|
7
10
|
isBrowser,
|
|
8
11
|
initialData,
|
|
@@ -12,10 +15,13 @@ function wrapRuntimeContextProvider(App, contextValue) {
|
|
|
12
15
|
...rest
|
|
13
16
|
};
|
|
14
17
|
return /*#__PURE__*/ jsx(InternalRuntimeContext.Provider, {
|
|
15
|
-
value:
|
|
18
|
+
value: internalContextValue,
|
|
16
19
|
children: /*#__PURE__*/ jsx(RuntimeContext.Provider, {
|
|
17
20
|
value: runtimeContextValue,
|
|
18
|
-
children:
|
|
21
|
+
children: /*#__PURE__*/ jsx(HelmetProvider, {
|
|
22
|
+
context: internalContextValue._helmetContext,
|
|
23
|
+
children: App
|
|
24
|
+
})
|
|
19
25
|
})
|
|
20
26
|
});
|
|
21
27
|
}
|