/** * * @author Ray * * @date 2023-04-06 * * @workspace ray-template * * @remark 今天也是元气满满撸代码的一天 */ /** * * 系统配置文件入口 * * 配置范围: * - 构建: 开发构建、打包构建、预览构建、体积分析构建等 * - 系统: 根路由、标题、浏览器标题、别名等 * - 请求: 代理配置 * * 如果需要新增相关内容, 需要在 src/types/cfg.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, buildOptions, mixinCSSPlugin, } from './vite-plugin/index' import { APP_PRIMARY_COLOR } from './src/appConfig/designConfig' import { PRE_LOADING_CONFIG, ROOT_ROUTE, SIDE_BAR_LOGO, } from './src/appConfig/appConfig' import type { AppConfigExport } from './src/types/cfg' const config: AppConfigExport = { /** 公共基础路径配置, 如果为空则会默认以 '/' 填充 */ base: '/ray-template/', /** 配置首屏加载信息 */ preloadingConfig: PRE_LOADING_CONFIG, /** 默认主题色(不可省略, 必填), 也用于 ejs 注入 */ appPrimaryColor: APP_PRIMARY_COLOR, sideBarLogo: SIDE_BAR_LOGO, /** * * 预处理全局需要注入的 css 文件 * * 预设: * - ./src/styles/mixins.scss * - ./src/styles/setting.scss * - ./src/styles/theme.scss * * 如果需要删除或者修改, 需要同步修改目录下的 css 文件 */ mixinCSS: mixinCSSPlugin([ './src/styles/mixins.scss', './src/styles/setting.scss', './src/styles/theme.scss', ]), /** * * 版权信息 * * 也可以当作页底设置, 看实际业务需求 */ copyright: 'Copyright © 2022-present Ray', /** * * 浏览器标题 */ title: HTMLTitlePlugin('Ray Template'), /** * * 配置 HMR 特定选项(端口、主机、路径和协议) */ server: { host: '0.0.0.0', port: 9527, open: false, https: false, strictPort: false, fs: { strict: false, allow: [], }, proxy: { '/api': { target: 'url', changeOrigin: true, rewrite: (path) => path.replace(/^\/api/, ''), }, '/office': { target: 'https://office.yka.one/', changeOrigin: true, rewrite: (path) => path.replace(/^\/office/, ''), }, }, }, /** * * 打包相关配置 */ buildOptions: buildOptions, /** * * 预设别名 * - `@`: `src` 根目录 * - `@use-utils`: `src/utils` 根目录 * - `@use-api`: `src/axios/api` 根目录 * - `@use-images`: `src/assets/images` 根目录 */ alias: [ { find: '@', replacement: path.resolve(__dirname, './src'), }, { find: '@use-utils', replacement: path.resolve(__dirname, './src/utils'), }, { find: '@use-api', replacement: path.resolve(__dirname, './src/axios/api'), }, { find: '@use-images', replacement: path.resolve(__dirname, './src/assets/images'), }, ], } export default config