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.
- package/README.md +48 -313
- package/dist/package.json +123 -13
- package/dist/plugin/bundle/deferredStaticGeneration.js +14 -39
- package/dist/plugin/bundle/manifests.js +30 -48
- package/dist/plugin/config/autoDiscover/resolveAutoDiscover.d.ts.map +1 -1
- package/dist/plugin/config/autoDiscover/resolveAutoDiscover.js +4 -1
- package/dist/plugin/config/envPrefixFromConfig.js +12 -7
- package/dist/plugin/config/getCondition.d.ts.map +1 -1
- package/dist/plugin/config/getCondition.js +7 -5
- package/dist/plugin/dev-server/virtualRscHmrPlugin.js +23 -23
- package/dist/plugin/environments/createBuildEventPlugin.js +88 -98
- package/dist/plugin/environments/createEnvironmentPlugin.js +222 -250
- package/dist/plugin/helpers/createRscRenderHelpers.js +33 -34
- package/dist/plugin/helpers/createSharedLoader.d.ts.map +1 -1
- package/dist/plugin/helpers/createSharedLoader.js +4 -2
- package/dist/plugin/helpers/headlessStreamReuseHandler.js +30 -22
- package/dist/plugin/helpers/headlessStreamState.js +15 -28
- package/dist/plugin/helpers/resolveComponent.d.ts.map +1 -1
- package/dist/plugin/helpers/resolveComponent.js +4 -2
- package/dist/plugin/index.client.d.ts +5 -0
- package/dist/plugin/index.client.d.ts.map +1 -0
- package/dist/plugin/index.client.js +4 -0
- package/dist/plugin/index.d.ts +4 -3
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +10 -5
- package/dist/plugin/index.server.d.ts +5 -0
- package/dist/plugin/index.server.d.ts.map +1 -0
- package/dist/plugin/index.server.js +4 -0
- package/dist/plugin/metrics/createWorkerStartupMetrics.js +31 -13
- package/dist/plugin/orchestrator/createPluginOrchestrator.client.js +41 -38
- package/dist/plugin/orchestrator/createPluginOrchestrator.server.js +43 -46
- package/dist/plugin/plugin.client.js +2 -2
- package/dist/plugin/plugin.server.js +2 -2
- package/dist/plugin/react-static/createBuildLoader.client.js +12 -6
- package/dist/plugin/react-static/createBuildLoader.server.js +255 -235
- package/dist/plugin/react-static/plugin.client.js +684 -770
- package/dist/plugin/react-static/plugin.server.js +517 -603
- package/dist/plugin/react-static/processCssFilesForPages.js +103 -88
- package/dist/plugin/react-static/renderPage.client.js +455 -529
- package/dist/plugin/react-static/renderPage.server.js +485 -508
- package/dist/plugin/react-static/renderPagesBatched.js +277 -275
- package/dist/plugin/react-static/rscToHtmlStream.client.js +48 -29
- package/dist/plugin/react-static/rscToHtmlStream.server.js +62 -37
- package/dist/plugin/react-static/temporaryReferences.server.js +11 -2
- package/dist/plugin/stream/createMainThreadHandlers.js +40 -31
- package/dist/plugin/stream/renderRscStream.server.d.ts.map +1 -1
- package/dist/plugin/stream/renderRscStream.server.js +127 -144
- package/dist/plugin/transformer/createTransformerPlugin.js +226 -265
- package/dist/plugin/utils/checkReactVersion.d.ts +7 -0
- package/dist/plugin/utils/checkReactVersion.d.ts.map +1 -0
- package/dist/plugin/utils/checkReactVersion.js +23 -0
- package/dist/plugin/utils/envUrls.node.js +12 -11
- package/dist/plugin/vendor/vendor-alias.js +84 -114
- package/dist/plugin/vendor/vendor.client.d.ts.map +1 -1
- package/dist/plugin/vendor/vendor.client.js +1 -3
- package/dist/plugin/worker/rsc/handleRscRender.d.ts.map +1 -1
- package/dist/plugin/worker/rsc/handleRscRender.js +3 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +123 -13
- package/plugin/config/autoDiscover/resolveAutoDiscover.ts +4 -0
- package/plugin/config/getCondition.ts +6 -4
- package/plugin/helpers/createRscRenderHelpers.ts +1 -1
- package/plugin/helpers/createSharedLoader.ts +6 -1
- package/plugin/helpers/resolveComponent.ts +6 -1
- package/plugin/index.client.ts +4 -0
- package/plugin/index.server.ts +4 -0
- package/plugin/index.ts +12 -5
- package/plugin/plugin.client.ts +1 -1
- package/plugin/plugin.server.ts +1 -1
- package/plugin/stream/renderRscStream.server.ts +3 -0
- package/plugin/utils/checkReactVersion.ts +28 -0
- package/plugin/vendor/vendor.client.ts +0 -2
- package/plugin/worker/rsc/handleRscRender.ts +2 -0
- package/scripts/generate-toc.mjs +27 -294
|
@@ -1,94 +1,109 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
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
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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
|
-
|
|
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
|
-
|
|
91
|
-
|
|
92
|
-
|
|
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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"}
|