123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- import { defineConfig, loadEnv } from 'vite'
- import path from 'path'
- import createVitePlugins from './vite/plugins'
- import tailwindcss from 'tailwindcss'
- import { sentryVitePlugin } from '@sentry/vite-plugin'
- // https://vitejs.dev/config/
- export default defineConfig(({ mode, command }) => {
- const env = loadEnv(mode, process.cwd())
- const { VITE_APP_ENV, VITE_SENTRY_AUTH_TOKEN } = env;
- return {
- // 部署生产环境和开发环境下的URL。
- // 默认情况下,vite 会假设你的应用是被部署在一个域名的根路径上
- // 例如 https://www.ruoyi.vip/。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 https://www.ruoyi.vip/admin/,则设置 baseUrl 为 /admin/。
- // base: VITE_APP_ENV === 'production' ? '/voiceMateWeb/' : '/',
- base: VITE_APP_ENV === 'production' ? '/' : '/',
- plugins: [
- createVitePlugins(env, command === 'build'),
- VITE_APP_ENV === 'production' ? sentryVitePlugin({
- url: 'https://sentry.fuxicarbon.com', // 你的 Sentry 服务器地址
- org: 'sentry', // 你的组织名称
- project: 'test-vue', // 你的 Sentry 项目名称
- release: 'sentry001', // 👈 修正格式,release 需要是 string
- authToken: VITE_SENTRY_AUTH_TOKEN,
- include: './dist', // 👈 确保匹配你的 `dist` 目录
- ignore: ['node_modules', 'dist/**/*.html'], // 忽略 node_modules 和 HTML
- }) : null,
- ],
- build: {
- sourcemap: true, // 开启 Source Map
- },
- resolve: {
- // https://cn.vitejs.dev/config/#resolve-alias
- alias: {
- // 设置路径
- '~': path.resolve(__dirname, './'),
- // 设置别名
- '@': path.resolve(__dirname, './src')
- },
- // https://cn.vitejs.dev/config/#resolve-extensions
- extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
- },
- // vite 相关配置
- server: {
- port: 80,
- host: true,
- open: true,
- proxy: {
- // https://cn.vitejs.dev/config/#server-proxy
- '/dev-api': {
- target: 'http://localhost:8080',
- changeOrigin: true,
- rewrite: (p) => p.replace(/^\/dev-api/, '')
- }
- }
- },
- //fix:error:stdin>:7356:1: warning: "@charset" must be the first rule in the file
- css: {
- postcss: {
- plugins: [
- tailwindcss,
- {
- postcssPlugin: 'internal:charset-removal',
- AtRule: {
- charset: (atRule) => {
- if (atRule.name === 'charset') {
- atRule.remove();
- }
- }
- }
- }
- ]
- }
- }
- }
- })
|