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
@@ -1,257 +1,229 @@
1
- import { resolveAutoDiscover } from "../config/autoDiscover/resolveAutoDiscover.js";
2
- import { resolveUserConfig } from "../config/resolveUserConfig.js";
3
- import { resolveOptions } from "../config/resolveOptions.js";
4
- import { handleError } from "../error/handleError.js";
5
- import { createDefaultModuleID } from "../config/createModuleID.js";
6
- import { createLogger } from "vite";
7
- import { join } from "node:path";
8
- import { DEFAULT_LOADER_CONFIG } from "../config/defaults.js";
9
- import { runDeferredStaticGeneration } from "../bundle/deferredStaticGeneration.js";
10
1
  /**
11
- * Creates a plugin that ensures consistent hash generation across environments
12
- * by using the original source file content as the basis for hash generation.
13
-
14
- */
15
- // Note: Path normalization should be handled in the file naming functions, not in writeBundle
16
- /**
17
- * Environment Configuration Plugin
18
- *
19
- * This plugin configures Vite Environment API environments for React Server Components.
20
- * It's separate from the env plugin which handles process environment variables.
21
- *
22
- * Environment mapping:
23
- * - client (Vite client = browser) → dist/client (React client components - real implementations)
24
- * - ssr (Vite SSR = SSR-safe) → dist/static (SSR-compatible static files)
25
- * - server (custom) → dist/server (React server components with registerClientReference)
2
+ * vite-plugin-react-server
3
+ * Copyright (c) Nico Brinkkemper
4
+ * MIT License
26
5
  */
