-
Notifications
You must be signed in to change notification settings - Fork 37
/
webpack.config.js
88 lines (76 loc) · 2.04 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
const path = require('path');
const webpack = require('webpack');
const BrowserSyncPlugin = require('browser-sync-webpack-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const isProduction = process.env.NODE_ENV == 'production' ? true : false;
const webpack_config = {
plugins: [],
module: {
rules: []
},
optimization: {}
};
webpack_config.mode = process.env.NODE_ENV;
webpack_config.entry = {
'scroll-lock': './src/scroll-lock.js'
};
if (isProduction) {
webpack_config.entry['scroll-lock.min'] = './src/scroll-lock.js';
}
webpack_config.output = {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
library: 'scrollLock',
libraryTarget: 'umd',
libraryExport: 'default',
globalObject: 'this'
};
webpack_config.plugins.push(
new webpack.DefinePlugin({
'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV)
})
);
webpack_config.module.rules.push({
test: /\.js$/,
exclude: [/node_modules/],
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env']
}
});
if (isProduction) {
webpack_config.optimization.minimizer = [
new UglifyJsPlugin({
include: /\.min\.js$/,
cache: true,
parallel: true,
uglifyOptions: {
compress: true,
warnings: false,
output: {
comments: false,
beautify: false
}
}
})
];
} else {
webpack_config.plugins.push(
new BrowserSyncPlugin({
host: 'localhost',
port: 1337,
files: ['./dist/**/*', './demos/**/*'],
server: {
baseDir: ['./'],
index: '/demos/index.html'
}
})
);
webpack_config.watch = true;
webpack_config.watchOptions = {
aggregateTimeout: 100,
ignored: /node_modules/
};
webpack_config.devtool = 'cheap-inline-module-source-map';
}
module.exports = webpack_config;