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.

113 lines
3.0 KiB

6 months ago
/** @format */
import { defineConfig, loadEnv } from 'vite';
import vue from '@vitejs/plugin-vue';
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons';
import { resolve } from 'path';
import dayjs from 'dayjs';
import pkg from './package.json';
import vueJsx from '@vitejs/plugin-vue-jsx';
import path from 'path';
import legacy from '@vitejs/plugin-legacy'
const { dependencies, devDependencies, name, version } = pkg;
const __APP_INFO__ = {
platform: process.env.PLATFORM,
pkg: { dependencies, devDependencies, name, version },
lastBuildTime: dayjs().format('YYYY-MM-DD HH:mm:ss'),
serviceMode: '',
};
function pathResolve(dir: string) {
return resolve(process.cwd(), '.', dir) + '/';
}
const serviceMode = 'paas';
// @ts-ignore
export default defineConfig(({ mode, command }) => {
const root = process.cwd();
const env = loadEnv(mode, root);
const { VITE_PORT, VITE_PROXY = '{}', VITE_LEGACY, VITE_PUBLIC_PATH } = env;
const port = Number(VITE_PORT);
const proxy = JSON.parse(VITE_PROXY);
const isBuild = command === 'build';
__APP_INFO__.serviceMode = serviceMode;
const server = {
host: true,
port,
proxy,
};
return {
base: VITE_PUBLIC_PATH,
build: {
lib: {
entry: path.resolve(__dirname, './lib/paas/index.ts'),
name: 'nerv-lib',
fileName: (format) => `nerv-lib.${format}.js`,
formats: ['es'],
},
rollupOptions: {
external: ['vue', 'vue-router', /^ant-design-vue(\/.+|$)/, 'vue-demi', 'pinia', 'dayjs'],
output: {
globals: {
vue: 'Vue',
'vue-router': 'vueRouter',
'vue-demi': 'VueDemi',
pinia: 'Pinia',
dayjs: 'dayjs',
'ant-design-vue': 'antd',
},
// inlineDynamicImports: true, //使用了按需加载
},
},
},
resolve: {
alias: [
{
find: 'vue-i18n',
replacement: 'vue-i18n/dist/vue-i18n.cjs.js',
},
{
find: /\/@\//,
replacement: pathResolve('src'),
},
{
find: /\/nerv-lib\//,
replacement: pathResolve('lib'),
},
{
find: /\/nerv-base\//,
replacement: pathResolve(`lib/${serviceMode}`),
},
],
},
server,
define: {
__APP_INFO__: JSON.stringify(__APP_INFO__),
},
css: {
preprocessorOptions: {
less: {
modifyVars: {
hack: `true; @import "/lib/${serviceMode}/theme/variable.less";`,
},
javascriptEnabled: true,
},
},
},
plugins: [
// commonjs(),
// nodePolyfills(),
legacy({
targets: ['defaults', 'not IE 11'],
}),
vue(),
vueJsx(),
createSvgIconsPlugin({
// 指定需要缓存的图标文件夹
iconDirs: [pathResolve('src/icon')],
svgoOptions: isBuild,
// 指定symbolId格式
symbolId: 'icon-[dir]-[name]',
}),
],
};
});