-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
83 lines (80 loc) · 1.97 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
const HtmlWebpackPlugin = require('html-webpack-plugin')
const CaseSensitivePathsPlugin = require('case-sensitive-paths-webpack-plugin')
const path = require('path')
const webpack = require('webpack')
const isProduction = process.env.NODE_ENV === 'production'
module.exports = {
devtool: 'eval-source-map',
mode: isProduction ? 'production' : 'development',
performance: {
hints: isProduction ? 'warning' : false,
},
output: {
publicPath: '',
path: path.resolve(__dirname, 'docs'),
filename: '[hash].js',
},
resolve: {
symlinks: false,
modules: [
path.resolve(__dirname, 'src'),
path.resolve(__dirname, 'node_modules'),
],
alias: {
'~style': path.resolve(__dirname, 'src', 'style'),
'~utils': path.resolve(__dirname, 'utils'),
}
},
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: /(node_modules)/,
use: 'babel-loader',
},
{
test: /\.(jpe?g|png|svg)$/i,
loader: 'file-loader?hash=sha512&digest=hex&name=img/[hash].[ext]',
},
{
test: /\.(css)$/,
use: [
'style-loader',
{
loader: 'css-loader',
options: {
sourceMap: true,
modules: true,
localIdentName: '[name]__[local]___[hash:base64:5]'
},
},
],
},
{
test: /\.(ttf|otf|eot|woff(2)?)(\?[a-z0-9]+)?$/,
loader: 'file-loader?name=fonts/[name].[ext]',
},
{
test: /\.txt$/,
use: 'raw-loader',
},
],
},
devServer: {
disableHostCheck: true,
historyApiFallback: true,
hot: true,
port: 8080,
contentBase: [path.join(__dirname, 'src')],
},
plugins: [
new CaseSensitivePathsPlugin(),
new HtmlWebpackPlugin({
title: 'place.eth',
template: path.join(__dirname, 'src', 'html', 'index.html')
}),
new webpack.EnvironmentPlugin({
NODE_ENV: 'development',
})
],
}