forked from PolymerX/polymer-skeleton
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
128 lines (123 loc) · 3.28 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
const {resolve, join} = require('path');
const webpack = require('webpack');
const WorkboxPlugin = require('workbox-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const pkg = require('./package.json');
/**
* === ENV configuration
*/
const isDev = process.argv.find(arg => arg.includes('webpack-dev-server'));
const ENV = isDev ? 'development' : 'production';
const BROWSERS = process.env.BROWSERS === 'module' ?
['last 2 Chrome versions', 'Safari 10'] : ['> 1%', 'last 2 versions', 'Firefox ESR', 'not ie <= 11'];
const IS_MODULE_BUILD = BROWSERS[0].includes('Chrome');
const outputPath = isDev ? resolve('src') : resolve('dist');
const processEnv = {
NODE_ENV: JSON.stringify(ENV),
appVersion: JSON.stringify(pkg.version)
};
/**
* === Copy static files configuration
*/
const copyStatics = {
copyWebcomponents: [{
from: resolve('./node_modules/@webcomponents/webcomponentsjs/webcomponents-loader.js'),
to: join(outputPath, 'vendor'),
flatten: true
}, {
from: resolve('./node_modules/@webcomponents/webcomponentsjs/webcomponents-lite.js'),
to: join(outputPath, 'vendor'),
flatten: true
}, {
from: resolve('./node_modules/@webcomponents/webcomponentsjs/webcomponents-sd-ce.js'),
to: join(outputPath, 'vendor'),
flatten: true
}, {
from: resolve('./node_modules/@webcomponents/webcomponentsjs/custom-elements-es5-adapter.js'),
to: join(outputPath, 'vendor'),
flatten: true
}],
copyOthers: [{
from: 'assets/**',
context: resolve('./src'),
to: outputPath
}, {
from: resolve('./src/index.html'),
to: outputPath,
flatten: true
}, {
from: resolve('./src/manifest.json'),
to: outputPath,
flatten: true
}]
};
/**
* Plugin configuration
*/
const plugins = isDev ? [
new CopyWebpackPlugin(copyStatics.copyWebcomponents),
new webpack.DefinePlugin({'process.env': processEnv})
] : [
new WorkboxPlugin({
globDirectory: outputPath,
globPatterns: ['**/*.{html,js,css}'],
swDest: join(outputPath, 'sw.js')
}),
new CopyWebpackPlugin(
[].concat(copyStatics.copyWebcomponents, copyStatics.copyOthers)
),
new CleanWebpackPlugin([outputPath], {verbose: true}),
new webpack.DefinePlugin({'process.env': processEnv})
];
/**
* === Webpack configuration
*/
module.exports = {
entry: './src/index.js',
output: {
path: outputPath,
filename: IS_MODULE_BUILD ? 'module.bundle.js' : 'bundle.js'
},
devtool: 'cheap-module-source-map',
module: {
rules: [
{
test: /\.js$/,
// We need to transpile Polymer itself and other ES6 code
// exclude: /(node_modules)/,
use: {
loader: 'babel-loader',
options: {
presets: [[
'env',
{
targets: {browsers: BROWSERS},
debug: true
}
]]
}
}
},
{
test: /\.html$/,
use: ['text-loader']
},
{
test: /\.postcss$/,
use: ['text-loader', 'postcss-loader']
}
]
},
plugins,
devServer: {
contentBase: resolve(outputPath),
compress: true,
overlay: {
errors: true
},
port: 3000,
host: '0.0.0.0',
disableHostCheck: true
}
};