webpack.dev.conf.js 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. var utils = require('./utils')
  2. var webpack = require('webpack')
  3. var config = require('../config')
  4. var merge = require('webpack-merge')
  5. var baseWebpackConfig = require('./webpack.base.conf')
  6. var HtmlWebpackPlugin = require('html-webpack-plugin')
  7. var FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
  8. // add hot-reload related code to entry chunks
  9. Object.keys(baseWebpackConfig.entry).forEach(function (name) {
  10. baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name])
  11. })
  12. module.exports = merge(baseWebpackConfig, {
  13. module: {
  14. rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap })
  15. },
  16. // cheap-module-eval-source-map is faster for development
  17. devtool: '#cheap-module-eval-source-map',
  18. plugins: [
  19. new webpack.ProvidePlugin({
  20. $: 'jquery',
  21. jquery: 'jquery',
  22. 'window.jQuery': 'jquery',
  23. jQuery: 'jquery'
  24. }),
  25. new webpack.DefinePlugin({
  26. 'process.env': config.dev.env
  27. }),
  28. // https://github.com/glenjamin/webpack-hot-middleware#installation--usage
  29. new webpack.HotModuleReplacementPlugin(),
  30. new webpack.NoEmitOnErrorsPlugin(),
  31. // https://github.com/ampedandwired/html-webpack-plugin
  32. new HtmlWebpackPlugin({
  33. filename: 'index.html',
  34. template: 'index.html',
  35. inject: true
  36. }),
  37. new FriendlyErrorsPlugin()
  38. ]
  39. })