forked from prebid/Shared-id-v2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
130 lines (119 loc) · 3.98 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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
'use strict';
const Webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const HtmlWebpackExcludeAssetsPlugin = require('html-webpack-exclude-assets-plugin');
const {CleanWebpackPlugin} = require('clean-webpack-plugin');
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
const pkg = require('./package.json');
const spdx_banner = `pubcid.js ${pkg.version} - https://github.com/prebid/Shared-id-v2/\nSPDX-License-Identifier: Apache-2.0`
module.exports = (env = {}, args = {}) => {
const mode = args.mode;
const mapType = (mode === 'production') ? 'hidden-source-map' : 'inline-source-map';
console.log('Mode: ' + mode);
console.log('Map: ' + mapType);
// Return 2 configs in an array. First one is a minimized script that is placed in CDN,
// and the second one as a library used by other projects.
const scriptConfig = {
mode: mode,
entry: {
'pubcid.min': './src/pubcid.js'
},
output: {
filename: '[name].js',
path: __dirname + '/dist'
}
,
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
// Transform to commonjs modules so sinon spies can work in unit tests
presets: [['@babel/preset-env', {modules: 'cjs'}]],
plugins: [
['@babel/plugin-transform-runtime', { corejs: 3 }],
],
},
}
}
]
},
plugins: [
new CleanWebpackPlugin(
// Only clean up files related to scripts before build
{cleanOnceBeforeBuildPatterns: ['pubcid.*', 'stats.json']}
),
new Webpack.BannerPlugin({
banner: spdx_banner,
})
]
,
devServer: {
host: 'mockpub'
},
devtool: mapType
};
const libConfig = {
mode: mode,
entry: {
'index':'./src/index.js'
},
output: {
filename: 'index.js',
path: __dirname + '/dist',
libraryTarget: 'umd'
},
module: {
rules: [
{
test: /\.(js)$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: [['@babel/preset-env', {}]],
plugins: [['@babel/plugin-transform-runtime', {
corejs: 3
}]]
},
}
},
],
},
plugins: [
new CleanWebpackPlugin(
// Only clean up files related to library before build
{cleanOnceBeforeBuildPatterns: ['index.*']}
),
new Webpack.BannerPlugin({
banner: spdx_banner,
})
],
devtool: mapType
};
// Generate the test page if in dev mode
if (mode !== 'production') {
scriptConfig.plugins = scriptConfig.plugins || [];
scriptConfig.plugins.push(
new HtmlWebpackPlugin({
filename: 'pubcid.html',
template: 'src/pubcid.html',
excludeAssets: [/index.js/]
}),
new HtmlWebpackExcludeAssetsPlugin()
);
}
else {
scriptConfig.plugins.push(
new BundleAnalyzerPlugin({
analyzerMode: 'disabled',
generateStatsFile: true,
statsOptions: { source: false }
})
)
}
return [scriptConfig, libConfig];
};