Files
clash-proxy/vite.config.mts

171 lines
4.9 KiB
TypeScript
Raw Normal View History

import path from "node:path";
2024-05-29 09:39:26 +08:00
import legacy from "@vitejs/plugin-legacy";
2025-10-30 10:19:29 +08:00
import react from "@vitejs/plugin-react-swc";
import monacoEditorPlugin, {
type IMonacoEditorOpts,
} from "vite-plugin-monaco-editor-esm";
import svgr from "vite-plugin-svgr";
2025-10-18 16:11:42 +08:00
import { defineConfig } from "vitest/config";
const monacoEditorPluginDefault = ((monacoEditorPlugin as any).default ??
monacoEditorPlugin) as (options: IMonacoEditorOpts) => any;
2021-12-08 23:34:23 +08:00
export default defineConfig({
root: "src",
2022-09-02 01:35:06 +08:00
server: { port: 3000 },
2022-07-05 00:52:22 +08:00
plugins: [
svgr(),
react(),
2024-05-29 09:39:26 +08:00
legacy({
targets: ["edge>=109", "safari>=13"],
2024-06-05 09:04:08 +08:00
renderLegacyChunks: false,
2024-05-29 09:39:26 +08:00
modernPolyfills: true,
additionalModernPolyfills: [
"core-js/modules/es.object.has-own.js",
2024-06-05 09:04:08 +08:00
"core-js/modules/web.structured-clone.js",
2024-05-30 20:27:12 +08:00
path.resolve("./src/polyfills/matchMedia.js"),
2024-05-29 09:39:26 +08:00
path.resolve("./src/polyfills/WeakRef.js"),
path.resolve("./src/polyfills/RegExp.js"),
],
}),
monacoEditorPluginDefault({
2024-05-13 22:58:25 +08:00
languageWorkers: ["editorWorkerService", "typescript", "css"],
customWorkers: [
{
label: "yaml",
entry: "monaco-yaml/yaml.worker",
},
],
2025-03-27 05:09:36 +08:00
globalAPI: false,
}),
2022-07-05 00:52:22 +08:00
],
2021-12-12 00:39:28 +08:00
build: {
outDir: "../dist",
2021-12-22 01:15:04 +08:00
emptyOutDir: true,
2025-03-27 05:09:36 +08:00
minify: "terser",
chunkSizeWarningLimit: 4000,
reportCompressedSize: false,
sourcemap: false,
cssCodeSplit: 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,
},
},
2025-03-27 05:09:36 +08:00
rollupOptions: {
treeshake: {
preset: "recommended",
moduleSideEffects: (id) => !id.endsWith(".css"),
2025-03-27 05:09:36 +08:00
tryCatchDeoptimization: false,
},
output: {
compact: true,
experimentalMinChunkSize: 100000,
2025-03-27 05:09:36 +08:00
dynamicImportInCjs: true,
manualChunks(id) {
if (id.includes("node_modules")) {
// Monaco Editor should be a separate chunk
if (id.includes("monaco-editor")) return "monaco-editor";
// React core libraries
2025-03-27 05:09:36 +08:00
if (
id.includes("react") ||
id.includes("react-dom") ||
id.includes("react-router")
) {
return "react-core";
}
// React UI libraries
if (
2025-03-27 05:09:36 +08:00
id.includes("react-transition-group") ||
id.includes("react-error-boundary") ||
id.includes("react-hook-form") ||
id.includes("react-markdown") ||
id.includes("react-virtuoso")
) {
return "react-ui";
2025-03-27 05:09:36 +08:00
}
// Material UI libraries (grouped together)
2025-03-27 05:09:36 +08:00
if (
id.includes("@mui/material") ||
id.includes("@mui/icons-material") ||
id.includes("@mui/lab") ||
id.includes("@mui/x-data-grid")
2025-03-27 05:09:36 +08:00
) {
return "mui";
2025-03-27 05:09:36 +08:00
}
// Tauri-related plugins: grouping together Tauri plugins
if (
id.includes("@tauri-apps/api") ||
id.includes("@tauri-apps/plugin-clipboard-manager") ||
id.includes("@tauri-apps/plugin-dialog") ||
id.includes("@tauri-apps/plugin-fs") ||
id.includes("@tauri-apps/plugin-global-shortcut") ||
id.includes("@tauri-apps/plugin-process") ||
id.includes("@tauri-apps/plugin-shell") ||
id.includes("@tauri-apps/plugin-updater")
) {
return "tauri-plugins";
}
// Utilities chunk: group commonly used utility libraries
2025-03-27 05:09:36 +08:00
if (
id.includes("axios") ||
id.includes("lodash-es") ||
id.includes("dayjs") ||
id.includes("js-base64") ||
id.includes("js-yaml") ||
id.includes("cli-color") ||
id.includes("nanoid")
2025-03-27 05:09:36 +08:00
) {
return "utils";
2025-03-27 05:09:36 +08:00
}
// Group other vendor packages together to reduce small chunks
const pkg = id.match(/node_modules\/([^/]+)/)?.[1];
if (pkg) {
// Large packages get their own chunks
if (
pkg.includes("monaco") ||
pkg.includes("lodash") ||
pkg.includes("antd") ||
pkg.includes("emotion")
) {
return `vendor-${pkg}`;
}
2025-03-27 05:09:36 +08:00
// Group all other packages together
return "vendor";
}
2025-03-27 05:09:36 +08:00
}
},
},
},
2021-12-12 00:39:28 +08:00
},
2022-08-06 02:35:11 +08:00
resolve: {
alias: {
"@": path.resolve("./src"),
"@root": path.resolve("."),
},
},
test: {
environment: "node",
include: ["**/*.{test,spec}.{ts,tsx}"],
},
define: {
OS_PLATFORM: `"${process.platform}"`,
},
2021-12-08 23:34:23 +08:00
});