This repository has been archived by the owner on Dec 4, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
webpack.config.js
118 lines (112 loc) · 2.68 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
const CleanWebpackPlugin = require('clean-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const DotenvPlugin = require('webpack-dotenv-plugin');
const OfflinePlugin = require('offline-plugin');
const webpack = require('webpack');
const isProd = process.env.NODE_ENV === 'PROD';
const extractSass = new ExtractTextPlugin({
filename: '[name].[contenthash].css',
disable: !isProd
});
const prodPlugins = [
new OfflinePlugin({
publicPath: 'https://rideaway.netlify.com',
caches: {
main: ['main.*.css', 'app.*.js'],
additional: [':externals:'],
optional: [':rest:']
},
events: true,
externals: ['./'],
ServiceWorker: {
navigateFallbackURL: './'
},
AppCache: {
FALLBACK: {
'/': '/offline-page.html'
}
}
})
];
const devPlugins = [];
// determine wether to use dev plugins or prod plugins
const plugins = isProd ? prodPlugins : devPlugins;
module.exports = {
entry: './src/app.js',
output: {
path: __dirname + '/build',
filename: 'app.bundle.[hash].js'
},
module: {
noParse: /(mapbox-gl)\.js$/,
rules: [
{
test: /\.scss$/,
use: extractSass.extract({
use: [
{
loader: 'css-loader'
},
{
loader: 'sass-loader'
}
],
fallback: 'style-loader'
})
},
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: ['es2015']
}
}
},
{
test: /\.(jpg|png|svg|woff)$/,
loader: 'file-loader',
options: {
name: 'static/[name].[hash].[ext]'
}
}
]
},
devServer: {
contentBase: __dirname + '/build',
compress: true,
disableHostCheck: true,
host: '0.0.0.0',
hot: true,
port: 3000,
stats: 'errors-only'
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
new CopyWebpackPlugin([
{ from: 'public/manifest.json' },
{ from: 'public/locales', to: 'locales' },
{ from: 'public/favicons' },
{ from: 'public/landing' },
{ from: 'public/logo' }
]),
new HtmlWebpackPlugin({
minify: {
collapseWhitespace: true
},
hash: true,
template: 'public/index.html'
}),
extractSass,
new DotenvPlugin({
sample: './.env.default',
path: './.env'
}),
new webpack.EnvironmentPlugin(['NODE_ENV']),
...plugins,
new CleanWebpackPlugin(['build'])
]
};