.webpackrc.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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. disableDynamicImport: true,
  29. cssLoaderOptions: {
  30. modules: true,
  31. getLocalIdent: (context, localIdentName, localName) => {
  32. if (
  33. context.resourcePath.includes('node_modules') ||
  34. context.resourcePath.includes('ant.design.pro.less')
  35. ) {
  36. return localName;
  37. }
  38. const antdProPath = context.resourcePath.match(/src(.*)/)[1].replace('.less', '');
  39. const arr = antdProPath
  40. .split('/')
  41. .map(a => a.replace(/([A-Z])/g, '-$1'))
  42. .map(a => a.toLowerCase());
  43. return `antd-pro${arr.join('-')}-${localName}`.replace(/--/g, '-');
  44. },
  45. },
  46. };