No Description

webpack.config.js 1.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. const fs = require('fs');
  2. const path = require('path');
  3. module.exports = ({ config }) => {
  4. config.resolve.modules = ['node_modules'];
  5. config.module.rules.push({
  6. test: /\.stories\.tsx?$/,
  7. loaders: [require.resolve('@storybook/source-loader')],
  8. enforce: 'pre',
  9. });
  10. config.module.rules.push({
  11. test: /\.less$/,
  12. include: /node_modules|antd\.less/,
  13. use: [
  14. "style-loader",
  15. "css-loader",
  16. {
  17. loader: "less-loader",
  18. options: {
  19. javascriptEnabled: true
  20. }
  21. }
  22. ]
  23. });
  24. config.module.rules.push({
  25. test: /\.less$/,
  26. use: [
  27. 'style-loader',
  28. {
  29. loader: 'css-loader',// translates CSS into CommonJS
  30. options: {
  31. modules: {
  32. localIdentName: '[name]__[local]___[hash:base64:5]',
  33. },
  34. }
  35. },
  36. 'postcss-loader',
  37. {
  38. loader: 'less-loader',
  39. options: {
  40. config: {
  41. path: path.join(path.resolve(__dirname, '..'), 'postcss.config.js')
  42. },
  43. javascriptEnabled: true,
  44. },
  45. }],
  46. exclude: /node_modules|antd\.less/,
  47. });
  48. config.module.rules.push({
  49. test: /\.(ts|tsx)$/,
  50. use: [
  51. {
  52. loader: require.resolve('babel-loader'),
  53. options: {
  54. presets: [['react-app', { flow: false, typescript: true }]],
  55. }
  56. },
  57. // Optional
  58. {
  59. loader: require.resolve("react-docgen-typescript-loader")
  60. },
  61. ]
  62. });
  63. config.resolve.extensions.push(".ts", ".tsx");
  64. config.resolve.alias = {
  65. ...config.resolve.alias,
  66. '@': `${path.resolve(fs.realpathSync(process.cwd()), './src')}`,
  67. '@components': `${path.resolve(fs.realpathSync(process.cwd()), './src')}/components`,
  68. }
  69. config.output.library = "[name]";
  70. return config;
  71. };