-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathwebpack.config.js
112 lines (108 loc) · 3.57 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
var path = require("path");
// variables
var isProduction = process.argv.indexOf("-p") >= 0 || process.env.NODE_ENV === "production";
var sourcePath = path.join(__dirname, "./src");
var outPath = path.join(__dirname, "./dist");
// plugins
var HtmlWebpackPlugin = require("html-webpack-plugin");
var MiniCssExtractPlugin = require("mini-css-extract-plugin");
var { CleanWebpackPlugin } = require("clean-webpack-plugin");
var HardSourceWebpackPlugin = require("hard-source-webpack-plugin");
var DotenvWebpackPlugin = require("dotenv-webpack");
module.exports = (env) => {
return {
context: sourcePath,
devtool: "inline-source-map",
entry: {
app: "./main.tsx",
},
mode: "production",
output: {
path: outPath,
filename: "js/[name].[hash].bundle.js",
publicPath: "/",
},
target: "web",
resolve: {
extensions: [".js", ".ts", ".tsx"],
// Fix webpack"s default behavior to not load packages with jsnext:main module
// (jsnext:main directs not usually distributable es6 format, but es6 sources)
mainFields: ["module", "browser", "main"],
alias: {
app: path.resolve(__dirname, "src/app/"),
},
},
module: {
rules: [
// .ts, .tsx
{
test: /\.tsx?$/,
use: [
isProduction && {
loader: "babel-loader",
options: { plugins: ["react-hot-loader/babel"] },
},
"ts-loader",
].filter(Boolean),
},
// css
{
test: /\.(scss|sass)$/,
use: [
MiniCssExtractPlugin.loader,
{
loader: "css-loader",
},
{
loader: "sass-loader",
options: {
sourceMap: true,
},
},
],
},
// static assets
{ test: /\.html$/, use: "html-loader" },
{ test: /\.(png|svg)$/, use: "url-loader?limit=10000" },
{ test: /\.(jpg|gif)$/, use: "file-loader" },
],
},
optimization: {
splitChunks: {
cacheGroups: {
vendors: {
test: /[\\/]node_modules[\\/]/,
name: "vendors",
chunks: "all",
},
},
},
},
plugins: [
new DotenvWebpackPlugin({
defaults: !isProduction,
systemvars: isProduction
}),
new CleanWebpackPlugin({
verbose: true,
}),
new MiniCssExtractPlugin({
filename: "css/[name].[contenthash].css",
}),
new HtmlWebpackPlugin({
template: "assets/index.html",
favicon: "assets/favicon.ico",
}),
new HardSourceWebpackPlugin(),
],
devServer: {
contentBase: sourcePath,
hot: true,
inline: true,
historyApiFallback: {
disableDotRule: true,
},
stats: "minimal",
},
};
};