2025-12-06 14:49:46 +08:00
|
|
|
|
import { defineConfig } from 'vite'
|
|
|
|
|
|
import vue from '@vitejs/plugin-vue'
|
|
|
|
|
|
import vueJsx from '@vitejs/plugin-vue-jsx'
|
2025-12-13 14:13:31 +08:00
|
|
|
|
import { federation } from '@module-federation/vite'
|
2025-12-06 14:49:46 +08:00
|
|
|
|
import { resolve, dirname } from 'path'
|
|
|
|
|
|
import { fileURLToPath } from 'url'
|
2025-12-27 17:34:19 +08:00
|
|
|
|
import fs from 'fs'
|
2025-12-06 14:49:46 +08:00
|
|
|
|
|
|
|
|
|
|
const __filename = fileURLToPath(import.meta.url)
|
|
|
|
|
|
const __dirname = dirname(__filename)
|
|
|
|
|
|
|
2026-01-02 14:56:14 +08:00
|
|
|
|
// 开发环境 shared 模块地址
|
2026-01-02 18:22:09 +08:00
|
|
|
|
const DEV_SHARED_URL = 'https://localhost:7000/shared/remoteEntry.js'
|
2026-01-02 14:56:14 +08:00
|
|
|
|
// 生产环境使用相对路径,通过 Nginx 代理访问
|
2026-01-02 18:22:09 +08:00
|
|
|
|
const PROD_SHARED_URL = '/shared/remoteEntry.js'
|
2026-01-02 14:56:14 +08:00
|
|
|
|
|
2026-01-07 15:30:29 +08:00
|
|
|
|
export default defineConfig(({ mode, command }) => {
|
|
|
|
|
|
// dev 和 preview 都需要访问本地 shared 服务
|
|
|
|
|
|
// command: 'serve' (dev), 'build', 或通过环境变量判断 preview
|
2026-01-02 14:56:14 +08:00
|
|
|
|
const isDev = mode === 'development'
|
2026-01-07 15:30:29 +08:00
|
|
|
|
// preview 模式通过 nginx 代理访问 shared,使用相对路径
|
2026-01-02 14:56:14 +08:00
|
|
|
|
const sharedEntry = isDev ? DEV_SHARED_URL : PROD_SHARED_URL
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
base: '/workcase/',
|
|
|
|
|
|
|
|
|
|
|
|
plugins: [
|
|
|
|
|
|
vue({
|
|
|
|
|
|
script: {
|
|
|
|
|
|
defineModel: true,
|
|
|
|
|
|
propsDestructure: true
|
|
|
|
|
|
}
|
|
|
|
|
|
}),
|
|
|
|
|
|
vueJsx(),
|
|
|
|
|
|
federation({
|
|
|
|
|
|
name: 'workcase',
|
|
|
|
|
|
remotes: {
|
|
|
|
|
|
shared: {
|
|
|
|
|
|
type: 'module',
|
|
|
|
|
|
name: 'shared',
|
|
|
|
|
|
entry: sharedEntry
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2025-12-13 14:13:31 +08:00
|
|
|
|
shared: {
|
2026-01-02 14:56:14 +08:00
|
|
|
|
vue: {},
|
|
|
|
|
|
'vue-router': {},
|
|
|
|
|
|
'element-plus': {},
|
|
|
|
|
|
axios: {}
|
2025-12-13 14:13:31 +08:00
|
|
|
|
}
|
2026-01-02 14:56:14 +08:00
|
|
|
|
})
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
|
|
|
|
define: {
|
|
|
|
|
|
__VUE_OPTIONS_API__: true,
|
|
|
|
|
|
__VUE_PROD_DEVTOOLS__: true,
|
|
|
|
|
|
__VUE_PROD_HYDRATION_MISMATCH_DETAILS__: true,
|
|
|
|
|
|
global: 'globalThis'
|
2025-12-27 17:34:19 +08:00
|
|
|
|
},
|
2026-01-02 14:56:14 +08:00
|
|
|
|
|
|
|
|
|
|
resolve: {
|
|
|
|
|
|
alias: {
|
|
|
|
|
|
'@': resolve(__dirname, 'src')
|
|
|
|
|
|
}
|
2025-12-20 17:12:42 +08:00
|
|
|
|
},
|
2026-01-02 14:56:14 +08:00
|
|
|
|
|
|
|
|
|
|
server: {
|
|
|
|
|
|
port: 7003,
|
|
|
|
|
|
host: true,
|
|
|
|
|
|
cors: true,
|
|
|
|
|
|
open: '/workcase/',
|
|
|
|
|
|
https: (() => {
|
|
|
|
|
|
try {
|
|
|
|
|
|
return {
|
|
|
|
|
|
key: fs.readFileSync('C:/Users/FK05/443/localhost+3-key.pem'),
|
|
|
|
|
|
cert: fs.readFileSync('C:/Users/FK05/443/localhost+3.pem')
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch {
|
|
|
|
|
|
return undefined
|
|
|
|
|
|
}
|
|
|
|
|
|
})(),
|
|
|
|
|
|
hmr: {
|
|
|
|
|
|
path: '/@vite/client',
|
|
|
|
|
|
port: 7003
|
|
|
|
|
|
},
|
|
|
|
|
|
proxy: {
|
|
|
|
|
|
'/api': {
|
|
|
|
|
|
target: 'http://localhost:8180',
|
|
|
|
|
|
changeOrigin: true,
|
|
|
|
|
|
ws: true,
|
|
|
|
|
|
rewrite: (path: string) => path.replace(/^\/api/, '')
|
|
|
|
|
|
}
|
2025-12-06 14:49:46 +08:00
|
|
|
|
}
|
2026-01-02 14:56:14 +08:00
|
|
|
|
},
|
2026-01-07 15:30:29 +08:00
|
|
|
|
preview: {
|
|
|
|
|
|
port: 7003,
|
|
|
|
|
|
host: true,
|
|
|
|
|
|
cors: true,
|
|
|
|
|
|
https: (() => {
|
|
|
|
|
|
try {
|
|
|
|
|
|
return {
|
|
|
|
|
|
key: fs.readFileSync('C:/Users/FK05/443/localhost+3-key.pem'),
|
|
|
|
|
|
cert: fs.readFileSync('C:/Users/FK05/443/localhost+3.pem')
|
|
|
|
|
|
}
|
|
|
|
|
|
} catch {
|
|
|
|
|
|
return undefined
|
|
|
|
|
|
}
|
|
|
|
|
|
})(),
|
|
|
|
|
|
headers: {
|
|
|
|
|
|
'Access-Control-Allow-Origin': '*',
|
|
|
|
|
|
'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',
|
|
|
|
|
|
'Access-Control-Allow-Headers': 'Content-Type, Authorization'
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2026-01-02 14:56:14 +08:00
|
|
|
|
build: {
|
2026-01-02 15:50:20 +08:00
|
|
|
|
target: 'esnext',
|
2026-01-02 14:56:14 +08:00
|
|
|
|
outDir: 'dist',
|
2026-01-07 15:30:29 +08:00
|
|
|
|
sourcemap: true
|
|
|
|
|
|
// 注意:不要使用 manualChunks 分割 vue/vue-router/element-plus
|
|
|
|
|
|
// 因为它们已经在 Module Federation 的 shared 中声明
|
|
|
|
|
|
// 同时使用会导致循环依赖死锁
|
2025-12-06 14:49:46 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
2026-01-02 14:56:14 +08:00
|
|
|
|
})
|