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
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* MIT License
|
|
5
5
|
*/
|
|
6
6
|
import { assertReactServer } from './config/getCondition.js';
|
|
7
|
-
import { createPluginOrchestrator } from './orchestrator/createPluginOrchestrator.js';
|
|
7
|
+
import { createPluginOrchestrator } from './orchestrator/createPluginOrchestrator.server.js';
|
|
8
8
|
|
|
9
9
|
assertReactServer();
|
|
10
10
|
const vitePluginReactServer = function _vitePluginReactServer(options, strategy) {
|
|
@@ -28,4 +28,4 @@ const vitePluginReactServer = function _vitePluginReactServer(options, strategy)
|
|
|
28
28
|
};
|
|
29
29
|
|
|
30
30
|
export { vitePluginReactServer };
|
|
31
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGx1Z2luLnNlcnZlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vcGx1Z2luL3BsdWdpbi5zZXJ2ZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBWaXRlUGx1Z2luTWFpbkZuIH0gZnJvbSBcIi4vdHlwZXMuanNcIjtcbmltcG9ydCB0eXBlIHsgVXNlck9wdGlvbnMsIFN0cmF0ZWd5IH0gZnJvbSBcIi4vb3JjaGVzdHJhdG9yL3R5cGVzLmpzXCI7XG5cbmltcG9ydCB7IGFzc2VydFJlYWN0U2VydmVyIH0gZnJvbSBcIi4vY29uZmlnL2dldENvbmRpdGlvbi5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlUGx1Z2luT3JjaGVzdHJhdG9yIH0gZnJvbSBcIi4vb3JjaGVzdHJhdG9yL2NyZWF0ZVBsdWdpbk9yY2hlc3RyYXRvci5zZXJ2ZXIuanNcIjtcblxuYXNzZXJ0UmVhY3RTZXJ2ZXIoKTtcblxuLyoqXG4gKiBNYWluIGVudHJ5cG9pbnQgZm9yIFJlYWN0IFNlcnZlciBDb21wb25lbnRzLlxuICpcbiAqIFRoaXMgcGx1Z2luIHVzZXMgdGhlIGludGVsbGlnZW50IG9yY2hlc3RyYXRvciB0byBhZGFwdCBpdHMgYmVoYXZpb3IgYmFzZWQgb24gdGhlIGJ1aWxkIGNvbnRleHQ6XG4gKiAtIEluIEVudmlyb25tZW50IEFQSSBidWlsZHM6IGxldmVyYWdlcyBmdWxsIFJTQyBjYXBhYmlsaXRpZXNcbiAqIC0gV2l0aCBzdGF0aWMgcGFnZXM6IGFkZHMgc3RhdGljIGdlbmVyYXRpb24gcGx1Z2luIHdoZW4gYXBwcm9wcmlhdGVcbiAqXG4gKiBVc2UgdGhpcyBmb3Igc2VydmVyLXNpZGUgcmVuZGVyaW5nIGFuZCBzdGF0aWMgZ2VuZXJhdGlvbiB3aXRoIGZ1bGwgUlNDIHN1cHBvcnQuXG4gKiBDb25maWd1cmUgdGhlIGJ1aWxkIHRhcmdldCB0aHJvdWdoIHRoZSBzdHJhdGVneSBwYXJhbWV0ZXIuXG4gKiBAcGFyYW0gb3B0aW9uc1xuICogQHBhcmFtIHN0cmF0ZWd5XG4gKiBAcmV0dXJuc1xuICovXG5leHBvcnQgY29uc3Qgdml0ZVBsdWdpblJlYWN0U2VydmVyOiBWaXRlUGx1Z2luTWFpbkZuID1cbiAgZnVuY3Rpb24gX3ZpdGVQbHVnaW5SZWFjdFNlcnZlcihvcHRpb25zLCBzdHJhdGVneT86IFN0cmF0ZWd5KSB7XG4gICAgaWYgKG9wdGlvbnMgPT0gbnVsbCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwib3B0aW9ucyBpcyByZXF1aXJlZFwiKTtcbiAgICB9XG5cblxuICAgIC8vIFVzZSB0aGUgaW50ZWxsaWdlbnQgb3JjaGVzdHJhdG9yIGZvciBwbHVnaW4gY29tcG9zaXRpb24gd2l0aCBzZXJ2ZXIgY29udGV4dFxuICAgIGNvbnN0IHVzZXJTdHJhdGVneSA9IChvcHRpb25zIGFzIFVzZXJPcHRpb25zKS5zdHJhdGVneSB8fCB7fTtcbiAgICBjb25zdCBmaW5hbFN0cmF0ZWd5OiBTdHJhdGVneSA9IHtcbiAgICAgIG1vZGU6IFwiYXV0b1wiLCAvLyBTZXJ2ZXIgYnVpbGRzXG4gICAgICBpbXBvcnRDb250ZXh0OiBcInJlYWN0LXNlcnZlclwiLCAvLyBJbmRpY2F0ZSB0aGlzIGNhbWUgZnJvbSBzZXJ2ZXIgY29udGV4dFxuICAgICAgZW52aXJvbm1lbnRUYXJnZXRzOiBuZXcgTWFwKFtbXCJjbGllbnRcIiwgXCJjbGllbnRcIl0sIFtcInNzclwiLCBcInNzclwiXSwgW1wic2VydmVyXCIsIFwic2VydmVyXCJdXSksIFxuICAgICAgLi4udXNlclN0cmF0ZWd5LFxuICAgICAgLi4uc3RyYXRlZ3lcbiAgICB9O1xuICAgIFxuXG4gICAgcmV0dXJuIGNyZWF0ZVBsdWdpbk9yY2hlc3RyYXRvcih7XG4gICAgICAuLi5vcHRpb25zLFxuICAgICAgc3RyYXRlZ3k6IGZpbmFsU3RyYXRlZ3lcbiAgICB9KTtcbiAgfTtcblxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBTUEsaUJBQWtCLEVBQUE7QUFlWCxNQUFNLHFCQUNYLEdBQUEsU0FBUyxzQkFBdUIsQ0FBQSxPQUFBLEVBQVMsUUFBcUIsRUFBQTtBQUM1RCxFQUFBLElBQUksV0FBVyxJQUFNLEVBQUE7QUFDbkIsSUFBTSxNQUFBLElBQUksTUFBTSxxQkFBcUIsQ0FBQTtBQUFBO0FBS3ZDLEVBQU0sTUFBQSxZQUFBLEdBQWdCLE9BQXdCLENBQUEsUUFBQSxJQUFZLEVBQUM7QUFDM0QsRUFBQSxNQUFNLGFBQTBCLEdBQUE7QUFBQSxJQUM5QixJQUFNLEVBQUEsTUFBQTtBQUFBO0FBQUEsSUFDTixhQUFlLEVBQUEsY0FBQTtBQUFBO0FBQUEsSUFDZixvQ0FBd0IsSUFBQSxHQUFBLENBQUksQ0FBQyxDQUFDLFVBQVUsUUFBUSxDQUFBLEVBQUcsQ0FBQyxLQUFBLEVBQU8sS0FBSyxDQUFHLEVBQUEsQ0FBQyxRQUFVLEVBQUEsUUFBUSxDQUFDLENBQUMsQ0FBQTtBQUFBLElBQ3hGLEdBQUcsWUFBQTtBQUFBLElBQ0gsR0FBRztBQUFBLEdBQ0w7QUFHQSxFQUFBLE9BQU8sd0JBQXlCLENBQUE7QUFBQSxJQUM5QixHQUFHLE9BQUE7QUFBQSxJQUNILFFBQVUsRUFBQTtBQUFBLEdBQ1gsQ0FBQTtBQUNIOzs7OyJ9
|
|
@@ -1,7 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
/**
|
|
2
|
+
* vite-plugin-react-server
|
|
3
|
+
* Copyright (c) Nico Brinkkemper
|
|
4
|
+
* MIT License
|
|
5
|
+
*/
|
|
6
|
+
function createBuildLoader() {
|
|
7
|
+
return async function buildLoader(_id) {
|
|
8
|
+
throw new Error("createBuildLoader is called from the client, but it is only available on the server.");
|
|
9
|
+
};
|
|
7
10
|
}
|
|
11
|
+
|
|
12
|
+
export { createBuildLoader };
|
|
13
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlQnVpbGRMb2FkZXIuY2xpZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9wbHVnaW4vcmVhY3Qtc3RhdGljL2NyZWF0ZUJ1aWxkTG9hZGVyLmNsaWVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gY3JlYXRlQnVpbGRMb2FkZXIoKSB7XG4gICAgLy8gSW4gY2xpZW50LXN0YXRpYywgdGhlIFJTQyB3b3JrZXIgaGFuZGxlcyBhbGwgbW9kdWxlIGxvYWRpbmdcbiAgICAvLyBUaGUgbWFpbiB0aHJlYWQgZG9lc24ndCBuZWVkIHRvIGxvYWQgbW9kdWxlcyBkaXJlY3RseVxuICAgIHJldHVybiBhc3luYyBmdW5jdGlvbiBidWlsZExvYWRlcihfaWQ6IHN0cmluZykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJjcmVhdGVCdWlsZExvYWRlciBpcyBjYWxsZWQgZnJvbSB0aGUgY2xpZW50LCBidXQgaXQgaXMgb25seSBhdmFpbGFibGUgb24gdGhlIHNlcnZlci5cIik7XG4gICAgfTtcbn0gICAiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBTyxTQUFTLGlCQUFvQixHQUFBO0FBR2hDLEVBQU8sT0FBQSxlQUFlLFlBQVksR0FBYSxFQUFBO0FBQzNDLElBQU0sTUFBQSxJQUFJLE1BQU0sc0ZBQXNGLENBQUE7QUFBQSxHQUMxRztBQUNKOzs7OyJ9
|
|
@@ -1,253 +1,273 @@
|
|
|
1
|
-
import { join, resolve } from "node:path";
|
|
2
|
-
import { pathToFileURL } from "node:url";
|
|
3
|
-
import { getModuleRef } from "../helpers/moduleRefs.js";
|
|
4
|
-
import { toError } from "../error/toError.js";
|
|
5
|
-
import { handleError } from "../error/handleError.js";
|
|
6
|
-
import { createSharedLoader } from "../helpers/createSharedLoader.js";
|
|
7
|
-
import { resolveVirtualAndNodeModules } from "../helpers/resolveVirtualAndNodeModules.js";
|
|
8
|
-
import { createLogger } from "vite";
|
|
9
1
|
/**
|
|
10
|
-
*
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
* - For inline modules: Handle them using bundle
|
|
2
|
+
* vite-plugin-react-server
|
|
3
|
+
* Copyright (c) Nico Brinkkemper
|
|
4
|
+
* MIT License
|
|
14
5
|
*/
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
6
|
+
import { join, resolve } from 'node:path';
|
|
7
|
+
import { pathToFileURL } from 'node:url';
|
|
8
|
+
import { getModuleRef } from '../helpers/moduleRefs.js';
|
|
9
|
+
import { toError } from '../error/toError.js';
|
|
10
|
+
import { handleError } from '../error/handleError.js';
|
|
11
|
+
import { createSharedLoader } from '../helpers/createSharedLoader.js';
|
|
12
|
+
import { resolveVirtualAndNodeModules } from '../helpers/resolveVirtualAndNodeModules.js';
|
|
13
|
+
import { createLogger } from 'vite';
|
|
14
|
+
|
|
15
|
+
const createBuildLoader = function _createBuildLoader({ userOptions, serverManifest, staticManifest }, bundle, temporaryReferences, logger = createLogger()) {
|
|
16
|
+
const manifestKeys = Object.keys(serverManifest);
|
|
17
|
+
if (!manifestKeys.length) {
|
|
18
|
+
throw new Error("Server manifest is empty");
|
|
19
|
+
}
|
|
20
|
+
return async function buildLoader(id) {
|
|
21
|
+
if (userOptions.verbose) {
|
|
22
|
+
logger.info(`[buildLoader] id: ${id}`);
|
|
23
|
+
logger.info(`[buildLoader] Starting lookup for: ${id}`);
|
|
19
24
|
}
|
|
20
|
-
|
|
25
|
+
const [withoutQuery, query] = id.split("?", 2);
|
|
26
|
+
const [moduleId, exportName] = withoutQuery.split("#", 2);
|
|
27
|
+
const [normalizedKey, normalizedValue] = userOptions.normalizer(moduleId);
|
|
28
|
+
const virtualOrNodeModule = await resolveVirtualAndNodeModules(
|
|
29
|
+
moduleId,
|
|
30
|
+
exportName,
|
|
31
|
+
userOptions.verbose,
|
|
32
|
+
logger
|
|
33
|
+
);
|
|
34
|
+
if (virtualOrNodeModule !== null) {
|
|
35
|
+
return virtualOrNodeModule;
|
|
36
|
+
}
|
|
37
|
+
const moduleRef = getModuleRef(id);
|
|
38
|
+
if (temporaryReferences?.has(moduleRef)) {
|
|
39
|
+
const mod = temporaryReferences.get(moduleRef);
|
|
40
|
+
if (typeof mod === "object" && mod !== null && "error" in mod) ; else {
|
|
41
|
+
return mod;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
try {
|
|
45
|
+
if (query === "inline") {
|
|
46
|
+
const manifestKey = normalizedValue;
|
|
21
47
|
if (userOptions.verbose) {
|
|
22
|
-
|
|
23
|
-
|
|
48
|
+
logger.info(
|
|
49
|
+
`[buildLoader] Looking for inline module: ${normalizedValue}`
|
|
50
|
+
);
|
|
24
51
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
43
|
-
else {
|
|
44
|
-
return mod;
|
|
52
|
+
let resolvedValue = normalizedValue;
|
|
53
|
+
if (normalizedValue.startsWith("assets/") && normalizedValue.endsWith(".css")) {
|
|
54
|
+
const basePath = normalizedValue.replace(
|
|
55
|
+
/-[a-zA-Z0-9]+\.css$/,
|
|
56
|
+
".css"
|
|
57
|
+
);
|
|
58
|
+
if (userOptions.verbose) {
|
|
59
|
+
logger.info(
|
|
60
|
+
`[buildLoader] CSS file detected, trying to resolve ${normalizedValue} to ${basePath}`
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
if (bundle[basePath]) {
|
|
64
|
+
resolvedValue = basePath;
|
|
65
|
+
if (userOptions.verbose) {
|
|
66
|
+
logger.info(
|
|
67
|
+
`[buildLoader] Resolved CSS file to: ${resolvedValue}`
|
|
68
|
+
);
|
|
45
69
|
}
|
|
70
|
+
}
|
|
46
71
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
72
|
+
if (userOptions.verbose) {
|
|
73
|
+
logger.info(
|
|
74
|
+
`[buildLoader] Trying bundle[moduleId]: bundle["${moduleId}"] = ${!!bundle[moduleId]}`
|
|
75
|
+
);
|
|
76
|
+
logger.info(
|
|
77
|
+
`[buildLoader] Trying bundle[normalizedValue]: bundle["${normalizedValue}"] = ${!!bundle[normalizedValue]}`
|
|
78
|
+
);
|
|
79
|
+
logger.info(
|
|
80
|
+
`[buildLoader] Trying bundle[resolvedValue]: bundle["${resolvedValue}"] = ${!!bundle[resolvedValue]}`
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
const serverChunk = bundle[moduleId] ?? bundle[normalizedValue] ?? bundle[resolvedValue] ?? bundle[serverManifest[manifestKey]?.file] ?? bundle[staticManifest[manifestKey]?.file] ?? bundle[serverManifest[normalizedKey]?.file] ?? bundle[staticManifest[normalizedKey]?.file] ?? Object.entries(bundle).find(
|
|
84
|
+
([, value]) => value.name === normalizedValue
|
|
85
|
+
)?.[1];
|
|
86
|
+
if (userOptions.verbose && serverChunk) {
|
|
87
|
+
logger.info(`[buildLoader] Found serverChunk: ${serverChunk.type}`);
|
|
88
|
+
}
|
|
89
|
+
if (serverChunk) {
|
|
90
|
+
if (serverChunk.type === "asset") {
|
|
91
|
+
if (userOptions.autoDiscover.jsonPattern.test(normalizedValue)) {
|
|
92
|
+
const jsonContent = serverChunk.source;
|
|
93
|
+
if (typeof jsonContent === "string") {
|
|
51
94
|
if (userOptions.verbose) {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
let resolvedValue = normalizedValue;
|
|
56
|
-
if (normalizedValue.startsWith("assets/") &&
|
|
57
|
-
normalizedValue.endsWith(".css")) {
|
|
58
|
-
// Extract the base path without hash
|
|
59
|
-
const basePath = normalizedValue.replace(/-[a-zA-Z0-9]+\.css$/, ".css");
|
|
60
|
-
if (userOptions.verbose) {
|
|
61
|
-
logger.info(`[buildLoader] CSS file detected, trying to resolve ${normalizedValue} to ${basePath}`);
|
|
62
|
-
}
|
|
63
|
-
// Try the base path first
|
|
64
|
-
if (bundle[basePath]) {
|
|
65
|
-
resolvedValue = basePath;
|
|
66
|
-
if (userOptions.verbose) {
|
|
67
|
-
logger.info(`[buildLoader] Resolved CSS file to: ${resolvedValue}`);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
95
|
+
logger.info(
|
|
96
|
+
`[buildLoader] Returning JSON content for: ${normalizedValue}`
|
|
97
|
+
);
|
|
70
98
|
}
|
|
71
|
-
|
|
99
|
+
return { default: JSON.parse(jsonContent) };
|
|
100
|
+
}
|
|
101
|
+
} else if (userOptions.autoDiscover.cssPattern.test(normalizedValue)) {
|
|
102
|
+
const cssContent = serverChunk.source;
|
|
103
|
+
if (typeof cssContent === "string") {
|
|
72
104
|
if (userOptions.verbose) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
}
|
|
77
|
-
const serverChunk = bundle[moduleId] ??
|
|
78
|
-
bundle[normalizedValue] ??
|
|
79
|
-
bundle[resolvedValue] ??
|
|
80
|
-
bundle[serverManifest[manifestKey]?.file] ??
|
|
81
|
-
bundle[staticManifest[manifestKey]?.file] ??
|
|
82
|
-
bundle[serverManifest[normalizedKey]?.file] ??
|
|
83
|
-
bundle[staticManifest[normalizedKey]?.file] ??
|
|
84
|
-
Object.entries(bundle).find(([, value]) => value.name === normalizedValue)?.[1];
|
|
85
|
-
if (userOptions.verbose && serverChunk) {
|
|
86
|
-
logger.info(`[buildLoader] Found serverChunk: ${serverChunk.type}`);
|
|
87
|
-
}
|
|
88
|
-
if (serverChunk) {
|
|
89
|
-
if (serverChunk.type === "asset") {
|
|
90
|
-
// For CSS files, ensure we're in the React Server environment
|
|
91
|
-
if (userOptions.autoDiscover.jsonPattern.test(normalizedValue)) {
|
|
92
|
-
const jsonContent = serverChunk.source;
|
|
93
|
-
if (typeof jsonContent === "string") {
|
|
94
|
-
if (userOptions.verbose) {
|
|
95
|
-
logger.info(`[buildLoader] Returning JSON content for: ${normalizedValue}`);
|
|
96
|
-
}
|
|
97
|
-
return { default: JSON.parse(jsonContent) };
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
else if (userOptions.autoDiscover.cssPattern.test(normalizedValue)) {
|
|
101
|
-
const cssContent = serverChunk.source;
|
|
102
|
-
if (typeof cssContent === "string") {
|
|
103
|
-
if (userOptions.verbose) {
|
|
104
|
-
logger.info(`[buildLoader] Returning CSS content for: ${normalizedValue}, length: ${cssContent.length}`);
|
|
105
|
-
}
|
|
106
|
-
return { default: cssContent };
|
|
107
|
-
}
|
|
108
|
-
else {
|
|
109
|
-
if (userOptions.verbose) {
|
|
110
|
-
logger.info(`[buildLoader] CSS source is not string: ${typeof cssContent}`);
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
if (userOptions.verbose) {
|
|
115
|
-
logger.info(`[buildLoader] Returning default asset source for: ${normalizedValue}`);
|
|
116
|
-
}
|
|
117
|
-
return { default: serverChunk.source };
|
|
118
|
-
}
|
|
119
|
-
else if ("code" in serverChunk) {
|
|
120
|
-
if (userOptions.verbose) {
|
|
121
|
-
logger.info(`[buildLoader] Returning code for: ${normalizedValue}`);
|
|
122
|
-
}
|
|
123
|
-
return { default: serverChunk.code };
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
const panicError = handleError({
|
|
127
|
-
error: new Error(`Could not find inline module for: ${normalizedValue}`),
|
|
128
|
-
logger,
|
|
129
|
-
log: true,
|
|
130
|
-
panicThreshold: userOptions.panicThreshold,
|
|
131
|
-
context: "Build Loader Error (inline)",
|
|
132
|
-
});
|
|
133
|
-
if (panicError != null) {
|
|
134
|
-
throw panicError;
|
|
135
|
-
}
|
|
136
|
-
return null;
|
|
137
|
-
}
|
|
138
|
-
// check the bundle manifest for a direct match
|
|
139
|
-
const bundleEntry = bundle[withoutQuery];
|
|
140
|
-
if (bundleEntry) {
|
|
141
|
-
try {
|
|
142
|
-
const filePath = join(userOptions.projectRoot, userOptions.build.outDir, userOptions.build.server, withoutQuery);
|
|
143
|
-
const fileUrl = pathToFileURL(filePath).href;
|
|
144
|
-
const module = await import(fileUrl);
|
|
145
|
-
temporaryReferences?.set(moduleRef, module);
|
|
146
|
-
return module;
|
|
147
|
-
}
|
|
148
|
-
catch (error) {
|
|
149
|
-
const panicError = handleError({
|
|
150
|
-
error: error,
|
|
151
|
-
logger,
|
|
152
|
-
panicThreshold: userOptions.panicThreshold,
|
|
153
|
-
context: "Build Loader Error (bundle)",
|
|
154
|
-
});
|
|
155
|
-
temporaryReferences?.delete(moduleRef);
|
|
156
|
-
if (panicError != null) {
|
|
157
|
-
throw panicError;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
// For static assets, use static manifest
|
|
162
|
-
const staticEntry = staticManifest[normalizedValue];
|
|
163
|
-
if (staticEntry) {
|
|
164
|
-
try {
|
|
165
|
-
const filePath = join(userOptions.projectRoot, userOptions.build.outDir, userOptions.build.static, staticEntry.file);
|
|
166
|
-
const fileUrl = pathToFileURL(filePath).href;
|
|
167
|
-
const module = await import(fileUrl);
|
|
168
|
-
temporaryReferences?.set(moduleRef, module);
|
|
169
|
-
// If we have an export name, make sure it's a key
|
|
170
|
-
if (exportName && !(exportName in module)) {
|
|
171
|
-
throw new Error(`Export ${exportName} not found in module ${normalizedValue}`);
|
|
172
|
-
}
|
|
173
|
-
return module;
|
|
105
|
+
logger.info(
|
|
106
|
+
`[buildLoader] Returning CSS content for: ${normalizedValue}, length: ${cssContent.length}`
|
|
107
|
+
);
|
|
174
108
|
}
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
});
|
|
182
|
-
temporaryReferences?.delete(moduleRef);
|
|
183
|
-
if (panicError != null) {
|
|
184
|
-
throw panicError;
|
|
185
|
-
}
|
|
109
|
+
return { default: cssContent };
|
|
110
|
+
} else {
|
|
111
|
+
if (userOptions.verbose) {
|
|
112
|
+
logger.info(
|
|
113
|
+
`[buildLoader] CSS source is not string: ${typeof cssContent}`
|
|
114
|
+
);
|
|
186
115
|
}
|
|
116
|
+
}
|
|
187
117
|
}
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
moduleId,
|
|
193
|
-
exportName,
|
|
194
|
-
verbose: userOptions.verbose,
|
|
195
|
-
logger,
|
|
196
|
-
resolveVirtual: true,
|
|
197
|
-
manifest: serverManifest,
|
|
198
|
-
normalizer: userOptions.normalizer,
|
|
199
|
-
moduleBase: userOptions.moduleBase,
|
|
200
|
-
preserveModulesRoot: userOptions.build.preserveModulesRoot,
|
|
201
|
-
projectRoot: userOptions.projectRoot,
|
|
202
|
-
buildOutDir: userOptions.build.outDir,
|
|
203
|
-
buildServerDir: userOptions.build.server,
|
|
204
|
-
isBuildMode: true,
|
|
205
|
-
isServeMode: false,
|
|
206
|
-
effectiveProjectRoot: userOptions.projectRoot,
|
|
207
|
-
build: {
|
|
208
|
-
outDir: userOptions.build.outDir,
|
|
209
|
-
server: userOptions.build.server,
|
|
210
|
-
client: userOptions.build.client,
|
|
211
|
-
static: userOptions.build.static,
|
|
212
|
-
},
|
|
213
|
-
});
|
|
214
|
-
// Store in temporary references for caching
|
|
215
|
-
temporaryReferences?.set(moduleRef, module);
|
|
216
|
-
return module;
|
|
118
|
+
if (userOptions.verbose) {
|
|
119
|
+
logger.info(
|
|
120
|
+
`[buildLoader] Returning default asset source for: ${normalizedValue}`
|
|
121
|
+
);
|
|
217
122
|
}
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
context: "Build Loader Error (shared)",
|
|
225
|
-
});
|
|
226
|
-
temporaryReferences?.delete(moduleRef);
|
|
227
|
-
if (panicError != null) {
|
|
228
|
-
throw panicError;
|
|
229
|
-
}
|
|
123
|
+
return { default: serverChunk.source };
|
|
124
|
+
} else if ("code" in serverChunk) {
|
|
125
|
+
if (userOptions.verbose) {
|
|
126
|
+
logger.info(
|
|
127
|
+
`[buildLoader] Returning code for: ${normalizedValue}`
|
|
128
|
+
);
|
|
230
129
|
}
|
|
130
|
+
return { default: serverChunk.code };
|
|
131
|
+
}
|
|
231
132
|
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
throw enhancedError;
|
|
244
|
-
}
|
|
245
|
-
const emptyExports = {
|
|
246
|
-
error: enhancedError,
|
|
247
|
-
id: id,
|
|
248
|
-
};
|
|
249
|
-
temporaryReferences?.delete(moduleRef);
|
|
250
|
-
return emptyExports;
|
|
133
|
+
const panicError = handleError({
|
|
134
|
+
error: new Error(
|
|
135
|
+
`Could not find inline module for: ${normalizedValue}`
|
|
136
|
+
),
|
|
137
|
+
logger,
|
|
138
|
+
log: true,
|
|
139
|
+
panicThreshold: userOptions.panicThreshold,
|
|
140
|
+
context: "Build Loader Error (inline)"
|
|
141
|
+
});
|
|
142
|
+
if (panicError != null) {
|
|
143
|
+
throw panicError;
|
|
251
144
|
}
|
|
252
|
-
|
|
145
|
+
return null;
|
|
146
|
+
}
|
|
147
|
+
const bundleEntry = bundle[withoutQuery];
|
|
148
|
+
if (bundleEntry) {
|
|
149
|
+
try {
|
|
150
|
+
const filePath = join(
|
|
151
|
+
userOptions.projectRoot,
|
|
152
|
+
userOptions.build.outDir,
|
|
153
|
+
userOptions.build.server,
|
|
154
|
+
withoutQuery
|
|
155
|
+
);
|
|
156
|
+
const fileUrl = pathToFileURL(filePath).href;
|
|
157
|
+
const module = await import(fileUrl);
|
|
158
|
+
temporaryReferences?.set(moduleRef, module);
|
|
159
|
+
return module;
|
|
160
|
+
} catch (error) {
|
|
161
|
+
const panicError = handleError({
|
|
162
|
+
error,
|
|
163
|
+
logger,
|
|
164
|
+
panicThreshold: userOptions.panicThreshold,
|
|
165
|
+
context: "Build Loader Error (bundle)"
|
|
166
|
+
});
|
|
167
|
+
temporaryReferences?.delete(moduleRef);
|
|
168
|
+
if (panicError != null) {
|
|
169
|
+
throw panicError;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
const staticEntry = staticManifest[normalizedValue];
|
|
174
|
+
if (staticEntry) {
|
|
175
|
+
try {
|
|
176
|
+
const filePath = join(
|
|
177
|
+
userOptions.projectRoot,
|
|
178
|
+
userOptions.build.outDir,
|
|
179
|
+
userOptions.build.static,
|
|
180
|
+
staticEntry.file
|
|
181
|
+
);
|
|
182
|
+
const fileUrl = pathToFileURL(filePath).href;
|
|
183
|
+
const module = await import(fileUrl);
|
|
184
|
+
temporaryReferences?.set(moduleRef, module);
|
|
185
|
+
if (exportName && !(exportName in module)) {
|
|
186
|
+
throw new Error(
|
|
187
|
+
`Export ${exportName} not found in module ${normalizedValue}`
|
|
188
|
+
);
|
|
189
|
+
}
|
|
190
|
+
return module;
|
|
191
|
+
} catch (error) {
|
|
192
|
+
const panicError = handleError({
|
|
193
|
+
error,
|
|
194
|
+
logger,
|
|
195
|
+
panicThreshold: userOptions.panicThreshold,
|
|
196
|
+
context: "Build Loader Error (static)"
|
|
197
|
+
});
|
|
198
|
+
temporaryReferences?.delete(moduleRef);
|
|
199
|
+
if (panicError != null) {
|
|
200
|
+
throw panicError;
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
try {
|
|
205
|
+
const module = await createSharedLoader({
|
|
206
|
+
moduleId,
|
|
207
|
+
exportName,
|
|
208
|
+
verbose: userOptions.verbose,
|
|
209
|
+
logger,
|
|
210
|
+
resolveVirtual: true,
|
|
211
|
+
manifest: serverManifest,
|
|
212
|
+
normalizer: userOptions.normalizer,
|
|
213
|
+
moduleBase: userOptions.moduleBase,
|
|
214
|
+
preserveModulesRoot: userOptions.build.preserveModulesRoot,
|
|
215
|
+
projectRoot: userOptions.projectRoot,
|
|
216
|
+
buildOutDir: userOptions.build.outDir,
|
|
217
|
+
buildServerDir: userOptions.build.server,
|
|
218
|
+
isBuildMode: true,
|
|
219
|
+
isServeMode: false,
|
|
220
|
+
effectiveProjectRoot: userOptions.projectRoot,
|
|
221
|
+
build: {
|
|
222
|
+
outDir: userOptions.build.outDir,
|
|
223
|
+
server: userOptions.build.server,
|
|
224
|
+
client: userOptions.build.client,
|
|
225
|
+
static: userOptions.build.static
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
temporaryReferences?.set(moduleRef, module);
|
|
229
|
+
return module;
|
|
230
|
+
} catch (error) {
|
|
231
|
+
const err = toError(error);
|
|
232
|
+
const panicError = handleError({
|
|
233
|
+
error: err,
|
|
234
|
+
logger,
|
|
235
|
+
panicThreshold: userOptions.panicThreshold,
|
|
236
|
+
context: "Build Loader Error (shared)"
|
|
237
|
+
});
|
|
238
|
+
temporaryReferences?.delete(moduleRef);
|
|
239
|
+
if (panicError != null) {
|
|
240
|
+
throw panicError;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
} catch (error) {
|
|
244
|
+
let enhancedError = error instanceof Error ? error : new Error(String(error));
|
|
245
|
+
if (enhancedError.message.includes("React Server Writer cannot be used outside a react-server environment")) {
|
|
246
|
+
const filePath = resolve(
|
|
247
|
+
userOptions.projectRoot,
|
|
248
|
+
userOptions.build.outDir,
|
|
249
|
+
userOptions.build.server,
|
|
250
|
+
moduleId
|
|
251
|
+
);
|
|
252
|
+
enhancedError = new Error(
|
|
253
|
+
`${enhancedError.message}
|
|
254
|
+
→ Imported from: ${moduleId}
|
|
255
|
+
→ Export: ${exportName}
|
|
256
|
+
→ File path: ${filePath}
|
|
257
|
+
→ NODE_OPTIONS: ${process.env.NODE_OPTIONS || "not set"}
|
|
258
|
+
→ execArgv: ${process.execArgv.join(" ") || "not set"}`
|
|
259
|
+
);
|
|
260
|
+
throw enhancedError;
|
|
261
|
+
}
|
|
262
|
+
const emptyExports = {
|
|
263
|
+
error: enhancedError,
|
|
264
|
+
id
|
|
265
|
+
};
|
|
266
|
+
temporaryReferences?.delete(moduleRef);
|
|
267
|
+
return emptyExports;
|
|
268
|
+
}
|
|
269
|
+
};
|
|
253
270
|
};
|
|
271
|
+
|
|
272
|
+
export { createBuildLoader };
|
|
273
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createBuildLoader.server.js","sources":["../../../plugin/react-static/createBuildLoader.server.ts"],"sourcesContent":["import { join, resolve } from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport { getModuleRef } from \"../helpers/moduleRefs.js\";\nimport { toError } from \"../error/toError.js\";\nimport { handleError } from \"../error/handleError.js\";\nimport { createSharedLoader } from \"../helpers/createSharedLoader.js\";\nimport { resolveVirtualAndNodeModules } from \"../helpers/resolveVirtualAndNodeModules.js\";\n\nimport type { CreateBuildLoaderFn } from \"./types.js\";\nimport { createLogger } from \"vite\";\n\n/**\n * Creates a loader function for handling module resolution during build.\n *\n * The loader handles the following strategy:\n *  - For inline modules: Handle them using bundle\n */\nexport const createBuildLoader: CreateBuildLoaderFn =\n  function _createBuildLoader(\n    { userOptions, serverManifest, staticManifest },\n    bundle,\n    temporaryReferences,\n    logger = createLogger()\n  ) {\n    const manifestKeys = Object.keys(serverManifest);\n    if (!manifestKeys.length) {\n      throw new Error(\"Server manifest is empty\");\n    }\n\n    return async function buildLoader(id) {\n      if (userOptions.verbose) {\n        logger.info(`[buildLoader] id: ${id}`);\n        logger.info(`[buildLoader] Starting lookup for: ${id}`);\n      }\n      const [withoutQuery, query] = id.split(\"?\", 2);\n      const [moduleId, exportName] = withoutQuery.split(\"#\", 2);\n      \n      // Normalize the moduleId early (used throughout the function)\n      const [normalizedKey, normalizedValue] = userOptions.normalizer(moduleId);\n      \n      // For virtual modules and node_modules, use shared utility (same as RSC worker loader)\n      // This handles _virtual/dynamic-import-helper.js and provides shims if needed\n      // Check this early, before build-specific handling\n      const virtualOrNodeModule = await resolveVirtualAndNodeModules(\n        moduleId,\n        exportName,\n        userOptions.verbose,\n        logger\n      );\n      if (virtualOrNodeModule !== null) {\n        return virtualOrNodeModule;\n      }\n      \n      const moduleRef = getModuleRef(id);\n\n      // Check if we have a temporary reference (cached module)\n      if (temporaryReferences?.has(moduleRef)) {\n        const mod = temporaryReferences.get(moduleRef);\n        if (typeof mod === \"object\" && mod !== null && \"error\" in mod) {\n          // ignore it\n        } else {\n          return mod;\n        }\n      }\n\n      try {\n        // For inline modules, handle them directly\n        if (query === \"inline\") {\n          const manifestKey = normalizedValue;\n          if (userOptions.verbose) {\n            logger.info(\n              `[buildLoader] Looking for inline module: ${normalizedValue}`\n            );\n          }\n\n          // For CSS files, try to resolve the hashed filename to the actual bundle filename\n          let resolvedValue = normalizedValue;\n          if (\n            normalizedValue.startsWith(\"assets/\") &&\n            normalizedValue.endsWith(\".css\")\n          ) {\n            // Extract the base path without hash\n            const basePath = normalizedValue.replace(\n              /-[a-zA-Z0-9]+\\.css$/,\n              \".css\"\n            );\n            if (userOptions.verbose) {\n              logger.info(\n                `[buildLoader] CSS file detected, trying to resolve ${normalizedValue} to ${basePath}`\n              );\n            }\n            // Try the base path first\n            if (bundle[basePath]) {\n              resolvedValue = basePath;\n              if (userOptions.verbose) {\n                logger.info(\n                  `[buildLoader] Resolved CSS file to: ${resolvedValue}`\n                );\n              }\n            }\n          }\n\n          // First try to find the module without the export name\n          if (userOptions.verbose) {\n            logger.info(\n              `[buildLoader] Trying bundle[moduleId]: bundle[\"${moduleId}\"] = ${!!bundle[\n                moduleId\n              ]}`\n            );\n            logger.info(\n              `[buildLoader] Trying bundle[normalizedValue]: bundle[\"${normalizedValue}\"] = ${!!bundle[\n                normalizedValue\n              ]}`\n            );\n            logger.info(\n              `[buildLoader] Trying bundle[resolvedValue]: bundle[\"${resolvedValue}\"] = ${!!bundle[\n                resolvedValue\n              ]}`\n            );\n          }\n          const serverChunk =\n            bundle[moduleId] ??\n            bundle[normalizedValue] ??\n            bundle[resolvedValue] ??\n            bundle[serverManifest[manifestKey]?.file] ??\n            bundle[staticManifest[manifestKey]?.file] ??\n            bundle[serverManifest[normalizedKey]?.file] ??\n            bundle[staticManifest[normalizedKey]?.file] ??\n            Object.entries(bundle).find(\n              ([, value]) => value.name === normalizedValue\n            )?.[1];\n\n          if (userOptions.verbose && serverChunk) {\n            logger.info(`[buildLoader] Found serverChunk: ${serverChunk.type}`);\n          }\n\n          if (serverChunk) {\n            if (serverChunk.type === \"asset\") {\n              // For CSS files, ensure we're in the React Server environment\n              if (userOptions.autoDiscover.jsonPattern.test(normalizedValue)) {\n                const jsonContent = serverChunk.source;\n                if (typeof jsonContent === \"string\") {\n                  if (userOptions.verbose) {\n                    logger.info(\n                      `[buildLoader] Returning JSON content for: ${normalizedValue}`\n                    );\n                  }\n                  return { default: JSON.parse(jsonContent) };\n                }\n              } else if (\n                userOptions.autoDiscover.cssPattern.test(normalizedValue)\n              ) {\n                const cssContent = serverChunk.source;\n                if (typeof cssContent === \"string\") {\n                  if (userOptions.verbose) {\n                    logger.info(\n                      `[buildLoader] Returning CSS content for: ${normalizedValue}, length: ${cssContent.length}`\n                    );\n                  }\n                  return { default: cssContent };\n                } else {\n                  if (userOptions.verbose) {\n                    logger.info(\n                      `[buildLoader] CSS source is not string: ${typeof cssContent}`\n                    );\n                  }\n                }\n              }\n              if (userOptions.verbose) {\n                logger.info(\n                  `[buildLoader] Returning default asset source for: ${normalizedValue}`\n                );\n              }\n              return { default: serverChunk.source };\n            } else if (\"code\" in serverChunk) {\n              if (userOptions.verbose) {\n                logger.info(\n                  `[buildLoader] Returning code for: ${normalizedValue}`\n                );\n              }\n              return { default: serverChunk.code };\n            }\n          }\n          const panicError = handleError({\n            error: new Error(\n              `Could not find inline module for: ${normalizedValue}`\n            ),\n            logger,\n            log: true,\n            panicThreshold: userOptions.panicThreshold,\n            context: \"Build Loader Error (inline)\",\n          });\n          if (panicError != null) {\n            throw panicError;\n          }\n          return null;\n        }\n\n        // check the bundle manifest for a direct match\n        const bundleEntry = bundle[withoutQuery];\n        if (bundleEntry) {\n          try {\n            const filePath = join(\n              userOptions.projectRoot,\n              userOptions.build.outDir,\n              userOptions.build.server,\n              withoutQuery\n            );\n            const fileUrl = pathToFileURL(filePath).href;\n            const module = await import(fileUrl);\n            temporaryReferences?.set(moduleRef, module);\n            return module;\n          } catch (error) {\n            const panicError = handleError({\n              error: error,\n              logger,\n              panicThreshold: userOptions.panicThreshold,\n              context: \"Build Loader Error (bundle)\",\n            });\n            temporaryReferences?.delete(moduleRef);\n            if (panicError != null) {\n              throw panicError;\n            }\n          }\n        }\n\n        // For static assets, use static manifest\n        const staticEntry = staticManifest[normalizedValue];\n        if (staticEntry) {\n          try {\n            const filePath = join(\n              userOptions.projectRoot,\n              userOptions.build.outDir,\n              userOptions.build.static,\n              staticEntry.file\n            );\n            const fileUrl = pathToFileURL(filePath).href;\n            const module = await import(fileUrl);\n            temporaryReferences?.set(moduleRef, module);\n            // If we have an export name, make sure it's a key\n            if (exportName && !(exportName in module)) {\n              throw new Error(\n                `Export ${exportName} not found in module ${normalizedValue}`\n              );\n            }\n            return module;\n          } catch (error) {\n            const panicError = handleError({\n              error: error,\n              logger,\n              panicThreshold: userOptions.panicThreshold,\n              context: \"Build Loader Error (static)\",\n            });\n            temporaryReferences?.delete(moduleRef);\n            if (panicError != null) {\n              throw panicError;\n            }\n          }\n        }\n\n        // Use shared loader utility for common cases (virtual modules, manifest resolution, imports)\n        // This handles the same logic as RSC worker loader\n        try {\n          const module = await createSharedLoader({\n            moduleId,\n            exportName,\n            verbose: userOptions.verbose,\n            logger,\n            resolveVirtual: true,\n            manifest: serverManifest,\n            normalizer: userOptions.normalizer,\n            moduleBase: userOptions.moduleBase,\n            preserveModulesRoot: userOptions.build.preserveModulesRoot,\n            projectRoot: userOptions.projectRoot,\n            buildOutDir: userOptions.build.outDir,\n            buildServerDir: userOptions.build.server,\n            isBuildMode: true,\n            isServeMode: false,\n            effectiveProjectRoot: userOptions.projectRoot,\n            build: {\n              outDir: userOptions.build.outDir,\n              server: userOptions.build.server,\n              client: userOptions.build.client,\n              static: userOptions.build.static,\n            },\n          });\n          \n          // Store in temporary references for caching\n          temporaryReferences?.set(moduleRef, module);\n          return module;\n        } catch (error) {\n          const err = toError(error);\n          const panicError = handleError({\n            error: err,\n            logger,\n            panicThreshold: userOptions.panicThreshold,\n            context: \"Build Loader Error (shared)\",\n          });\n          temporaryReferences?.delete(moduleRef);\n          if (panicError != null) {\n            throw panicError;\n          }\n        }\n      } catch (error) {\n        // Enhance React Server DOM errors with import context\n        let enhancedError = error instanceof Error ? error : new Error(String(error));\n        if (enhancedError.message.includes('React Server Writer cannot be used outside a react-server environment')) {\n          const filePath = resolve(\n            userOptions.projectRoot,\n            userOptions.build.outDir,\n            userOptions.build.server,\n            moduleId\n          );\n          enhancedError = new Error(\n            `${enhancedError.message}\\n` +\n            `  → Imported from: ${moduleId}\\n` +\n            `  → Export: ${exportName}\\n` +\n            `  → File path: ${filePath}\\n` +\n            `  → NODE_OPTIONS: ${process.env.NODE_OPTIONS || 'not set'}\\n` +\n            `  → execArgv: ${process.execArgv.join(' ') || 'not set'}`\n          );\n          throw enhancedError;\n        }\n        \n        const emptyExports = {\n          error: enhancedError,\n          id: id,\n        };\n        temporaryReferences?.delete(moduleRef);\n        return emptyExports;\n      }\n    };\n  };\n"],"names":[],"mappings":"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"}
|