vite-plugin-react-server 1.4.1 → 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.
- package/README.md +48 -313
- package/dist/package.json +123 -13
- package/dist/plugin/bundle/deferredStaticGeneration.js +14 -39
- package/dist/plugin/bundle/manifests.js +30 -48
- package/dist/plugin/config/autoDiscover/resolveAutoDiscover.d.ts.map +1 -1
- package/dist/plugin/config/autoDiscover/resolveAutoDiscover.js +4 -1
- package/dist/plugin/config/envPrefixFromConfig.js +12 -7
- package/dist/plugin/config/getCondition.d.ts.map +1 -1
- package/dist/plugin/config/getCondition.js +7 -5
- package/dist/plugin/dev-server/configureReactServer.server.d.ts.map +1 -1
- package/dist/plugin/dev-server/configureReactServer.server.js +5 -8
- package/dist/plugin/dev-server/plugin.client.d.ts.map +1 -1
- package/dist/plugin/dev-server/plugin.client.js +2 -1
- package/dist/plugin/dev-server/plugin.server.d.ts.map +1 -1
- package/dist/plugin/dev-server/plugin.server.js +2 -36
- package/dist/plugin/dev-server/virtualRscHmrPlugin.js +23 -23
- package/dist/plugin/environments/createBuildEventPlugin.js +88 -98
- package/dist/plugin/environments/createEnvironmentPlugin.js +222 -250
- package/dist/plugin/error/index.d.ts +1 -2
- package/dist/plugin/error/index.d.ts.map +1 -1
- package/dist/plugin/error/index.js +2 -3
- package/dist/plugin/error/panicThresholdHandler.js +14 -3
- package/dist/plugin/error/setupGlobalErrorHandler.d.ts.map +1 -1
- package/dist/plugin/error/setupGlobalErrorHandler.js +23 -16
- package/dist/plugin/helpers/createRscRenderHelpers.d.ts +0 -5
- package/dist/plugin/helpers/createRscRenderHelpers.d.ts.map +1 -1
- package/dist/plugin/helpers/createRscRenderHelpers.js +32 -55
- package/dist/plugin/helpers/createSharedLoader.d.ts.map +1 -1
- package/dist/plugin/helpers/createSharedLoader.js +4 -2
- package/dist/plugin/helpers/headlessStreamReuseHandler.js +30 -22
- package/dist/plugin/helpers/headlessStreamState.d.ts +0 -38
- package/dist/plugin/helpers/headlessStreamState.d.ts.map +1 -1
- package/dist/plugin/helpers/headlessStreamState.js +15 -76
- package/dist/plugin/helpers/index.d.ts +0 -3
- package/dist/plugin/helpers/index.d.ts.map +1 -1
- package/dist/plugin/helpers/index.js +1 -4
- package/dist/plugin/helpers/requestInfo.d.ts.map +1 -1
- package/dist/plugin/helpers/requestInfo.js +3 -3
- package/dist/plugin/helpers/resolveComponent.d.ts.map +1 -1
- package/dist/plugin/helpers/resolveComponent.js +4 -2
- package/dist/plugin/helpers/workerCleanup.d.ts +1 -12
- package/dist/plugin/helpers/workerCleanup.d.ts.map +1 -1
- package/dist/plugin/helpers/workerCleanup.js +1 -1
- package/dist/plugin/index.client.d.ts +5 -0
- package/dist/plugin/index.client.d.ts.map +1 -0
- package/dist/plugin/index.client.js +4 -0
- package/dist/plugin/index.d.ts +4 -3
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +10 -5
- package/dist/plugin/index.server.d.ts +5 -0
- package/dist/plugin/index.server.d.ts.map +1 -0
- package/dist/plugin/index.server.js +4 -0
- package/dist/plugin/loader/directives/index.d.ts +0 -1
- package/dist/plugin/loader/directives/index.d.ts.map +1 -1
- package/dist/plugin/loader/directives/index.js +1 -2
- package/dist/plugin/metrics/createWorkerStartupMetrics.js +31 -13
- package/dist/plugin/orchestrator/createPluginOrchestrator.client.js +41 -38
- package/dist/plugin/orchestrator/createPluginOrchestrator.server.js +43 -46
- package/dist/plugin/plugin.client.js +2 -2
- package/dist/plugin/plugin.server.js +2 -2
- package/dist/plugin/react-static/createBuildLoader.client.js +12 -6
- package/dist/plugin/react-static/createBuildLoader.server.js +255 -235
- package/dist/plugin/react-static/plugin.client.js +684 -770
- package/dist/plugin/react-static/plugin.server.js +517 -603
- package/dist/plugin/react-static/processCssFilesForPages.js +103 -88
- package/dist/plugin/react-static/renderPage.client.js +455 -529
- package/dist/plugin/react-static/renderPage.server.js +485 -508
- package/dist/plugin/react-static/renderPagesBatched.js +277 -275
- package/dist/plugin/react-static/rscToHtmlStream.client.js +48 -29
- package/dist/plugin/react-static/rscToHtmlStream.server.js +62 -37
- package/dist/plugin/react-static/temporaryReferences.server.js +11 -2
- package/dist/plugin/stream/createMainThreadHandlers.js +40 -31
- package/dist/plugin/stream/renderRscStream.server.d.ts.map +1 -1
- package/dist/plugin/stream/renderRscStream.server.js +127 -144
- package/dist/plugin/transformer/createTransformerPlugin.js +226 -265
- package/dist/plugin/utils/checkReactVersion.d.ts +7 -0
- package/dist/plugin/utils/checkReactVersion.d.ts.map +1 -0
- package/dist/plugin/utils/checkReactVersion.js +23 -0
- package/dist/plugin/utils/envUrls.node.js +12 -11
- package/dist/plugin/vendor/vendor-alias.js +84 -114
- package/dist/plugin/vendor/vendor.client.d.ts.map +1 -1
- package/dist/plugin/vendor/vendor.client.js +1 -3
- package/dist/plugin/worker/rsc/handleRscRender.d.ts.map +1 -1
- package/dist/plugin/worker/rsc/handleRscRender.js +3 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +123 -13
- package/plugin/config/autoDiscover/resolveAutoDiscover.ts +4 -0
- package/plugin/config/getCondition.ts +6 -4
- package/plugin/dev-server/configureReactServer.server.ts +7 -10
- package/plugin/dev-server/plugin.client.ts +2 -0
- package/plugin/dev-server/plugin.server.ts +2 -49
- package/plugin/error/index.ts +1 -2
- package/plugin/error/setupGlobalErrorHandler.ts +24 -25
- package/plugin/helpers/createRscRenderHelpers.ts +0 -29
- package/plugin/helpers/createSharedLoader.ts +6 -1
- package/plugin/helpers/headlessStreamState.ts +0 -69
- package/plugin/helpers/index.ts +0 -3
- package/plugin/helpers/requestInfo.ts +1 -2
- package/plugin/helpers/resolveComponent.ts +6 -1
- package/plugin/helpers/workerCleanup.ts +1 -38
- package/plugin/index.client.ts +4 -0
- package/plugin/index.server.ts +4 -0
- package/plugin/index.ts +12 -5
- package/plugin/loader/directives/index.ts +0 -1
- package/plugin/plugin.client.ts +1 -1
- package/plugin/plugin.server.ts +1 -1
- package/plugin/stream/renderRscStream.server.ts +3 -0
- package/plugin/transformer/README.md +1 -1
- package/plugin/utils/checkReactVersion.ts +28 -0
- package/plugin/vendor/vendor.client.ts +0 -2
- package/plugin/worker/html/README.md +1 -1
- package/plugin/worker/rsc/README.md +1 -1
- package/plugin/worker/rsc/handleRscRender.ts +2 -0
- package/scripts/generate-toc.mjs +27 -294
- package/dist/plugin/error/assertPanic.d.ts +0 -2
- package/dist/plugin/error/assertPanic.d.ts.map +0 -1
- package/dist/plugin/error/assertPanic.js +0 -15
- package/dist/plugin/error/directiveError.d.ts +0 -13
- package/dist/plugin/error/directiveError.d.ts.map +0 -1
- package/dist/plugin/error/directiveError.js +0 -21
- package/dist/plugin/error/enhanceError.d.ts +0 -14
- package/dist/plugin/error/enhanceError.d.ts.map +0 -1
- package/dist/plugin/error/enhanceError.js +0 -24
- package/dist/plugin/helpers/createSafePageComponent.d.ts +0 -36
- package/dist/plugin/helpers/createSafePageComponent.d.ts.map +0 -1
- package/dist/plugin/helpers/createSafePageComponent.js +0 -50
- package/dist/plugin/helpers/moduleResolver.d.ts +0 -25
- package/dist/plugin/helpers/moduleResolver.d.ts.map +0 -1
- package/dist/plugin/helpers/moduleResolver.js +0 -64
- package/dist/plugin/helpers/stashReturnValue.d.ts +0 -3
- package/dist/plugin/helpers/stashReturnValue.d.ts.map +0 -1
- package/dist/plugin/helpers/stashReturnValue.js +0 -23
- package/dist/plugin/helpers/workerManager.d.ts +0 -5
- package/dist/plugin/helpers/workerManager.d.ts.map +0 -1
- package/dist/plugin/helpers/workerManager.js +0 -18
- package/dist/plugin/loader/directives/collectExportsFromModule.d.ts +0 -6
- package/dist/plugin/loader/directives/collectExportsFromModule.d.ts.map +0 -1
- package/dist/plugin/loader/directives/collectExportsFromModule.js +0 -24
- package/plugin/error/assertPanic.ts +0 -9
- package/plugin/error/directiveError.ts +0 -29
- package/plugin/error/enhanceError.ts +0 -41
- package/plugin/helpers/createSafePageComponent.ts +0 -64
- package/plugin/helpers/moduleResolver.ts +0 -91
- package/plugin/helpers/stashReturnValue.ts +0 -19
- package/plugin/helpers/workerManager.ts +0 -16
- package/plugin/loader/directives/collectExportsFromModule.ts +0 -25
|
@@ -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
|
-
*
|
|
12
|
-
*
|
|
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
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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
|
-
|
|
76
|
-
|
|
77
|
-
|
|
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
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
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
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
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,7 +1,6 @@
|
|
|
1
1
|
export { toError } from "./toError.js";
|
|
2
2
|
export { logError } from "./logError.js";
|
|
3
|
-
export { enhanceError, createContextualError } from "./enhanceError.js";
|
|
4
3
|
export { handleError } from "./handleError.js";
|
|
5
4
|
export { shouldPanic, PANIC_SYMBOL, isPanic } from "./shouldPanic.js";
|
|
6
|
-
export {
|
|
5
|
+
export { shouldCausePanic, handlePanicThreshold, isPanicError } from "./panicThresholdHandler.js";
|
|
7
6
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../plugin/error/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../plugin/error/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC"}
|
|
@@ -5,8 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
export { toError } from './toError.js';
|
|
7
7
|
export { logError } from './logError.js';
|
|
8
|
-
export { createContextualError, enhanceError } from './enhanceError.js';
|
|
9
8
|
export { handleError } from './handleError.js';
|
|
10
9
|
export { PANIC_SYMBOL, isPanic, shouldPanic } from './shouldPanic.js';
|
|
11
|
-
export {
|
|
12
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10
|
+
export { handlePanicThreshold, isPanicError, shouldCausePanic } from './panicThresholdHandler.js';
|
|
11
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7In0=
|
|
@@ -3,11 +3,22 @@
|
|
|
3
3
|
* Copyright (c) Nico Brinkkemper
|
|
4
4
|
* MIT License
|
|
5
5
|
*/
|
|
6
|
-
import { shouldPanic } from './shouldPanic.js';
|
|
6
|
+
import { isPanic, shouldPanic } from './shouldPanic.js';
|
|
7
7
|
|
|
8
8
|
function shouldCausePanic(error, options) {
|
|
9
9
|
return shouldPanic(error, options.panicThreshold, options.critical);
|
|
10
10
|
}
|
|
11
|
+
function handlePanicThreshold(error, options) {
|
|
12
|
+
if (shouldCausePanic(error, options)) {
|
|
13
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
14
|
+
err[Symbol.for("vite-plugin-react-server.panic")] = true;
|
|
15
|
+
return err;
|
|
16
|
+
}
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
function isPanicError(error) {
|
|
20
|
+
return isPanic(error);
|
|
21
|
+
}
|
|
11
22
|
|
|
12
|
-
export { shouldCausePanic };
|
|
13
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFuaWNUaHJlc2hvbGRIYW5kbGVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9wbHVnaW4vZXJyb3IvcGFuaWNUaHJlc2hvbGRIYW5kbGVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2VudHJhbGl6ZWQgcGFuaWMgdGhyZXNob2xkIGhhbmRsaW5nIGxvZ2ljXG4gKiBcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgc2luZ2xlIHBsYWNlIHRvIGhhbmRsZSBwYW5pYyB0aHJlc2hvbGQgZGVjaXNpb25zXG4gKiBpbnN0ZWFkIG9mIHNjYXR0ZXJpbmcgdGhlIGxvZ2ljIGFjcm9zcyBtdWx0aXBsZSBmaWxlcy5cbiAqL1xuXG5pbXBvcnQgeyBzaG91bGRQYW5pYywgaXNQYW5pYyB9IGZyb20gXCIuL3Nob3VsZFBhbmljLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFBhbmljVGhyZXNob2xkIH0gZnJvbSBcIi4uL3R5cGVzLmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFuaWNUaHJlc2hvbGRPcHRpb25zIHtcbiAgcGFuaWNUaHJlc2hvbGQ6IFBhbmljVGhyZXNob2xkO1xuICBjcml0aWNhbD86IGJvb2xlYW47XG4gIGxvZ2dlcj86IGFueTtcbiAgY29udGV4dD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBEZXRlcm1pbmVzIGlmIGFuIGVycm9yIHNob3VsZCBjYXVzZSBhIHBhbmljIGJhc2VkIG9uIHBhbmljIHRocmVzaG9sZCBzZXR0aW5nc1xuICovXG5leHBvcnQgZnVuY3Rpb24gc2hvdWxkQ2F1c2VQYW5pYyhcbiAgZXJyb3I6IHVua25vd24sXG4gIG9wdGlvbnM6IFBhbmljVGhyZXNob2xkT3B0aW9uc1xuKTogYm9vbGVhbiB7XG4gIHJldHVybiBzaG91bGRQYW5pYyhlcnJvciwgb3B0aW9ucy5wYW5pY1RocmVzaG9sZCwgb3B0aW9ucy5jcml0aWNhbCk7XG59XG5cbi8qKlxuICogSGFuZGxlcyBhbiBlcnJvciBiYXNlZCBvbiBwYW5pYyB0aHJlc2hvbGQgc2V0dGluZ3NcbiAqIFJldHVybnMgdGhlIGVycm9yIGlmIGl0IHNob3VsZCBjYXVzZSBhIHBhbmljLCBudWxsIG90aGVyd2lzZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlUGFuaWNUaHJlc2hvbGQoXG4gIGVycm9yOiB1bmtub3duLFxuICBvcHRpb25zOiBQYW5pY1RocmVzaG9sZE9wdGlvbnNcbik6IEVycm9yIHwgbnVsbCB7XG4gIGlmIChzaG91bGRDYXVzZVBhbmljKGVycm9yLCBvcHRpb25zKSkge1xuICAgIC8vIE1hcmsgZXJyb3IgZm9yIHBhbmljIGFuZCByZXR1cm4gaXQgdG8gYmUgdGhyb3duXG4gICAgY29uc3QgZXJyID0gZXJyb3IgaW5zdGFuY2VvZiBFcnJvciA/
|
|
23
|
+
export { handlePanicThreshold, isPanicError, shouldCausePanic };
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFuaWNUaHJlc2hvbGRIYW5kbGVyLmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi9wbHVnaW4vZXJyb3IvcGFuaWNUaHJlc2hvbGRIYW5kbGVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ2VudHJhbGl6ZWQgcGFuaWMgdGhyZXNob2xkIGhhbmRsaW5nIGxvZ2ljXG4gKiBcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgc2luZ2xlIHBsYWNlIHRvIGhhbmRsZSBwYW5pYyB0aHJlc2hvbGQgZGVjaXNpb25zXG4gKiBpbnN0ZWFkIG9mIHNjYXR0ZXJpbmcgdGhlIGxvZ2ljIGFjcm9zcyBtdWx0aXBsZSBmaWxlcy5cbiAqL1xuXG5pbXBvcnQgeyBzaG91bGRQYW5pYywgaXNQYW5pYyB9IGZyb20gXCIuL3Nob3VsZFBhbmljLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFBhbmljVGhyZXNob2xkIH0gZnJvbSBcIi4uL3R5cGVzLmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFuaWNUaHJlc2hvbGRPcHRpb25zIHtcbiAgcGFuaWNUaHJlc2hvbGQ6IFBhbmljVGhyZXNob2xkO1xuICBjcml0aWNhbD86IGJvb2xlYW47XG4gIGxvZ2dlcj86IGFueTtcbiAgY29udGV4dD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBEZXRlcm1pbmVzIGlmIGFuIGVycm9yIHNob3VsZCBjYXVzZSBhIHBhbmljIGJhc2VkIG9uIHBhbmljIHRocmVzaG9sZCBzZXR0aW5nc1xuICovXG5leHBvcnQgZnVuY3Rpb24gc2hvdWxkQ2F1c2VQYW5pYyhcbiAgZXJyb3I6IHVua25vd24sXG4gIG9wdGlvbnM6IFBhbmljVGhyZXNob2xkT3B0aW9uc1xuKTogYm9vbGVhbiB7XG4gIHJldHVybiBzaG91bGRQYW5pYyhlcnJvciwgb3B0aW9ucy5wYW5pY1RocmVzaG9sZCwgb3B0aW9ucy5jcml0aWNhbCk7XG59XG5cbi8qKlxuICogSGFuZGxlcyBhbiBlcnJvciBiYXNlZCBvbiBwYW5pYyB0aHJlc2hvbGQgc2V0dGluZ3NcbiAqIFJldHVybnMgdGhlIGVycm9yIGlmIGl0IHNob3VsZCBjYXVzZSBhIHBhbmljLCBudWxsIG90aGVyd2lzZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlUGFuaWNUaHJlc2hvbGQoXG4gIGVycm9yOiB1bmtub3duLFxuICBvcHRpb25zOiBQYW5pY1RocmVzaG9sZE9wdGlvbnNcbik6IEVycm9yIHwgbnVsbCB7XG4gIGlmIChzaG91bGRDYXVzZVBhbmljKGVycm9yLCBvcHRpb25zKSkge1xuICAgIC8vIE1hcmsgZXJyb3IgZm9yIHBhbmljIGFuZCByZXR1cm4gaXQgdG8gYmUgdGhyb3duXG4gICAgY29uc3QgZXJyID0gZXJyb3IgaW5zdGFuY2VvZiBFcnJvciA/IGVycm9yIDogbmV3IEVycm9yKFN0cmluZyhlcnJvcikpO1xuICAgIChlcnIgYXMgYW55KVtTeW1ib2wuZm9yKCd2aXRlLXBsdWdpbi1yZWFjdC1zZXJ2ZXIucGFuaWMnKV0gPSB0cnVlO1xuICAgIHJldHVybiBlcnI7XG4gIH1cbiAgcmV0dXJuIG51bGw7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIGFuIGVycm9yIGlzIGFscmVhZHkgbWFya2VkIGFzIGEgcGFuaWMgZXJyb3JcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzUGFuaWNFcnJvcihlcnJvcjogdW5rbm93bik6IGJvb2xlYW4ge1xuICByZXR1cm4gaXNQYW5pYyhlcnJvcik7XG59XG5cblxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFvQk8sU0FBUyxnQkFBQSxDQUNkLE9BQ0EsT0FDUyxFQUFBO0FBQ1QsRUFBQSxPQUFPLFdBQVksQ0FBQSxLQUFBLEVBQU8sT0FBUSxDQUFBLGNBQUEsRUFBZ0IsUUFBUSxRQUFRLENBQUE7QUFDcEU7QUFNTyxTQUFTLG9CQUFBLENBQ2QsT0FDQSxPQUNjLEVBQUE7QUFDZCxFQUFJLElBQUEsZ0JBQUEsQ0FBaUIsS0FBTyxFQUFBLE9BQU8sQ0FBRyxFQUFBO0FBRXBDLElBQU0sTUFBQSxHQUFBLEdBQU0saUJBQWlCLEtBQVEsR0FBQSxLQUFBLEdBQVEsSUFBSSxLQUFNLENBQUEsTUFBQSxDQUFPLEtBQUssQ0FBQyxDQUFBO0FBQ3BFLElBQUMsR0FBWSxDQUFBLE1BQUEsQ0FBTyxHQUFJLENBQUEsZ0NBQWdDLENBQUMsQ0FBSSxHQUFBLElBQUE7QUFDN0QsSUFBTyxPQUFBLEdBQUE7QUFBQTtBQUVULEVBQU8sT0FBQSxJQUFBO0FBQ1Q7QUFLTyxTQUFTLGFBQWEsS0FBeUIsRUFBQTtBQUNwRCxFQUFBLE9BQU8sUUFBUSxLQUFLLENBQUE7QUFDdEI7Ozs7In0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setupGlobalErrorHandler.d.ts","sourceRoot":"","sources":["../../../plugin/error/setupGlobalErrorHandler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,2BAA2B,EAC3B,yBAAyB,EAC1B,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"setupGlobalErrorHandler.d.ts","sourceRoot":"","sources":["../../../plugin/error/setupGlobalErrorHandler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,2BAA2B,EAC3B,yBAAyB,EAC1B,MAAM,YAAY,CAAC;AAMpB,eAAO,MAAM,uBAAuB,EAAE,yBA0CnC,CAAC;AAEJ,eAAO,MAAM,yBAAyB,EAAE,2BAgBrC,CAAC"}
|