47 lines
1.2 KiB
JavaScript
47 lines
1.2 KiB
JavaScript
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__',
|
||
}),
|
||
]
|