2024-01-24 13:40:15 +00:00
|
|
|
import { resolve } from 'path';
|
|
|
|
import { defineConfig } from 'vite';
|
|
|
|
import vue from '@vitejs/plugin-vue';
|
|
|
|
import vueJsx from '@vitejs/plugin-vue-jsx';
|
|
|
|
import svgLoader from 'vite-svg-loader';
|
|
|
|
import configArcoStyleImportPlugin from './plugin/arcoStyleImport';
|
|
|
|
|
2024-02-04 07:13:25 +00:00
|
|
|
import AutoImport from 'unplugin-auto-import/vite';
|
|
|
|
import Components from 'unplugin-vue-components/vite';
|
|
|
|
import { TDesignResolver } from 'unplugin-vue-components/resolvers';
|
2024-02-04 09:11:30 +00:00
|
|
|
import { ArcoResolver } from 'unplugin-vue-components/resolvers';
|
2024-02-04 07:13:25 +00:00
|
|
|
|
2024-07-02 02:55:12 +00:00
|
|
|
import htmlPlugin from "vite-plugin-html-config";
|
|
|
|
|
2024-01-24 13:40:15 +00:00
|
|
|
export default defineConfig({
|
2024-02-04 20:04:55 +00:00
|
|
|
base: './',
|
2024-01-24 13:40:15 +00:00
|
|
|
plugins: [
|
|
|
|
vue(),
|
|
|
|
vueJsx(),
|
|
|
|
svgLoader({ svgoConfig: {} }),
|
|
|
|
configArcoStyleImportPlugin(),
|
2024-02-04 07:13:25 +00:00
|
|
|
AutoImport({
|
|
|
|
resolvers: [TDesignResolver({
|
|
|
|
library: 'vue-next'
|
|
|
|
})],
|
|
|
|
}),
|
|
|
|
Components({
|
|
|
|
resolvers: [TDesignResolver({
|
|
|
|
library: 'vue-next'
|
2024-02-04 09:11:30 +00:00
|
|
|
}), ArcoResolver()],
|
2024-02-04 07:13:25 +00:00
|
|
|
}),
|
2024-07-02 02:55:12 +00:00
|
|
|
htmlPlugin({
|
|
|
|
metas: [
|
|
|
|
{
|
|
|
|
name: "builtTime",
|
|
|
|
content: Math.ceil(parseInt(new Date().toISOString().replace(/[.:TZ-]/g, '')) / 1000).toString()
|
|
|
|
},
|
|
|
|
]
|
|
|
|
})
|
2024-01-24 13:40:15 +00:00
|
|
|
],
|
|
|
|
resolve: {
|
|
|
|
alias: [
|
|
|
|
{
|
|
|
|
find: '@',
|
|
|
|
replacement: resolve(__dirname, '../src'),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
find: 'assets',
|
|
|
|
replacement: resolve(__dirname, '../src/assets'),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
find: 'vue-i18n',
|
|
|
|
replacement: 'vue-i18n/dist/vue-i18n.cjs.js', // Resolve the i18n warning issue
|
|
|
|
},
|
|
|
|
{
|
|
|
|
find: 'vue',
|
|
|
|
replacement: 'vue/dist/vue.esm-bundler.js', // compile template
|
|
|
|
},
|
|
|
|
],
|
2024-02-04 07:13:25 +00:00
|
|
|
extensions: ['.ts', '.js', '.css'],
|
2024-01-24 13:40:15 +00:00
|
|
|
},
|
|
|
|
define: {
|
|
|
|
'process.env': {},
|
|
|
|
},
|
|
|
|
css: {
|
|
|
|
preprocessorOptions: {
|
|
|
|
less: {
|
|
|
|
modifyVars: {
|
|
|
|
hack: `true; @import (reference) "${resolve(
|
|
|
|
'src/assets/style/breakpoint.less'
|
|
|
|
)}";`,
|
|
|
|
},
|
|
|
|
javascriptEnabled: true,
|
|
|
|
},
|
|
|
|
},
|
2024-08-04 05:39:01 +00:00
|
|
|
postcss: {
|
|
|
|
plugins: [
|
|
|
|
require('postcss-px-to-viewport')({
|
|
|
|
viewportWidth: 2560, // 视口宽度,对应设计稿宽度
|
2024-08-04 06:22:35 +00:00
|
|
|
viewporHeight: 1440, // 视口高度,对应设计稿高度
|
2024-08-04 05:39:01 +00:00
|
|
|
unitPrecision: 3, // 指定px转换之后的小数位数
|
|
|
|
viewportUnit: 'vw', // 转换的单位
|
|
|
|
fontViewportUnit: 'vw', // 字体使用的单位
|
|
|
|
replace: false, // 是否直接更换属性值,而不添加备用属性
|
2024-08-04 06:22:35 +00:00
|
|
|
selectorBlackList: ['.ignore', '.hairlines', '.arco', '.layout', '.nav-btn'], // 指定不转换的类
|
2024-08-04 05:39:01 +00:00
|
|
|
exclude: /(\/|\\)(node_modules)(\/|\\)/, //禁止更改第三方UI框架样式
|
|
|
|
minPixelValue: 15, // 小于或等于1px不转换
|
|
|
|
mediaQuery: true, // 允许在媒体查询中转换
|
|
|
|
})
|
|
|
|
]
|
|
|
|
}
|
2024-01-24 13:40:15 +00:00
|
|
|
},
|
|
|
|
});
|