webpack.dev.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /**
  2. * @author: Yuki Takei <yuki@weseek.co.jp>
  3. */
  4. const webpack = require('webpack');
  5. const helpers = require('./helpers');
  6. const webpackMerge = require('webpack-merge');
  7. const webpackMergeDll = webpackMerge.strategy({plugins: 'replace'});
  8. const commonConfig = require('./webpack.common.js');
  9. /*
  10. * Webpack Plugins
  11. */
  12. // problem with copy-webpack-plugin
  13. const AssetsPlugin = require('assets-webpack-plugin');
  14. const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin');
  15. const CopyWebpackPlugin = require('copy-webpack-plugin');
  16. const DllBundlesPlugin = require('webpack-dll-bundles-plugin').DllBundlesPlugin;
  17. const LiveReloadPlugin = require('webpack-livereload-plugin');
  18. /*
  19. * Webpack Constants
  20. */
  21. const ENV = process.env.ENV = process.env.NODE_ENV = 'development';
  22. const HOST = process.env.HOST || '0.0.0.0';
  23. const PORT = process.env.PORT || 3000;
  24. const WATCH = helpers.hasProcessFlag('watch');
  25. /*
  26. * Webpack configuration
  27. *
  28. * See: http://webpack.github.io/docs/configuration.html#cli
  29. */
  30. module.exports = function (options) {
  31. return webpackMerge(commonConfig({ env: ENV }), {
  32. devtool: 'cheap-module-source-map',
  33. entry: {
  34. // dev: WATCH ?
  35. // ['./resource/js/dev', 'reload/lib/reload-client']:
  36. // ['./resource/js/dev'],
  37. dev: './resource/js/dev',
  38. },
  39. output: {
  40. path: helpers.root('public/js'),
  41. publicPath: '/js/',
  42. filename: '[name].bundle.js',
  43. sourceMapFilename: '[file].map',
  44. },
  45. resolve: {
  46. extensions: ['.js', '.json'],
  47. modules: [helpers.root('src'), helpers.root('node_modules')],
  48. },
  49. module: {
  50. rules: [
  51. ],
  52. },
  53. plugins: [
  54. new DllBundlesPlugin({
  55. bundles: {
  56. vendor: [
  57. 'react',
  58. 'react-dom',
  59. 'jquery',
  60. 'jquery.cookie',
  61. ],
  62. },
  63. dllDir: helpers.root('public/js/dll'),
  64. webpackConfig: webpackMergeDll(commonConfig({env: ENV}), {
  65. devtool: 'cheap-module-source-map',
  66. plugins: [],
  67. })
  68. }),
  69. new LiveReloadPlugin(),
  70. new webpack.NoEmitOnErrorsPlugin(),
  71. ]
  72. });
  73. }