@bleedingdev/modern-js-runtime 3.2.0-ultramodern.11 → 3.2.0-ultramodern.110

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.
Files changed (229) hide show
  1. package/dist/cjs/boundary-debugger/index.js +303 -0
  2. package/dist/cjs/cache/index.js +9 -5
  3. package/dist/cjs/cli/alias.js +9 -5
  4. package/dist/cjs/cli/code.js +9 -5
  5. package/dist/cjs/cli/constants.js +20 -16
  6. package/dist/cjs/cli/entry.js +9 -5
  7. package/dist/cjs/cli/index.js +9 -5
  8. package/dist/cjs/cli/ssr/index.js +14 -20
  9. package/dist/cjs/cli/ssr/loadable-bundler-plugin.js +9 -5
  10. package/dist/cjs/cli/ssr/mode.js +12 -8
  11. package/dist/cjs/cli/template.js +9 -5
  12. package/dist/cjs/cli/template.server.js +10 -5
  13. package/dist/cjs/common.js +14 -10
  14. package/dist/cjs/core/browser/hydrate.js +9 -5
  15. package/dist/cjs/core/browser/index.js +9 -5
  16. package/dist/cjs/core/browser/withCallback.js +9 -5
  17. package/dist/cjs/core/compat/hooks.js +14 -10
  18. package/dist/cjs/core/compat/index.js +9 -5
  19. package/dist/cjs/core/compat/requestContext.js +13 -9
  20. package/dist/cjs/core/config.js +12 -8
  21. package/dist/cjs/core/constants.js +15 -10
  22. package/dist/cjs/core/context/index.js +9 -5
  23. package/dist/cjs/core/context/monitors/default.js +12 -8
  24. package/dist/cjs/core/context/monitors/index.js +9 -5
  25. package/dist/cjs/core/context/monitors/index.server.js +9 -5
  26. package/dist/cjs/core/context/request/index.js +12 -8
  27. package/dist/cjs/core/context/request/index.server.js +9 -5
  28. package/dist/cjs/core/context/response/index.js +15 -11
  29. package/dist/cjs/core/context/response/index.server.js +9 -5
  30. package/dist/cjs/core/context/runtime.js +9 -5
  31. package/dist/cjs/core/context/serverPayload/index.js +13 -9
  32. package/dist/cjs/core/context/serverPayload/index.server.js +9 -5
  33. package/dist/cjs/core/index.js +9 -5
  34. package/dist/cjs/core/plugin/index.js +9 -5
  35. package/dist/cjs/core/react/index.js +9 -5
  36. package/dist/cjs/core/react/wrapper.js +18 -8
  37. package/dist/cjs/core/server/constants.js +15 -11
  38. package/dist/cjs/core/server/federatedCss.js +51 -0
  39. package/dist/cjs/core/server/helmet.js +17 -7
  40. package/dist/cjs/core/server/index.js +9 -5
  41. package/dist/cjs/core/server/react/index.js +9 -5
  42. package/dist/cjs/core/server/react/no-ssr-cache/index.js +9 -5
  43. package/dist/cjs/core/server/react/nossr/index.js +9 -5
  44. package/dist/cjs/core/server/requestHandler.js +9 -5
  45. package/dist/cjs/core/server/scriptOrder.js +63 -0
  46. package/dist/cjs/core/server/server.js +9 -5
  47. package/dist/cjs/core/server/shared.js +12 -8
  48. package/dist/cjs/core/server/stream/afterTemplate.js +22 -10
  49. package/dist/cjs/core/server/stream/beforeTemplate.js +22 -25
  50. package/dist/cjs/core/server/stream/beforeTemplate.worker.js +102 -0
  51. package/dist/cjs/core/server/stream/createReadableStream.js +16 -7
  52. package/dist/cjs/core/server/stream/createReadableStream.worker.js +13 -7
  53. package/dist/cjs/core/server/stream/deferredScript.js +9 -5
  54. package/dist/cjs/core/server/stream/index.js +9 -5
  55. package/dist/cjs/core/server/stream/shared.js +12 -6
  56. package/dist/cjs/core/server/stream/template.js +9 -5
  57. package/dist/cjs/core/server/string/index.js +25 -14
  58. package/dist/cjs/core/server/string/loadable.js +83 -15
  59. package/dist/cjs/core/server/string/ssrData.js +9 -5
  60. package/dist/cjs/core/server/tracer.js +13 -9
  61. package/dist/cjs/core/server/utils.js +9 -5
  62. package/dist/cjs/document/Body.js +9 -5
  63. package/dist/cjs/document/Comment.js +9 -5
  64. package/dist/cjs/document/DocumentContext.js +9 -5
  65. package/dist/cjs/document/DocumentStructureContext.js +9 -5
  66. package/dist/cjs/document/Head.js +9 -5
  67. package/dist/cjs/document/Html.js +9 -5
  68. package/dist/cjs/document/Links.js +9 -5
  69. package/dist/cjs/document/Root.js +9 -5
  70. package/dist/cjs/document/Script.js +9 -5
  71. package/dist/cjs/document/Scripts.js +9 -5
  72. package/dist/cjs/document/Style.js +9 -5
  73. package/dist/cjs/document/Title.js +9 -5
  74. package/dist/cjs/document/cli/index.js +12 -6
  75. package/dist/cjs/document/constants.js +9 -5
  76. package/dist/cjs/document/index.js +9 -5
  77. package/dist/cjs/exports/config-routes.js +12 -8
  78. package/dist/cjs/exports/head.js +209 -10
  79. package/dist/cjs/exports/loadable.js +51 -12
  80. package/dist/cjs/exports/tanstack-router.js +320 -59
  81. package/dist/cjs/index.js +9 -5
  82. package/dist/cjs/internal.js +9 -5
  83. package/dist/cjs/react-server.js +9 -5
  84. package/dist/cjs/router/cli/code/getClientRoutes/getRoutes.js +9 -5
  85. package/dist/cjs/router/cli/code/getClientRoutes/index.js +9 -5
  86. package/dist/cjs/router/cli/code/getClientRoutes/utils.js +9 -5
  87. package/dist/cjs/router/cli/code/index.js +9 -5
  88. package/dist/cjs/router/cli/code/inspect.js +9 -5
  89. package/dist/cjs/router/cli/code/makeLegalIdentifier.js +12 -8
  90. package/dist/cjs/router/cli/code/nestedRoutes.js +9 -5
  91. package/dist/cjs/router/cli/code/tanstackTypes.js +125 -56
  92. package/dist/cjs/router/cli/code/templates.js +24 -14
  93. package/dist/cjs/router/cli/code/utils.js +9 -5
  94. package/dist/cjs/router/cli/config-routes/converter.js +9 -5
  95. package/dist/cjs/router/cli/config-routes/parseRouteConfig.js +9 -5
  96. package/dist/cjs/router/cli/constants.js +23 -19
  97. package/dist/cjs/router/cli/entry.js +9 -5
  98. package/dist/cjs/router/cli/handler.js +9 -5
  99. package/dist/cjs/router/cli/index.js +9 -5
  100. package/dist/cjs/router/index.js +9 -5
  101. package/dist/cjs/router/internal.js +12 -8
  102. package/dist/cjs/router/runtime/CSSLinks.js +9 -5
  103. package/dist/cjs/router/runtime/DefaultNotFound.js +9 -5
  104. package/dist/cjs/router/runtime/DeferredDataScripts.js +12 -8
  105. package/dist/cjs/router/runtime/DeferredDataScripts.node.js +9 -5
  106. package/dist/cjs/router/runtime/PrefetchLink.js +162 -26
  107. package/dist/cjs/router/runtime/constants.js +9 -5
  108. package/dist/cjs/router/runtime/hooks.js +9 -5
  109. package/dist/cjs/router/runtime/index.js +15 -10
  110. package/dist/cjs/router/runtime/internal.js +9 -5
  111. package/dist/cjs/router/runtime/lifecycle.js +18 -14
  112. package/dist/cjs/router/runtime/plugin.js +9 -5
  113. package/dist/cjs/router/runtime/plugin.node.js +9 -5
  114. package/dist/cjs/router/runtime/routerHelper.js +9 -5
  115. package/dist/cjs/router/runtime/rsc-router.js +9 -5
  116. package/dist/cjs/router/runtime/rsc.js +9 -5
  117. package/dist/cjs/router/runtime/server.js +9 -5
  118. package/dist/cjs/router/runtime/tanstack/basepathRewrite.js +12 -8
  119. package/dist/cjs/router/runtime/tanstack/dataMutation.js +9 -5
  120. package/dist/cjs/router/runtime/tanstack/hydrationBoundary.js +48 -0
  121. package/dist/cjs/router/runtime/tanstack/outlet.js +58 -0
  122. package/dist/cjs/router/runtime/tanstack/plugin.js +199 -96
  123. package/dist/cjs/router/runtime/tanstack/plugin.node.js +13 -19
  124. package/dist/cjs/router/runtime/tanstack/prefetchLink.js +10 -6
  125. package/dist/cjs/router/runtime/tanstack/routeTree.js +73 -17
  126. package/dist/cjs/router/runtime/tanstack/rsc/ClientSlot.js +9 -5
  127. package/dist/cjs/router/runtime/tanstack/rsc/CompositeComponent.js +9 -5
  128. package/dist/cjs/router/runtime/tanstack/rsc/ReplayableStream.js +14 -9
  129. package/dist/cjs/router/runtime/tanstack/rsc/RscNodeRenderer.js +9 -5
  130. package/dist/cjs/router/runtime/tanstack/rsc/SlotContext.js +9 -5
  131. package/dist/cjs/router/runtime/tanstack/rsc/client.js +9 -5
  132. package/dist/cjs/router/runtime/tanstack/rsc/createRscProxy.js +9 -5
  133. package/dist/cjs/router/runtime/tanstack/rsc/index.js +9 -5
  134. package/dist/cjs/router/runtime/tanstack/rsc/server.js +9 -5
  135. package/dist/cjs/router/runtime/tanstack/rsc/slotUsageSanitizer.js +9 -5
  136. package/dist/cjs/router/runtime/tanstack/rsc/symbols.js +20 -15
  137. package/dist/cjs/router/runtime/utils.js +9 -5
  138. package/dist/cjs/router/runtime/withRouter.js +9 -5
  139. package/dist/cjs/rsc/client.js +12 -8
  140. package/dist/cjs/rsc/server.js +9 -5
  141. package/dist/cjs/rsc/server.worker.js +62 -0
  142. package/dist/cjs/ssr/index.node.js +13 -9
  143. package/dist/cjs/ssr/serverRender/renderToStream/buildTemplate.after.js +9 -5
  144. package/dist/cjs/ssr/serverRender/renderToString/entry.js +18 -13
  145. package/dist/cjs/ssr/serverRender/types.js +9 -5
  146. package/dist/esm/boundary-debugger/index.mjs +263 -0
  147. package/dist/esm/cli/ssr/index.mjs +5 -15
  148. package/dist/esm/cli/template.server.mjs +1 -0
  149. package/dist/esm/core/react/wrapper.mjs +9 -3
  150. package/dist/esm/core/server/federatedCss.mjs +13 -0
  151. package/dist/esm/core/server/helmet.mjs +5 -2
  152. package/dist/esm/core/server/scriptOrder.mjs +25 -0
  153. package/dist/esm/core/server/stream/afterTemplate.mjs +14 -6
  154. package/dist/esm/core/server/stream/beforeTemplate.mjs +14 -11
  155. package/dist/esm/core/server/stream/beforeTemplate.worker.mjs +64 -0
  156. package/dist/esm/core/server/stream/createReadableStream.mjs +7 -2
  157. package/dist/esm/core/server/stream/createReadableStream.worker.mjs +4 -2
  158. package/dist/esm/core/server/stream/shared.mjs +3 -1
  159. package/dist/esm/core/server/string/index.mjs +17 -9
  160. package/dist/esm/core/server/string/loadable.mjs +70 -9
  161. package/dist/esm/document/cli/index.mjs +3 -1
  162. package/dist/esm/exports/head.mjs +193 -4
  163. package/dist/esm/exports/loadable.mjs +26 -3
  164. package/dist/esm/exports/tanstack-router.mjs +2 -1
  165. package/dist/esm/router/cli/code/tanstackTypes.mjs +116 -51
  166. package/dist/esm/router/cli/code/templates.mjs +15 -9
  167. package/dist/esm/router/runtime/PrefetchLink.mjs +153 -21
  168. package/dist/esm/router/runtime/tanstack/hydrationBoundary.mjs +10 -0
  169. package/dist/esm/router/runtime/tanstack/outlet.mjs +17 -0
  170. package/dist/esm/router/runtime/tanstack/plugin.mjs +193 -94
  171. package/dist/esm/router/runtime/tanstack/plugin.node.mjs +5 -15
  172. package/dist/esm/router/runtime/tanstack/prefetchLink.mjs +1 -1
  173. package/dist/esm/router/runtime/tanstack/routeTree.mjs +65 -13
  174. package/dist/esm/rsc/server.worker.mjs +1 -0
  175. package/dist/esm/ssr/serverRender/renderToString/entry.mjs +9 -6
  176. package/dist/esm-node/boundary-debugger/index.mjs +264 -0
  177. package/dist/esm-node/cli/ssr/index.mjs +5 -15
  178. package/dist/esm-node/cli/template.server.mjs +1 -0
  179. package/dist/esm-node/core/react/wrapper.mjs +9 -3
  180. package/dist/esm-node/core/server/federatedCss.mjs +14 -0
  181. package/dist/esm-node/core/server/helmet.mjs +5 -2
  182. package/dist/esm-node/core/server/scriptOrder.mjs +26 -0
  183. package/dist/esm-node/core/server/stream/afterTemplate.mjs +14 -6
  184. package/dist/esm-node/core/server/stream/beforeTemplate.mjs +14 -11
  185. package/dist/esm-node/core/server/stream/beforeTemplate.worker.mjs +65 -0
  186. package/dist/esm-node/core/server/stream/createReadableStream.mjs +7 -2
  187. package/dist/esm-node/core/server/stream/createReadableStream.worker.mjs +4 -2
  188. package/dist/esm-node/core/server/stream/shared.mjs +3 -1
  189. package/dist/esm-node/core/server/string/index.mjs +17 -9
  190. package/dist/esm-node/core/server/string/loadable.mjs +70 -9
  191. package/dist/esm-node/document/cli/index.mjs +3 -1
  192. package/dist/esm-node/exports/head.mjs +193 -4
  193. package/dist/esm-node/exports/loadable.mjs +26 -3
  194. package/dist/esm-node/exports/tanstack-router.mjs +2 -1
  195. package/dist/esm-node/router/cli/code/tanstackTypes.mjs +116 -51
  196. package/dist/esm-node/router/cli/code/templates.mjs +15 -9
  197. package/dist/esm-node/router/runtime/PrefetchLink.mjs +153 -21
  198. package/dist/esm-node/router/runtime/tanstack/hydrationBoundary.mjs +11 -0
  199. package/dist/esm-node/router/runtime/tanstack/outlet.mjs +18 -0
  200. package/dist/esm-node/router/runtime/tanstack/plugin.mjs +193 -94
  201. package/dist/esm-node/router/runtime/tanstack/plugin.node.mjs +5 -15
  202. package/dist/esm-node/router/runtime/tanstack/prefetchLink.mjs +1 -1
  203. package/dist/esm-node/router/runtime/tanstack/routeTree.mjs +65 -13
  204. package/dist/esm-node/rsc/server.worker.mjs +2 -0
  205. package/dist/esm-node/ssr/serverRender/renderToString/entry.mjs +9 -6
  206. package/dist/types/boundary-debugger/index.d.ts +28 -0
  207. package/dist/types/cli/entry.d.ts +2 -2
  208. package/dist/types/core/context/response/index.server.d.ts +4 -1
  209. package/dist/types/core/context/runtime.d.ts +4 -0
  210. package/dist/types/core/plugin/index.d.ts +1 -1
  211. package/dist/types/core/server/federatedCss.d.ts +5 -0
  212. package/dist/types/core/server/helmet.d.ts +5 -3
  213. package/dist/types/core/server/scriptOrder.d.ts +1 -0
  214. package/dist/types/core/server/stream/beforeTemplate.d.ts +1 -0
  215. package/dist/types/core/server/stream/beforeTemplate.worker.d.ts +10 -0
  216. package/dist/types/core/server/stream/shared.d.ts +8 -0
  217. package/dist/types/core/server/string/loadable.d.ts +11 -0
  218. package/dist/types/core/server/utils.d.ts +11 -1
  219. package/dist/types/document/constants.d.ts +3 -1
  220. package/dist/types/exports/head.d.ts +10 -3
  221. package/dist/types/exports/loadable.d.ts +8 -1
  222. package/dist/types/exports/tanstack-router.d.ts +3 -1
  223. package/dist/types/router/cli/code/utils.d.ts +1 -1
  224. package/dist/types/router/cli/entry.d.ts +1 -1
  225. package/dist/types/router/runtime/PrefetchLink.d.ts +5 -1
  226. package/dist/types/router/runtime/tanstack/hydrationBoundary.d.ts +2 -0
  227. package/dist/types/router/runtime/tanstack/outlet.d.ts +2 -0
  228. package/dist/types/rsc/server.worker.d.ts +1 -0
  229. 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 { Suspense, useContext } from "react";
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(Suspense, {
231
- fallback: null,
232
- children: /*#__PURE__*/ jsx(RouterProvider, {
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 preload;
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: toRouteComponent(routeObject),
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.component;
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?.component;
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: rootLikeRoute ? toRouteComponent(rootLikeRoute) : void 0,
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 route = match.route;
425
- return route?.options?.staticData?.modernRouteId;
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 react_helmet from "react-helmet";
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 = react_helmet.renderStatic();
64
- return helmetData ? helmet(html, helmetData) : html;
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 App = react.createElement(this.App, {
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 && !useModuleFederationNodeOutput && outputModule
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: serverBundlerChain || (useLoadablePlugin ? (chain)=>{
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: {
@@ -36,6 +36,7 @@ const handleRequest = async (request, ServerRoot, options) => {
36
36
  </ServerRoot>,
37
37
  {
38
38
  ...options,
39
+ rscManifest: __rspack_rsc_manifest__,
39
40
  rscRoot: options.rscRoot,
40
41
  },
41
42
  );
@@ -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: contextValue,
18
+ value: internalContextValue,
16
19
  children: /*#__PURE__*/ jsx(RuntimeContext.Provider, {
17
20
  value: runtimeContextValue,
18
- children: App
21
+ children: /*#__PURE__*/ jsx(HelmetProvider, {
22
+ context: internalContextValue._helmetContext,
23
+ children: App
24
+ })
19
25
  })
20
26
  });
21
27
  }