This repository has been archived by the owner on Nov 12, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
110 lines (107 loc) · 2.9 KB
/
webpack.config.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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
const path = require('path');
const webpack = require('webpack');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const cssImport = require('postcss-import');
const cssNext = require('postcss-cssnext');
const ENV = process.env.NODE_ENV || 'development';
const isProd = ENV === 'production';
const isDev = ENV === 'development';
const cssLocalName = isDev ? '[path][name]__[local]' : '[hash:base64:5]';
module.exports = {
entry: path.resolve(path.join(__dirname, 'src', 'client.jsx')),
output: {
path: path.resolve(path.join(__dirname, 'src', 'static', 'js')),
publicPath: path.resolve(path.join(__dirname, 'src', 'static')),
filename: '[name].js'
},
resolve: {
extensions: [
'.js',
'.jsx',
'.json',
'.css',
'.jpg'
]
},
module: {
loaders: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
use: [{loader: 'babel-loader'}]
},
{
test: /\.css$/,
use: ExtractTextPlugin.extract([
{
loader: 'css-loader',
// this must be `query`. if it is `option` the imported classNames are all `undefined`.
query: {
modules: true,
sourceMap: isDev,
minimize: isProd,
localIdentName: cssLocalName
},
},
{
loader: 'postcss-loader',
options: {
plugins: function () {
return [
cssImport(),
// use css4
cssNext({
browsers: ['last 2 versions', '> 5%']
})
]
}
}
}
])
}
]
},
devtool: "source-map",
plugins: [
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
minChunks: function (module) {
// this assumes your vendor imports exist in the node_modules directory
return module.context && module.context.indexOf('node_modules') !== -1;
}
}),
// new webpack.optimize.UglifyJsPlugin({
// sourceMap: true,
// compress: {
// warnings: true,
// drop_console: true,
// },
// //include: /\.min\.js$/,
// minimize: false
// }),
new ExtractTextPlugin({
filename: '../style/[name].css',
disable: false,
allChunks: true
}),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify(ENV)
}
}),
new webpack.BannerPlugin({
banner: [
"/**",
" * West Track Story App v1.0.0",
" *",
" * Copyright 2017, Netapsys Atlantique",
" * Tous droits réservés.",
" *",
" */"
].join("\n"),
raw: true, // if true, banner will not be wrapped in a comment
entryOnly: true, // if true, the banner will only be added to the entry chunks
}
)
]
};