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.
46 lines
1.2 KiB
46 lines
1.2 KiB
import { resolve } from 'path'
|
|
import AutoImport from 'unplugin-auto-import/vite'
|
|
import Components from 'unplugin-vue-components/vite'
|
|
import { NaiveUiResolver } from 'unplugin-vue-components/resolvers'
|
|
import { FileSystemIconLoader } from 'unplugin-icons/loaders'
|
|
import IconsResolver from 'unplugin-icons/resolver'
|
|
|
|
/**
|
|
* * unplugin-icons插件,自动引入iconify图标
|
|
* usage: https://github.com/antfu/unplugin-icons
|
|
* 图标库: https://icones.js.org/
|
|
*/
|
|
import Icons from 'unplugin-icons/vite'
|
|
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
|
|
|
|
import { getSrcPath } from '../utils'
|
|
|
|
const customIconPath = resolve(getSrcPath(), 'assets/svg')
|
|
|
|
export default [
|
|
AutoImport({
|
|
imports: ['vue', 'vue-router'],
|
|
dts: false,
|
|
}),
|
|
Icons({
|
|
compiler: 'vue3',
|
|
customCollections: {
|
|
custom: FileSystemIconLoader(customIconPath),
|
|
},
|
|
scale: 1,
|
|
defaultClass: 'inline-block',
|
|
}),
|
|
Components({
|
|
resolvers: [
|
|
NaiveUiResolver(),
|
|
IconsResolver({ customCollections: ['custom'], componentPrefix: 'icon' }),
|
|
],
|
|
dts: false,
|
|
}),
|
|
createSvgIconsPlugin({
|
|
iconDirs: [customIconPath],
|
|
symbolId: 'icon-custom-[dir]-[name]',
|
|
inject: 'body-last',
|
|
customDomId: '__CUSTOM_SVG_ICON__',
|
|
}),
|
|
]
|
|
|