config.ts 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. // https://umijs.org/config/
  2. const prodGzipList = ['js', 'css', 'html']
  3. import { defineConfig } from '@umijs/max'
  4. import defaultSettings from './defaultSettings'
  5. import proxy from './proxy'
  6. import routes from './routes'
  7. const { REACT_APP_ENV } = process.env
  8. export default defineConfig({
  9. plugins: [require.resolve('@umijs/plugins/dist/unocss')],
  10. npmClient: 'pnpm',
  11. hash: true,
  12. antd: { import: true },
  13. model: {},
  14. moment2dayjs: {},
  15. request: {},
  16. initialState: {},
  17. access: {},
  18. dva: {},
  19. mfsu: {},
  20. srcTranspiler: 'esbuild',
  21. fastRefresh: true,
  22. unocss: {
  23. watch: ['src/pages/**/*.{jsx,tsx,less}', 'src/components/**/*.{jsx,tsx,less}'] // 添加其他包含 unocss 的 classname 的文件目录
  24. },
  25. // Fast Refresh 热更新
  26. theme: { 'primary-color': '#886ab5' },
  27. layout: {},
  28. locale: {
  29. default: 'zh-CN',
  30. antd: false,
  31. baseNavigator: false
  32. },
  33. define: { REACT_APP_ENV: REACT_APP_ENV || false },
  34. targets: { ie: 11 },
  35. routes,
  36. title: false,
  37. proxy: proxy[REACT_APP_ENV || 'dev'],
  38. manifest: { basePath: '/' },
  39. extraBabelPlugins: [
  40. ['import', { libraryName: 'antd', libraryDirectory: 'es', style: true }, 'antd'],
  41. [
  42. 'import',
  43. {
  44. libraryName: '@icon-park/react',
  45. libraryDirectory: 'es/icons',
  46. camel2DashComponentName: false
  47. },
  48. '@icon-park/react'
  49. ]
  50. ],
  51. externals: {
  52. react: 'React',
  53. 'react-dom': 'ReactDOM'
  54. },
  55. chainWebpack(config, { env }) {
  56. if (env === 'production') {
  57. // config.merge({
  58. // optimization: {
  59. // minimize: true,
  60. // splitChunks: {
  61. // chunks: 'all',
  62. // minSize: 30000,
  63. // minChunks: 2,
  64. // automaticNameDelimiter: '.',
  65. // cacheGroups: {
  66. // vendor: {
  67. // name: 'vendors',
  68. // test: ({ resource }) => /[\\/]node_modules[\\/]/.test(resource),
  69. // chunks: 'all',
  70. // priority: 20
  71. // }
  72. // }
  73. // }
  74. // }
  75. // })
  76. config.plugin('compression-webpack-plugin').use(
  77. new CompressionPlugin({
  78. // filename: 文件名称,这里我们不设置,让它保持和未压缩的文件同一个名称
  79. algorithm: 'gzip', // 指定生成gzip格式
  80. test: new RegExp('\\.(' + prodGzipList.join('|') + ')$'), // 匹配哪些格式文件需要压缩
  81. threshold: 10000, //对超过10k的数据进行压缩
  82. minRatio: 0.6 // 压缩比例,值为0 ~ 1
  83. })
  84. )
  85. }
  86. }
  87. })