From 4db8fda68bff686a29c6b59db954be623e8552a6 Mon Sep 17 00:00:00 2001 From: Katja Durrani Date: Sun, 3 Sep 2017 23:04:47 +0100 Subject: [PATCH] make react hot reloading work again --- dev.js | 2 +- webpack.config.js | 40 ++++++++++++++++++++++++---------------- 2 files changed, 25 insertions(+), 17 deletions(-) diff --git a/dev.js b/dev.js index bb0d52c..f8e10d8 100644 --- a/dev.js +++ b/dev.js @@ -16,7 +16,7 @@ const port = 3000; const compiler = webpack(config) app.use(express.static(path.join(__dirname + '/public'))); -app.use(webpackDevMiddleware(compiler, { noInfo: true, publicPath: config.output.publicPath })) +app.use(webpackDevMiddleware(compiler, { noInfo: true, publicPath: config.output.path })) app.use(webpackHotMiddleware(compiler)); app.use(routes); diff --git a/webpack.config.js b/webpack.config.js index e37e111..5f74c95 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -14,23 +14,15 @@ var cssConfig = isProd ? cssProd : cssDev console.log(cssConfig, isProd); -module.exports = { - entry: [ - 'webpack-hot-middleware/client', - './src/index.js' - ], - output: { - path: path.join(__dirname,'public'), - filename: 'bundle.js' - }, +let pluginsCommon = [ + new webpack.HotModuleReplacementPlugin(), + new webpack.NoEmitOnErrorsPlugin(), + new webpack.ProvidePlugin({ + 'fetch': 'imports-loader?this=>global!exports-loader?global.fetch!whatwg-fetch' + }) +] - plugins: [ - new webpack.HotModuleReplacementPlugin(), - new webpack.NoEmitOnErrorsPlugin(), - new webpack.ProvidePlugin({ - 'fetch': 'imports-loader?this=>global!exports-loader?global.fetch!whatwg-fetch' - }), - new HtmlWebpackPlugin({ +let pluginsProd = [ new HtmlWebpackPlugin({ title: 'JavaScript tools and resources', minify: { collapseWhitespace: true @@ -43,7 +35,23 @@ module.exports = { disable: !isProd, allChunks: true }) +] + +const plugins = isProd ? pluginsCommon.concat(pluginsProd) : pluginsCommon + + +module.exports = { + entry: [ + 'webpack-hot-middleware/client', + './src/index.js' ], + output: { + path: path.join(__dirname,'public'), + publicPath: path.join(__dirname, 'public'), + filename: 'bundle.js' + }, + + plugins: plugins, module: { rules: [ {