vite-plugin-react-server 1.2.1 → 1.2.3
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 +2 -1
- package/dist/package.json +1 -1
- package/dist/plugin/helpers/createSharedLoader.d.ts +1 -1
- package/dist/plugin/helpers/createSharedLoader.d.ts.map +1 -1
- package/dist/plugin/helpers/createSharedLoader.js +14 -56
- package/dist/plugin/loader/react-loader.d.ts.map +1 -1
- package/dist/plugin/loader/react-loader.js +4 -70
- package/dist/plugin/react-static/plugin.client.js +4 -4
- package/dist/plugin/react-static/plugin.server.js +3 -3
- package/dist/plugin/stream/createRenderToPipeableStreamHandler.client.js +2 -2
- package/dist/plugin/worker/rsc/createRscWorkerLoader.d.ts +2 -6
- package/dist/plugin/worker/rsc/createRscWorkerLoader.d.ts.map +1 -1
- package/dist/plugin/worker/rsc/createRscWorkerLoader.js +1 -34
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/plugin/helpers/createSharedLoader.ts +17 -70
- package/plugin/loader/react-loader.ts +5 -79
- package/plugin/react-static/plugin.client.ts +4 -4
- package/plugin/react-static/plugin.server.ts +3 -3
- package/plugin/stream/createRenderToPipeableStreamHandler.client.ts +2 -2
- package/plugin/worker/rsc/createRscWorkerLoader.ts +4 -51
package/README.md
CHANGED
|
@@ -306,7 +306,7 @@ export function Counter() {
|
|
|
306
306
|
|
|
307
307
|
## Contributing
|
|
308
308
|
|
|
309
|
-
This project uses experimental React features and includes a patch system for compatibility. See [
|
|
309
|
+
This project uses experimental React features and includes a patch system for compatibility. See [React Type Compatibility](./docs/react-type-compatibility.md) for maintenance details.
|
|
310
310
|
|
|
311
311
|
## Documentation
|
|
312
312
|
|
|
@@ -325,6 +325,7 @@ This project uses experimental React features and includes a patch system for co
|
|
|
325
325
|
| [React Compatibility](./docs/react-type-compatibility.md) |
|
|
326
326
|
| [Troubleshooting](./docs/troubleshooting-guide.md) |
|
|
327
327
|
| [Package Exports](./docs/package-exports.md) |
|
|
328
|
+
| [Transformations](./docs/transformations.md) |
|
|
328
329
|
|
|
329
330
|
|
|
330
331
|
## License
|
package/dist/package.json
CHANGED
|
@@ -16,7 +16,7 @@ import type { InputNormalizer } from "../types.js";
|
|
|
16
16
|
* @param options - Loader configuration options
|
|
17
17
|
* @returns The resolved module (already a module object, not a Promise)
|
|
18
18
|
*/
|
|
19
|
-
export declare function createSharedLoader({ moduleId, exportName, verbose, logger, resolveVirtual, manifest, normalizer, moduleBase, preserveModulesRoot, projectRoot, buildOutDir, buildServerDir, isBuildMode, isServeMode, effectiveProjectRoot, build, }: {
|
|
19
|
+
export declare function createSharedLoader({ moduleId, exportName, verbose, logger, resolveVirtual, manifest, normalizer, moduleBase, preserveModulesRoot, projectRoot, buildOutDir, buildServerDir, isBuildMode, isServeMode: _isServeMode, effectiveProjectRoot, build, }: {
|
|
20
20
|
moduleId: string;
|
|
21
21
|
exportName?: string;
|
|
22
22
|
verbose?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createSharedLoader.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/createSharedLoader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAInD;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,QAAQ,EACR,UAAU,EACV,OAAe,EACf,MAAM,EAEN,cAAqB,EAErB,QAAQ,EACR,UAAU,EACV,UAAU,EACV,mBAAmB,EACnB,WAAW,EACX,WAAW,EACX,cAAc,EAEd,WAAmB,EACnB,
|
|
1
|
+
{"version":3,"file":"createSharedLoader.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/createSharedLoader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAInD;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,QAAQ,EACR,UAAU,EACV,OAAe,EACf,MAAM,EAEN,cAAqB,EAErB,QAAQ,EACR,UAAU,EACV,UAAU,EACV,mBAAmB,EACnB,WAAW,EACX,WAAW,EACX,cAAc,EAEd,WAAmB,EACnB,WAAW,EAAE,YAAoB,EACjC,oBAAoB,EACpB,KAAK,GACN,EAAE;IACD,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,cAAc,CAAC,EAAE,OAAO,CAAC;IAEzB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS,CAAC,CAAC;IACxD,UAAU,CAAC,EAAE,eAAe,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,KAAK,CAAC,EAAE;QACN,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAoF/B"}
|
|
@@ -25,7 +25,7 @@ async function createSharedLoader({
|
|
|
25
25
|
buildServerDir,
|
|
26
26
|
// Direct import options
|
|
27
27
|
isBuildMode = false,
|
|
28
|
-
isServeMode = false,
|
|
28
|
+
isServeMode: _isServeMode = false,
|
|
29
29
|
effectiveProjectRoot,
|
|
30
30
|
build
|
|
31
31
|
}) {
|
|
@@ -56,82 +56,40 @@ async function createSharedLoader({
|
|
|
56
56
|
});
|
|
57
57
|
if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {
|
|
58
58
|
resolvedModuleID = manifestResolution.resolvedPath;
|
|
59
|
-
if (verbose) {
|
|
60
|
-
logger?.info(
|
|
61
|
-
`[createSharedLoader] Build mode: resolved via manifest to: ${resolvedModuleID}`
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
59
|
} else {
|
|
65
60
|
resolvedModuleID = manifestResolution.builtModuleId;
|
|
66
|
-
if (verbose) {
|
|
67
|
-
logger?.info(
|
|
68
|
-
`[createSharedLoader] Build mode: not in manifest, using builtModuleId: ${resolvedModuleID}`
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
61
|
const isSourcePath = moduleId.startsWith(moduleBase + "/") || moduleId.startsWith("./" + moduleBase + "/") || isAbsolute(moduleId) && moduleId.includes(moduleBase);
|
|
72
62
|
if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {
|
|
73
|
-
|
|
63
|
+
resolvedModuleID = join(
|
|
74
64
|
effectiveProjectRoot,
|
|
75
65
|
build.outDir || "dist",
|
|
76
|
-
build.server || "server"
|
|
77
|
-
|
|
78
|
-
resolvedModuleID = join(serverBuildPath, resolvedModuleID);
|
|
79
|
-
if (verbose) {
|
|
80
|
-
logger?.info(
|
|
81
|
-
`[createSharedLoader] Build mode: prefixing with ${serverBuildPath}: ${resolvedModuleID}`
|
|
82
|
-
);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
} else if (isServeMode) {
|
|
87
|
-
if (verbose) {
|
|
88
|
-
logger?.info(
|
|
89
|
-
`[createSharedLoader] Dev mode: loading directly from source`
|
|
90
|
-
);
|
|
91
|
-
}
|
|
92
|
-
} else if (isBuildMode && effectiveProjectRoot && build) {
|
|
93
|
-
if (!isAbsolute(resolvedModuleID)) {
|
|
94
|
-
const serverBuildPath = join(
|
|
95
|
-
effectiveProjectRoot,
|
|
96
|
-
build.outDir || "dist",
|
|
97
|
-
build.server || "server"
|
|
98
|
-
);
|
|
99
|
-
resolvedModuleID = join(serverBuildPath, resolvedModuleID);
|
|
100
|
-
if (verbose) {
|
|
101
|
-
logger?.info(
|
|
102
|
-
`[createSharedLoader] Build mode fallback: prefixing with ${serverBuildPath}: ${resolvedModuleID}`
|
|
66
|
+
build.server || "server",
|
|
67
|
+
resolvedModuleID
|
|
103
68
|
);
|
|
104
69
|
}
|
|
105
70
|
}
|
|
71
|
+
} else if (isBuildMode && effectiveProjectRoot && build && !isAbsolute(resolvedModuleID)) {
|
|
72
|
+
resolvedModuleID = join(
|
|
73
|
+
effectiveProjectRoot,
|
|
74
|
+
build.outDir || "dist",
|
|
75
|
+
build.server || "server",
|
|
76
|
+
resolvedModuleID
|
|
77
|
+
);
|
|
106
78
|
}
|
|
107
79
|
const fullPath = isAbsolute(resolvedModuleID) ? resolvedModuleID : effectiveProjectRoot ? join(effectiveProjectRoot, resolvedModuleID) : resolvedModuleID;
|
|
108
|
-
if (verbose) {
|
|
109
|
-
logger?.info(`[createSharedLoader] Importing from: ${fullPath}`);
|
|
110
|
-
}
|
|
111
80
|
const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;
|
|
112
81
|
const result = await import(fileUrl);
|
|
113
82
|
if (result == null) {
|
|
114
83
|
throw new Error(`Module "${moduleId}" does not have any exports`);
|
|
115
84
|
}
|
|
116
85
|
if (!Object.keys(result).length && exportName?.length) {
|
|
117
|
-
throw new Error(
|
|
118
|
-
`Module "${moduleId}" is a module, but does not have any exports so it can't find ${exportName}`
|
|
119
|
-
);
|
|
86
|
+
throw new Error(`Module "${moduleId}" has no exports, can't find ${exportName}`);
|
|
120
87
|
}
|
|
121
88
|
if (exportName && !(exportName in result)) {
|
|
122
|
-
throw new Error(
|
|
123
|
-
`Module "${moduleId}" exists, but does not export "${exportName}"`
|
|
124
|
-
);
|
|
125
|
-
}
|
|
126
|
-
if (verbose) {
|
|
127
|
-
logger?.info(
|
|
128
|
-
`[createSharedLoader] Module loaded successfully, exports: ${Object.keys(
|
|
129
|
-
result
|
|
130
|
-
).join(", ")}`
|
|
131
|
-
);
|
|
89
|
+
throw new Error(`Module "${moduleId}" does not export "${exportName}"`);
|
|
132
90
|
}
|
|
133
91
|
return result;
|
|
134
92
|
}
|
|
135
93
|
|
|
136
94
|
export { createSharedLoader };
|
|
137
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createSharedLoader.js","sources":["../../../plugin/helpers/createSharedLoader.ts"],"sourcesContent":["import { join, isAbsolute } from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport type { Logger } from \"vite\";\nimport type { InputNormalizer } from \"../types.js\";\nimport { resolveVirtualAndNodeModules } from \"./resolveVirtualAndNodeModules.js\";\nimport { resolveModuleFromManifest } from \"./resolveModuleFromManifest.js\";\n\n/**\n * Shared loader utility that both RSC worker loader and build loader can use.\n * \n * This handles the common pattern:\n * 1. Parse id to get moduleId and exportName\n * 2. Handle virtual modules and node_modules (via resolveVirtualAndNodeModules)\n * 3. Try manifest-based resolution (build mode)\n * 4. Import the module\n * 5. Validate exports\n * \n * If the result is already a module object (not a Promise), it's returned directly.\n * This allows loaders to reuse already-loaded modules.\n * \n * @param options - Loader configuration options\n * @returns The resolved module (already a module object, not a Promise)\n */\nexport async function createSharedLoader({\n  moduleId,\n  exportName,\n  verbose = false,\n  logger,\n  // Virtual module handling\n  resolveVirtual = true,\n  // Manifest resolution\n  manifest,\n  normalizer,\n  moduleBase,\n  preserveModulesRoot,\n  projectRoot,\n  buildOutDir,\n  buildServerDir,\n  // Direct import options\n  isBuildMode = false,\n  isServeMode = false,\n  effectiveProjectRoot,\n  build,\n}: {\n  moduleId: string;\n  exportName?: string;\n  verbose?: boolean;\n  logger?: Logger;\n  // Virtual module handling\n  resolveVirtual?: boolean;\n  // Manifest resolution\n  manifest?: Record<string, { file: string } | undefined>;\n  normalizer?: InputNormalizer;\n  moduleBase?: string;\n  preserveModulesRoot?: boolean;\n  projectRoot?: string;\n  buildOutDir?: string;\n  buildServerDir?: string;\n  // Direct import options\n  isBuildMode?: boolean;\n  isServeMode?: boolean;\n  effectiveProjectRoot?: string;\n  build?: {\n    server?: string;\n    client?: string;\n    static?: string;\n    outDir?: string;\n  };\n}): Promise<Record<string, any>> {\n  // Step 1: Handle virtual modules and node_modules first (if enabled)\n  if (resolveVirtual) {\n    const virtualOrNodeModule = await resolveVirtualAndNodeModules(\n      moduleId,\n      exportName,\n      verbose,\n      logger\n    );\n    if (virtualOrNodeModule !== null) {\n      // resolveVirtualAndNodeModules returns a module object directly (not a Promise)\n      // If it's already a module object, return it directly\n      return virtualOrNodeModule;\n    }\n  }\n\n  // Step 2: Try manifest-based resolution (build mode)\n  let resolvedModuleID = moduleId;\n  if (isBuildMode && manifest && normalizer && moduleBase && projectRoot && buildOutDir && buildServerDir) {\n    const manifestResolution = resolveModuleFromManifest({\n      moduleId,\n      normalizer,\n      manifest,\n      moduleBase,\n      preserveModulesRoot,\n      projectRoot,\n      buildOutDir,\n      buildServerDir,\n      verbose,\n      logger,\n    });\n\n    if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {\n      // Found in manifest - use the resolved path (it's already a full absolute path)\n      resolvedModuleID = manifestResolution.resolvedPath;\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode: resolved via manifest to: ${resolvedModuleID}`\n        );\n      }\n    } else {\n      // Not in manifest - use the builtModuleId from resolution\n      resolvedModuleID = manifestResolution.builtModuleId;\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode: not in manifest, using builtModuleId: ${resolvedModuleID}`\n        );\n      }\n      \n      // Check if we need to prefix with build directory\n      // A source path starts with moduleBase (e.g., \"src/\"), a built path doesn't\n      // Also check if it's already an absolute path or starts with file://\n      const isSourcePath = moduleId.startsWith(moduleBase + \"/\") || \n                          moduleId.startsWith(\"./\" + moduleBase + \"/\") ||\n                          (isAbsolute(moduleId) && moduleId.includes(moduleBase));\n      \n      // If it's not a source path and not already absolute, prefix with server build directory\n      if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {\n        const serverBuildPath = join(\n          effectiveProjectRoot,\n          build.outDir || \"dist\",\n          build.server || \"server\"\n        );\n        resolvedModuleID = join(serverBuildPath, resolvedModuleID);\n        if (verbose) {\n          logger?.info(\n            `[createSharedLoader] Build mode: prefixing with ${serverBuildPath}: ${resolvedModuleID}`\n          );\n        }\n      }\n    }\n  } else if (isServeMode) {\n    // Dev mode: load directly from source files, no build path prefixing\n    if (verbose) {\n      logger?.info(\n        `[createSharedLoader] Dev mode: loading directly from source`\n      );\n    }\n  } else if (isBuildMode && effectiveProjectRoot && build) {\n    // Build mode fallback: prefix with server build directory even without manifest/normalizer\n    if (!isAbsolute(resolvedModuleID)) {\n      const serverBuildPath = join(\n        effectiveProjectRoot,\n        build.outDir || \"dist\",\n        build.server || \"server\"\n      );\n      resolvedModuleID = join(serverBuildPath, resolvedModuleID);\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode fallback: prefixing with ${serverBuildPath}: ${resolvedModuleID}`\n        );\n      }\n    }\n  }\n\n  // Step 3: Construct the full path and import\n  const fullPath = isAbsolute(resolvedModuleID) \n    ? resolvedModuleID \n    : effectiveProjectRoot \n      ? join(effectiveProjectRoot, resolvedModuleID)\n      : resolvedModuleID;\n\n  if (verbose) {\n    logger?.info(`[createSharedLoader] Importing from: ${fullPath}`);\n  }\n\n  // Step 4: Import the module\n  const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;\n  const result = await import(fileUrl);\n\n  // Step 5: Validate exports\n  if (result == null) {\n    throw new Error(`Module \"${moduleId}\" does not have any exports`);\n  }\n\n  if (!Object.keys(result).length && exportName?.length) {\n    throw new Error(\n      `Module \"${moduleId}\" is a module, but does not have any exports so it can't find ${exportName}`\n    );\n  }\n\n  if (exportName && !(exportName in result)) {\n    throw new Error(\n      `Module \"${moduleId}\" exists, but does not export \"${exportName}\"`\n    );\n  }\n\n  if (verbose) {\n    logger?.info(\n      `[createSharedLoader] Module loaded successfully, exports: ${Object.keys(\n        result\n      ).join(\", \")}`\n    );\n  }\n\n  // Import always returns a module object (not a Promise), so return it directly\n  return result;\n}\n\n"],"names":[],"mappings":"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"}
|
|
95
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createSharedLoader.js","sources":["../../../plugin/helpers/createSharedLoader.ts"],"sourcesContent":["import { join, isAbsolute } from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport type { Logger } from \"vite\";\nimport type { InputNormalizer } from \"../types.js\";\nimport { resolveVirtualAndNodeModules } from \"./resolveVirtualAndNodeModules.js\";\nimport { resolveModuleFromManifest } from \"./resolveModuleFromManifest.js\";\n\n/**\n * Shared loader utility that both RSC worker loader and build loader can use.\n * \n * This handles the common pattern:\n * 1. Parse id to get moduleId and exportName\n * 2. Handle virtual modules and node_modules (via resolveVirtualAndNodeModules)\n * 3. Try manifest-based resolution (build mode)\n * 4. Import the module\n * 5. Validate exports\n * \n * If the result is already a module object (not a Promise), it's returned directly.\n * This allows loaders to reuse already-loaded modules.\n * \n * @param options - Loader configuration options\n * @returns The resolved module (already a module object, not a Promise)\n */\nexport async function createSharedLoader({\n  moduleId,\n  exportName,\n  verbose = false,\n  logger,\n  // Virtual module handling\n  resolveVirtual = true,\n  // Manifest resolution\n  manifest,\n  normalizer,\n  moduleBase,\n  preserveModulesRoot,\n  projectRoot,\n  buildOutDir,\n  buildServerDir,\n  // Direct import options\n  isBuildMode = false,\n  isServeMode: _isServeMode = false,\n  effectiveProjectRoot,\n  build,\n}: {\n  moduleId: string;\n  exportName?: string;\n  verbose?: boolean;\n  logger?: Logger;\n  // Virtual module handling\n  resolveVirtual?: boolean;\n  // Manifest resolution\n  manifest?: Record<string, { file: string } | undefined>;\n  normalizer?: InputNormalizer;\n  moduleBase?: string;\n  preserveModulesRoot?: boolean;\n  projectRoot?: string;\n  buildOutDir?: string;\n  buildServerDir?: string;\n  // Direct import options\n  isBuildMode?: boolean;\n  isServeMode?: boolean;\n  effectiveProjectRoot?: string;\n  build?: {\n    server?: string;\n    client?: string;\n    static?: string;\n    outDir?: string;\n  };\n}): Promise<Record<string, any>> {\n  // Step 1: Handle virtual modules and node_modules first (if enabled)\n  if (resolveVirtual) {\n    const virtualOrNodeModule = await resolveVirtualAndNodeModules(\n      moduleId,\n      exportName,\n      verbose,\n      logger\n    );\n    if (virtualOrNodeModule !== null) {\n      // resolveVirtualAndNodeModules returns a module object directly (not a Promise)\n      // If it's already a module object, return it directly\n      return virtualOrNodeModule;\n    }\n  }\n\n  // Step 2: Try manifest-based resolution (build mode)\n  let resolvedModuleID = moduleId;\n  if (isBuildMode && manifest && normalizer && moduleBase && projectRoot && buildOutDir && buildServerDir) {\n    const manifestResolution = resolveModuleFromManifest({\n      moduleId,\n      normalizer,\n      manifest,\n      moduleBase,\n      preserveModulesRoot,\n      projectRoot,\n      buildOutDir,\n      buildServerDir,\n      verbose,\n      logger,\n    });\n\n    if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {\n      resolvedModuleID = manifestResolution.resolvedPath;\n    } else {\n      resolvedModuleID = manifestResolution.builtModuleId;\n      \n      // Prefix non-source, non-absolute paths with server build directory\n      const isSourcePath = moduleId.startsWith(moduleBase + \"/\") || \n                          moduleId.startsWith(\"./\" + moduleBase + \"/\") ||\n                          (isAbsolute(moduleId) && moduleId.includes(moduleBase));\n      \n      if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {\n        resolvedModuleID = join(\n          effectiveProjectRoot,\n          build.outDir || \"dist\",\n          build.server || \"server\",\n          resolvedModuleID\n        );\n      }\n    }\n  } else if (isBuildMode && effectiveProjectRoot && build && !isAbsolute(resolvedModuleID)) {\n    // Build mode fallback without manifest\n    resolvedModuleID = join(\n      effectiveProjectRoot,\n      build.outDir || \"dist\",\n      build.server || \"server\",\n      resolvedModuleID\n    );\n  }\n\n  // Step 3: Construct the full path and import\n  const fullPath = isAbsolute(resolvedModuleID) \n    ? resolvedModuleID \n    : effectiveProjectRoot \n      ? join(effectiveProjectRoot, resolvedModuleID)\n      : resolvedModuleID;\n\n  // Import the module\n  const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;\n  const result = await import(fileUrl);\n\n  // Validate exports\n  if (result == null) {\n    throw new Error(`Module \"${moduleId}\" does not have any exports`);\n  }\n  if (!Object.keys(result).length && exportName?.length) {\n    throw new Error(`Module \"${moduleId}\" has no exports, can't find ${exportName}`);\n  }\n  if (exportName && !(exportName in result)) {\n    throw new Error(`Module \"${moduleId}\" does not export \"${exportName}\"`);\n  }\n\n  return result;\n}\n\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react-loader.d.ts","sourceRoot":"","sources":["../../../plugin/loader/react-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,wBAAwB,EACxB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASvD,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAOzD,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAyB7E,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,WAAW,EAAE,qBAAqB,CAAC;IACnC,cAAc,EAAE,wBAAwB,CAAC;CAC1C,QA4CA;AAED,eAAO,MAAM,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"react-loader.d.ts","sourceRoot":"","sources":["../../../plugin/loader/react-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,wBAAwB,EACxB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASvD,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAOzD,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAyB7E,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,WAAW,EAAE,qBAAqB,CAAC;IACnC,cAAc,EAAE,wBAAwB,CAAC;CAC1C,QA4CA;AAED,eAAO,MAAM,IAAI,EAAE,QAqHlB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAErB,CAAC"}
|
|
@@ -65,26 +65,9 @@ const load = async (url, context, nextLoad) => {
|
|
|
65
65
|
});
|
|
66
66
|
}
|
|
67
67
|
const verbose2 = userOptions?.verbose ?? false;
|
|
68
|
-
if (verbose2) {
|
|
69
|
-
logger.info(`Attempting to load: ${url}`);
|
|
70
|
-
logger.info(`Context: ${JSON.stringify({
|
|
71
|
-
format: context.format,
|
|
72
|
-
conditions: context.conditions
|
|
73
|
-
})}`);
|
|
74
|
-
}
|
|
75
68
|
const { format } = context;
|
|
76
69
|
if (format === "module" || format === "module-typescript") {
|
|
77
|
-
if (verbose2) {
|
|
78
|
-
logger.info(`Loading module: ${url}`);
|
|
79
|
-
}
|
|
80
70
|
const result = await nextLoad(url, context);
|
|
81
|
-
if (verbose2) {
|
|
82
|
-
logger.info(`Next load result: ${JSON.stringify({
|
|
83
|
-
format: result.format,
|
|
84
|
-
shortCircuit: result.shortCircuit,
|
|
85
|
-
source: typeof result.source
|
|
86
|
-
})}`);
|
|
87
|
-
}
|
|
88
71
|
let source = typeof result.source === "string" ? result.source : result.source instanceof Uint8Array ? new TextDecoder().decode(result.source) : String(result.source);
|
|
89
72
|
if (!url.includes("node_modules")) {
|
|
90
73
|
const namedImportRe = /import\s*\{([^}]+)\}\s*from\s*["']react["']\s*;?/g;
|
|
@@ -104,35 +87,13 @@ const load = async (url, context, nextLoad) => {
|
|
|
104
87
|
const hasFileLevelClientDirective = source.startsWith('"use client"') || source.startsWith("'use client'");
|
|
105
88
|
const isServer = hasFileLevelServerDirective || (typeof isServerFunction === "function" ? isServerFunction(source, url) : false);
|
|
106
89
|
const isClient = hasFileLevelClientDirective || (typeof isClientComponent === "function" ? isClientComponent(source, url) : false);
|
|
107
|
-
if (verbose2) {
|
|
108
|
-
let startPreviewIndex = 0;
|
|
109
|
-
let startLine = 0;
|
|
110
|
-
const lines = source.split("\n");
|
|
111
|
-
while (lines[startLine].trim() === "" || lines[startLine].trim() === "\r" || // comment lines
|
|
112
|
-
lines[startLine].trim().startsWith("//") || lines[startLine].trim().startsWith("/**") || lines[startLine].trim().startsWith("*")) {
|
|
113
|
-
startPreviewIndex += lines[startLine].length;
|
|
114
|
-
startLine++;
|
|
115
|
-
}
|
|
116
|
-
logger.info(`Module analysis: ${JSON.stringify({
|
|
117
|
-
url,
|
|
118
|
-
isServer,
|
|
119
|
-
isClient,
|
|
120
|
-
hasFileLevelServerDirective,
|
|
121
|
-
hasFileLevelClientDirective,
|
|
122
|
-
sourceLength: source.length,
|
|
123
|
-
sourcePreview: source.slice(startPreviewIndex, startPreviewIndex + 100) + "..."
|
|
124
|
-
})}`);
|
|
125
|
-
}
|
|
126
90
|
if (!isServer && !isClient) {
|
|
127
|
-
if (verbose2) {
|
|
128
|
-
logger.info(`Skipping non-server/non-client module: ${url}`);
|
|
129
|
-
}
|
|
130
91
|
return { ...result, source };
|
|
131
92
|
}
|
|
132
|
-
const filePath = url.startsWith("file://") ? fileURLToPath(url) : url;
|
|
133
93
|
if (verbose2) {
|
|
134
|
-
logger.info(`
|
|
94
|
+
logger.info(`[react-loader] ${isServer ? "server" : "client"} module: ${url}`);
|
|
135
95
|
}
|
|
96
|
+
const filePath = url.startsWith("file://") ? fileURLToPath(url) : url;
|
|
136
97
|
if (typeof userOptions.moduleID !== "function") {
|
|
137
98
|
const buildConfigEnv = resolvedConfig?.configEnv ?? { command: "build"};
|
|
138
99
|
userOptions.moduleID = createDefaultModuleID({
|
|
@@ -151,24 +112,9 @@ const load = async (url, context, nextLoad) => {
|
|
|
151
112
|
const [, value] = userOptions.normalizer(filePath);
|
|
152
113
|
moduleID = join(userOptions.moduleBasePath, value);
|
|
153
114
|
finalID = userOptions.moduleID?.(moduleID) || moduleID;
|
|
154
|
-
if (verbose2) {
|
|
155
|
-
logger.info(`Normalized IDs: ${moduleID} -> ${finalID}`);
|
|
156
|
-
logger.info(`userOptions: ${JSON.stringify(userOptions)}`);
|
|
157
|
-
}
|
|
158
115
|
}
|
|
159
116
|
const { code: transformed, map } = await transformer(source, moduleID, finalID);
|
|
160
|
-
if (verbose2) {
|
|
161
|
-
logger.info(`Transformation result: ${JSON.stringify({
|
|
162
|
-
originalLength: source.length,
|
|
163
|
-
transformedLength: transformed.length,
|
|
164
|
-
wasTransformed: source !== transformed,
|
|
165
|
-
hasSourceMap: !!map
|
|
166
|
-
})}`);
|
|
167
|
-
}
|
|
168
117
|
if (loaderPort) {
|
|
169
|
-
if (verbose2) {
|
|
170
|
-
logger.info("Sending SERVER_MODULE message");
|
|
171
|
-
}
|
|
172
118
|
loaderPort.postMessage({
|
|
173
119
|
type: "SERVER_MODULE",
|
|
174
120
|
id: finalID,
|
|
@@ -182,23 +128,11 @@ const load = async (url, context, nextLoad) => {
|
|
|
182
128
|
map
|
|
183
129
|
};
|
|
184
130
|
}
|
|
185
|
-
if (verbose2) {
|
|
186
|
-
logger.info(`Skipping non-module format: ${format}`);
|
|
187
|
-
}
|
|
188
131
|
return nextLoad(url, context);
|
|
189
132
|
};
|
|
190
133
|
const resolve = async (specifier, context, nextResolve) => {
|
|
191
|
-
|
|
192
|
-
if (verbose) {
|
|
193
|
-
logger.info(`Resolving: ${specifier}`);
|
|
194
|
-
logger.info(`Resolve context: ${JSON.stringify(context)}`);
|
|
195
|
-
}
|
|
196
|
-
const result = await nextResolve(specifier, context);
|
|
197
|
-
if (verbose) {
|
|
198
|
-
logger.info(`Resolve result: ${JSON.stringify(result)}`);
|
|
199
|
-
}
|
|
200
|
-
return result;
|
|
134
|
+
return nextResolve(specifier, context);
|
|
201
135
|
};
|
|
202
136
|
|
|
203
137
|
export { initialize, load, resolve };
|
|
204
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"react-loader.js","sources":["../../../plugin/loader/react-loader.ts"],"sourcesContent":["import type {\n  ResolvedUserOptions,\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { ModuleInfo } from \"rollup\";\nimport { parentPort } from \"node:worker_threads\";\nimport type { MessagePort } from \"node:worker_threads\";\nimport type {\n  InitializedReactLoaderMessage,\n  ServerModuleMessage,\n} from \"../worker/rsc/types.js\";\nimport { fileURLToPath } from \"node:url\";\nimport { join } from \"node:path\";\nimport { hydrateUserOptions } from \"../helpers/hydrateUserOptions.js\";\nimport { DEFAULT_LOADER_CONFIG } from \"../config/defaults.js\";\nimport type { LoadHook, ResolveHook } from \"node:module\";\nimport type { RawSourceMap } from \"source-map\";\nimport { createTransformer } from \"./createTransformer.js\";\n\nimport { createLogger, type Logger } from \"vite\";\nimport { createDefaultModuleID } from \"../config/createModuleID.js\";\n\nexport type LoaderOptions = {\n  id: string;\n  resolveDependencies?: boolean;\n  format?: string;\n  conditions?: string[];\n  importAssertions?: Record<string, unknown>;\n  importAttributes?: Record<string, unknown>;\n  source: string;\n};\n\nexport type LoaderFunction = (options: LoaderOptions) => Promise<ModuleInfo>;\n\nlet initialized = false;\nlet userOptions: ResolvedUserOptions;\nlet loaderPort: MessagePort | null;\nlet resolvedConfig: SerializedResolvedConfig;\nlet isServerFunction:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n\nlet isClientComponent:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isClientComponentCode;\nlet logger: Logger;\nlet verbose: boolean;\nlet transformer: (\n  source: string,\n  moduleId: string,\n  transformedModuleId: string\n) => Promise<{ code: string; map: RawSourceMap | null }>;\n\nexport function initialize(data: {\n  id: string;\n  port: MessagePort;\n  userOptions: SerializedUserOptions;\n  resolvedConfig: SerializedResolvedConfig;\n}) {\n  const {\n    id,\n    port,\n    userOptions: serializedUserOptions,\n    resolvedConfig: serializedResolvedConfig,\n  } = data;\n  \n  verbose = serializedUserOptions?.verbose ?? false;\n  logger = createLogger(serializedResolvedConfig?.logLevel ?? \"info\", {\n    prefix: id,\n  });\n  \n  // Store resolvedConfig at module level for use in other functions\n  resolvedConfig = serializedResolvedConfig;\n  \n  if (verbose) {\n    logger.info(`Initializing with options: ${id}`);\n  }\n  loaderPort = port;\n  \n  // when user options are provided, use the user options using the hydrateUserOptions function\n  const resolvedUserOptions = hydrateUserOptions(serializedUserOptions);\n  if (resolvedUserOptions.type === \"error\") {\n    throw resolvedUserOptions.error;\n  }\n\n  // Use the hydrated user options directly (includes recreated functions)\n  userOptions = resolvedUserOptions.userOptions;\n\n  isServerFunction = userOptions.loader?.isServerFunctionCode ?? DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n  isClientComponent = userOptions.loader?.isClientComponentCode ?? DEFAULT_LOADER_CONFIG.isClientComponentCode;\n  \n  transformer = createTransformer({\n    options: userOptions,\n  });\n  \n  if (!initialized && loaderPort) {\n    loaderPort.postMessage({\n      type: \"INITIALIZED_REACT_LOADER\",\n      id,\n    } satisfies InitializedReactLoaderMessage);\n  }\n  initialized = true;\n}\n\nexport const load: LoadHook = async (url, context, nextLoad) => {\n  if (!initialized) {\n    // Fallback initialization when not properly set up\n    // This should not happen in normal usage, but provides a basic fallback\n    initialize({\n      id: \"react-loader\",\n      port: parentPort!,\n      userOptions: {} as any,\n      resolvedConfig: {} as any,\n    });\n  }\n  const verbose = userOptions?.verbose ?? false;\n  if (verbose) {\n    logger.info(`Attempting to load: ${url}`);\n    logger.info(`Context: ${JSON.stringify({\n      format: context.format,\n      conditions: context.conditions,\n    })}`);\n  }\n\n  const { format } = context;\n  if (format === \"module\" || format === \"module-typescript\") {\n    if (verbose) {\n      logger.info(`Loading module: ${url}`);\n    }\n    \n    // Load the URL normally\n    const result = await nextLoad(url, context);\n    \n    if (verbose) {\n      logger.info(`Next load result: ${JSON.stringify({\n        format: result.format,\n        shortCircuit: result.shortCircuit,\n        source: typeof result.source,\n      })}`);\n    }\n\n    let source =\n      typeof result.source === \"string\"\n        ? result.source\n        : result.source instanceof Uint8Array\n        ? new TextDecoder().decode(result.source)\n        : String(result.source);\n\n    // Fix CJS React named imports: React's react-server condition exports CJS,\n    // but esbuild/tsx transforms produce ESM named imports that fail at runtime.\n    // Rewrite `import { X } from \"react\"` → `import __react from \"react\"; const { X } = __react;`\n    if (!url.includes('node_modules')) {\n      const namedImportRe = /import\\s*\\{([^}]+)\\}\\s*from\\s*[\"']react[\"']\\s*;?/g;\n      if (namedImportRe.test(source)) {\n        namedImportRe.lastIndex = 0;\n        let counter = 0;\n        source = source.replace(namedImportRe, (_match: string, imports: string) => {\n          const alias = `__react_cjs_${counter++}`;\n          return `import ${alias} from \"react\"; const {${imports}} = ${alias};`;\n        });\n        if (verbose) {\n          logger.info(`Rewrote CJS React named imports in: ${url}`);\n        }\n      }\n    }\n\n    // Check for file-level server directive first\n    const hasFileLevelServerDirective =\n      source.startsWith('\"use server\"') || source.startsWith(\"'use server'\");\n    const hasFileLevelClientDirective =\n      source.startsWith('\"use client\"') || source.startsWith(\"'use client'\");\n\n    const isServer =\n      hasFileLevelServerDirective ||\n      (typeof isServerFunction === \"function\"\n        ? isServerFunction(source, url)\n        : false);\n\n    const isClient =\n      hasFileLevelClientDirective ||\n      (typeof isClientComponent === \"function\"\n        ? isClientComponent(source, url)\n        : false);\n\n    if (verbose) {\n      let startPreviewIndex = 0;\n      let startLine = 0;\n      const lines = source.split(\"\\n\");\n      while (\n        lines[startLine].trim() === \"\" || lines[startLine].trim() === \"\\r\" ||\n        // comment lines\n        lines[startLine].trim().startsWith(\"//\")\n        || lines[startLine].trim().startsWith(\"/**\")\n        || lines[startLine].trim().startsWith(\"*\")\n      ) {\n        startPreviewIndex += lines[startLine].length;\n        startLine++;\n      }\n      logger.info(`Module analysis: ${JSON.stringify({\n        url,\n        isServer,\n        isClient,\n        hasFileLevelServerDirective,\n        hasFileLevelClientDirective,\n        sourceLength: source.length,\n        sourcePreview: source.slice(startPreviewIndex, startPreviewIndex + 100) + \"...\",\n      })}`);\n    }\n\n    if (!isServer && !isClient) {\n      if (verbose) {\n        logger.info(`Skipping non-server/non-client module: ${url}`);\n      }\n      // Return modified source if CJS React imports were rewritten\n      return { ...result, source };\n    }\n\n    // Handle file URLs\n    const filePath = url.startsWith(\"file://\") ? fileURLToPath(url) : url;\n    if (verbose) {\n      logger.info(`File path: ${filePath}`);\n    }\n\n    if(typeof userOptions.moduleID !== \"function\") {\n      // Ensure we have proper build context for RSC worker\n      // If configEnv is not available or doesn't indicate build mode, create a build-compatible configEnv\n      const buildConfigEnv = resolvedConfig?.configEnv ?? { command: \"build\", mode: \"production\" };\n      \n      userOptions.moduleID = createDefaultModuleID({\n        moduleBase: userOptions.moduleBase,\n        moduleBasePath: userOptions.moduleBasePath,\n        autoDiscover: userOptions.autoDiscover,\n        build: userOptions.build,\n        dev: userOptions.dev,\n        moduleBaseURL: userOptions.moduleBaseURL,\n        projectRoot: userOptions.projectRoot,\n      }, buildConfigEnv);\n    }\n\n    // Normalize the URL using the same logic as plugin.server.ts\n    let moduleID = filePath;\n    let finalID = filePath;\n    if (userOptions?.normalizer) {\n      const [, value] = userOptions.normalizer(filePath);\n      moduleID = join(userOptions.moduleBasePath, value);\n      finalID = userOptions.moduleID?.(moduleID) || moduleID;\n      if (verbose) {\n        logger.info(`Normalized IDs: ${moduleID} -> ${finalID}`);\n        logger.info(`userOptions: ${JSON.stringify(userOptions)}`);\n      }\n    }\n\n    const { code: transformed, map } = await transformer(source, moduleID, finalID);\n\n    if (verbose) {\n      logger.info(`Transformation result: ${JSON.stringify({\n        originalLength: source.length,\n        transformedLength: transformed.length,\n        wasTransformed: source !== transformed,\n        hasSourceMap: !!map,\n      })}`);\n    }\n\n    if (loaderPort) {\n      if (verbose) {\n        logger.info(\"Sending SERVER_MODULE message\");\n      }\n      loaderPort.postMessage({\n        type: \"SERVER_MODULE\",\n        id: finalID,\n        url: filePath,\n        source: transformed,\n      } satisfies ServerModuleMessage);\n    }\n\n    return {\n      ...result,\n      source: transformed,\n      map,\n    };\n  }\n\n  if (verbose) {\n    logger.info(`Skipping non-module format: ${format}`);\n  }\n  return nextLoad(url, context);\n};\n\nexport const resolve: ResolveHook = async (specifier, context, nextResolve) => {\n  verbose = userOptions?.verbose ?? false;\n  if (verbose) {\n    logger.info(`Resolving: ${specifier}`);\n    logger.info(`Resolve context: ${JSON.stringify(context)}`);\n  }\n  const result = await nextResolve(specifier, context);\n  if (verbose) {\n    logger.info(`Resolve result: ${JSON.stringify(result)}`);\n  }\n  return result;\n};\n"],"names":["verbose"],"mappings":";;;;;;;;;;;;;;AAmCA,IAAI,WAAc,GAAA,KAAA;AAClB,IAAI,WAAA;AACJ,IAAI,UAAA;AACJ,IAAI,cAAA;AACJ,IAAI,mBAIO,qBAAsB,CAAA,oBAAA;AAEjC,IAAI,oBAIO,qBAAsB,CAAA,qBAAA;AACjC,IAAI,MAAA;AACJ,IAAI,OAAA;AACJ,IAAI,WAAA;AAMG,SAAS,WAAW,IAKxB,EAAA;AACD,EAAM,MAAA;AAAA,IACJ,EAAA;AAAA,IACA,IAAA;AAAA,IACA,WAAa,EAAA,qBAAA;AAAA,IACb,cAAgB,EAAA;AAAA,GACd,GAAA,IAAA;AAEJ,EAAA,OAAA,GAAU,uBAAuB,OAAW,IAAA,KAAA;AAC5C,EAAS,MAAA,GAAA,YAAA,CAAa,wBAA0B,EAAA,QAAA,IAAY,MAAQ,EAAA;AAAA,IAClE,MAAQ,EAAA;AAAA,GACT,CAAA;AAGD,EAAiB,cAAA,GAAA,wBAAA;AAEjB,EAAA,IAAI,OAAS,EAAA;AACX,IAAO,MAAA,CAAA,IAAA,CAAK,CAA8B,2BAAA,EAAA,EAAE,CAAE,CAAA,CAAA;AAAA;AAEhD,EAAa,UAAA,GAAA,IAAA;AAGb,EAAM,MAAA,mBAAA,GAAsB,mBAAmB,qBAAqB,CAAA;AACpE,EAAI,IAAA,mBAAA,CAAoB,SAAS,OAAS,EAAA;AACxC,IAAA,MAAM,mBAAoB,CAAA,KAAA;AAAA;AAI5B,EAAA,WAAA,GAAc,mBAAoB,CAAA,WAAA;AAElC,EAAmB,gBAAA,GAAA,WAAA,CAAY,MAAQ,EAAA,oBAAA,IAAwB,qBAAsB,CAAA,oBAAA;AACrF,EAAoB,iBAAA,GAAA,WAAA,CAAY,MAAQ,EAAA,qBAAA,IAAyB,qBAAsB,CAAA,qBAAA;AAEvF,EAAA,WAAA,GAAc,iBAAkB,CAAA;AAAA,IAC9B,OAAS,EAAA;AAAA,GACV,CAAA;AAED,EAAI,IAAA,CAAC,eAAe,UAAY,EAAA;AAC9B,IAAA,UAAA,CAAW,WAAY,CAAA;AAAA,MACrB,IAAM,EAAA,0BAAA;AAAA,MACN;AAAA,KACuC,CAAA;AAAA;AAE3C,EAAc,WAAA,GAAA,IAAA;AAChB;AAEO,MAAM,IAAiB,GAAA,OAAO,GAAK,EAAA,OAAA,EAAS,QAAa,KAAA;AAC9D,EAAA,IAAI,CAAC,WAAa,EAAA;AAGhB,IAAW,UAAA,CAAA;AAAA,MACT,EAAI,EAAA,cAAA;AAAA,MACJ,IAAM,EAAA,UAAA;AAAA,MACN,aAAa,EAAC;AAAA,MACd,gBAAgB;AAAC,KAClB,CAAA;AAAA;AAEH,EAAMA,MAAAA,QAAAA,GAAU,aAAa,OAAW,IAAA,KAAA;AACxC,EAAA,IAAIA,QAAS,EAAA;AACX,IAAO,MAAA,CAAA,IAAA,CAAK,CAAuB,oBAAA,EAAA,GAAG,CAAE,CAAA,CAAA;AACxC,IAAO,MAAA,CAAA,IAAA,CAAK,CAAY,SAAA,EAAA,IAAA,CAAK,SAAU,CAAA;AAAA,MACrC,QAAQ,OAAQ,CAAA,MAAA;AAAA,MAChB,YAAY,OAAQ,CAAA;AAAA,KACrB,CAAC,CAAE,CAAA,CAAA;AAAA;AAGN,EAAM,MAAA,EAAE,QAAW,GAAA,OAAA;AACnB,EAAI,IAAA,MAAA,KAAW,QAAY,IAAA,MAAA,KAAW,mBAAqB,EAAA;AACzD,IAAA,IAAIA,QAAS,EAAA;AACX,MAAO,MAAA,CAAA,IAAA,CAAK,CAAmB,gBAAA,EAAA,GAAG,CAAE,CAAA,CAAA;AAAA;AAItC,IAAA,MAAM,MAAS,GAAA,MAAM,QAAS,CAAA,GAAA,EAAK,OAAO,CAAA;AAE1C,IAAA,IAAIA,QAAS,EAAA;AACX,MAAO,MAAA,CAAA,IAAA,CAAK,CAAqB,kBAAA,EAAA,IAAA,CAAK,SAAU,CAAA;AAAA,QAC9C,QAAQ,MAAO,CAAA,MAAA;AAAA,QACf,cAAc,MAAO,CAAA,YAAA;AAAA,QACrB,MAAA,EAAQ,OAAO,MAAO,CAAA;AAAA,OACvB,CAAC,CAAE,CAAA,CAAA;AAAA;AAGN,IAAA,IAAI,SACF,OAAO,MAAA,CAAO,WAAW,QACrB,GAAA,MAAA,CAAO,SACP,MAAO,CAAA,MAAA,YAAkB,aACzB,IAAI,WAAA,GAAc,MAAO,CAAA,MAAA,CAAO,MAAM,CACtC,GAAA,MAAA,CAAO,OAAO,MAAM,CAAA;AAK1B,IAAA,IAAI,CAAC,GAAA,CAAI,QAAS,CAAA,cAAc,CAAG,EAAA;AACjC,MAAA,MAAM,aAAgB,GAAA,mDAAA;AACtB,MAAI,IAAA,aAAA,CAAc,IAAK,CAAA,MAAM,CAAG,EAAA;AAC9B,QAAA,aAAA,CAAc,SAAY,GAAA,CAAA;AAC1B,QAAA,IAAI,OAAU,GAAA,CAAA;AACd,QAAA,MAAA,GAAS,MAAO,CAAA,OAAA,CAAQ,aAAe,EAAA,CAAC,QAAgB,OAAoB,KAAA;AAC1E,UAAM,MAAA,KAAA,GAAQ,eAAe,OAAS,EAAA,CAAA,CAAA;AACtC,UAAA,OAAO,CAAU,OAAA,EAAA,KAAK,CAAyB,sBAAA,EAAA,OAAO,OAAO,KAAK,CAAA,CAAA,CAAA;AAAA,SACnE,CAAA;AACD,QAAA,IAAIA,QAAS,EAAA;AACX,UAAO,MAAA,CAAA,IAAA,CAAK,CAAuC,oCAAA,EAAA,GAAG,CAAE,CAAA,CAAA;AAAA;AAC1D;AACF;AAIF,IAAA,MAAM,8BACJ,MAAO,CAAA,UAAA,CAAW,cAAc,CAAK,IAAA,MAAA,CAAO,WAAW,cAAc,CAAA;AACvE,IAAA,MAAM,8BACJ,MAAO,CAAA,UAAA,CAAW,cAAc,CAAK,IAAA,MAAA,CAAO,WAAW,cAAc,CAAA;AAEvE,IAAM,MAAA,QAAA,GACJ,gCACC,OAAO,gBAAA,KAAqB,aACzB,gBAAiB,CAAA,MAAA,EAAQ,GAAG,CAC5B,GAAA,KAAA,CAAA;AAEN,IAAM,MAAA,QAAA,GACJ,gCACC,OAAO,iBAAA,KAAsB,aAC1B,iBAAkB,CAAA,MAAA,EAAQ,GAAG,CAC7B,GAAA,KAAA,CAAA;AAEN,IAAA,IAAIA,QAAS,EAAA;AACX,MAAA,IAAI,iBAAoB,GAAA,CAAA;AACxB,MAAA,IAAI,SAAY,GAAA,CAAA;AAChB,MAAM,MAAA,KAAA,GAAQ,MAAO,CAAA,KAAA,CAAM,IAAI,CAAA;AAC/B,MACE,OAAA,KAAA,CAAM,SAAS,CAAA,CAAE,IAAK,EAAA,KAAM,MAAM,KAAM,CAAA,SAAS,CAAE,CAAA,IAAA,EAAW,KAAA,IAAA;AAAA,MAE9D,KAAA,CAAM,SAAS,CAAE,CAAA,IAAA,GAAO,UAAW,CAAA,IAAI,CACpC,IAAA,KAAA,CAAM,SAAS,CAAA,CAAE,MAAO,CAAA,UAAA,CAAW,KAAK,CAAA,IACxC,KAAM,CAAA,SAAS,EAAE,IAAK,EAAA,CAAE,UAAW,CAAA,GAAG,CACzC,EAAA;AACA,QAAqB,iBAAA,IAAA,KAAA,CAAM,SAAS,CAAE,CAAA,MAAA;AACtC,QAAA,SAAA,EAAA;AAAA;AAEF,MAAO,MAAA,CAAA,IAAA,CAAK,CAAoB,iBAAA,EAAA,IAAA,CAAK,SAAU,CAAA;AAAA,QAC7C,GAAA;AAAA,QACA,QAAA;AAAA,QACA,QAAA;AAAA,QACA,2BAAA;AAAA,QACA,2BAAA;AAAA,QACA,cAAc,MAAO,CAAA,MAAA;AAAA,QACrB,eAAe,MAAO,CAAA,KAAA,CAAM,iBAAmB,EAAA,iBAAA,GAAoB,GAAG,CAAI,GAAA;AAAA,OAC3E,CAAC,CAAE,CAAA,CAAA;AAAA;AAGN,IAAI,IAAA,CAAC,QAAY,IAAA,CAAC,QAAU,EAAA;AAC1B,MAAA,IAAIA,QAAS,EAAA;AACX,QAAO,MAAA,CAAA,IAAA,CAAK,CAA0C,uCAAA,EAAA,GAAG,CAAE,CAAA,CAAA;AAAA;AAG7D,MAAO,OAAA,EAAE,GAAG,MAAA,EAAQ,MAAO,EAAA;AAAA;AAI7B,IAAA,MAAM,WAAW,GAAI,CAAA,UAAA,CAAW,SAAS,CAAI,GAAA,aAAA,CAAc,GAAG,CAAI,GAAA,GAAA;AAClE,IAAA,IAAIA,QAAS,EAAA;AACX,MAAO,MAAA,CAAA,IAAA,CAAK,CAAc,WAAA,EAAA,QAAQ,CAAE,CAAA,CAAA;AAAA;AAGtC,IAAG,IAAA,OAAO,WAAY,CAAA,QAAA,KAAa,UAAY,EAAA;AAG7C,MAAA,MAAM,iBAAiB,cAAgB,EAAA,SAAA,IAAa,EAAE,OAAS,EAAA,OAA4B,CAAA;AAE3F,MAAA,WAAA,CAAY,WAAW,qBAAsB,CAAA;AAAA,QAC3C,YAAY,WAAY,CAAA,UAAA;AAAA,QACxB,gBAAgB,WAAY,CAAA,cAAA;AAAA,QAC5B,cAAc,WAAY,CAAA,YAAA;AAAA,QAC1B,OAAO,WAAY,CAAA,KAAA;AAAA,QACnB,KAAK,WAAY,CAAA,GAAA;AAAA,QACjB,eAAe,WAAY,CAAA,aAAA;AAAA,QAC3B,aAAa,WAAY,CAAA;AAAA,SACxB,cAAc,CAAA;AAAA;AAInB,IAAA,IAAI,QAAW,GAAA,QAAA;AACf,IAAA,IAAI,OAAU,GAAA,QAAA;AACd,IAAA,IAAI,aAAa,UAAY,EAAA;AAC3B,MAAA,MAAM,GAAG,KAAK,CAAI,GAAA,WAAA,CAAY,WAAW,QAAQ,CAAA;AACjD,MAAW,QAAA,GAAA,IAAA,CAAK,WAAY,CAAA,cAAA,EAAgB,KAAK,CAAA;AACjD,MAAU,OAAA,GAAA,WAAA,CAAY,QAAW,GAAA,QAAQ,CAAK,IAAA,QAAA;AAC9C,MAAA,IAAIA,QAAS,EAAA;AACX,QAAA,MAAA,CAAO,IAAK,CAAA,CAAA,gBAAA,EAAmB,QAAQ,CAAA,IAAA,EAAO,OAAO,CAAE,CAAA,CAAA;AACvD,QAAA,MAAA,CAAO,KAAK,CAAgB,aAAA,EAAA,IAAA,CAAK,SAAU,CAAA,WAAW,CAAC,CAAE,CAAA,CAAA;AAAA;AAC3D;AAGF,IAAM,MAAA,EAAE,MAAM,WAAa,EAAA,GAAA,KAAQ,MAAM,WAAA,CAAY,MAAQ,EAAA,QAAA,EAAU,OAAO,CAAA;AAE9E,IAAA,IAAIA,QAAS,EAAA;AACX,MAAO,MAAA,CAAA,IAAA,CAAK,CAA0B,uBAAA,EAAA,IAAA,CAAK,SAAU,CAAA;AAAA,QACnD,gBAAgB,MAAO,CAAA,MAAA;AAAA,QACvB,mBAAmB,WAAY,CAAA,MAAA;AAAA,QAC/B,gBAAgB,MAAW,KAAA,WAAA;AAAA,QAC3B,YAAA,EAAc,CAAC,CAAC;AAAA,OACjB,CAAC,CAAE,CAAA,CAAA;AAAA;AAGN,IAAA,IAAI,UAAY,EAAA;AACd,MAAA,IAAIA,QAAS,EAAA;AACX,QAAA,MAAA,CAAO,KAAK,+BAA+B,CAAA;AAAA;AAE7C,MAAA,UAAA,CAAW,WAAY,CAAA;AAAA,QACrB,IAAM,EAAA,eAAA;AAAA,QACN,EAAI,EAAA,OAAA;AAAA,QACJ,GAAK,EAAA,QAAA;AAAA,QACL,MAAQ,EAAA;AAAA,OACqB,CAAA;AAAA;AAGjC,IAAO,OAAA;AAAA,MACL,GAAG,MAAA;AAAA,MACH,MAAQ,EAAA,WAAA;AAAA,MACR;AAAA,KACF;AAAA;AAGF,EAAA,IAAIA,QAAS,EAAA;AACX,IAAO,MAAA,CAAA,IAAA,CAAK,CAA+B,4BAAA,EAAA,MAAM,CAAE,CAAA,CAAA;AAAA;AAErD,EAAO,OAAA,QAAA,CAAS,KAAK,OAAO,CAAA;AAC9B;AAEO,MAAM,OAAuB,GAAA,OAAO,SAAW,EAAA,OAAA,EAAS,WAAgB,KAAA;AAC7E,EAAA,OAAA,GAAU,aAAa,OAAW,IAAA,KAAA;AAClC,EAAA,IAAI,OAAS,EAAA;AACX,IAAO,MAAA,CAAA,IAAA,CAAK,CAAc,WAAA,EAAA,SAAS,CAAE,CAAA,CAAA;AACrC,IAAA,MAAA,CAAO,KAAK,CAAoB,iBAAA,EAAA,IAAA,CAAK,SAAU,CAAA,OAAO,CAAC,CAAE,CAAA,CAAA;AAAA;AAE3D,EAAA,MAAM,MAAS,GAAA,MAAM,WAAY,CAAA,SAAA,EAAW,OAAO,CAAA;AACnD,EAAA,IAAI,OAAS,EAAA;AACX,IAAA,MAAA,CAAO,KAAK,CAAmB,gBAAA,EAAA,IAAA,CAAK,SAAU,CAAA,MAAM,CAAC,CAAE,CAAA,CAAA;AAAA;AAEzD,EAAO,OAAA,MAAA;AACT;;;;"}
|
|
138
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"react-loader.js","sources":["../../../plugin/loader/react-loader.ts"],"sourcesContent":["import type {\n  ResolvedUserOptions,\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { ModuleInfo } from \"rollup\";\nimport { parentPort } from \"node:worker_threads\";\nimport type { MessagePort } from \"node:worker_threads\";\nimport type {\n  InitializedReactLoaderMessage,\n  ServerModuleMessage,\n} from \"../worker/rsc/types.js\";\nimport { fileURLToPath } from \"node:url\";\nimport { join } from \"node:path\";\nimport { hydrateUserOptions } from \"../helpers/hydrateUserOptions.js\";\nimport { DEFAULT_LOADER_CONFIG } from \"../config/defaults.js\";\nimport type { LoadHook, ResolveHook } from \"node:module\";\nimport type { RawSourceMap } from \"source-map\";\nimport { createTransformer } from \"./createTransformer.js\";\n\nimport { createLogger, type Logger } from \"vite\";\nimport { createDefaultModuleID } from \"../config/createModuleID.js\";\n\nexport type LoaderOptions = {\n  id: string;\n  resolveDependencies?: boolean;\n  format?: string;\n  conditions?: string[];\n  importAssertions?: Record<string, unknown>;\n  importAttributes?: Record<string, unknown>;\n  source: string;\n};\n\nexport type LoaderFunction = (options: LoaderOptions) => Promise<ModuleInfo>;\n\nlet initialized = false;\nlet userOptions: ResolvedUserOptions;\nlet loaderPort: MessagePort | null;\nlet resolvedConfig: SerializedResolvedConfig;\nlet isServerFunction:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n\nlet isClientComponent:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isClientComponentCode;\nlet logger: Logger;\nlet verbose: boolean;\nlet transformer: (\n  source: string,\n  moduleId: string,\n  transformedModuleId: string\n) => Promise<{ code: string; map: RawSourceMap | null }>;\n\nexport function initialize(data: {\n  id: string;\n  port: MessagePort;\n  userOptions: SerializedUserOptions;\n  resolvedConfig: SerializedResolvedConfig;\n}) {\n  const {\n    id,\n    port,\n    userOptions: serializedUserOptions,\n    resolvedConfig: serializedResolvedConfig,\n  } = data;\n  \n  verbose = serializedUserOptions?.verbose ?? false;\n  logger = createLogger(serializedResolvedConfig?.logLevel ?? \"info\", {\n    prefix: id,\n  });\n  \n  // Store resolvedConfig at module level for use in other functions\n  resolvedConfig = serializedResolvedConfig;\n  \n  if (verbose) {\n    logger.info(`Initializing with options: ${id}`);\n  }\n  loaderPort = port;\n  \n  // when user options are provided, use the user options using the hydrateUserOptions function\n  const resolvedUserOptions = hydrateUserOptions(serializedUserOptions);\n  if (resolvedUserOptions.type === \"error\") {\n    throw resolvedUserOptions.error;\n  }\n\n  // Use the hydrated user options directly (includes recreated functions)\n  userOptions = resolvedUserOptions.userOptions;\n\n  isServerFunction = userOptions.loader?.isServerFunctionCode ?? DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n  isClientComponent = userOptions.loader?.isClientComponentCode ?? DEFAULT_LOADER_CONFIG.isClientComponentCode;\n  \n  transformer = createTransformer({\n    options: userOptions,\n  });\n  \n  if (!initialized && loaderPort) {\n    loaderPort.postMessage({\n      type: \"INITIALIZED_REACT_LOADER\",\n      id,\n    } satisfies InitializedReactLoaderMessage);\n  }\n  initialized = true;\n}\n\nexport const load: LoadHook = async (url, context, nextLoad) => {\n  if (!initialized) {\n    // Fallback initialization when not properly set up\n    // This should not happen in normal usage, but provides a basic fallback\n    initialize({\n      id: \"react-loader\",\n      port: parentPort!,\n      userOptions: {} as any,\n      resolvedConfig: {} as any,\n    });\n  }\n  const verbose = userOptions?.verbose ?? false;\n\n  const { format } = context;\n  if (format === \"module\" || format === \"module-typescript\") {\n    // Load the URL normally\n    const result = await nextLoad(url, context);\n\n    let source =\n      typeof result.source === \"string\"\n        ? result.source\n        : result.source instanceof Uint8Array\n        ? new TextDecoder().decode(result.source)\n        : String(result.source);\n\n    // Fix CJS React named imports: React's react-server condition exports CJS,\n    // but esbuild/tsx transforms produce ESM named imports that fail at runtime.\n    // Rewrite `import { X } from \"react\"` → `import __react from \"react\"; const { X } = __react;`\n    if (!url.includes('node_modules')) {\n      const namedImportRe = /import\\s*\\{([^}]+)\\}\\s*from\\s*[\"']react[\"']\\s*;?/g;\n      if (namedImportRe.test(source)) {\n        namedImportRe.lastIndex = 0;\n        let counter = 0;\n        source = source.replace(namedImportRe, (_match: string, imports: string) => {\n          const alias = `__react_cjs_${counter++}`;\n          return `import ${alias} from \"react\"; const {${imports}} = ${alias};`;\n        });\n        if (verbose) {\n          logger.info(`Rewrote CJS React named imports in: ${url}`);\n        }\n      }\n    }\n\n    // Check for file-level server directive first\n    const hasFileLevelServerDirective =\n      source.startsWith('\"use server\"') || source.startsWith(\"'use server'\");\n    const hasFileLevelClientDirective =\n      source.startsWith('\"use client\"') || source.startsWith(\"'use client'\");\n\n    const isServer =\n      hasFileLevelServerDirective ||\n      (typeof isServerFunction === \"function\"\n        ? isServerFunction(source, url)\n        : false);\n\n    const isClient =\n      hasFileLevelClientDirective ||\n      (typeof isClientComponent === \"function\"\n        ? isClientComponent(source, url)\n        : false);\n\n    if (!isServer && !isClient) {\n      // Return modified source if CJS React imports were rewritten\n      return { ...result, source };\n    }\n\n    if (verbose) {\n      logger.info(`[react-loader] ${isServer ? 'server' : 'client'} module: ${url}`);\n    }\n\n    // Handle file URLs\n    const filePath = url.startsWith(\"file://\") ? fileURLToPath(url) : url;\n\n    if(typeof userOptions.moduleID !== \"function\") {\n      // Ensure we have proper build context for RSC worker\n      // If configEnv is not available or doesn't indicate build mode, create a build-compatible configEnv\n      const buildConfigEnv = resolvedConfig?.configEnv ?? { command: \"build\", mode: \"production\" };\n      \n      userOptions.moduleID = createDefaultModuleID({\n        moduleBase: userOptions.moduleBase,\n        moduleBasePath: userOptions.moduleBasePath,\n        autoDiscover: userOptions.autoDiscover,\n        build: userOptions.build,\n        dev: userOptions.dev,\n        moduleBaseURL: userOptions.moduleBaseURL,\n        projectRoot: userOptions.projectRoot,\n      }, buildConfigEnv);\n    }\n\n    // Normalize the URL using the same logic as plugin.server.ts\n    let moduleID = filePath;\n    let finalID = filePath;\n    if (userOptions?.normalizer) {\n      const [, value] = userOptions.normalizer(filePath);\n      moduleID = join(userOptions.moduleBasePath, value);\n      finalID = userOptions.moduleID?.(moduleID) || moduleID;\n    }\n\n    const { code: transformed, map } = await transformer(source, moduleID, finalID);\n\n    if (loaderPort) {\n      loaderPort.postMessage({\n        type: \"SERVER_MODULE\",\n        id: finalID,\n        url: filePath,\n        source: transformed,\n      } satisfies ServerModuleMessage);\n    }\n\n    return {\n      ...result,\n      source: transformed,\n      map,\n    };\n  }\n\n  return nextLoad(url, context);\n};\n\nexport const resolve: ResolveHook = async (specifier, context, nextResolve) => {\n  return nextResolve(specifier, context);\n};\n"],"names":["verbose"],"mappings":"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"}
|
|
@@ -400,18 +400,18 @@ export const reactStaticPlugin = function _reactStaticPlugin(options) {
|
|
|
400
400
|
const indexHtml = staticManifest?.["index.html"]?.file;
|
|
401
401
|
const serverPipeableStreamOptions = {
|
|
402
402
|
...userOptions.serverPipeableStreamOptions,
|
|
403
|
-
|
|
403
|
+
bootstrapModules: [
|
|
404
404
|
...(indexHtml ? [baseURL(indexHtml)] : []),
|
|
405
|
-
...(userOptions.serverPipeableStreamOptions?.
|
|
405
|
+
...(userOptions.serverPipeableStreamOptions?.bootstrapModules ??
|
|
406
406
|
[]),
|
|
407
407
|
],
|
|
408
408
|
};
|
|
409
409
|
userOptions.serverPipeableStreamOptions = serverPipeableStreamOptions;
|
|
410
410
|
const clientPipeableStreamOptions = {
|
|
411
411
|
...userOptions.clientPipeableStreamOptions,
|
|
412
|
-
|
|
412
|
+
bootstrapModules: [
|
|
413
413
|
...(indexHtml ? [baseURL(indexHtml)] : []),
|
|
414
|
-
...(userOptions.clientPipeableStreamOptions?.
|
|
414
|
+
...(userOptions.clientPipeableStreamOptions?.bootstrapModules ??
|
|
415
415
|
[]),
|
|
416
416
|
],
|
|
417
417
|
};
|
|
@@ -257,7 +257,7 @@ export const reactStaticPlugin = function _reactStaticPlugin(options) {
|
|
|
257
257
|
const indexHtml = staticManifest?.["index.html"]?.file;
|
|
258
258
|
const serverPipeableStreamOptions = {
|
|
259
259
|
...userOptions.serverPipeableStreamOptions,
|
|
260
|
-
|
|
260
|
+
bootstrapModules: [
|
|
261
261
|
...(indexHtml ? [baseURL(indexHtml)] : []),
|
|
262
262
|
...(userOptions.serverPipeableStreamOptions?.bootstrapModules ??
|
|
263
263
|
[]),
|
|
@@ -266,9 +266,9 @@ export const reactStaticPlugin = function _reactStaticPlugin(options) {
|
|
|
266
266
|
userOptions.serverPipeableStreamOptions = serverPipeableStreamOptions;
|
|
267
267
|
const clientPipeableStreamOptions = {
|
|
268
268
|
...userOptions.clientPipeableStreamOptions,
|
|
269
|
-
|
|
269
|
+
bootstrapModules: [
|
|
270
270
|
...(indexHtml ? [baseURL(indexHtml)] : []),
|
|
271
|
-
...(userOptions.clientPipeableStreamOptions?.
|
|
271
|
+
...(userOptions.clientPipeableStreamOptions?.bootstrapModules ??
|
|
272
272
|
[]),
|
|
273
273
|
],
|
|
274
274
|
};
|
|
@@ -66,7 +66,7 @@ const createRenderToPipeableStreamHandler = function _createRenderToPipeableStre
|
|
|
66
66
|
);
|
|
67
67
|
}
|
|
68
68
|
const { pipe, abort } = ReactDOMServer.renderToPipeableStream(reactElements, {
|
|
69
|
-
|
|
69
|
+
bootstrapModules: clientPipeableStreamOptions?.bootstrapModules || [],
|
|
70
70
|
onShellReady() {
|
|
71
71
|
if (verbose) {
|
|
72
72
|
logger?.info(
|
|
@@ -185,4 +185,4 @@ const createRenderToPipeableStreamHandler = function _createRenderToPipeableStre
|
|
|
185
185
|
};
|
|
186
186
|
|
|
187
187
|
export { createRenderToPipeableStreamHandler };
|
|
188
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createRenderToPipeableStreamHandler.client.js","sources":["../../../plugin/stream/createRenderToPipeableStreamHandler.client.ts"],"sourcesContent":["import type { CreateRenderToPipeableStreamHandlerFn } from \"./createRenderToPipeableStreamHandler.types.js\";\nimport { ReactDOMServer } from \"../vendor/vendor.client.js\";\nimport { assertNonReactServer } from \"../config/getCondition.js\";\nimport { createFromNodeStream } from \"./createFromNodeStream.client.js\";\nimport { createStreamMetrics } from \"../metrics/createStreamMetrics.js\";\nimport { handleError } from \"../error/handleError.js\";\nimport { PassThrough } from \"node:stream\";\n\nassertNonReactServer();\n\n/**\n * Client version of createRenderToPipeableStreamHandler.\n *\n * Strategy: Use simple Node.js stream APIs to naturally handle RSC-to-HTML conversion.\n * This follows the HTML worker pattern exactly - create a custom writable stream\n * and pipe the React stream directly to it, then provide a proper stream for fileWriter.\n */\nexport const createRenderToPipeableStreamHandler: CreateRenderToPipeableStreamHandlerFn<\"client\"> =\n  function _createRenderToPipeableStreamHandler(options) {\n    const {\n      route,\n      logger,\n      verbose = false,\n      rscStream,\n      children,\n      moduleRootPath,\n      moduleBasePath,\n      moduleBaseURL,\n      clientPipeableStreamOptions,\n    } = options;\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] Starting RSC-to-HTML conversion using natural Node.js streams`\n      );\n    }\n\n    // Create stream metrics\n    const streamMetrics = createStreamMetrics();\n\n    // Get React elements - either from children or by converting RSC stream\n    let reactElements: React.ReactElement;\n    if (children) {\n      if (verbose) {\n        logger?.info(\n          `[createRenderToPipeableStreamHandler.client:${route}] Using provided children directly`\n        );\n      }\n      // Ensure children is a React element\n      if (typeof children === 'string' || typeof children === 'number' || typeof children === 'boolean') {\n        throw new Error(`[createRenderToPipeableStreamHandler.client:${route}] Children must be a React element, got: ${typeof children}`);\n      }\n      reactElements = children as React.ReactElement;\n    } else if (rscStream) {\n      if (verbose) {\n        logger?.info(\n          `[createRenderToPipeableStreamHandler.client:${route}] Converting RSC stream to React elements using natural Node.js streams`\n        );\n      }\n      const result = createFromNodeStream({\n        rscStream,\n        moduleRootPath,\n        moduleBasePath,\n        moduleBaseURL,\n        logger,\n        verbose,\n      });\n      reactElements = result.children;\n    } else {\n      throw new Error(\n        `[createRenderToPipeableStreamHandler.client:${route}] Either children or rscStream is required`\n      );\n    }\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] React elements ready, starting HTML rendering`\n      );\n    }\n\n    // Create the React HTML stream using ReactDOMServer.renderToPipeableStream\n    const { pipe, abort } = ReactDOMServer.renderToPipeableStream(reactElements, {\n      bootstrapScripts:\n        clientPipeableStreamOptions?.bootstrapScripts || [],\n      onShellReady() {\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] Shell ready, starting to pipe HTML`\n          );\n        }\n      },\n      onAllReady() {\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] All ready, HTML rendering complete`\n          );\n        }\n      },\n      onError(error: unknown) {\n        if (verbose) {\n          logger?.error(\n            `[createRenderToPipeableStreamHandler.client:${route}] React rendering error: ${error instanceof Error ? error.message : String(error)}`\n          );\n        }\n        \n        // Destroy the HTML stream with the error to prevent hanging\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] Destroying HTML stream due to React error`\n          );\n        }\n        htmlStream.destroy(error instanceof Error ? error : new Error(String(error)));\n        \n        // Handle error according to panic threshold\n        const panicError = handleError({\n          error: error,\n          logger: logger,\n          panicThreshold: options.panicThreshold,\n          context: `RSC stream onError for route ${route}`,\n        });\n\n        if (panicError != null) {\n          // This is a panic threshold error, emit event to notify parent\n          options.onEvent?.({\n            type: \"route.error\",\n            data: {\n              route: route,\n              error: panicError,\n            },\n          });\n        } else {\n          // For non-panic errors, just log and send event\n          options.onEvent?.({\n            type: \"route.error\",\n            data: {\n              route: route,\n              error: error,\n            },\n          });\n        }\n      },\n    });\n\n    // Create a PassThrough stream that the fileWriter can consume\n    // This follows the HTML worker pattern but provides a proper stream interface\n    const htmlStream = new PassThrough();\n    \n    // Add error handler to prevent unhandled errors\n    htmlStream.on('error', (error) => {\n      // Ignore errors during abort - they're expected\n      if (verbose) {\n        logger?.info(`[createRenderToPipeableStreamHandler.client:${route}] HTML stream error (ignored): ${error.message}`);\n      }\n    });\n\n    // Create a custom writable stream that pipes to our PassThrough\n    // This ensures the stream is consumed to completion naturally\n    const customWritable = {\n      write(chunk: any, _encoding?: any, callback?: any) {\n        // Pipe the chunk to our PassThrough stream\n        htmlStream.write(chunk);\n        if (callback) callback();\n      },\n      end(chunk?: any, _encoding?: any, callback?: any) {\n        if (chunk) {\n          htmlStream.write(chunk);\n        }\n        // End the PassThrough stream\n        htmlStream.end();\n        if (callback) callback();\n      },\n      destroy(error?: Error) {\n        // Destroy the PassThrough stream with the error\n        try {\n          htmlStream.destroy(error);\n        } catch (destroyError) {\n          // Stream may already be destroyed, ignore\n        }\n      },\n      on() {}, // No-op for event listeners\n      once() {}, // No-op for event listeners\n      emit() { return false; }, // No-op for event emitters\n    };\n\n    // Pipe the React stream directly to our custom writable\n    // This ensures the stream is consumed to completion naturally\n    pipe(customWritable as any);\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] React stream piped to custom writable, using natural Node.js stream handling`\n      );\n    }\n\n    // Return a result that provides a proper stream for fileWriter\n    return {\n      type: \"client\" as const,\n      pipe: <Writable extends NodeJS.WritableStream>(destination: Writable) => {\n        // Pipe our PassThrough stream to the destination\n        htmlStream.pipe(destination);\n        return destination;\n      },\n      abort: (reason?: unknown) => {\n        try {\n          abort();\n        } catch (error) {\n          // React abort may already be called, ignore\n        }\n        try {\n          htmlStream.destroy(new Error(String(reason || \"Aborted HTML stream\")));\n        } catch (error) {\n          // Stream may already be destroyed, ignore\n        }\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] HTML stream aborted: ${reason}`\n          );\n        }\n      },\n      htmlStream: htmlStream,\n      elements: reactElements,\n      metrics: streamMetrics,\n    };\n  };\n"],"names":[],"mappings":"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"}
|
|
188
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createRenderToPipeableStreamHandler.client.js","sources":["../../../plugin/stream/createRenderToPipeableStreamHandler.client.ts"],"sourcesContent":["import type { CreateRenderToPipeableStreamHandlerFn } from \"./createRenderToPipeableStreamHandler.types.js\";\nimport { ReactDOMServer } from \"../vendor/vendor.client.js\";\nimport { assertNonReactServer } from \"../config/getCondition.js\";\nimport { createFromNodeStream } from \"./createFromNodeStream.client.js\";\nimport { createStreamMetrics } from \"../metrics/createStreamMetrics.js\";\nimport { handleError } from \"../error/handleError.js\";\nimport { PassThrough } from \"node:stream\";\n\nassertNonReactServer();\n\n/**\n * Client version of createRenderToPipeableStreamHandler.\n *\n * Strategy: Use simple Node.js stream APIs to naturally handle RSC-to-HTML conversion.\n * This follows the HTML worker pattern exactly - create a custom writable stream\n * and pipe the React stream directly to it, then provide a proper stream for fileWriter.\n */\nexport const createRenderToPipeableStreamHandler: CreateRenderToPipeableStreamHandlerFn<\"client\"> =\n  function _createRenderToPipeableStreamHandler(options) {\n    const {\n      route,\n      logger,\n      verbose = false,\n      rscStream,\n      children,\n      moduleRootPath,\n      moduleBasePath,\n      moduleBaseURL,\n      clientPipeableStreamOptions,\n    } = options;\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] Starting RSC-to-HTML conversion using natural Node.js streams`\n      );\n    }\n\n    // Create stream metrics\n    const streamMetrics = createStreamMetrics();\n\n    // Get React elements - either from children or by converting RSC stream\n    let reactElements: React.ReactElement;\n    if (children) {\n      if (verbose) {\n        logger?.info(\n          `[createRenderToPipeableStreamHandler.client:${route}] Using provided children directly`\n        );\n      }\n      // Ensure children is a React element\n      if (typeof children === 'string' || typeof children === 'number' || typeof children === 'boolean') {\n        throw new Error(`[createRenderToPipeableStreamHandler.client:${route}] Children must be a React element, got: ${typeof children}`);\n      }\n      reactElements = children as React.ReactElement;\n    } else if (rscStream) {\n      if (verbose) {\n        logger?.info(\n          `[createRenderToPipeableStreamHandler.client:${route}] Converting RSC stream to React elements using natural Node.js streams`\n        );\n      }\n      const result = createFromNodeStream({\n        rscStream,\n        moduleRootPath,\n        moduleBasePath,\n        moduleBaseURL,\n        logger,\n        verbose,\n      });\n      reactElements = result.children;\n    } else {\n      throw new Error(\n        `[createRenderToPipeableStreamHandler.client:${route}] Either children or rscStream is required`\n      );\n    }\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] React elements ready, starting HTML rendering`\n      );\n    }\n\n    // Create the React HTML stream using ReactDOMServer.renderToPipeableStream\n    const { pipe, abort } = ReactDOMServer.renderToPipeableStream(reactElements, {\n      bootstrapModules:\n        clientPipeableStreamOptions?.bootstrapModules || [],\n      onShellReady() {\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] Shell ready, starting to pipe HTML`\n          );\n        }\n      },\n      onAllReady() {\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] All ready, HTML rendering complete`\n          );\n        }\n      },\n      onError(error: unknown) {\n        if (verbose) {\n          logger?.error(\n            `[createRenderToPipeableStreamHandler.client:${route}] React rendering error: ${error instanceof Error ? error.message : String(error)}`\n          );\n        }\n        \n        // Destroy the HTML stream with the error to prevent hanging\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] Destroying HTML stream due to React error`\n          );\n        }\n        htmlStream.destroy(error instanceof Error ? error : new Error(String(error)));\n        \n        // Handle error according to panic threshold\n        const panicError = handleError({\n          error: error,\n          logger: logger,\n          panicThreshold: options.panicThreshold,\n          context: `RSC stream onError for route ${route}`,\n        });\n\n        if (panicError != null) {\n          // This is a panic threshold error, emit event to notify parent\n          options.onEvent?.({\n            type: \"route.error\",\n            data: {\n              route: route,\n              error: panicError,\n            },\n          });\n        } else {\n          // For non-panic errors, just log and send event\n          options.onEvent?.({\n            type: \"route.error\",\n            data: {\n              route: route,\n              error: error,\n            },\n          });\n        }\n      },\n    });\n\n    // Create a PassThrough stream that the fileWriter can consume\n    // This follows the HTML worker pattern but provides a proper stream interface\n    const htmlStream = new PassThrough();\n    \n    // Add error handler to prevent unhandled errors\n    htmlStream.on('error', (error) => {\n      // Ignore errors during abort - they're expected\n      if (verbose) {\n        logger?.info(`[createRenderToPipeableStreamHandler.client:${route}] HTML stream error (ignored): ${error.message}`);\n      }\n    });\n\n    // Create a custom writable stream that pipes to our PassThrough\n    // This ensures the stream is consumed to completion naturally\n    const customWritable = {\n      write(chunk: any, _encoding?: any, callback?: any) {\n        // Pipe the chunk to our PassThrough stream\n        htmlStream.write(chunk);\n        if (callback) callback();\n      },\n      end(chunk?: any, _encoding?: any, callback?: any) {\n        if (chunk) {\n          htmlStream.write(chunk);\n        }\n        // End the PassThrough stream\n        htmlStream.end();\n        if (callback) callback();\n      },\n      destroy(error?: Error) {\n        // Destroy the PassThrough stream with the error\n        try {\n          htmlStream.destroy(error);\n        } catch (destroyError) {\n          // Stream may already be destroyed, ignore\n        }\n      },\n      on() {}, // No-op for event listeners\n      once() {}, // No-op for event listeners\n      emit() { return false; }, // No-op for event emitters\n    };\n\n    // Pipe the React stream directly to our custom writable\n    // This ensures the stream is consumed to completion naturally\n    pipe(customWritable as any);\n\n    if (verbose) {\n      logger?.info(\n        `[createRenderToPipeableStreamHandler.client:${route}] React stream piped to custom writable, using natural Node.js stream handling`\n      );\n    }\n\n    // Return a result that provides a proper stream for fileWriter\n    return {\n      type: \"client\" as const,\n      pipe: <Writable extends NodeJS.WritableStream>(destination: Writable) => {\n        // Pipe our PassThrough stream to the destination\n        htmlStream.pipe(destination);\n        return destination;\n      },\n      abort: (reason?: unknown) => {\n        try {\n          abort();\n        } catch (error) {\n          // React abort may already be called, ignore\n        }\n        try {\n          htmlStream.destroy(new Error(String(reason || \"Aborted HTML stream\")));\n        } catch (error) {\n          // Stream may already be destroyed, ignore\n        }\n        if (verbose) {\n          logger?.info(\n            `[createRenderToPipeableStreamHandler.client:${route}] HTML stream aborted: ${reason}`\n          );\n        }\n      },\n      htmlStream: htmlStream,\n      elements: reactElements,\n      metrics: streamMetrics,\n    };\n  };\n"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { type Logger } from "vite";
|
|
2
2
|
import type { GenericModuleLoader } from "../../types.js";
|
|
3
3
|
/**
|
|
4
|
-
* Creates a
|
|
5
|
-
*
|
|
6
|
-
* This follows the same pattern as the main thread server version:
|
|
7
|
-
* - Simple dynamic import-based loading
|
|
8
|
-
* - Proper export name resolution
|
|
9
|
-
* - Works in both dev and build scenarios
|
|
4
|
+
* Creates a GenericModuleLoader for the RSC worker.
|
|
5
|
+
* Uses createSharedLoader for virtual modules, manifest resolution, and imports.
|
|
10
6
|
*/
|
|
11
7
|
export declare const createRscWorkerLoader: ({ verbose, logger, projectRoot, build, manifest, }?: {
|
|
12
8
|
verbose?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createRscWorkerLoader.d.ts","sourceRoot":"","sources":["../../../../plugin/worker/rsc/createRscWorkerLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D
|
|
1
|
+
{"version":3,"file":"createRscWorkerLoader.d.ts","sourceRoot":"","sources":["../../../../plugin/worker/rsc/createRscWorkerLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D;;;GAGG;AACH,eAAO,MAAM,qBAAqB,GAAI,qDAQnC;IACD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE;QACN,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAC3B,KAAG,mBA4BR,CAAC"}
|