2026-02-15 10:28:27 +09:00
|
|
|
import { defineConfig, loadEnv, type Plugin } from 'vite';
|
2026-01-30 13:01:54 +09:00
|
|
|
import react from '@vitejs/plugin-react';
|
|
|
|
|
|
2026-02-15 11:37:37 +09:00
|
|
|
export default defineConfig(({ mode, command }) => {
|
2026-01-30 13:01:54 +09:00
|
|
|
const env = loadEnv(mode, process.cwd(), '');
|
|
|
|
|
|
2026-02-05 06:35:31 +09:00
|
|
|
const isLocalDev = mode === 'development';
|
|
|
|
|
const isBuild = command === 'build';
|
|
|
|
|
|
2026-02-12 13:54:21 +09:00
|
|
|
const base = env.VITE_BASE_URL || '/';
|
2026-02-05 06:35:31 +09:00
|
|
|
|
|
|
|
|
console.log(`[Vite] Mode: ${mode}, Command: ${command}, Base: ${base}, isLocalDev: ${isLocalDev}`);
|
|
|
|
|
|
2026-02-15 10:28:27 +09:00
|
|
|
const excludePatterns: RegExp[] = isBuild && !isLocalDev
|
2026-02-05 06:35:31 +09:00
|
|
|
? [
|
|
|
|
|
/[/\\]publish[/\\]/,
|
|
|
|
|
/[/\\]component[/\\]wrap[/\\]/,
|
|
|
|
|
]
|
|
|
|
|
: [];
|
|
|
|
|
|
2026-02-15 11:37:37 +09:00
|
|
|
return {
|
2026-02-05 06:35:31 +09:00
|
|
|
base,
|
|
|
|
|
define: {
|
2026-02-15 10:28:27 +09:00
|
|
|
global: 'globalThis',
|
2026-02-05 06:35:31 +09:00
|
|
|
},
|
2026-01-30 13:01:54 +09:00
|
|
|
server: {
|
|
|
|
|
host: true,
|
|
|
|
|
port: 3000,
|
|
|
|
|
proxy: {
|
2026-02-15 07:02:22 +09:00
|
|
|
'/snp-api': {
|
|
|
|
|
target: env.VITE_SNP_API_TARGET || 'http://211.208.115.83:8041',
|
2026-01-30 13:01:54 +09:00
|
|
|
changeOrigin: true,
|
|
|
|
|
secure: false,
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
2026-02-05 06:35:31 +09:00
|
|
|
plugins: [
|
|
|
|
|
react(),
|
2026-02-15 10:28:27 +09:00
|
|
|
isBuild && !isLocalDev && ({
|
2026-02-05 06:35:31 +09:00
|
|
|
name: 'exclude-dev-folders',
|
2026-02-15 10:28:27 +09:00
|
|
|
resolveId(source: string) {
|
2026-02-05 06:35:31 +09:00
|
|
|
const normalizedSource = source.replace(/\\/g, '/');
|
|
|
|
|
for (const pattern of excludePatterns) {
|
|
|
|
|
if (pattern.test(normalizedSource)) {
|
|
|
|
|
return { id: 'virtual:empty-module', moduleSideEffects: false };
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
},
|
2026-02-15 10:28:27 +09:00
|
|
|
load(id: string) {
|
2026-02-05 06:35:31 +09:00
|
|
|
if (id === 'virtual:empty-module') {
|
|
|
|
|
return 'export default null;';
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
},
|
2026-02-15 10:28:27 +09:00
|
|
|
} satisfies Plugin),
|
2026-02-05 06:35:31 +09:00
|
|
|
].filter(Boolean),
|
2026-01-30 13:01:54 +09:00
|
|
|
resolve: {
|
|
|
|
|
alias: {
|
|
|
|
|
'@': '/src',
|
|
|
|
|
},
|
|
|
|
|
},
|
2026-02-05 06:35:31 +09:00
|
|
|
esbuild: isBuild && !isLocalDev
|
|
|
|
|
? {
|
|
|
|
|
drop: ['console', 'debugger'],
|
|
|
|
|
}
|
|
|
|
|
: {},
|
2026-01-30 13:01:54 +09:00
|
|
|
build: {
|
2026-02-15 11:37:37 +09:00
|
|
|
target: 'es2022',
|
2026-01-30 13:01:54 +09:00
|
|
|
outDir: 'dist',
|
|
|
|
|
cssCodeSplit: true,
|
|
|
|
|
rollupOptions: {
|
|
|
|
|
output: {
|
|
|
|
|
manualChunks: {
|
|
|
|
|
vendor: ['react', 'react-dom', 'react-router-dom'],
|
|
|
|
|
map: ['ol', 'ol-ext'],
|
|
|
|
|
state: ['zustand'],
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
},
|
2026-02-15 11:37:37 +09:00
|
|
|
};
|
|
|
|
|
});
|