You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
106 lines
2.8 KiB
106 lines
2.8 KiB
9 months ago
|
import { resolve } from 'node:path';
|
||
|
|
||
|
import dayjs from 'dayjs';
|
||
|
import { readPackageJSON } from 'pkg-types';
|
||
|
import { defineConfig, loadEnv, mergeConfig, type UserConfig } from 'vite';
|
||
|
|
||
|
import { createPlugins } from '../plugins';
|
||
|
import { generateModifyVars } from '../utils/modifyVars';
|
||
|
import { commonConfig } from './common';
|
||
|
|
||
|
interface DefineOptions {
|
||
|
overrides?: UserConfig;
|
||
|
options?: {
|
||
|
//
|
||
|
};
|
||
|
}
|
||
|
|
||
|
function defineApplicationConfig(defineOptions: DefineOptions = {}) {
|
||
|
const { overrides = {} } = defineOptions;
|
||
|
|
||
|
return defineConfig(async ({ command, mode }) => {
|
||
|
const root = process.cwd();
|
||
|
const isBuild = command === 'build';
|
||
|
const { VITE_PUBLIC_PATH, VITE_BUILD_COMPRESS, VITE_ENABLE_ANALYZE } = loadEnv(mode, root);
|
||
|
|
||
|
const defineData = await createDefineData(root);
|
||
|
const plugins = await createPlugins({
|
||
|
isBuild,
|
||
|
root,
|
||
|
enableAnalyze: VITE_ENABLE_ANALYZE === 'true',
|
||
|
compress: VITE_BUILD_COMPRESS,
|
||
|
});
|
||
|
|
||
|
const pathResolve = (pathname: string) => resolve(root, '.', pathname);
|
||
|
const timestamp = new Date().getTime();
|
||
|
const applicationConfig: UserConfig = {
|
||
|
base: VITE_PUBLIC_PATH,
|
||
|
resolve: {
|
||
|
alias: [
|
||
|
{
|
||
|
find: 'vue-i18n',
|
||
|
replacement: 'vue-i18n/dist/vue-i18n.cjs.js',
|
||
|
},
|
||
|
// @/xxxx => src/xxxx
|
||
|
{
|
||
|
find: /@\//,
|
||
|
replacement: pathResolve('src') + '/',
|
||
|
},
|
||
|
// #/xxxx => types/xxxx
|
||
|
{
|
||
|
find: /#\//,
|
||
|
replacement: pathResolve('types') + '/',
|
||
|
},
|
||
|
],
|
||
|
},
|
||
|
define: defineData,
|
||
|
build: {
|
||
|
target: 'es2015',
|
||
|
cssTarget: 'chrome80',
|
||
|
rollupOptions: {
|
||
|
output: {
|
||
|
// 入口文件名
|
||
|
entryFileNames: `assets/entry/[name]-[hash]-${timestamp}.js`,
|
||
|
manualChunks: {
|
||
|
vue: ['vue', 'pinia', 'vue-router'],
|
||
|
antd: ['ant-design-vue', '@ant-design/icons-vue'],
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
css: {
|
||
|
preprocessorOptions: {
|
||
|
less: {
|
||
|
modifyVars: generateModifyVars(),
|
||
|
javascriptEnabled: true,
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
plugins,
|
||
|
};
|
||
|
|
||
|
const mergedConfig = mergeConfig(commonConfig(mode), applicationConfig);
|
||
|
|
||
|
return mergeConfig(mergedConfig, overrides);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
async function createDefineData(root: string) {
|
||
|
try {
|
||
|
const pkgJson = await readPackageJSON(root);
|
||
|
const { dependencies, devDependencies, name, version } = pkgJson;
|
||
|
|
||
|
const __APP_INFO__ = {
|
||
|
pkg: { dependencies, devDependencies, name, version },
|
||
|
lastBuildTime: dayjs().format('YYYY-MM-DD HH:mm:ss'),
|
||
|
};
|
||
|
return {
|
||
|
__APP_INFO__: JSON.stringify(__APP_INFO__),
|
||
|
};
|
||
|
} catch (error) {
|
||
|
return {};
|
||
|
}
|
||
|
}
|
||
|
|
||
|
export { defineApplicationConfig };
|