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.
167 lines
5.6 KiB
167 lines
5.6 KiB
import { defineConfig, loadEnv,normalizePath} from 'vite' |
|
import vue from '@vitejs/plugin-vue' |
|
import { resolve } from 'path' |
|
import { OUTPUT_DIR, brotliSize, chunkSizeWarningLimit, terserOptions, rollupOptions } from './build/constant' |
|
import viteCompression from 'vite-plugin-compression' |
|
import {axiosPre, cesiumApi} from './src/settings/httpSetting' |
|
import { viteMockServe } from 'vite-plugin-mock' |
|
import monacoEditorPlugin from 'vite-plugin-monaco-editor' |
|
import { viteExternalsPlugin } from 'vite-plugin-externals' |
|
import { viteStaticCopy } from 'vite-plugin-static-copy' |
|
import path from 'path' |
|
import cesium from 'vite-plugin-cesium' |
|
function pathResolve(dir: string) { |
|
return resolve(process.cwd(), '.', dir) |
|
} |
|
|
|
export default ({ mode }) => defineConfig({ |
|
base: process.env.NODE_ENV === 'production' ? './' : '/', |
|
// 路径重定向 |
|
resolve: { |
|
alias: [ |
|
{ |
|
find: /\/#\//, |
|
replacement: pathResolve('types') |
|
}, |
|
{ |
|
find: '@', |
|
replacement: pathResolve('src') |
|
}, |
|
{ |
|
find: 'vue-i18n', |
|
replacement: 'vue-i18n/dist/vue-i18n.cjs.js', //解决i8n警告 |
|
} |
|
], |
|
dedupe: ['vue'] |
|
}, |
|
// 全局 css 注册 |
|
css: { |
|
preprocessorOptions: { |
|
scss: { |
|
javascriptEnabled: true, |
|
additionalData: `@import "src/styles/common/style.scss";` |
|
} |
|
} |
|
}, |
|
// 开发服务器配置 |
|
server: { |
|
host: true, |
|
open: true, |
|
port: Number(loadEnv(mode, process.cwd()).VITE_DEV_PORT), |
|
proxy: { |
|
[axiosPre]: { |
|
// @ts-ignore |
|
target: loadEnv(mode, process.cwd()).VITE_DEV_PATH, |
|
changeOrigin: true, |
|
ws: true, |
|
secure: true, |
|
}, |
|
[cesiumApi]: { |
|
target: 'http://192.168.2.249:9033', |
|
changeOrigin: true, |
|
ws: true, |
|
secure: true |
|
} |
|
} |
|
}, |
|
plugins: [ |
|
vue({ |
|
template: { |
|
compilerOptions: { |
|
// 排除 iconify 图标影子组件编译报错 |
|
isCustomElement: tag => tag.startsWith('iconify-icon') |
|
} |
|
} |
|
}), |
|
cesium(), |
|
viteExternalsPlugin({ |
|
'cesium': 'Cesium', |
|
|
|
'xbsj-renderer/dist-node/xr-base-utils': 'xbsj["xr-base-utils"]', |
|
'xbsj-renderer/dist-node/xr-math': 'xbsj["xr-math"]', |
|
'xbsj-renderer/dist-node/xr-utils': 'xbsj["xr-utils"]', |
|
'xbsj-renderer/dist-node/xr-cesium': 'xbsj["xr-cesium"]', |
|
|
|
'xbsj-xe2/dist-node/xe2': 'XE2["xe2"]', |
|
'xbsj-xe2/dist-node/xe2-base': 'XE2["xe2-base"]', |
|
'xbsj-xe2/dist-node/xe2-base-utils': 'XE2["xe2-base-utils"]', |
|
'xbsj-xe2/dist-node/xe2-utils': 'XE2["xe2-utils"]', |
|
'xbsj-xe2/dist-node/xe2-cesium': 'XE2["xe2-cesium"]', |
|
'xbsj-xe2/dist-node/xe2-mapbox': 'XE2["xe2-mapbox"]', |
|
'xbsj-xe2/dist-node/xe2-ue': 'XE2["xe2-ue"]', |
|
'xbsj-xe2/dist-node/utility-xe2-plugin': 'XE2["utility-xe2-plugin"]', |
|
'xbsj-xe2/dist-node/xe2-all-in-one': 'XE2["xe2-all-in-one"]', |
|
'xbsj-xe2/dist-node/xe2-base-objects': 'XE2["xe2-base-objects"]', |
|
'xbsj-xe2/dist-node/xe2-objects': 'XE2["xe2-objects"]', |
|
'xbsj-xe2/dist-node/xe2-cesium-objects': 'XE2["xe2-cesium-objects"]', |
|
'xbsj-xe2/dist-node/xe2-ue-objects': 'XE2["xe2-ue-objects"]', |
|
'xbsj-xe2/dist-node/xe2-openlayers': 'XE2["xe2-openlayers"]', |
|
'xbsj-xe2/dist-node/xe2-openlayers-objects': 'XE2["xe2-openlayers-objects"]', |
|
|
|
'smplotting-xe2-plugin/dist-node/smplotting-xe2-plugin': 'XE2["smplotting-xe2-plugin"]', |
|
'smplotting-xe2-plugin/dist-node/smplotting-xe2-plugin-main': 'XE2["smplotting-xe2-plugin-main"]', |
|
'esobjs-xe2-plugin/dist-node/esobjs-xe2-plugin': 'XE2["esobjs-xe2-plugin"]', |
|
'esobjs-xe2-plugin/dist-node/esobjs-xe2-plugin-main': 'XE2["esobjs-xe2-plugin-main"]', |
|
}, { useWindow: false }), |
|
// 运行和构建时copy |
|
viteStaticCopy({ |
|
targets: [ |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/xbsj-xe2/dist-web')),//wu |
|
dest: './js/xbsj-xe2' |
|
}, |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/xbsj-xe2-assets/dist-web')),//w |
|
dest: './js/xbsj-xe2-assets' |
|
}, |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/smplotting-xe2-plugin/dist-web')),//wu |
|
dest: './js/smplotting-xe2-plugin' |
|
}, |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/esobjs-xe2-plugin/dist-web')), |
|
dest: './js/esobjs-xe2-plugin' |
|
}, |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/esobjs-xe2-plugin-assets/dist-web')),//wu |
|
dest: './js/esobjs-xe2-plugin-assets' |
|
}, |
|
{ |
|
src: normalizePath(path.resolve(__dirname, './node_modules/vue-xe2-plugin/dist-web')), |
|
dest: './js/vue-xe2-plugin' |
|
} |
|
] |
|
}), |
|
(monacoEditorPlugin as any).default({ |
|
languageWorkers: ['editorWorkerService', 'typescript', 'json', 'html'] |
|
}), |
|
viteMockServe({ |
|
mockPath: '/src/api/mock', |
|
// 开发打包开关 |
|
localEnabled: true, |
|
// 生产打包开关 |
|
prodEnabled: true, |
|
// 打开后,可以读取 ts 文件模块。 请注意,打开后将无法监视.js 文件 |
|
supportTs: true, |
|
// 监视文件更改 |
|
watchFiles: true |
|
}), |
|
// 压缩 |
|
viteCompression({ |
|
verbose: true, |
|
disable: false, |
|
threshold: 10240, |
|
algorithm: 'gzip', |
|
ext: '.gz' |
|
}) |
|
], |
|
build: { |
|
target: 'es2020', |
|
outDir: OUTPUT_DIR, |
|
// minify: 'terser', // 如果需要用terser混淆,可打开这两行 |
|
// terserOptions: terserOptions, |
|
rollupOptions: rollupOptions, |
|
reportCompressedSize: brotliSize, |
|
chunkSizeWarningLimit: chunkSizeWarningLimit |
|
} |
|
})
|
|
|