mirror of
https://github.com/sunniejs/vue-h5-template.git
synced 2025-11-19 22:50:16 +08:00
91 lines
2.9 KiB
TypeScript
91 lines
2.9 KiB
TypeScript
import { createVitePlugins } from './build/vite/plugins';
|
|
import type { ConfigEnv, UserConfig } from 'vite';
|
|
import { loadEnv } from 'vite';
|
|
import { wrapperEnv } from './build/utils';
|
|
import { fileURLToPath, URL } from 'node:url';
|
|
import { readdirSync, statSync } from 'node:fs';
|
|
import { dirname } from 'node:path';
|
|
|
|
// https://vitejs.dev/config/
|
|
export default function ({ command, mode }: ConfigEnv): UserConfig {
|
|
const isProduction = command === 'build';
|
|
const root = process.cwd();
|
|
const env = loadEnv(mode, root);
|
|
const viteEnv = wrapperEnv(env);
|
|
|
|
const devOptimizeDepsInclude: Array<string> = ['eruda', 'vant/es,@varlet/ui'];
|
|
if (!isProduction) {
|
|
const excludedDirs = ['utils', 'style', 'composables'];
|
|
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
|
|
// 需要自动优化的 UI 库
|
|
const uiLibraries = [
|
|
{ name: 'vant/es', path: 'node_modules/vant/es' },
|
|
{ name: '@nutui/nutui/dist/packages', path: 'node_modules/@nutui/nutui/dist/packages' },
|
|
{ name: '@varlet/ui/es', path: 'node_modules/@varlet/ui/es' },
|
|
];
|
|
|
|
uiLibraries.forEach((lib) => {
|
|
try {
|
|
const dirNames = readdirSync(`${__dirname}/${lib.path}`);
|
|
dirNames
|
|
.filter((dirName) => {
|
|
const fullPath = `${__dirname}/${lib.path}/${dirName}`;
|
|
const isDir = statSync(fullPath).isDirectory();
|
|
const isExcluded = excludedDirs.includes(dirName);
|
|
return isDir && !isExcluded;
|
|
})
|
|
.forEach((dirName) => {
|
|
if (lib.name === '@nutui/nutui/dist/packages') {
|
|
if (dirName !== 'locale') {
|
|
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/css`);
|
|
}
|
|
} else if (lib.name === 'vant/es') {
|
|
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/index`);
|
|
} else {
|
|
devOptimizeDepsInclude.push(`${lib.name}/${dirName}/style/index.mjs`);
|
|
}
|
|
});
|
|
} catch (err) {
|
|
console.warn(`Failed to read directory for ${lib.name}: ${err}`);
|
|
}
|
|
});
|
|
}
|
|
|
|
return {
|
|
base: '/',
|
|
root,
|
|
resolve: {
|
|
alias: { '@': fileURLToPath(new URL('./src', import.meta.url)), '#': fileURLToPath(new URL('./types', import.meta.url)) },
|
|
},
|
|
server: {
|
|
host: true,
|
|
hmr: true,
|
|
},
|
|
plugins: createVitePlugins(viteEnv, isProduction),
|
|
build: {
|
|
minify: 'terser',
|
|
terserOptions: {
|
|
compress: {
|
|
//生产环境时移除console
|
|
drop_console: true,
|
|
drop_debugger: true,
|
|
},
|
|
},
|
|
},
|
|
css: {
|
|
preprocessorOptions: {
|
|
scss: {
|
|
quietDeps: true,
|
|
silenceDeprecations: ['legacy-js-api'],
|
|
// 配置 nutui 全局 scss 变量
|
|
additionalData: `@use "@nutui/nutui/dist/styles/variables.scss" as *; @use '@/styles/vant.scss' as *;`,
|
|
},
|
|
},
|
|
},
|
|
optimizeDeps: {
|
|
include: [...devOptimizeDepsInclude],
|
|
},
|
|
};
|
|
}
|