feat: update Vite configuration for improved chunking and build options

This commit is contained in:
Tunglies
2025-09-06 21:24:10 +08:00
parent 579f9bd1f8
commit 5dca724017

View File

@@ -17,8 +17,8 @@ export default defineConfig({
svgr(), svgr(),
react(), react(),
legacy({ legacy({
targets: ["edge>=109", "safari>=13"],
renderLegacyChunks: false, renderLegacyChunks: false,
modernTargets: ["edge>=109", "safari>=13"],
modernPolyfills: true, modernPolyfills: true,
additionalModernPolyfills: [ additionalModernPolyfills: [
"core-js/modules/es.object.has-own.js", "core-js/modules/es.object.has-own.js",
@@ -42,13 +42,24 @@ export default defineConfig({
build: { build: {
outDir: "../dist", outDir: "../dist",
emptyOutDir: true, emptyOutDir: true,
target: "es2020",
minify: "terser", minify: "terser",
chunkSizeWarningLimit: 4000, chunkSizeWarningLimit: 4000,
reportCompressedSize: false, reportCompressedSize: false,
sourcemap: false, sourcemap: false,
cssCodeSplit: true, cssCodeSplit: true,
cssMinify: true, cssMinify: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: true,
pure_funcs: ["console.debug", "console.trace"],
dead_code: true,
unused: true,
},
mangle: {
safari10: true,
},
},
rollupOptions: { rollupOptions: {
treeshake: { treeshake: {
preset: "recommended", preset: "recommended",
@@ -57,38 +68,41 @@ export default defineConfig({
}, },
output: { output: {
compact: true, compact: true,
experimentalMinChunkSize: 30000, experimentalMinChunkSize: 100000,
dynamicImportInCjs: true, dynamicImportInCjs: true,
manualChunks(id) { manualChunks(id) {
if (id.includes("node_modules")) { if (id.includes("node_modules")) {
// Monaco Editor should be a separate chunk // Monaco Editor should be a separate chunk
if (id.includes("monaco-editor")) return "monaco-editor"; if (id.includes("monaco-editor")) return "monaco-editor";
// React-related libraries (react, react-dom, react-router-dom, etc.) // React core libraries
if ( if (
id.includes("react") || id.includes("react") ||
id.includes("react-dom") || id.includes("react-dom") ||
id.includes("react-router-dom") || id.includes("react-router-dom")
) {
return "react-core";
}
// React UI libraries
if (
id.includes("react-transition-group") || id.includes("react-transition-group") ||
id.includes("react-error-boundary") || id.includes("react-error-boundary") ||
id.includes("react-hook-form") || id.includes("react-hook-form") ||
id.includes("react-markdown") || id.includes("react-markdown") ||
id.includes("react-virtuoso") id.includes("react-virtuoso")
) { ) {
return "react"; return "react-ui";
} }
// Utilities chunk: group commonly used utility libraries // Material UI libraries (grouped together)
if ( if (
id.includes("axios") || id.includes("@mui/material") ||
id.includes("lodash-es") || id.includes("@mui/icons-material") ||
id.includes("dayjs") || id.includes("@mui/lab") ||
id.includes("js-base64") || id.includes("@mui/x-data-grid")
id.includes("js-yaml") ||
id.includes("cli-color") ||
id.includes("nanoid")
) { ) {
return "utils"; return "mui";
} }
// Tauri-related plugins: grouping together Tauri plugins // Tauri-related plugins: grouping together Tauri plugins
@@ -106,22 +120,35 @@ export default defineConfig({
return "tauri-plugins"; return "tauri-plugins";
} }
// Material UI libraries (grouped together) // Utilities chunk: group commonly used utility libraries
if ( if (
id.includes("@mui/material") || id.includes("axios") ||
id.includes("@mui/icons-material") || id.includes("lodash-es") ||
id.includes("@mui/lab") || id.includes("dayjs") ||
id.includes("@mui/x-data-grid") id.includes("js-base64") ||
id.includes("js-yaml") ||
id.includes("cli-color") ||
id.includes("nanoid")
) { ) {
return "mui"; return "utils";
} }
// Small vendor packages // Group other vendor packages together to reduce small chunks
const pkg = id.match(/node_modules\/([^/]+)/)?.[1]; const pkg = id.match(/node_modules\/([^/]+)/)?.[1];
if (pkg && pkg.length < 8) return "small-vendors"; if (pkg) {
// Large packages get their own chunks
if (
pkg.includes("monaco") ||
pkg.includes("lodash") ||
pkg.includes("antd") ||
pkg.includes("emotion")
) {
return `vendor-${pkg}`;
}
// Large vendor packages // Group all other packages together
return "large-vendor"; return "vendor";
}
} }
}, },
}, },
@@ -135,6 +162,6 @@ export default defineConfig({
}, },
define: { define: {
OS_PLATFORM: `"${process.platform}"`, OS_PLATFORM: '"unknown"',
}, },
}); });