cpnode-front/.fes.js
2022-01-04 10:21:56 +08:00

151 lines
3.3 KiB
JavaScript
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// .fes.js 只负责管理编译时配置只能使用plain Object
import ESLintPlugin from 'eslint-webpack-plugin'
import StylelintPlugin from 'stylelint-webpack-plugin'
import AutoImportPlugin from 'unplugin-auto-import/webpack'
import VueComponentsPlugin from 'unplugin-vue-components/webpack'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
import IconsPlugin from 'unplugin-icons/webpack'
import IconsResolver from 'unplugin-icons/resolver'
export default {
publicPath: './',
alias: {
'~': '/src',
},
access: {
roles: {
admin: ['*'],
manager: ['/'],
},
},
layout: {
title: '数联网控制系统',
footer: 'Created by MumbleFe',
multiTabs: false,
menus: [
{
name: 'index',
icon: 'home'
},
{
name:'networking',
icon:'apartment',
children:[
{
name:'unionManage'
},
{
name:'levelManage'
}
]
},
{
name:'repoManage',
icon:'database',
children:[
{
name:'repoList'
},
{
name:'repoDetail'
}
]
},
{
name:'objectSearch',
icon:'search'
},
{
name:'globalManage',
icon:'fullscreen',
children:[
{
name:'manageUnion'
},
{
name:'manageConfig'
},
{
name:'manageTemplate'
},
{
name:'manageData'
}
]
},
{
name:'doRight',
icon:'edit'
},
{
name:'set_up',
icon:'setting'
}
],
},
devServer: {
port: 8000,
},
enums: {
status: [
['0', '无效的'],
['1', '有效的'],
],
},
chainWebpack(config) {
config.plugin('eslint').use(ESLintPlugin, [
{
files: 'src/**/*.{js,ts,tsx,vue}',
fix: true,
},
])
config.plugin('stylelint').use(StylelintPlugin, [
{
extensions: ['css', 'scss', 'vue', 'tsx'],
fix: true,
},
])
config.plugin('auto-import').use(
AutoImportPlugin({
dts: './src/types/auto-imports.d.ts',
include: [
/src\/.+\.[tj]sx?$/, // .ts, .tsx, .js, .jsx
/src\/.+\.vue$/,
/src\/.+\.vue\?vue/, // .vue
/src\/.+\.md$/, // .md
],
// global imports to register
imports: [
// presets
'vue',
'vue-router',
],
resolvers: [ElementPlusResolver()],
}),
)
config.plugin('vue-components').use(
VueComponentsPlugin({
dts: './src/types/components.d.ts',
include: [
/src\/.+\.vue$/,
/src\/.+\.vue\?vue/, // .vue
],
resolvers: [ElementPlusResolver(), IconsResolver()],
}),
)
// Temporary workaround for Element Plus + unplugin-vue-components bug when importing `v-loading`
// See: https://github.com/element-plus/element-plus/issues/4855
config.externals({
'element-plus/es/components/loading-directive/style/css': 'undefined',
})
config.plugin('icons').use(
IconsPlugin({
compiler: 'vue3',
autoInstall: true, // expiremental
}),
)
},
}