.webpackrc.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. const path = require('path');
  2. export default {
  3. entry: 'src/index.js',
  4. extraBabelPlugins: [['import', { libraryName: 'antd', libraryDirectory: 'es', style: true }]],
  5. env: {
  6. development: {
  7. extraBabelPlugins: ['dva-hmr'],
  8. },
  9. },
  10. externals: {
  11. '@antv/data-set': 'DataSet',
  12. bizcharts: 'BizCharts',
  13. rollbar: 'rollbar',
  14. },
  15. alias: {
  16. components: path.resolve(__dirname, 'src/components/'),
  17. },
  18. ignoreMomentLocale: true,
  19. theme: './src/theme.js',
  20. html: {
  21. template: './src/index.ejs',
  22. },
  23. publicPath: '/',
  24. hash: true,
  25. lessLoaderOptions: {
  26. javascriptEnabled: true,
  27. },
  28. cssLoaderOptions: {
  29. modules: true,
  30. getLocalIdent: (context, localIdentName, localName) => {
  31. if (
  32. context.resourcePath.includes('node_modules') ||
  33. context.resourcePath.includes('ant.design.pro.less')
  34. ) {
  35. return localName;
  36. }
  37. const antdProPath = context.resourcePath.match(/src(.*)/)[1].replace('.less', '');
  38. const arr = antdProPath
  39. .split('/')
  40. .map(a => a.replace(/([A-Z])/g, '-$1'))
  41. .map(a => a.toLowerCase());
  42. return `antd-pro${arr.join('-')}-${localName}`.replace(/--/g, '-');
  43. },
  44. },
  45. };