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 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 [Patch System](./docs/patch-system.md) for maintenance details.
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vite-plugin-react-server",
3
- "version": "1.2.1",
3
+ "version": "1.2.3",
4
4
  "description": "Vite plugin for React Server Components (RSC)",
5
5
  "type": "module",
6
6
  "main": "./dist/plugin/index.js",
@@ -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,WAAmB,EACnB,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,CAyI/B"}
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
- const serverBuildPath = join(
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":";;;;;;;;;;AAuBA,eAAsB,kBAAmB,CAAA;AAAA,EACvC,QAAA;AAAA,EACA,UAAA;AAAA,EACA,OAAU,GAAA,KAAA;AAAA,EACV,MAAA;AAAA;AAAA,EAEA,cAAiB,GAAA,IAAA;AAAA;AAAA,EAEjB,QAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,mBAAA;AAAA,EACA,WAAA;AAAA,EACA,WAAA;AAAA,EACA,cAAA;AAAA;AAAA,EAEA,WAAc,GAAA,KAAA;AAAA,EACd,WAAc,GAAA,KAAA;AAAA,EACd,oBAAA;AAAA,EACA;AACF,CAyBiC,EAAA;AAE/B,EAAA,IAAI,cAAgB,EAAA;AAClB,IAAA,MAAM,sBAAsB,MAAM,4BAAA;AAAA,MAChC,QAAA;AAAA,MACA,UAAA;AAAA,MACA,OAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,IAAI,wBAAwB,IAAM,EAAA;AAGhC,MAAO,OAAA,mBAAA;AAAA;AACT;AAIF,EAAA,IAAI,gBAAmB,GAAA,QAAA;AACvB,EAAA,IAAI,eAAe,QAAY,IAAA,UAAA,IAAc,UAAc,IAAA,WAAA,IAAe,eAAe,cAAgB,EAAA;AACvG,IAAA,MAAM,qBAAqB,yBAA0B,CAAA;AAAA,MACnD,QAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,UAAA;AAAA,MACA,mBAAA;AAAA,MACA,WAAA;AAAA,MACA,WAAA;AAAA,MACA,cAAA;AAAA,MACA,OAAA;AAAA,MACA;AAAA,KACD,CAAA;AAED,IAAI,IAAA,kBAAA,CAAmB,aAAiB,IAAA,kBAAA,CAAmB,YAAc,EAAA;AAEvE,MAAA,gBAAA,GAAmB,kBAAmB,CAAA,YAAA;AACtC,MAAA,IAAI,OAAS,EAAA;AACX,QAAQ,MAAA,EAAA,IAAA;AAAA,UACN,8DAA8D,gBAAgB,CAAA;AAAA,SAChF;AAAA;AACF,KACK,MAAA;AAEL,MAAA,gBAAA,GAAmB,kBAAmB,CAAA,aAAA;AACtC,MAAA,IAAI,OAAS,EAAA;AACX,QAAQ,MAAA,EAAA,IAAA;AAAA,UACN,0EAA0E,gBAAgB,CAAA;AAAA,SAC5F;AAAA;AAMF,MAAA,MAAM,eAAe,QAAS,CAAA,UAAA,CAAW,UAAa,GAAA,GAAG,KACrC,QAAS,CAAA,UAAA,CAAW,IAAO,GAAA,UAAA,GAAa,GAAG,CAC1C,IAAA,UAAA,CAAW,QAAQ,CAAK,IAAA,QAAA,CAAS,SAAS,UAAU,CAAA;AAGzE,MAAA,IAAI,CAAC,YAAgB,IAAA,CAAC,WAAW,gBAAgB,CAAA,IAAK,wBAAwB,KAAO,EAAA;AACnF,QAAA,MAAM,eAAkB,GAAA,IAAA;AAAA,UACtB,oBAAA;AAAA,UACA,MAAM,MAAU,IAAA,MAAA;AAAA,UAChB,MAAM,MAAU,IAAA;AAAA,SAClB;AACA,QAAmB,gBAAA,GAAA,IAAA,CAAK,iBAAiB,gBAAgB,CAAA;AACzD,QAAA,IAAI,OAAS,EAAA;AACX,UAAQ,MAAA,EAAA,IAAA;AAAA,YACN,CAAA,gDAAA,EAAmD,eAAe,CAAA,EAAA,EAAK,gBAAgB,CAAA;AAAA,WACzF;AAAA;AACF;AACF;AACF,aACS,WAAa,EAAA;AAEtB,IAAA,IAAI,OAAS,EAAA;AACX,MAAQ,MAAA,EAAA,IAAA;AAAA,QACN,CAAA,2DAAA;AAAA,OACF;AAAA;AACF,GACF,MAAA,IAAW,WAAe,IAAA,oBAAA,IAAwB,KAAO,EAAA;AAEvD,IAAI,IAAA,CAAC,UAAW,CAAA,gBAAgB,CAAG,EAAA;AACjC,MAAA,MAAM,eAAkB,GAAA,IAAA;AAAA,QACtB,oBAAA;AAAA,QACA,MAAM,MAAU,IAAA,MAAA;AAAA,QAChB,MAAM,MAAU,IAAA;AAAA,OAClB;AACA,MAAmB,gBAAA,GAAA,IAAA,CAAK,iBAAiB,gBAAgB,CAAA;AACzD,MAAA,IAAI,OAAS,EAAA;AACX,QAAQ,MAAA,EAAA,IAAA;AAAA,UACN,CAAA,yDAAA,EAA4D,eAAe,CAAA,EAAA,EAAK,gBAAgB,CAAA;AAAA,SAClG;AAAA;AACF;AACF;AAIF,EAAM,MAAA,QAAA,GAAW,WAAW,gBAAgB,CAAA,GACxC,mBACA,oBACE,GAAA,IAAA,CAAK,oBAAsB,EAAA,gBAAgB,CAC3C,GAAA,gBAAA;AAEN,EAAA,IAAI,OAAS,EAAA;AACX,IAAQ,MAAA,EAAA,IAAA,CAAK,CAAwC,qCAAA,EAAA,QAAQ,CAAE,CAAA,CAAA;AAAA;AAIjE,EAAA,MAAM,UAAU,UAAW,CAAA,QAAQ,IAAI,aAAc,CAAA,QAAQ,EAAE,IAAO,GAAA,QAAA;AACtE,EAAM,MAAA,MAAA,GAAS,MAAM,OAAO,OAAA,CAAA;AAG5B,EAAA,IAAI,UAAU,IAAM,EAAA;AAClB,IAAA,MAAM,IAAI,KAAA,CAAM,CAAW,QAAA,EAAA,QAAQ,CAA6B,2BAAA,CAAA,CAAA;AAAA;AAGlE,EAAA,IAAI,CAAC,MAAO,CAAA,IAAA,CAAK,MAAM,CAAE,CAAA,MAAA,IAAU,YAAY,MAAQ,EAAA;AACrD,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,QAAQ,CAAA,8DAAA,EAAiE,UAAU,CAAA;AAAA,KAChG;AAAA;AAGF,EAAI,IAAA,UAAA,IAAc,EAAE,UAAA,IAAc,MAAS,CAAA,EAAA;AACzC,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,QAAQ,CAAA,+BAAA,EAAkC,UAAU,CAAA,CAAA;AAAA,KACjE;AAAA;AAGF,EAAA,IAAI,OAAS,EAAA;AACX,IAAQ,MAAA,EAAA,IAAA;AAAA,MACN,6DAA6D,MAAO,CAAA,IAAA;AAAA,QAClE;AAAA,OACF,CAAE,IAAK,CAAA,IAAI,CAAC,CAAA;AAAA,KACd;AAAA;AAIF,EAAO,OAAA,MAAA;AACT;;;;"}
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,QAsLlB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAWrB,CAAC"}
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(`File path: ${filePath}`);
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
- verbose = userOptions?.verbose ?? false;
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":"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"}
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
- bootstrapScripts: [
403
+ bootstrapModules: [
404
404
  ...(indexHtml ? [baseURL(indexHtml)] : []),
405
- ...(userOptions.serverPipeableStreamOptions?.bootstrapScripts ??
405
+ ...(userOptions.serverPipeableStreamOptions?.bootstrapModules ??
406
406
  []),
407
407
  ],
408
408
  };
409
409
  userOptions.serverPipeableStreamOptions = serverPipeableStreamOptions;
410
410
  const clientPipeableStreamOptions = {
411
411
  ...userOptions.clientPipeableStreamOptions,
412
- bootstrapScripts: [
412
+ bootstrapModules: [
413
413
  ...(indexHtml ? [baseURL(indexHtml)] : []),
414
- ...(userOptions.clientPipeableStreamOptions?.bootstrapScripts ??
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
- bootstrapScripts: [
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
- bootstrapScripts: [
269
+ bootstrapModules: [
270
270
  ...(indexHtml ? [baseURL(indexHtml)] : []),
271
- ...(userOptions.clientPipeableStreamOptions?.bootstrapScripts ??
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
- bootstrapScripts: clientPipeableStreamOptions?.bootstrapScripts || [],
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 simple GenericModuleLoader for the RSC worker
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;;;;;;;GAOG;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,mBAuER,CAAC"}
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"}