config.ts 3.4 KB
Newer Older
1 2 3
// https://umijs.org/config/
import os from 'os';
import slash from 'slash2';
4 5 6
import { IPlugin } from 'umi-types';
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
      },
      pwa: {
        workboxPluginMode: 'InjectManifest',
        workboxOptions: {
          importWorkboxFrom: 'local',
        },
ๆ„š้“'s avatar
ๆ„š้“ committed
34
      },
35 36 37 38 39 40 41 42 43 44
    },
  ],
  [
    'umi-plugin-pro-block',
    {
      moveMock: false,
      moveService: false,
      modifyRequest: true,
      autoAddMenu: true,
    },
ๆ„š้“'s avatar
ๆ„š้“ committed
45
  ],
46 47 48 49 50 51 52 53 54 55 56 57 58
  // ...(!process.env.TEST && os.platform() === 'darwin'
  //   ? {
  //       dll: {
  //         include: ['dva', 'dva/router', 'dva/saga', 'dva/fetch'],
  //         exclude: ['@babel/runtime'],
  //       },
  //       hardSource: true,
  //     }
  //   : {}),
];

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

export default {
  // add for transfer to umi
  plugins,
  define: {
Yu's avatar
Yu committed
72
    APP_TYPE: APP_TYPE || '',
73 74
  },
  treeShaking: true,
75 76 77
  targets: {
    ie: 11,
  },
78
  // ่ทฏ็”ฑ้…็ฝฎ
79
  routes: [
80
    {
81
      path: '/user',
82 83
      components: ['../layouts/UserLayout'],
      routes: [],
84
    },
85 86 87
    {
      path: '/',
      component: '../layouts/BasicLayout',
88 89
      Routes: ['src/pages/Authorized'],
      authority: ['admin', 'user'],
90 91 92
      routes: [
        // dashboard
        {
93
          path: '/',
ๆ„š้“'s avatar
ๆ„š้“ committed
94 95 96 97
          name: 'welcome',
          icon: 'smile',
          component: './Welcome',
        },
98 99 100
      ],
    },
  ],
afc163's avatar
afc163 committed
101 102
  // Theme for antd
  // https://ant.design/docs/react/customize-theme-cn
ๆ„š้“'s avatar
ๆ„š้“ committed
103
  theme: {
Yu's avatar
Yu committed
104
    'primary-color': primaryColor,
ๆ„š้“'s avatar
ๆ„š้“ committed
105
  },
106 107
  externals: {
    '@antv/data-set': 'DataSet',
Yu's avatar
Yu committed
108
    bizcharts: 'BizCharts',
109
  },
110 111 112 113 114 115 116
  // proxy: {
  //   '/server/api/': {
  //     target: 'https://preview.pro.ant.design/',
  //     changeOrigin: true,
  //     pathRewrite: { '^/server': '' },
  //   },
  // },
117 118 119 120
  ignoreMomentLocale: true,
  lessLoaderOptions: {
    javascriptEnabled: true,
  },
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 146 147 148
  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
149
};