config.ts 3.41 KB
Newer Older
1
// https://umijs.org/config/
2
import os from 'os';
3
import slash from 'slash2';
ไฝ•ไน's avatar
ไฝ•ไน committed
4
import { IPlugin, IConfig } from 'umi-types';
5 6
import defaultSettings from './defaultSettings';
import webpackPlugin from './plugin.config';
7

Yu's avatar
Yu committed
8
const { pwa, primaryColor } = defaultSettings;
9
const { APP_TYPE, TEST } = process.env;
Yu's avatar
Yu committed
10

11
const plugins: IPlugin[] = [
12 13 14 15 16 17 18 19 20 21 22
  [
    'umi-plugin-react',
    {
      antd: true,
      dva: {
        hmr: true,
      },
      locale: {
        enable: true, // default false
        default: 'zh-CN', // default zh-CN
        baseNavigator: true, // default true, when it is true, will use `navigator.language` overwrite default
xiaoiver's avatar
xiaoiver committed
23
      },
24 25 26
      dynamicImport: {
        loadingComponent: './components/PageLoading/index',
        webpackChunkName: true,
Yu's avatar
Yu committed
27
        level: 3,
28
      },
29 30 31 32 33 34 35
      pwa: pwa
        ? {
            workboxPluginMode: 'InjectManifest',
            workboxOptions: {
              importWorkboxFrom: 'local',
            },
          }
yaphet's avatar
yaphet committed
36
        : false,
37
      ...(!TEST && os.platform() === 'darwin'
38 39 40
        ? {
            dll: {
              include: ['dva', 'dva/router', 'dva/saga', 'dva/fetch'],
41
              exclude: ['@babel/runtime', 'netlify-lambda'],
42
            },
43
            hardSource: false,
44 45
          }
        : {}),
46 47 48 49 50 51 52 53 54 55
    },
  ],
  [
    'umi-plugin-pro-block',
    {
      moveMock: false,
      moveService: false,
      modifyRequest: true,
      autoAddMenu: true,
    },
ๆ„š้“'s avatar
ๆ„š้“ committed
56
  ],
57 58 59 60
];

// ้’ˆๅฏน preview.pro.ant.design ็š„ GA ็ปŸ่ฎกไปฃ็ 
// ไธšๅŠกไธŠไธ้œ€่ฆ่ฟ™ไธช
Yu's avatar
Yu committed
61
if (APP_TYPE === 'site') {
62 63 64 65 66 67 68 69 70 71 72 73
  plugins.push([
    'umi-plugin-ga',
    {
      code: 'UA-72788897-6',
    },
  ]);
}

export default {
  // add for transfer to umi
  plugins,
  define: {
Yu's avatar
Yu committed
74
    APP_TYPE: APP_TYPE || '',
75 76
  },
  treeShaking: true,
77 78 79
  targets: {
    ie: 11,
  },
80
  // ่ทฏ็”ฑ้…็ฝฎ
81
  routes: [
82
    {
83
      path: '/user',
84 85
      components: ['../layouts/UserLayout'],
      routes: [],
86
    },
87 88 89
    {
      path: '/',
      component: '../layouts/BasicLayout',
90 91
      Routes: ['src/pages/Authorized'],
      authority: ['admin', 'user'],
92 93 94
      routes: [
        // dashboard
        {
95
          path: '/',
ๆ„š้“'s avatar
ๆ„š้“ committed
96 97 98 99
          name: 'welcome',
          icon: 'smile',
          component: './Welcome',
        },
100 101 102
      ],
    },
  ],
afc163's avatar
afc163 committed
103 104
  // Theme for antd
  // https://ant.design/docs/react/customize-theme-cn
ๆ„š้“'s avatar
ๆ„š้“ committed
105
  theme: {
Yu's avatar
Yu committed
106
    'primary-color': primaryColor,
ๆ„š้“'s avatar
ๆ„š้“ committed
107
  },
108 109 110 111 112 113 114
  // proxy: {
  //   '/server/api/': {
  //     target: 'https://preview.pro.ant.design/',
  //     changeOrigin: true,
  //     pathRewrite: { '^/server': '' },
  //   },
  // },
115 116 117 118
  ignoreMomentLocale: true,
  lessLoaderOptions: {
    javascriptEnabled: true,
  },
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
  disableRedirectHoist: true,
  cssLoaderOptions: {
    modules: true,
    getLocalIdent: (context, localIdentName, localName) => {
      if (
        context.resourcePath.includes('node_modules') ||
        context.resourcePath.includes('ant.design.pro.less') ||
        context.resourcePath.includes('global.less')
      ) {
        return localName;
      }
      const match = context.resourcePath.match(/src(.*)/);
      if (match && match[1]) {
        const antdProPath = match[1].replace('.less', '');
        const arr = slash(antdProPath)
          .split('/')
          .map(a => a.replace(/([A-Z])/g, '-$1'))
          .map(a => a.toLowerCase());
        return `antd-pro${arr.join('-')}-${localName}`.replace(/--/g, '-');
      }
      return localName;
    },
  },
  manifest: {
    basePath: '/',
  },
  chainWebpack: webpackPlugin,
ไฝ•ไน's avatar
ไฝ•ไน committed
146
} as IConfig;