-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
127 lines (123 loc) · 3.38 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
/// <binding ProjectOpened='Watch - Development' />
const path = require("path");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const OptimizeCSSAssetsPlugin = require("optimize-css-assets-webpack-plugin");
const UglifyJsPlugin = require("uglifyjs-webpack-plugin");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const autoprefixer = require("autoprefixer");
module.exports = (env, options) => {
//let production = options.mode === 'undefined' ? process.env.NODE_ENV === 'production' : options.mode === 'production';
let production = process.env.NODE_ENV === "production";
const clientBundleConfig = {
devtool: production ? "" : "source-map",
entry: {
utopia: "./utopia/src/index.tsx"
},
output: {
filename: "[name]/bundle.js",
path: path.resolve(__dirname, "dist/"),
publicPath: "dist/",
globalObject: 'this'
},
// optimization: {
// splitChunks: {
// cacheGroups: {
// utopiaCss: {
// test: (m, c, entry = "utopia") =>
// m.constructor.name === "CssModule" &&
// recursiveIssuer(m) === entry,
// name: "main",
// chunks: "all",
// enforce: true
// }
// }
// },
// minimizer: production
// ? [
// new UglifyJsPlugin({
// cache: true,
// parallel: true,
// sourceMap: false,
// uglifyOptions: {
// compress: {
// drop_console: true
// }
// }
// }),
// new OptimizeCSSAssetsPlugin({})
// ]
// : []
// },
module: {
rules: [
{
test: /\.(ts|tsx)$/,
exclude: /node_modules/,
loader: "ts-loader"
},
{ enforce: "pre", test: /\.js$/, loader: "source-map-loader" },
{
test: /\.scss|css$/,
exclude: /node_modules/,
use: [
// 'css-hot-loader',
// MiniCssExtractPlugin.loader,
'style-loader',
{
loader: "css-loader",
options: {
sourceMap: true,
url: false
}
},
{
loader: "postcss-loader",
options: {
plugins: [
autoprefixer({
browsers: ["ie >= 8", "last 4 version"]
})
],
sourceMap: true
}
},
{
loader: "sass-loader"
}
]
}
]
},
devServer: {
contentBase: "./",
publicPath: '/',
hot: true,
},
resolve: {
extensions: [".tsx", ".ts", ".js", ".jsx"]
},
plugins: [
// new MiniCssExtractPlugin({
// filename: "/[name]/style.css"
// }),
new HtmlWebpackPlugin({
filename: "utopia/index.html",
baseUrl: process.env.NODE_ENV == 'development'?'/':'./',
template: './utopia/template.html',
chunks: ['utopia'],
inject: false
})
],
mode: production ? "production" : "development",
};
return [clientBundleConfig];
};
function recursiveIssuer(m) {
if (m.issuer) {
return recursiveIssuer(m.issuer);
} else if (m.name) {
return m.name;
} else {
return false;
}
}