vite-plugin-react-server 1.4.2 → 1.4.4

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 (74) hide show
  1. package/README.md +48 -313
  2. package/dist/package.json +123 -13
  3. package/dist/plugin/bundle/deferredStaticGeneration.js +14 -39
  4. package/dist/plugin/bundle/manifests.js +30 -48
  5. package/dist/plugin/config/autoDiscover/resolveAutoDiscover.d.ts.map +1 -1
  6. package/dist/plugin/config/autoDiscover/resolveAutoDiscover.js +4 -1
  7. package/dist/plugin/config/envPrefixFromConfig.js +12 -7
  8. package/dist/plugin/config/getCondition.d.ts.map +1 -1
  9. package/dist/plugin/config/getCondition.js +7 -5
  10. package/dist/plugin/dev-server/virtualRscHmrPlugin.js +23 -23
  11. package/dist/plugin/environments/createBuildEventPlugin.js +88 -98
  12. package/dist/plugin/environments/createEnvironmentPlugin.js +222 -250
  13. package/dist/plugin/helpers/createRscRenderHelpers.js +33 -34
  14. package/dist/plugin/helpers/createSharedLoader.d.ts.map +1 -1
  15. package/dist/plugin/helpers/createSharedLoader.js +4 -2
  16. package/dist/plugin/helpers/headlessStreamReuseHandler.js +30 -22
  17. package/dist/plugin/helpers/headlessStreamState.js +15 -28
  18. package/dist/plugin/helpers/resolveComponent.d.ts.map +1 -1
  19. package/dist/plugin/helpers/resolveComponent.js +4 -2
  20. package/dist/plugin/index.client.d.ts +5 -0
  21. package/dist/plugin/index.client.d.ts.map +1 -0
  22. package/dist/plugin/index.client.js +4 -0
  23. package/dist/plugin/index.d.ts +4 -3
  24. package/dist/plugin/index.d.ts.map +1 -1
  25. package/dist/plugin/index.js +10 -5
  26. package/dist/plugin/index.server.d.ts +5 -0
  27. package/dist/plugin/index.server.d.ts.map +1 -0
  28. package/dist/plugin/index.server.js +4 -0
  29. package/dist/plugin/metrics/createWorkerStartupMetrics.js +31 -13
  30. package/dist/plugin/orchestrator/createPluginOrchestrator.client.js +41 -38
  31. package/dist/plugin/orchestrator/createPluginOrchestrator.server.js +43 -46
  32. package/dist/plugin/plugin.client.js +2 -2
  33. package/dist/plugin/plugin.server.js +2 -2
  34. package/dist/plugin/react-static/createBuildLoader.client.js +12 -6
  35. package/dist/plugin/react-static/createBuildLoader.server.js +255 -235
  36. package/dist/plugin/react-static/plugin.client.js +684 -770
  37. package/dist/plugin/react-static/plugin.server.js +517 -603
  38. package/dist/plugin/react-static/processCssFilesForPages.js +103 -88
  39. package/dist/plugin/react-static/renderPage.client.js +455 -529
  40. package/dist/plugin/react-static/renderPage.server.js +485 -508
  41. package/dist/plugin/react-static/renderPagesBatched.js +277 -275
  42. package/dist/plugin/react-static/rscToHtmlStream.client.js +48 -29
  43. package/dist/plugin/react-static/rscToHtmlStream.server.js +62 -37
  44. package/dist/plugin/react-static/temporaryReferences.server.js +11 -2
  45. package/dist/plugin/stream/createMainThreadHandlers.js +40 -31
  46. package/dist/plugin/stream/renderRscStream.server.d.ts.map +1 -1
  47. package/dist/plugin/stream/renderRscStream.server.js +127 -144
  48. package/dist/plugin/transformer/createTransformerPlugin.js +226 -265
  49. package/dist/plugin/utils/checkReactVersion.d.ts +7 -0
  50. package/dist/plugin/utils/checkReactVersion.d.ts.map +1 -0
  51. package/dist/plugin/utils/checkReactVersion.js +23 -0
  52. package/dist/plugin/utils/envUrls.node.js +12 -11
  53. package/dist/plugin/vendor/vendor-alias.js +84 -114
  54. package/dist/plugin/vendor/vendor.client.d.ts.map +1 -1
  55. package/dist/plugin/vendor/vendor.client.js +1 -3
  56. package/dist/plugin/worker/rsc/handleRscRender.d.ts.map +1 -1
  57. package/dist/plugin/worker/rsc/handleRscRender.js +3 -1
  58. package/dist/tsconfig.tsbuildinfo +1 -1
  59. package/package.json +123 -13
  60. package/plugin/config/autoDiscover/resolveAutoDiscover.ts +4 -0
  61. package/plugin/config/getCondition.ts +6 -4
  62. package/plugin/helpers/createRscRenderHelpers.ts +1 -1
  63. package/plugin/helpers/createSharedLoader.ts +6 -1
  64. package/plugin/helpers/resolveComponent.ts +6 -1
  65. package/plugin/index.client.ts +4 -0
  66. package/plugin/index.server.ts +4 -0
  67. package/plugin/index.ts +12 -5
  68. package/plugin/plugin.client.ts +1 -1
  69. package/plugin/plugin.server.ts +1 -1
  70. package/plugin/stream/renderRscStream.server.ts +3 -0
  71. package/plugin/utils/checkReactVersion.ts +28 -0
  72. package/plugin/vendor/vendor.client.ts +0 -2
  73. package/plugin/worker/rsc/handleRscRender.ts +2 -0
  74. package/scripts/generate-toc.mjs +27 -294
