webpack.dev.js 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /**
  2. * @author: Yuki Takei <yuki@weseek.co.jp>
  3. */
  4. const path = require('path');
  5. const webpack = require('webpack');
  6. const helpers = require('./helpers');
  7. const webpackMerge = require('webpack-merge');
  8. const webpackMergeDll = webpackMerge.strategy({plugins: 'replace'});
  9. const commonConfig = require('./webpack.common.js');
  10. /*
  11. * Webpack Plugins
  12. */
  13. const DllBundlesPlugin = require('webpack-dll-bundles-plugin').DllBundlesPlugin;
  14. const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
  15. /*
  16. * Webpack Constants
  17. */
  18. const ANALYZE = process.env.ANALYZE;
  19. const ENV = process.env.ENV = process.env.NODE_ENV = 'development';
  20. /*
  21. * Webpack configuration
  22. *
  23. * See: http://webpack.github.io/docs/configuration.html#cli
  24. */
  25. module.exports = function(options) {
  26. return webpackMerge(commonConfig({ env: ENV }), {
  27. devtool: 'cheap-module-eval-source-map',
  28. entry: {
  29. dev: './resource/js/dev',
  30. },
  31. output: {
  32. path: helpers.root('public/js'),
  33. publicPath: '/js/',
  34. filename: '[name].bundle.js',
  35. },
  36. resolve: {
  37. extensions: ['.js', '.json'],
  38. modules: [helpers.root('src'), helpers.root('node_modules'), path.join(process.env.HOME, '.node_modules')],
  39. },
  40. module: {
  41. rules: [
  42. {
  43. test: /\.css$/,
  44. use: [
  45. 'style-loader',
  46. { loader: 'css-loader', options: { sourceMap: true } },
  47. ],
  48. include: [helpers.root('resource/styles/scss')]
  49. },
  50. {
  51. test: /\.scss$/,
  52. use: [
  53. 'style-loader',
  54. { loader: 'css-loader', options: { sourceMap: true } },
  55. { loader: 'sass-loader', options: { sourceMap: true } },
  56. ],
  57. include: [helpers.root('resource/styles/scss')]
  58. },
  59. ],
  60. },
  61. plugins: [
  62. new DllBundlesPlugin({
  63. bundles: {
  64. vendor: [
  65. 'react',
  66. 'react-dom'
  67. ],
  68. },
  69. dllDir: helpers.root('public/dll'),
  70. webpackConfig: webpackMergeDll(commonConfig({env: ENV}), {
  71. devtool: undefined,
  72. plugins: [],
  73. })
  74. }),
  75. new webpack.NoEmitOnErrorsPlugin(),
  76. new BundleAnalyzerPlugin({
  77. analyzerMode: ANALYZE ? 'server' : 'disabled',
  78. }),
  79. ]
  80. });
  81. }