ray-template/vite.custom.config.ts
2024-05-17 15:26:25 +08:00

152 lines
3.6 KiB
TypeScript

/**
*
* @author Ray <https://github.com/XiaoDaiGua-Ray>
*
* @date 2023-04-06
*
* @workspace ray-template
*
* @remark 今天也是元气满满撸代码的一天
*/
/**
*
* 系统配置文件入口
*
* 配置范围:
* - 构建: 开发构建、打包构建、预览构建、体积分析构建等
* - 系统: 根路由、标题、浏览器标题、别名等
* - 请求: 代理配置
*
* 如果需要新增相关内容, 需要在 src/types/modules/viteCustomConfig.ts 中进行类型配置
* ```
* interface Config // config 内容类型配置
*
* interface AppConfig // __APP_CFG__ 内容配置
* ```
*
* __APP_CFG__ 说明
* ```
* 该属性是用于全局注入的配置方法
*
* const { appPrimaryColor } = __APP_CFG__
*
* 以上例子展示, 从 __APP_CFG__ 中解构取出 appPrimaryColor 根路由配置信息
* __APP_CFG__ 会被挂载于全局变量 `window` 下(vite define 默认是挂载于 window 下)
* ```
*/
import path from 'node:path'
import { htmlTitlePlugin, mixinCss } from './vite-helper'
import { APP_THEME } from './src/app-config/design-config'
import { PRE_LOADING_CONFIG, SIDE_BAR_LOGO } from './src/app-config/app-config'
import type { AppConfigExport } from '@/types'
import type { BuildOptions } from 'vite'
const config: AppConfigExport = {
/** 公共基础路径配置, 如果为空则会默认以 '/' 填充 */
base: '/ray-template/',
/** 配置首屏加载信息 */
preloadingConfig: PRE_LOADING_CONFIG,
/** 默认主题色(不可省略, 必填), 也用于 ejs 注入 */
appPrimaryColor: APP_THEME.appPrimaryColor,
sideBarLogo: SIDE_BAR_LOGO,
/**
*
* 预处理全局需要注入的 css 文件
*
* 预设:
* - ./src/styles/mixins.scss
* - ./src/styles/setting.scss
*
* 如果需要删除或者修改, 需要同步修改目录下的 css 文件
*/
mixinCSS: mixinCss(['./src/styles/mixins.scss', './src/styles/setting.scss']),
/**
*
* 版权信息
*
* 也可以当作页底设置, 看实际业务需求
*/
copyright: 'Copyright © 2022-present Ray',
/**
*
* 浏览器标题
*/
title: htmlTitlePlugin(PRE_LOADING_CONFIG.title || 'Ray Template'),
/**
*
* 配置 HMR 特定选项(端口、主机、路径和协议)
*/
server: {
host: '0.0.0.0',
port: 9527,
open: false,
strictPort: false,
fs: {
strict: false,
allow: [],
},
proxy: {
'^/api': {
target: 'http://localhost',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, ''),
},
},
},
/**
*
* 打包相关配置
*/
buildOptions: (mode: string): BuildOptions => {
const productionBuildOptions = {
sourcemap: false,
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
},
},
}
const defaultOptions = {
sourcemap: true,
terserOptions: {
compress: {
drop_console: false,
drop_debugger: false,
},
},
}
const outDir = `dist/${mode}`
return mode === 'production'
? {
...productionBuildOptions,
outDir,
}
: {
...defaultOptions,
outDir,
}
},
/**
*
* 预设别名
* - @: src 根目录
* - @api: src/axios/api 根目录
* - @images: src/assets/images 根目录
* - @mock: mock 根目录
*/
alias: {
'@': path.resolve(__dirname, './src'),
'@api': path.resolve(__dirname, './src/axios/api'),
'@images': path.resolve(__dirname, './src/assets/images'),
'@mock': path.resolve(__dirname, './mock'),
},
}
export default config