-
Notifications
You must be signed in to change notification settings - Fork 1
/
webpack.config.js
89 lines (84 loc) · 2.84 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
const fs = require('fs');
const path = require('path');
const debugBuild = process.env.NODE_ENV === 'development';
/*
configuring babel:
- when babel runs alone (for `test-unit` for instance), we let him deal with
ES6 modules, because node doesn't support them yet (planned for v10 lts).
- however, webpack also has ES6 module support and these 2 don't play well
together. When running webpack (either `build` or `start` script), we prefer
to rely on webpack loaders (much more powerful and gives more possibilities),
so let's disable modules for babel here.
- we also dynamise the value of __DEBUG__ according to the env var
*/
// Note that we don't support .babelrc in parent folders
var babelrc = fs.readFileSync(path.resolve(__dirname, '.babelrc'));
var babelConf = JSON.parse(babelrc);
var newPresets = [];
for (var preset of babelConf.presets) {
if (!Array.isArray(preset)) {
preset = [preset];
}
preset.push({ modules: false });
newPresets.push(preset);
}
babelConf.presets = newPresets;
babelConf.babelrc = false; // disabel babelrc reading, as we've just done it
const replacementPluginConf = babelConf.plugins.find(plugin => Array.isArray(plugin) && plugin[0] === 'minify-replace');
replacementPluginConf[1].replacements.find(decl => decl.identifierName === '__DEBUG__').replacement.value = debugBuild;
const include = [
path.resolve(__dirname, 'src'),
path.resolve(__dirname, 'test'),
path.resolve(__dirname, 'utils'),
];
module.exports = (env) => {
const babelLoaderOptions = [];
if (!(env && env.noInline)) {
babelLoaderOptions.push('babel-inline-import-loader');
}
babelLoaderOptions.push({
loader: 'babel-loader',
options: babelConf,
});
return {
context: path.resolve(__dirname),
resolve: {
modules: [path.resolve(__dirname, 'src'), 'node_modules'],
},
entry: {
itowns: ['@babel/polyfill', 'url-polyfill', 'whatwg-fetch', './src/MainBundle.js'],
debug: ['./utils/debug/Main.js'],
},
devtool: 'source-map',
output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].js',
library: '[name]',
libraryTarget: 'umd',
umdNamedDefine: true,
},
optimization: {
runtimeChunk: {
name: 'itowns',
},
},
module: {
rules: [
{
test: /\.js$/,
enforce: 'pre',
include,
loader: 'eslint-loader',
},
{
test: /\.js$/,
include,
use: babelLoaderOptions,
},
],
},
devServer: {
publicPath: '/dist/',
},
};
};