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