-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
109 lines (95 loc) · 2.5 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
'use strict';
const NODE_ENV = process.env.NODE_ENV || 'development';
const webpack = require('webpack');
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const AssetsPlugin = require('assets-webpack-plugin');
const rimraf = require('rimraf');
module.exports = {
context: __dirname + '/src',
entry: {
"app": "./app/index",
"vendor": [ "./vendor/index" ],
},
output: {
path: __dirname + '/assets',
publicPath: "/assets/",
filename: "[name].js",
chunkFilename: "[id].js",
library: "[name]"
},
watch: NODE_ENV == 'development',
watchOptions: {
aggregateTimeout: 100
},
devtool: NODE_ENV == 'development' ? "cheap-inline-module-source-map" : null,
plugins: [
{
apply: (compiler) => {
rimraf.sync(compiler.options.output.path);
}
},
new ExtractTextPlugin('[name].css', {allChunks: true}),
new webpack.optimize.CommonsChunkPlugin({
name: 'common'
}),
new webpack.NoErrorsPlugin(),
new webpack.DefinePlugin({
NODE_ENV: JSON.stringify(NODE_ENV),
LANG: JSON.stringify('ru')
}),
new webpack.ProvidePlugin({
_: 'lodash'
}),
new AssetsPlugin({
filename: 'assets.json',
path: __dirname + '/assets'
})
],
//
resolve: {
// modulesDirectories: ['node_modules'],
extensions: ['', '.js', '.scss']
},
//
// resolveLoader: {
// modulesDirectories: ['node_modules'],
// moduleTemplates: ['*-loader', '*'],
// extensions: ['', '.js']
// },
module: {
loaders: [
{
test: /\.js$/,
exclude: /(node_modules)/,
loader: 'babel'
},
{
"test": /\.css?$/,
"loader": "style!css?modules&localIdentName=[name]---[local]---[hash:base64:5]"
},
// {
// "test": /\.scss?$/,
// loaders: ['style', 'css', 'sass']
// },
{
test: /\.scss/,
loader: ExtractTextPlugin.extract('css!sass?resolve url')
}, {
test: /\.(png|jpg|svg|ttf|eot|woff|woff2)$/,
loader: 'file?name=[path][name].[ext]',
}
]
}
};
if (NODE_ENV == 'production') {
module.exports.plugins.push(
new webpack.optimize.UglifyJsPlugin({
compress: {
// don't show unreachable variables etc
warnings: false,
drop_console: true,
unsafe: true
}
})
);
}