webpack.dev.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /**
  2. * @author: Yuki Takei <yuki@weseek.co.jp>
  3. */
  4. /*
  5. * Webpack Plugins
  6. */
  7. const MiniCssExtractPlugin = require('mini-css-extract-plugin');
  8. const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
  9. const helpers = require('../src/lib/util/helpers');
  10. /**
  11. * Webpack Constants
  12. */
  13. const { ANALYZE } = process.env;
  14. module.exports = require('./webpack.common')({
  15. mode: 'development',
  16. devtool: 'cheap-module-eval-source-map',
  17. entry: {
  18. 'js/dev': './src/client/js/dev',
  19. },
  20. resolve: {
  21. modules: ['../node_modules'],
  22. },
  23. module: {
  24. rules: [
  25. {
  26. test: /\.(css|scss)$/,
  27. use: [
  28. 'style-loader',
  29. { loader: 'css-loader', options: { sourceMap: true } },
  30. { loader: 'sass-loader', options: { sourceMap: true } },
  31. ],
  32. exclude: [
  33. helpers.root('src/client/styles/hackmd'),
  34. helpers.root('src/client/styles/scss/style-presentation.scss'),
  35. ],
  36. },
  37. { // Dump CSS for HackMD
  38. test: /\.(css|scss)$/,
  39. use: [
  40. MiniCssExtractPlugin.loader,
  41. 'css-loader',
  42. 'sass-loader',
  43. ],
  44. include: [
  45. helpers.root('src/client/styles/hackmd'),
  46. helpers.root('src/client/styles/scss/style-presentation.scss'),
  47. ],
  48. },
  49. ],
  50. },
  51. plugins: [
  52. new MiniCssExtractPlugin({
  53. filename: '[name].bundle.css',
  54. }),
  55. new BundleAnalyzerPlugin({
  56. analyzerMode: ANALYZE ? 'server' : 'disabled',
  57. }),
  58. ],
  59. optimization: {},
  60. performance: {
  61. hints: false,
  62. },
  63. });