27
- export const createEnvironmentPlugin = (options) => {
28
- const environmentPlugin = {
29
- name: "vite:plugin-react-server/environments",
30
- enforce: "pre",
31
- async config(config, configEnv) {
32
- // Resolve plugin options
33
- const resolvedOptionsResult = resolveOptions(options);
34
- if (resolvedOptionsResult.type === "error") {
35
- throw resolvedOptionsResult.error;
36
- }
37
- const userOptions = resolvedOptionsResult.userOptions;
38
- // Add transformer plugins at the Vite level with proper environment filtering
39
- if (!config.plugins) {
40
- config.plugins = [];
41
- }
42
- // Note: Transformer is now added via orchestrator, so skip adding it here
43
- // to avoid duplicates and ensure proper registration
44
- // Note: Hash coordination is handled by the sequential build approach
45
- // Each environment will use the manifest from the previous build
46
- // Set up logger and moduleID
47
- const logger = config.customLogger || createLogger();
48
- if (typeof userOptions.moduleID !== "function") {
49
- userOptions.moduleID = createDefaultModuleID(userOptions, configEnv, userOptions.loader?.mode);
50
- }
51
- // Always override the moduleID function to ensure it has the forTransformer logic
52
- if (!userOptions.loader) {
53
- userOptions.loader = DEFAULT_LOADER_CONFIG;
54
- }
55
- userOptions.loader.moduleID = createDefaultModuleID(userOptions, configEnv, userOptions.loader?.mode);
56
- // Run auto-discovery once to get all files - we don't need separate calls since
57
- // the file discovery process is identical, only the organization differs
58
- const autoDiscoverResult = await resolveAutoDiscover({
59
- config,
60
- configEnv,
61
- userOptions,
62
- logger,
63
- });
64
- if (autoDiscoverResult.type === "error") {
65
- const panicError = handleError({
66
- error: autoDiscoverResult.error,
67
- logger,
68
- context: "createEnvironmentPlugin(autoDiscover)",
69
- panicThreshold: userOptions.panicThreshold,
70
- critical: true, // Auto-discovery is critical for environment setup
71
- });
72
- if (panicError != null) {
73
- throw panicError;
6
+ import { resolveAutoDiscover } from '../config/autoDiscover/resolveAutoDiscover.js';
7
+ import { resolveUserConfig } from '../config/resolveUserConfig.js';
8
+ import { resolveOptions } from '../config/resolveOptions.js';
9
+ import { handleError } from '../error/handleError.js';
10
+ import { createDefaultModuleID } from '../config/createModuleID.js';
11
+ import { createLogger } from 'vite';
12
+ import { join } from 'node:path';
13
+ import { DEFAULT_LOADER_CONFIG } from '../config/defaults.js';
14
+ import { runDeferredStaticGeneration } from '../bundle/deferredStaticGeneration.js';
15
+
16
+ const createEnvironmentPlugin = (options) => {
17
+ const environmentPlugin = {
18
+ name: "vite:plugin-react-server/environments",
19
+ enforce: "pre",
20
+ async config(config, configEnv) {
21
+ const resolvedOptionsResult = resolveOptions(options);
22
+ if (resolvedOptionsResult.type === "error") {
23
+ throw resolvedOptionsResult.error;
24
+ }
25
+ const userOptions = resolvedOptionsResult.userOptions;
26
+ if (!config.plugins) {
27
+ config.plugins = [];
28
+ }
29
+ const logger = config.customLogger || createLogger();
30
+ if (typeof userOptions.moduleID !== "function") {
31
+ userOptions.moduleID = createDefaultModuleID(
32
+ userOptions,
33
+ configEnv,
34
+ userOptions.loader?.mode
35
+ );
36
+ }
37
+ if (!userOptions.loader) {
38
+ userOptions.loader = DEFAULT_LOADER_CONFIG;
39
+ }
40
+ userOptions.loader.moduleID = createDefaultModuleID(
41
+ userOptions,
42
+ configEnv,
43
+ userOptions.loader?.mode
44
+ );
45
+ const autoDiscoverResult = await resolveAutoDiscover({
46
+ config,
47
+ configEnv,
48
+ userOptions,
49
+ logger
50
+ });
51
+ if (autoDiscoverResult.type === "error") {
52
+ const panicError = handleError({
53
+ error: autoDiscoverResult.error,
54
+ logger,
55
+ panicThreshold: userOptions.panicThreshold,
56
+ critical: true
57
+ // Auto-discovery is critical for environment setup
58
+ });
59
+ if (panicError != null) {
60
+ throw panicError;
61
+ } else {
62
+ throw new Error("Cannot continue without auto-discovery");
63
+ }
64
+ }
65
+ const autoDiscoveredFiles = autoDiscoverResult.autoDiscoveredFiles;
66
+ const allEnvironmentConfigs = [
67
+ {
68
+ name: "client",
69
+ condition: "react-client",
70
+ ssr: false,
71
+ outDir: join(userOptions.build.outDir, userOptions.build.static)
72
+ },
73
+ {
74
+ name: "ssr",
75
+ condition: "react-client",
76
+ ssr: true,
77
+ outDir: join(userOptions.build.outDir, userOptions.build.client)
78
+ },
79
+ {
80
+ name: "server",
81
+ condition: "react-server",
82
+ ssr: true,
83
+ outDir: join(userOptions.build.outDir, userOptions.build.server)
84
+ }
85
+ ];
86
+ const availableEnvironments = userOptions.availableEnvironments || ["client", "ssr", "server"];
87
+ const environmentConfigs = allEnvironmentConfigs.filter(
88
+ (config2) => availableEnvironments.includes(config2.name)
89
+ );
90
+ const environments = {};
91
+ const sortedEnvConfigs = environmentConfigs;
92
+ for (const envConfig of sortedEnvConfigs) {
93
+ const configResult = resolveUserConfig({
94
+ condition: envConfig.condition,
95
+ config,
96
+ configEnv,
97
+ userOptions,
98
+ autoDiscoveredFiles,
99
+ ssr: envConfig.ssr
100
+ });
101
+ if (configResult.type === "error") {
102
+ const panicError = handleError({
103
+ error: configResult.error,
104
+ logger,
105
+ context: `createEnvironmentPlugin(${envConfig.name}Config)`,
106
+ panicThreshold: userOptions.panicThreshold,
107
+ critical: true
108
+ });
109
+ if (panicError != null) {
110
+ throw panicError;
111
+ } else {
112
+ throw new Error(
113
+ `Cannot continue without ${envConfig.name} environment configuration`
114
+ );
115
+ }
116
+ }
117
+ const userConfig = configResult.userConfig;
118
+ if (userOptions.verbose) {
119
+ logger?.info(
120
+ `${envConfig.name} environment rollup inputs: ${JSON.stringify(
121
+ userConfig.build.rollupOptions.input,
122
+ null,
123
+ 2
124
+ )}`
125
+ );
126
+ logger?.info(
127
+ `${envConfig.name} environment output preserveModulesRoot: ${JSON.stringify(
128
+ userConfig.build.rollupOptions.output,
129
+ null,
130
+ 2
131
+ )}`
132
+ );
133
+ }
134
+ if (userOptions.verbose) {
135
+ logger?.info(
136
+ `${envConfig.name} userConfig.resolve: ${JSON.stringify(
137
+ userConfig.resolve,
138
+ null,
139
+ 2
140
+ )}`
141
+ );
142
+ logger?.info(
143
+ `${envConfig.name} userConfig.build.rollupOptions.external: ${JSON.stringify(
144
+ userConfig.build.rollupOptions.external,
145
+ null,
146
+ 2
147
+ )}`
148
+ );
149
+ }
150
+ const legacyBuild = userOptions.strategy?.legacyBuilder && !config?.builder;
151
+ const implicitSsr = userOptions.strategy?.mainThreadCondition === "react-server" && userOptions.strategy?.legacyBuilder;
152
+ const implicitViteBuildName = userOptions.strategy?.legacyBuilder && !config.build?.ssr ? "client" : "ssr";
153
+ const consumer = legacyBuild ? implicitViteBuildName === "ssr" ? "server" : "client" : envConfig.name === "server" || envConfig.name === "ssr" ? "server" : "client";
154
+ environments[envConfig.name] = {
155
+ keepProcessEnv: envConfig.name === "server" ? true : false,
156
+ define: userConfig.define,
157
+ consumer,
158
+ resolve: {
159
+ ...userConfig.resolve,
160
+ // IMPORTANT: Map externals from resolveUserConfig (rollupOptions.external) to Environment API format
161
+ // In Environment API, externals go in resolve.external, not build.rollupOptions.external
162
+ // For static builds (browser/ESM): don't externalize anything - bundle everything to avoid _virtual files
163
+ // For client/server builds (SSR): externalize as configured
164
+ external: (() => {
165
+ const isStaticBuild = envConfig.name === "static" || !envConfig.ssr && envConfig.name === "client";
166
+ if (isStaticBuild) {
167
+ return [];
168
+ }
169
+ return Array.isArray(userConfig.build.rollupOptions.external) ? userConfig.build.rollupOptions.external.filter(
170
+ (item) => typeof item === "string"
171
+ ) : [];
172
+ })()
173
+ },
174
+ build: {
175
+ ...userConfig.build,
176
+ ssr: envConfig.name === "server" ? true : legacyBuild ? implicitSsr : envConfig.name === "ssr",
177
+ target: userConfig.build.target,
178
+ // Remove externals from rollupOptions since they should be in resolve.external for Environment API
179
+ rollupOptions: {
180
+ ...userConfig.build.rollupOptions,
181
+ external: void 0,
182
+ // Remove external from rollupOptions, it's now in resolve.external
183
+ // Set preserveModules in the output configuration, not at the top level
184
+ output: (() => {
185
+ const output = userConfig.build.rollupOptions.output;
186
+ if (Array.isArray(output)) {
187
+ const pluginOutput = output.find((o) => o && typeof o === "object" && "preserveModulesRoot" in o);
188
+ if (pluginOutput) {
189
+ return pluginOutput;
190
+ }
191
+ if (output.length > 0) {
192
+ return output[0];
193
+ }
74
194
  }
75
- else {
76
- // If handleError returns null but this is critical, we can't continue
77
- throw new Error("Cannot continue without auto-discovery");
195
+ if (output && typeof output === "object" && !Array.isArray(output)) {
196
+ const hasPreserveModulesRoot = "preserveModulesRoot" in output;
197
+ if (hasPreserveModulesRoot) {
198
+ return output;
199
+ } else {
200
+ const preserveModulesRootString = userOptions.build.preserveModulesRoot === false ? userOptions.moduleBase : void 0;
201
+ return { ...output, preserveModulesRoot: preserveModulesRootString };
202
+ }
78
203
  }
204
+ return output;
205
+ })()
79
206
  }
80
- // Get the auto-discovered files (safe to access since we checked for errors above)
81
- const autoDiscoveredFiles = autoDiscoverResult.autoDiscoveredFiles;
82
- // Define environment configurations
83
- const allEnvironmentConfigs = [
84
- {
85
- name: "client",
86
- condition: "react-client",
87
- ssr: false,
88
- outDir: join(userOptions.build.outDir, userOptions.build.static),
89
- },
90
- {
91
- name: "ssr",
92
- condition: "react-client",
93
- ssr: true,
94
- outDir: join(userOptions.build.outDir, userOptions.build.client),
95
- },
96
- {
97
- name: "server",
98
- condition: "react-server",
99
- ssr: true,
100
- outDir: join(userOptions.build.outDir, userOptions.build.server),
101
- },
102
- ];
103
- // Filter environments based on availableEnvironments from orchestrator
104
- const availableEnvironments = userOptions
105
- .availableEnvironments || ["client", "ssr", "server"];
106
- const environmentConfigs = allEnvironmentConfigs.filter((config) => availableEnvironments.includes(config.name));
107
- // Resolve all environment configurations using resolveUserConfig
108
- const environments = {};
109
- // Sort environments to process static first (to establish hashes)
110
- // Use the environment configs as-is
111
- const sortedEnvConfigs = environmentConfigs;
112
- for (const envConfig of sortedEnvConfigs) {
113
- const configResult = resolveUserConfig({
114
- condition: envConfig.condition,
115
- config,
116
- configEnv,
117
- userOptions,
118
- autoDiscoveredFiles,
119
- ssr: envConfig.ssr,
120
- });
121
- if (configResult.type === "error") {
122
- const panicError = handleError({
123
- error: configResult.error,
124
- logger,
125
- context: `createEnvironmentPlugin(${envConfig.name}Config)`,
126
- panicThreshold: userOptions.panicThreshold,
127
- critical: true,
128
- });
129
- if (panicError != null) {
130
- throw panicError;
131
- }
132
- else {
133
- throw new Error(`Cannot continue without ${envConfig.name} environment configuration`);
134
- }
135
- }
136
- // Map the resolved user config to Environment API compatible options
137
- const userConfig = configResult.userConfig;
138
- // Log the rollup inputs for this environment (only in verbose mode)
139
- if (userOptions.verbose) {
140
- logger?.info(`${envConfig.name} environment rollup inputs: ${JSON.stringify(userConfig.build.rollupOptions.input, null, 2)}`);
141
- logger?.info(`${envConfig.name} environment output preserveModulesRoot: ${JSON.stringify(userConfig.build.rollupOptions.output, null, 2)}`);
142
- }
143
- // Debug: Log what resolveUserConfig provided
144
- if (userOptions.verbose) {
145
- logger?.info(`${envConfig.name} userConfig.resolve: ${JSON.stringify(userConfig.resolve, null, 2)}`);
146
- logger?.info(`${envConfig.name} userConfig.build.rollupOptions.external: ${JSON.stringify(userConfig.build.rollupOptions.external, null, 2)}`);
147
- }
148
- // detect if legacy build or not
149
- const legacyBuild = userOptions.strategy?.legacyBuilder && !config?.builder;
150
- const implicitSsr = userOptions.strategy?.mainThreadCondition === "react-server" &&
151
- userOptions.strategy?.legacyBuilder;
152
- // this follows vite's logic for legacy builds
153
- const implicitViteBuildName = userOptions.strategy?.legacyBuilder && !config.build?.ssr
154
- ? "client"
155
- : "ssr";
156
- const consumer = legacyBuild
157
- ? implicitViteBuildName === "ssr"
158
- ? "server"
159
- : "client"
160
- : envConfig.name === "server" || envConfig.name === "ssr"
161
- ? "server"
162
- : "client";
163
- // Note: Path normalization should be handled in the file naming functions
164
- environments[envConfig.name] = {
165
- keepProcessEnv: envConfig.name === "server" ? true : false,
166
- define: userConfig.define,
167
- consumer: consumer,
168
- resolve: {
169
- ...userConfig.resolve,
170
- // IMPORTANT: Map externals from resolveUserConfig (rollupOptions.external) to Environment API format
171
- // In Environment API, externals go in resolve.external, not build.rollupOptions.external
172
- // For static builds (browser/ESM): don't externalize anything - bundle everything to avoid _virtual files
173
- // For client/server builds (SSR): externalize as configured
174
- external: (() => {
175
- const isStaticBuild = envConfig.name === "static" || (!envConfig.ssr && envConfig.name === "client");
176
- if (isStaticBuild) {
177
- // For static builds, don't externalize anything (bundle everything)
178
- return [];
179
- }
180
- // For SSR builds, use configured externals
181
- return Array.isArray(userConfig.build.rollupOptions.external)
182
- ? userConfig.build.rollupOptions.external.filter((item) => typeof item === "string")
183
- : [];
184
- })(),
185
- },
186
- build: {
187
- ...userConfig.build,
188
- ssr: envConfig.name === "server"
189
- ? true
190
- : legacyBuild
191
- ? implicitSsr
192
- : envConfig.name === "ssr",
193
- target: userConfig.build.target,
194
- // Remove externals from rollupOptions since they should be in resolve.external for Environment API
195
- rollupOptions: {
196
- ...userConfig.build.rollupOptions,
197
- external: undefined, // Remove external from rollupOptions, it's now in resolve.external
198
- // Set preserveModules in the output configuration, not at the top level
199
- output: (() => {
200
- const output = userConfig.build.rollupOptions.output;
201
- // Handle array output configuration - extract the plugin output that contains preserveModulesRoot
202
- if (Array.isArray(output)) {
203
- const pluginOutput = output.find(o => o && typeof o === 'object' && 'preserveModulesRoot' in o);
204
- if (pluginOutput) {
205
- return pluginOutput;
206
- }
207
- // If no pluginOutput found, use the first output configuration
208
- if (output.length > 0) {
209
- return output[0];
210
- }
211
- }
212
- // Ensure preserveModulesRoot is always present in the output configuration
213
- if (output && typeof output === 'object' && !Array.isArray(output)) {
214
- // Check if the property exists in the object (not just checking the value)
215
- const hasPreserveModulesRoot = 'preserveModulesRoot' in output;
216
- if (hasPreserveModulesRoot) {
217
- // Property exists, preserve the preserveModules value from the output (don't override it)
218
- // This is critical for static builds where preserveModules: false is set
219
- return output; // Return as-is, preserveModules is already set correctly
220
- }
221
- else {
222
- // Property missing, add it based on user options
223
- const preserveModulesRootString = userOptions.build.preserveModulesRoot === false
224
- ? userOptions.moduleBase
225
- : undefined;
226
- return { ...output, preserveModulesRoot: preserveModulesRootString };
227
- }
228
- }
229
- return output;
230
- })(),
231
- },
232
- },
233
- };
207
+ }
208
+ };
209
+ }
210
+ return {
211
+ root: userOptions.projectRoot,
212
+ ...config,
213
+ environments,
214
+ builder: {
215
+ async buildApp(builder) {
216
+ for (const environment of Object.values(builder.environments)) {
217
+ await builder.build(environment);
234
218
  }
235
- // Return the configuration with all environments
236
- // Build order: client → ssr → server → static generation (step 4)
237
- // Server build runs LAST so dist/client exists when HTML rendering references client components
238
- // Static generation is deferred to run after ALL environments complete (needs server manifest)
239
- return {
240
- root: userOptions.projectRoot,
241
- ...config,
242
- environments,
243
- builder: {
244
- async buildApp(builder) {
245
- // Build all environments in definition order
246
- for (const environment of Object.values(builder.environments)) {
247
- await builder.build(environment);
248
- }
249
- // Step 4: Run deferred static generation now that all manifests are available
250
- await runDeferredStaticGeneration();
251
- },
252
- },
253
- };
254
- },
255
- };
256
- return environmentPlugin;
219
+ await runDeferredStaticGeneration();
220
+ }
221
+ }
222
+ };
223
+ }
224
+ };
225
+ return environmentPlugin;
257
226
  };
227
+
228
+ export { createEnvironmentPlugin };
229
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createEnvironmentPlugin.js","sources":["../../../plugin/environments/createEnvironmentPlugin.ts"],"sourcesContent":["import type { Plugin, UserConfig, ViteBuilder } from \"vite\";\nimport type { VitePluginFn } from \"../types.js\";\n\nimport { resolveAutoDiscover } from \"../config/autoDiscover/resolveAutoDiscover.js\";\nimport { resolveUserConfig } from \"../config/resolveUserConfig.js\";\nimport { resolveOptions } from \"../config/resolveOptions.js\";\nimport { handleError } from \"../error/handleError.js\";\nimport { createDefaultModuleID } from \"../config/createModuleID.js\";\nimport { createLogger } from \"vite\";\nimport { join } from \"node:path\";\nimport { DEFAULT_LOADER_CONFIG } from \"../config/defaults.js\";\nimport { runDeferredStaticGeneration } from \"../bundle/deferredStaticGeneration.js\";\n\n/**\n * Creates a plugin that ensures consistent hash generation across environments\n * by using the original source file content as the basis for hash generation.\n\n*/\n// Note: Path normalization should be handled in the file naming functions, not in writeBundle\n\n/**\n * Environment Configuration Plugin\n *\n * This plugin configures Vite Environment API environments for React Server Components.\n * It's separate from the env plugin which handles process environment variables.\n *\n * Environment mapping:\n * - client (Vite client = browser) → dist/client (React client components - real implementations)\n * - ssr (Vite SSR = SSR-safe) → dist/static (SSR-compatible static files)\n * - server (custom) → dist/server (React server components with registerClientReference)\n */\nexport const createEnvironmentPlugin: VitePluginFn = (options): Plugin => {\n  const environmentPlugin: Plugin = {\n    name: \"vite:plugin-react-server/environments\",\n    enforce: \"pre\",\n\n    async config(config: UserConfig, configEnv) {\n      // Resolve plugin options\n      const resolvedOptionsResult = resolveOptions(options);\n      if (resolvedOptionsResult.type === \"error\") {\n        throw resolvedOptionsResult.error;\n      }\n      const userOptions = resolvedOptionsResult.userOptions;\n\n      // Add transformer plugins at the Vite level with proper environment filtering\n      if (!config.plugins) {\n        config.plugins = [];\n      }\n\n      // Note: Transformer is now added via orchestrator, so skip adding it here\n      // to avoid duplicates and ensure proper registration\n\n      // Note: Hash coordination is handled by the sequential build approach\n      // Each environment will use the manifest from the previous build\n\n      // Set up logger and moduleID\n      const logger = config.customLogger || createLogger();\n      if (typeof userOptions.moduleID !== \"function\") {\n        userOptions.moduleID = createDefaultModuleID(\n          userOptions,\n          configEnv,\n          userOptions.loader?.mode\n        );\n      }\n      // Always override the moduleID function to ensure it has the forTransformer logic\n      if (!userOptions.loader) {\n        userOptions.loader = DEFAULT_LOADER_CONFIG;\n      }\n      userOptions.loader.moduleID = createDefaultModuleID(\n        userOptions,\n        configEnv,\n        userOptions.loader?.mode\n      );\n\n      // Run auto-discovery once to get all files - we don't need separate calls since\n      // the file discovery process is identical, only the organization differs\n      const autoDiscoverResult = await resolveAutoDiscover({\n        config,\n        configEnv,\n        userOptions,\n        logger,\n      });\n\n      if (autoDiscoverResult.type === \"error\") {\n        const panicError = handleError({\n          error: autoDiscoverResult.error,\n          logger,\n          context: \"createEnvironmentPlugin(autoDiscover)\",\n          panicThreshold: userOptions.panicThreshold,\n          critical: true, // Auto-discovery is critical for environment setup\n        });\n        if (panicError != null) {\n          throw panicError;\n        } else {\n          // If handleError returns null but this is critical, we can't continue\n          throw new Error(\"Cannot continue without auto-discovery\");\n        }\n      }\n\n      // Get the auto-discovered files (safe to access since we checked for errors above)\n      const autoDiscoveredFiles = autoDiscoverResult.autoDiscoveredFiles!;\n\n      // Define environment configurations\n      const allEnvironmentConfigs = [\n        {\n          name: \"client\",\n          condition: \"react-client\" as const,\n          ssr: false,\n          outDir: join(userOptions.build.outDir, userOptions.build.static),\n        },\n        {\n          name: \"ssr\",\n          condition: \"react-client\" as const,\n          ssr: true,\n          outDir: join(userOptions.build.outDir, userOptions.build.client),\n        },\n        {\n          name: \"server\",\n          condition: \"react-server\" as const,\n          ssr: true,\n          outDir: join(userOptions.build.outDir, userOptions.build.server),\n        },\n      ];\n\n      // Filter environments based on availableEnvironments from orchestrator\n\n      const availableEnvironments = (userOptions as any)\n        .availableEnvironments || [\"client\", \"ssr\", \"server\"];\n\n      const environmentConfigs = allEnvironmentConfigs.filter((config) =>\n        availableEnvironments.includes(config.name)\n      );\n\n\n      // Resolve all environment configurations using resolveUserConfig\n      const environments: Record<string, import(\"vite\").EnvironmentOptions> =\n        {};\n\n      // Sort environments to process static first (to establish hashes)\n      // Use the environment configs as-is\n      const sortedEnvConfigs = environmentConfigs;\n\n      for (const envConfig of sortedEnvConfigs) {\n        const configResult = resolveUserConfig({\n          condition: envConfig.condition,\n          config,\n          configEnv,\n          userOptions,\n          autoDiscoveredFiles,\n          ssr: envConfig.ssr,\n        });\n\n        if (configResult.type === \"error\") {\n          const panicError = handleError({\n            error: configResult.error,\n            logger,\n            context: `createEnvironmentPlugin(${envConfig.name}Config)`,\n            panicThreshold: userOptions.panicThreshold,\n            critical: true,\n          });\n          if (panicError != null) {\n            throw panicError;\n          } else {\n            throw new Error(\n              `Cannot continue without ${envConfig.name} environment configuration`\n            );\n          }\n        }\n\n        // Map the resolved user config to Environment API compatible options\n        const userConfig = configResult.userConfig;\n\n        // Log the rollup inputs for this environment (only in verbose mode)\n        if (userOptions.verbose) {\n          logger?.info(\n            `${envConfig.name} environment rollup inputs: ${JSON.stringify(\n              userConfig.build.rollupOptions.input,\n              null,\n              2\n            )}`\n          );\n          logger?.info(\n            `${\n              envConfig.name\n            } environment output preserveModulesRoot: ${JSON.stringify(\n              userConfig.build.rollupOptions.output,\n              null,\n              2\n            )}`\n          );\n        }\n\n        // Debug: Log what resolveUserConfig provided\n        if (userOptions.verbose) {\n          logger?.info(\n            `${envConfig.name} userConfig.resolve: ${JSON.stringify(\n              userConfig.resolve,\n              null,\n              2\n            )}`\n          );\n          logger?.info(\n            `${\n              envConfig.name\n            } userConfig.build.rollupOptions.external: ${JSON.stringify(\n              userConfig.build.rollupOptions.external,\n              null,\n              2\n            )}`\n          );\n        }\n        // detect if legacy build or not\n        const legacyBuild = userOptions.strategy?.legacyBuilder && !config?.builder;\n        const implicitSsr =\n          userOptions.strategy?.mainThreadCondition === \"react-server\" &&\n          userOptions.strategy?.legacyBuilder;\n        // this follows vite's logic for legacy builds\n        const implicitViteBuildName =\n          userOptions.strategy?.legacyBuilder && !config.build?.ssr\n            ? \"client\"\n            : \"ssr\";\n        const consumer = legacyBuild\n          ? implicitViteBuildName === \"ssr\"\n            ? \"server\"\n            : \"client\"\n          : envConfig.name === \"server\" || envConfig.name === \"ssr\"\n          ? \"server\"\n          : \"client\";\n\n        // Note: Path normalization should be handled in the file naming functions\n        environments[envConfig.name] = {\n          keepProcessEnv: envConfig.name === \"server\" ? true : false,\n          define: userConfig.define,\n          consumer: consumer,\n          resolve: {\n            ...userConfig.resolve,\n            // IMPORTANT: Map externals from resolveUserConfig (rollupOptions.external) to Environment API format\n            // In Environment API, externals go in resolve.external, not build.rollupOptions.external\n            // For static builds (browser/ESM): don't externalize anything - bundle everything to avoid _virtual files\n            // For client/server builds (SSR): externalize as configured\n            external: (() => {\n              const isStaticBuild = envConfig.name === \"static\" || (!envConfig.ssr && envConfig.name === \"client\");\n              if (isStaticBuild) {\n                // For static builds, don't externalize anything (bundle everything)\n                return [];\n              }\n              // For SSR builds, use configured externals\n              return Array.isArray(userConfig.build.rollupOptions.external)\n                ? userConfig.build.rollupOptions.external.filter(\n                    (item): item is string => typeof item === \"string\"\n                  )\n                : [];\n            })(),\n          },\n          build: {\n            ...userConfig.build,\n            ssr:\n              envConfig.name === \"server\"\n                ? true\n                : legacyBuild\n                ? implicitSsr\n                : envConfig.name === \"ssr\",\n            target: userConfig.build.target,\n            // Remove externals from rollupOptions since they should be in resolve.external for Environment API\n            rollupOptions: {\n              ...userConfig.build.rollupOptions,\n              external: undefined, // Remove external from rollupOptions, it's now in resolve.external\n              // Set preserveModules in the output configuration, not at the top level\n              output: (() => {\n                const output = userConfig.build.rollupOptions.output;\n                \n                // Handle array output configuration - extract the plugin output that contains preserveModulesRoot\n                if (Array.isArray(output)) {\n                  const pluginOutput = output.find(o => o && typeof o === 'object' && 'preserveModulesRoot' in o);\n                  if (pluginOutput) {\n                    return pluginOutput;\n                  }\n                  // If no pluginOutput found, use the first output configuration\n                  if (output.length > 0) {\n                    return output[0];\n                  }\n                }\n                \n                // Ensure preserveModulesRoot is always present in the output configuration\n                if (output && typeof output === 'object' && !Array.isArray(output)) {\n                  // Check if the property exists in the object (not just checking the value)\n                  const hasPreserveModulesRoot = 'preserveModulesRoot' in output;\n                  \n                  if (hasPreserveModulesRoot) {\n                    // Property exists, preserve the preserveModules value from the output (don't override it)\n                    // This is critical for static builds where preserveModules: false is set\n                    return output; // Return as-is, preserveModules is already set correctly\n                  } else {\n                    // Property missing, add it based on user options\n                    const preserveModulesRootString = userOptions.build.preserveModulesRoot === false\n                      ? userOptions.moduleBase\n                      : undefined;\n                    return { ...output, preserveModulesRoot: preserveModulesRootString };\n                  }\n                }\n                \n                return output;\n              })(),\n            },\n          },\n        };\n      }\n\n      // Return the configuration with all environments\n      // Build order: client → ssr → server → static generation (step 4)\n      // Server build runs LAST so dist/client exists when HTML rendering references client components\n      // Static generation is deferred to run after ALL environments complete (needs server manifest)\n      return {\n        root: userOptions.projectRoot,\n        ...config,\n        environments,\n        builder: {\n          async buildApp(builder: ViteBuilder) {\n            // Build all environments in definition order\n            for (const environment of Object.values(builder.environments)) {\n              await builder.build(environment);\n            }\n            // Step 4: Run deferred static generation now that all manifests are available\n            await runDeferredStaticGeneration();\n          },\n        },\n      };\n    },\n  };\n\n  return environmentPlugin;\n};\n"],"names":["config"],"mappings":"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"}
@@ -1,38 +1,37 @@
1
- import { createElementWithReact } from "./createElementWithReact.js";
2
- import { React } from "../vendor/vendor.server.js";
3
- import { createHeadlessReusePageComponent } from "./headlessStreamReuseHandler.js";
4
1
  /**
5
- * Pure function for creating React element
6
- * This is environment-agnostic and can be used in both client and server
2
+ * vite-plugin-react-server
3
+ * Copyright (c) Nico Brinkkemper
4
+ * MIT License
7
5
  */
8
- export function createReactElement(options, context) {
9
- // Determine if this is a headless stream by checking if htmlPath is empty
10
- // This is more reliable than checking the ID
11
- const isHeadless = options.htmlPath === "";
12
- // Handle headless stream reuse for full streams
13
- let finalOptions = options;
14
- if (!isHeadless && context.reuseHeadlessStreamId) {
15
- const reusePageComponent = createHeadlessReusePageComponent({
16
- reuseHeadlessStreamId: context.reuseHeadlessStreamId,
17
- headlessStreamElements: context.headlessStreamElements || new Map(),
18
- headlessStreamErrors: context.headlessStreamErrors || new Map(),
19
- route: context.route,
20
- verbose: context.verbose,
21
- logger: context.logger,
22
- });
23
- if (reusePageComponent !== undefined) {
24
- finalOptions = {
25
- ...options,
26
- PageComponent: reusePageComponent,
27
- };
28
- }
29
- }
30
- return createElementWithReact(React, {
31
- ...finalOptions,
32
- Html: isHeadless ? React.Fragment : finalOptions.HtmlComponent,
33
- as: isHeadless ? React.Fragment : "div",
6
+ import { createElementWithReact } from './createElementWithReact.js';
7
+ import { React } from '../vendor/vendor.server.js';
8
+ import { createHeadlessReusePageComponent } from './headlessStreamReuseHandler.js';
9
+
10
+ function createReactElement(options, context) {
11
+ const isHeadless = options.htmlPath === "";
12
+ let finalOptions = options;
13
+ if (!isHeadless && context.reuseHeadlessStreamId) {
14
+ const reusePageComponent = createHeadlessReusePageComponent({
15
+ reuseHeadlessStreamId: context.reuseHeadlessStreamId,
16
+ headlessStreamElements: context.headlessStreamElements || /* @__PURE__ */ new Map(),
17
+ headlessStreamErrors: context.headlessStreamErrors || /* @__PURE__ */ new Map(),
18
+ route: context.route,
19
+ verbose: context.verbose,
20
+ logger: context.logger
34
21
  });
22
+ if (reusePageComponent !== void 0) {
23
+ finalOptions = {
24
+ ...options,
25
+ PageComponent: reusePageComponent
26
+ };
27
+ }
28
+ }
29
+ return createElementWithReact(React, {
30
+ ...finalOptions,
31
+ Html: isHeadless ? React.Fragment : finalOptions.HtmlComponent,
32
+ as: isHeadless ? React.Fragment : "div"
33
+ });
35
34
  }
36
- /**
37
- * Pure function for storing headless stream data
38
- */
35
+
36
+ export { createReactElement };
37
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlUnNjUmVuZGVySGVscGVycy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGx1Z2luL2hlbHBlcnMvY3JlYXRlUnNjUmVuZGVySGVscGVycy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENyZWF0ZUhhbmRsZXJPcHRpb25zIH0gZnJvbSBcIi4uL3R5cGVzLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFJzY1JlbmRlckNvbnRleHQgfSBmcm9tIFwiLi4vc3RyZWFtL3JlbmRlclJzY1N0cmVhbS50eXBlcy5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlRWxlbWVudFdpdGhSZWFjdCB9IGZyb20gXCIuL2NyZWF0ZUVsZW1lbnRXaXRoUmVhY3QuanNcIjtcbmltcG9ydCB7IFJlYWN0IH0gZnJvbSBcIi4uL3ZlbmRvci92ZW5kb3Iuc2VydmVyLmpzXCI7XG5pbXBvcnQgeyBjcmVhdGVIZWFkbGVzc1JldXNlUGFnZUNvbXBvbmVudCB9IGZyb20gXCIuL2hlYWRsZXNzU3RyZWFtUmV1c2VIYW5kbGVyLmpzXCI7XG5cbi8qKlxuICogUHVyZSBmdW5jdGlvbiBmb3IgY3JlYXRpbmcgUmVhY3QgZWxlbWVudFxuICogVGhpcyBpcyBlbnZpcm9ubWVudC1hZ25vc3RpYyBhbmQgY2FuIGJlIHVzZWQgaW4gYm90aCBjbGllbnQgYW5kIHNlcnZlclxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVhY3RFbGVtZW50KFxuICBvcHRpb25zOiBDcmVhdGVIYW5kbGVyT3B0aW9ucyxcbiAgY29udGV4dDogUnNjUmVuZGVyQ29udGV4dCxcbikge1xuICAvLyBEZXRlcm1pbmUgaWYgdGhpcyBpcyBhIGhlYWRsZXNzIHN0cmVhbSBieSBjaGVja2luZyBpZiBodG1sUGF0aCBpcyBlbXB0eVxuICAvLyBUaGlzIGlzIG1vcmUgcmVsaWFibGUgdGhhbiBjaGVja2luZyB0aGUgSURcbiAgY29uc3QgaXNIZWFkbGVzcyA9IG9wdGlvbnMuaHRtbFBhdGggPT09IFwiXCI7XG5cbiAgLy8gSGFuZGxlIGhlYWRsZXNzIHN0cmVhbSByZXVzZSBmb3IgZnVsbCBzdHJlYW1zXG4gIGxldCBmaW5hbE9wdGlvbnMgPSBvcHRpb25zO1xuICBpZiAoIWlzSGVhZGxlc3MgJiYgY29udGV4dC5yZXVzZUhlYWRsZXNzU3RyZWFtSWQpIHtcbiAgICBjb25zdCByZXVzZVBhZ2VDb21wb25lbnQgPSBjcmVhdGVIZWFkbGVzc1JldXNlUGFnZUNvbXBvbmVudCh7XG4gICAgICByZXVzZUhlYWRsZXNzU3RyZWFtSWQ6IGNvbnRleHQucmV1c2VIZWFkbGVzc1N0cmVhbUlkLFxuICAgICAgaGVhZGxlc3NTdHJlYW1FbGVtZW50czogY29udGV4dC5oZWFkbGVzc1N0cmVhbUVsZW1lbnRzIHx8IG5ldyBNYXA8c3RyaW5nLCBhbnk+KCksXG4gICAgICBoZWFkbGVzc1N0cmVhbUVycm9yczogY29udGV4dC5oZWFkbGVzc1N0cmVhbUVycm9ycyB8fCBuZXcgTWFwPHN0cmluZywgYW55PigpLFxuICAgICAgcm91dGU6IGNvbnRleHQucm91dGUsXG4gICAgICB2ZXJib3NlOiBjb250ZXh0LnZlcmJvc2UsXG4gICAgICBsb2dnZXI6IGNvbnRleHQubG9nZ2VyLFxuICAgIH0pO1xuICAgIFxuICAgIGlmIChyZXVzZVBhZ2VDb21wb25lbnQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgZmluYWxPcHRpb25zID0ge1xuICAgICAgICAuLi5vcHRpb25zLFxuICAgICAgICBQYWdlQ29tcG9uZW50OiByZXVzZVBhZ2VDb21wb25lbnQsXG4gICAgICB9O1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBjcmVhdGVFbGVtZW50V2l0aFJlYWN0KFJlYWN0LCB7XG4gICAgLi4uZmluYWxPcHRpb25zLFxuICAgIEh0bWw6IGlzSGVhZGxlc3MgPyBSZWFjdC5GcmFnbWVudCA6IGZpbmFsT3B0aW9ucy5IdG1sQ29tcG9uZW50LFxuICAgIGFzOiBpc0hlYWRsZXNzID8gUmVhY3QuRnJhZ21lbnQgOiBcImRpdlwiLFxuICB9KTtcbn1cblxuLyoqXG4gKiBQdXJlIGZ1bmN0aW9uIGZvciBzdG9yaW5nIGhlYWRsZXNzIHN0cmVhbSBkYXRhXG4gKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFVTyxTQUFTLGtCQUFBLENBQ2QsU0FDQSxPQUNBLEVBQUE7QUFHQSxFQUFNLE1BQUEsVUFBQSxHQUFhLFFBQVEsUUFBYSxLQUFBLEVBQUE7QUFHeEMsRUFBQSxJQUFJLFlBQWUsR0FBQSxPQUFBO0FBQ25CLEVBQUksSUFBQSxDQUFDLFVBQWMsSUFBQSxPQUFBLENBQVEscUJBQXVCLEVBQUE7QUFDaEQsSUFBQSxNQUFNLHFCQUFxQixnQ0FBaUMsQ0FBQTtBQUFBLE1BQzFELHVCQUF1QixPQUFRLENBQUEscUJBQUE7QUFBQSxNQUMvQixzQkFBd0IsRUFBQSxPQUFBLENBQVEsc0JBQTBCLG9CQUFBLElBQUksR0FBaUIsRUFBQTtBQUFBLE1BQy9FLG9CQUFzQixFQUFBLE9BQUEsQ0FBUSxvQkFBd0Isb0JBQUEsSUFBSSxHQUFpQixFQUFBO0FBQUEsTUFDM0UsT0FBTyxPQUFRLENBQUEsS0FBQTtBQUFBLE1BQ2YsU0FBUyxPQUFRLENBQUEsT0FBQTtBQUFBLE1BQ2pCLFFBQVEsT0FBUSxDQUFBO0FBQUEsS0FDakIsQ0FBQTtBQUVELElBQUEsSUFBSSx1QkFBdUIsTUFBVyxFQUFBO0FBQ3BDLE1BQWUsWUFBQSxHQUFBO0FBQUEsUUFDYixHQUFHLE9BQUE7QUFBQSxRQUNILGFBQWUsRUFBQTtBQUFBLE9BQ2pCO0FBQUE7QUFDRjtBQUdGLEVBQUEsT0FBTyx1QkFBdUIsS0FBTyxFQUFBO0FBQUEsSUFDbkMsR0FBRyxZQUFBO0FBQUEsSUFDSCxJQUFNLEVBQUEsVUFBQSxHQUFhLEtBQU0sQ0FBQSxRQUFBLEdBQVcsWUFBYSxDQUFBLGFBQUE7QUFBQSxJQUNqRCxFQUFBLEVBQUksVUFBYSxHQUFBLEtBQUEsQ0FBTSxRQUFXLEdBQUE7QUFBQSxHQUNuQyxDQUFBO0FBQ0g7Ozs7In0=
@@ -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,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"}
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,CAyF/B"}