@@ -1,94 +1,109 @@
1
- import { collectManifestCss } from "../helpers/collectManifestCss.js";
2
- import { createUnifiedCssProcessor } from "../helpers/createUnifiedCssProcessor.js";
3
- import { join } from "node:path";
4
- export function processCssFilesForPages({ userOptions, autoDiscoveredFiles, staticManifest, serverManifest, bundle, logger, }) {
5
- const cssFilesByPage = new Map();
6
- // First collect global styles from index.html
7
- const indexHtmlCssInputs = collectManifestCss(staticManifest ?? {}, "index.html");
8
- const clientEntryCssInputs = userOptions.clientEntry
9
- ? collectManifestCss(staticManifest ?? {}, userOptions.clientEntry)
10
- : null;
11
- const globalCssInputs = {
12
- ...indexHtmlCssInputs,
13
- ...clientEntryCssInputs,
14
- };
15
- // transform the server manifest to include the css files from the static manifest
16
- // The server manifest needs CSS info for inlining or requesting .js modules for classnames
17
- const transformedServerManifest = Object.fromEntries(Object.entries(serverManifest ?? {}).map(([key, value]) => {
18
- const manifestEntry = value;
19
- // If it's a bundle entry, just use the file property directly
20
- if (manifestEntry.isEntry && manifestEntry.file) {
21
- // Find the corresponding static manifest entry by matching the file path
22
- for (const [, staticValue] of Object.entries(staticManifest ?? {})) {
23
- if (staticValue && typeof staticValue === 'object' && 'file' in staticValue) {
24
- if (staticValue.file === manifestEntry.file && staticValue.css?.length) {
25
- return [
26
- key,
27
- {
28
- ...manifestEntry,
29
- css: staticValue.css,
30
- },
31
- ];
32
- }
1
+ /**
2
+ * vite-plugin-react-server
3
+ * Copyright (c) Nico Brinkkemper
4
+ * MIT License
5
+ */
6
+ import { collectManifestCss } from '../helpers/collectManifestCss.js';
7
+ import { createUnifiedCssProcessor } from '../helpers/createUnifiedCssProcessor.js';
8
+ import { join } from 'node:path';
9
+
10
+ function processCssFilesForPages({
11
+ userOptions,
12
+ autoDiscoveredFiles,
13
+ staticManifest,
14
+ serverManifest,
15
+ bundle,
16
+ logger
17
+ }) {
18
+ const cssFilesByPage = /* @__PURE__ */ new Map();
19
+ const indexHtmlCssInputs = collectManifestCss(
20
+ staticManifest ?? {},
21
+ "index.html"
22
+ );
23
+ const clientEntryCssInputs = userOptions.clientEntry ? collectManifestCss(
24
+ staticManifest ?? {},
25
+ userOptions.clientEntry
26
+ ) : null;
27
+ const globalCssInputs = {
28
+ ...indexHtmlCssInputs,
29
+ ...clientEntryCssInputs
30
+ };
31
+ const transformedServerManifest = Object.fromEntries(
32
+ Object.entries(serverManifest ?? {}).map(([key, value]) => {
33
+ const manifestEntry = value;
34
+ if (manifestEntry.isEntry && manifestEntry.file) {
35
+ for (const [, staticValue] of Object.entries(staticManifest ?? {})) {
36
+ if (staticValue && typeof staticValue === "object" && "file" in staticValue) {
37
+ if (staticValue.file === manifestEntry.file && staticValue.css?.length) {
38
+ return [
39
+ key,
40
+ {
41
+ ...manifestEntry,
42
+ css: staticValue.css
33
43
  }
44
+ ];
34
45
  }
46
+ }
35
47
  }
36
- return [key, value];
37
- }));
38
- const globalCss = new Map();
39
- const { urlMap = new Map() } = autoDiscoveredFiles ?? {};
40
- // Create unified CSS processor
41
- const cssProcessor = createUnifiedCssProcessor({
42
- userOptions,
43
- logger,
44
- verbose: userOptions.verbose,
45
- staticOutDir: staticManifest ? join(userOptions.projectRoot || '', userOptions.build.outDir, userOptions.build.client) : undefined,
46
- staticManifest,
47
- bundle,
48
- });
49
- // Collect CSS files for each page and its props
50
- for (const [url, { page, props }] of urlMap) {
51
- if (userOptions.verbose) {
52
- logger.info(`[plugin.server] Processing route: ${url}, page: ${page}, props: ${props}`);
53
- }
54
- // Use the transformed server manifest which now includes CSS info from the static manifest
55
- // This allows the server to inline CSS or request .js modules for classnames
56
- if (userOptions.verbose) {
57
- logger.info(`[plugin.server] transformedServerManifest keys: ${Object.keys(transformedServerManifest).join(', ')}`);
58
- logger.info(`[plugin.server] Looking for CSS starting from: ${page} and ${props || 'none'}`);
59
- if (transformedServerManifest[page]) {
60
- logger.info(`[plugin.server] Page entry: ${JSON.stringify(transformedServerManifest[page], null, 2)}`);
61
- }
62
- if (props && transformedServerManifest[props]) {
63
- logger.info(`[plugin.server] Props entry: ${JSON.stringify(transformedServerManifest[props], null, 2)}`);
64
- }
65
- // Debug: Check what CSS entries exist in the transformed manifest
66
- for (const [key, value] of Object.entries(transformedServerManifest)) {
67
- if (value && typeof value === 'object' && 'css' in value && Array.isArray(value.css) && value.css.length > 0) {
68
- logger.info(`[plugin.server] Found CSS entry: ${key} -> ${JSON.stringify(value.css)}`);
69
- }
70
- }
71
- }
72
- const cssInputs = collectManifestCss(transformedServerManifest, props ? [page, props] : page);
73
- if (userOptions.verbose) {
74
- logger.info(`[plugin.server] CSS inputs for ${url}: ${Object.keys(cssInputs).length} files`);
75
- for (const [key, value] of Object.entries(cssInputs)) {
76
- logger.info(`[plugin.server] CSS input: ${key} -> ${value}`);
77
- }
78
- }
79
- // Process CSS files using unified CSS processor
80
- const pageCssMap = cssProcessor.processCssFromStaticBuild(cssInputs);
81
- // Add global styles if they exist
82
- if (Object.keys(globalCssInputs).length > 0) {
83
- const globalCssMap = cssProcessor.processCssFromStaticBuild(globalCssInputs);
84
- for (const [key, value] of globalCssMap.entries()) {
85
- globalCss.set(key, value);
86
- }
48
+ }
49
+ return [key, value];
50
+ })
51
+ );
52
+ const globalCss = /* @__PURE__ */ new Map();
53
+ const { urlMap = /* @__PURE__ */ new Map() } = autoDiscoveredFiles ?? {};
54
+ const cssProcessor = createUnifiedCssProcessor({
55
+ userOptions,
56
+ logger,
57
+ verbose: userOptions.verbose,
58
+ staticOutDir: staticManifest ? join(userOptions.projectRoot || "", userOptions.build.outDir, userOptions.build.client) : void 0,
59
+ staticManifest});
60
+ for (const [url, { page, props }] of urlMap) {
61
+ if (userOptions.verbose) {
62
+ logger.info(
63
+ `[plugin.server] Processing route: ${url}, page: ${page}, props: ${props}`
64
+ );
65
+ }
66
+ if (userOptions.verbose) {
67
+ logger.info(`[plugin.server] transformedServerManifest keys: ${Object.keys(transformedServerManifest).join(", ")}`);
68
+ logger.info(`[plugin.server] Looking for CSS starting from: ${page} and ${props || "none"}`);
69
+ if (transformedServerManifest[page]) {
70
+ logger.info(`[plugin.server] Page entry: ${JSON.stringify(transformedServerManifest[page], null, 2)}`);
71
+ }
72
+ if (props && transformedServerManifest[props]) {
73
+ logger.info(`[plugin.server] Props entry: ${JSON.stringify(transformedServerManifest[props], null, 2)}`);
74
+ }
75
+ for (const [key, value] of Object.entries(transformedServerManifest)) {
76
+ if (value && typeof value === "object" && "css" in value && Array.isArray(value.css) && value.css.length > 0) {
77
+ logger.info(`[plugin.server] Found CSS entry: ${key} -> ${JSON.stringify(value.css)}`);
87
78
  }
88
- cssFilesByPage.set(url, pageCssMap);
79
+ }
80
+ }
81
+ const cssInputs = collectManifestCss(
82
+ transformedServerManifest,
83
+ props ? [page, props] : page
84
+ );
85
+ if (userOptions.verbose) {
86
+ logger.info(
87
+ `[plugin.server] CSS inputs for ${url}: ${Object.keys(cssInputs).length} files`
88
+ );
89
+ for (const [key, value] of Object.entries(cssInputs)) {
90
+ logger.info(`[plugin.server] CSS input: ${key} -> ${value}`);
91
+ }
92
+ }
93
+ const pageCssMap = cssProcessor.processCssFromStaticBuild(cssInputs);
94
+ if (Object.keys(globalCssInputs).length > 0) {
95
+ const globalCssMap = cssProcessor.processCssFromStaticBuild(globalCssInputs);
96
+ for (const [key, value] of globalCssMap.entries()) {
97
+ globalCss.set(key, value);
98
+ }
89
99
  }
90
- return {
91
- cssFilesByPage,
92
- globalCss,
93
- };
100
+ cssFilesByPage.set(url, pageCssMap);
101
+ }
102
+ return {
103
+ cssFilesByPage,
104
+ globalCss
105
+ };
94
106
  }
107
+
108
+ export { processCssFilesForPages };
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"processCssFilesForPages.js","sources":["../../../plugin/react-static/processCssFilesForPages.ts"],"sourcesContent":["import type {\n  AutoDiscoveredFiles,\n  CssContent,\n  ResolvedUserOptions,\n} from \"../types.js\";\nimport type { Logger, Manifest } from \"vite\";\nimport { collectManifestCss } from \"../helpers/collectManifestCss.js\";\nimport { createUnifiedCssProcessor } from \"../helpers/createUnifiedCssProcessor.js\";\nimport { join } from \"node:path\";\n\ninterface ProcessCssFilesForPagesOptions {\n  userOptions: ResolvedUserOptions;\n  autoDiscoveredFiles: AutoDiscoveredFiles | null;\n  staticManifest: Manifest | undefined;\n  serverManifest: Manifest | undefined;\n  bundle: any;\n  logger: Logger;\n}\n\nexport function processCssFilesForPages({\n  userOptions,\n  autoDiscoveredFiles,\n  staticManifest,\n  serverManifest,\n  bundle,\n  logger,\n}: ProcessCssFilesForPagesOptions): {\n  cssFilesByPage: Map<string, Map<string, CssContent>>;\n  globalCss: Map<string, CssContent>;\n} {\n  const cssFilesByPage = new Map();\n\n  // First collect global styles from index.html\n  const indexHtmlCssInputs = collectManifestCss(\n    staticManifest ?? {},\n    \"index.html\"\n  );\n  const clientEntryCssInputs = userOptions.clientEntry\n    ? collectManifestCss(\n        staticManifest ?? {},\n        userOptions.clientEntry\n      )\n    : null;\n  const globalCssInputs = {\n    ...indexHtmlCssInputs,\n    ...clientEntryCssInputs,\n  };\n\n  // transform the server manifest to include the css files from the static manifest\n  // The server manifest needs CSS info for inlining or requesting .js modules for classnames\n  const transformedServerManifest = Object.fromEntries(\n    Object.entries(serverManifest ?? {}).map(([key, value]) => {\n      const manifestEntry = value as any;\n      \n      // If it's a bundle entry, just use the file property directly\n      if (manifestEntry.isEntry && manifestEntry.file) {\n        // Find the corresponding static manifest entry by matching the file path\n        for (const [, staticValue] of Object.entries(staticManifest ?? {})) {\n          if (staticValue && typeof staticValue === 'object' && 'file' in staticValue) {\n            if (staticValue.file === manifestEntry.file && staticValue.css?.length) {\n              return [\n                key,\n                {\n                  ...manifestEntry,\n                  css: staticValue.css,\n                },\n              ];\n            }\n          }\n        }\n      }\n      \n      return [key, value];\n    })\n  );\n  const globalCss = new Map();\n  const { urlMap = new Map() } = autoDiscoveredFiles ?? {};\n\n  // Create unified CSS processor\n  const cssProcessor = createUnifiedCssProcessor({\n    userOptions,\n    logger,\n    verbose: userOptions.verbose,\n    staticOutDir: staticManifest ? join(userOptions.projectRoot || '', userOptions.build.outDir, userOptions.build.client) : undefined,\n    staticManifest,\n    bundle,\n  });\n\n  // Collect CSS files for each page and its props\n  for (const [url, { page, props }] of urlMap) {\n    if (userOptions.verbose) {\n      logger.info(\n        `[plugin.server] Processing route: ${url}, page: ${page}, props: ${props}`\n      );\n    }\n    // Use the transformed server manifest which now includes CSS info from the static manifest\n    // This allows the server to inline CSS or request .js modules for classnames\n    if (userOptions.verbose) {\n      logger.info(`[plugin.server] transformedServerManifest keys: ${Object.keys(transformedServerManifest).join(', ')}`);\n      logger.info(`[plugin.server] Looking for CSS starting from: ${page} and ${props || 'none'}`);\n      if (transformedServerManifest[page]) {\n        logger.info(`[plugin.server] Page entry: ${JSON.stringify(transformedServerManifest[page], null, 2)}`);\n      }\n      if (props && transformedServerManifest[props]) {\n        logger.info(`[plugin.server] Props entry: ${JSON.stringify(transformedServerManifest[props], null, 2)}`);\n      }\n      \n      // Debug: Check what CSS entries exist in the transformed manifest\n      for (const [key, value] of Object.entries(transformedServerManifest)) {\n        if (value && typeof value === 'object' && 'css' in value && Array.isArray(value.css) && value.css.length > 0) {\n          logger.info(`[plugin.server] Found CSS entry: ${key} -> ${JSON.stringify(value.css)}`);\n        }\n      }\n    }\n    \n    const cssInputs = collectManifestCss(\n      transformedServerManifest,\n      props ? [page, props] : page\n    );\n    if (userOptions.verbose) {\n      logger.info(\n        `[plugin.server] CSS inputs for ${url}: ${\n          Object.keys(cssInputs).length\n        } files`\n      );\n      for (const [key, value] of Object.entries(cssInputs)) {\n        logger.info(`[plugin.server] CSS input: ${key} -> ${value}`);\n      }\n    }\n\n    // Process CSS files using unified CSS processor\n    const pageCssMap = cssProcessor.processCssFromStaticBuild(cssInputs);\n\n    // Add global styles if they exist\n    if (Object.keys(globalCssInputs).length > 0) {\n      const globalCssMap = cssProcessor.processCssFromStaticBuild(globalCssInputs);\n      for (const [key, value] of globalCssMap.entries()) {\n        globalCss.set(key, value);\n      }\n    }\n    cssFilesByPage.set(url, pageCssMap);\n  }\n\n  return {\n    cssFilesByPage,\n    globalCss,\n  };\n}\n"],"names":[],"mappings":"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"}