-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.server.prod.js
95 lines (91 loc) · 2.87 KB
/
webpack.config.server.prod.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
/**
* Created by peter on 2/5/17.
*/
var webpack = require('webpack');
var path = require('path');
var fs = require('fs');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var nodeModules = {};
fs.readdirSync('node_modules')
.filter(function(x){
return ['.bin'].indexOf(x) === -1;
}).forEach(function(mod){
nodeModules[mod] = 'commonjs ' + mod;
});
function replacePath(newResource){
let request = newResource.request;
console.log('Replacing '+request);
newResource.request = request.replace(/async_version$/,'sync_version');
console.log("With "+newResource.request);
return newResource;
}
module.exports = {
entry: {
backend: [
// TODO remove this and replace with bluebird
'babel-polyfill',
'./server'],
test_db: ['babel-polyfill','./server/api/db/test_set/setup.js']
},
target: 'node',
// Backend should be in the protected dist (distribution) folder
output: {
path: path.join(__dirname,'dist/'),
publicPath: '/public/',
filename: '[name].js'
},
externals: nodeModules,
plugins: [
// Set environment variable
new webpack.DefinePlugin({
// This form removes all process.env variables, except NODE_ENV, which
// we do not want!
//'process.env': {
// 'NODE_ENV': JSON.stringify('production')
//}
// This only replaces NODE_ENV, which can then optimize code based on
// if statements that is either always true or false
'process.env.NODE_ENV' : JSON.stringify('production')
}),
new webpack.LoaderOptionsPlugin({
minimize: true,
debug: false
}),
// Plugin to NOT split if we by error encounter an import() or require.ensure
new webpack.optimize.LimitChunkCountPlugin({
maxChunks: 1
}),
// Makes sure we use synchronous components on server side
new webpack.NormalModuleReplacementPlugin(
/\/async_version/,
replacePath
//'/sync_component'
),
// Optimization, uglify added by -p option of webpack
//new webpack.optimize.UglifyJsPlugin(),
// Client bundler takes care of css
//new ExtractTextPlugin({
// filename: "/public/styles.css",
// disable: false,
// allChunks: true
//})
],
module: {
rules: [
{
test: /\.js$/,
use: [
'babel-loader'
],
exclude: /node_modules/
},
{
test: /\.(graphql|gql)$/,
exclude: /node_modules/,
loader: 'graphql-tag/loader',
},
{ test: /\.css$/, loader: 'ignore-loader' }
]
},
devtool: 'sourcemap'
}