-
Notifications
You must be signed in to change notification settings - Fork 51
/
Copy pathwebpack.common.js
69 lines (67 loc) · 1.85 KB
/
webpack.common.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
const helpers = require('./helpers');
const {CheckerPlugin} = require('awesome-typescript-loader');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require("extract-text-webpack-plugin");
const ContextReplacementPlugin = require('webpack/lib/ContextReplacementPlugin');
const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin');
module.exports = {
entry: {
'polyfills': './src/polyfills.ts',
'vendor': './src/vendor.ts',
'main': './src/main.ts'
},
resolve: {
extensions: ['.ts', '.js'],
alias: {
lodash: 'lodash-es',
aphrodite: 'aphrodite/no-important',
},
},
module: {
rules: [
{
test: /\.ts$/,
loaders: [
'@angularclass/hmr-loader',
'awesome-typescript-loader',
'angular2-template-loader',
'angular2-router-loader?loader=system',
],
exclude: [/\.spec\.ts$/]
},
// global css
{
test: /\.css$/,
exclude: [helpers.root('src')],
loader: ExtractTextPlugin.extract({
fallbackLoader: "style-loader",
loader: "css-loader",
}),
},
{test: /\.html$/, loader: 'raw-loader'},
]
},
plugins: [
new HtmlWebpackPlugin({
template: 'src/index.html',
chunksSortMode: 'dependency',
}),
new CheckerPlugin(),
new ContextReplacementPlugin(
// The (\\|\/) piece accounts for path separators in *nix and Windows
/angular(\\|\/)core(\\|\/)(esm(\\|\/)src|src)(\\|\/)linker/,
helpers.root('src') // location of your src
),
new CommonsChunkPlugin({
name: ['polyfills', 'vendor'].reverse()
}),
new ExtractTextPlugin('[name].[chunkhash].css'),
],
node: {
global: true,
crypto: 'empty',
module: false,
clearImmediate: false,
setImmediate: false,
}
};