2020-04-14 10:53:19 +03:00
|
|
|
const webpack = require("webpack");
|
|
|
|
const path = require("path");
|
|
|
|
const HtmlWebpackPlugin = require("html-webpack-plugin");
|
|
|
|
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
|
|
|
|
const webpackBundleAnalyzer = require("webpack-bundle-analyzer");
|
2020-05-27 01:31:31 +03:00
|
|
|
const CopyPlugin = require('copy-webpack-plugin');
|
2020-04-14 10:53:19 +03:00
|
|
|
|
|
|
|
process.env.NODE_ENV = "production";
|
2020-05-26 23:58:00 +03:00
|
|
|
process.env.PUBLIC_URL = "/reverse-proxy";
|
2020-04-14 10:53:19 +03:00
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
mode: "production",
|
|
|
|
target: "web",
|
|
|
|
devtool: "source-map",
|
|
|
|
entry: "./src/index",
|
|
|
|
output: {
|
|
|
|
path: path.resolve(__dirname, "build"),
|
2020-05-26 23:58:00 +03:00
|
|
|
publicPath: process.env.PUBLIC_URL,
|
2020-04-14 10:53:19 +03:00
|
|
|
filename: "bundle.js"
|
|
|
|
},
|
|
|
|
plugins: [
|
|
|
|
// Display bundle stats
|
|
|
|
new webpackBundleAnalyzer.BundleAnalyzerPlugin({ analyzerMode: "static" }),
|
|
|
|
|
|
|
|
new MiniCssExtractPlugin({
|
|
|
|
filename: "[name].[contenthash].css"
|
|
|
|
}),
|
|
|
|
|
|
|
|
new webpack.DefinePlugin({
|
|
|
|
// This global makes sure React is built in prod mode.
|
|
|
|
"process.env.NODE_ENV": JSON.stringify(process.env.NODE_ENV),
|
2020-05-26 23:58:00 +03:00
|
|
|
"process.env.PUBLIC_URL": JSON.stringify(process.env.PUBLIC_URL),
|
2020-05-13 14:17:30 +03:00
|
|
|
"process.env.REVERSE_PROXY_API_URL": JSON.stringify(
|
|
|
|
"https://toodle.ddns.net/reverse-proxy-api"
|
|
|
|
)
|
2020-04-14 10:53:19 +03:00
|
|
|
}),
|
|
|
|
new HtmlWebpackPlugin({
|
|
|
|
template: "src/index.html",
|
|
|
|
favicon: "src/favicon.ico",
|
|
|
|
minify: {
|
|
|
|
// see https://github.com/kangax/html-minifier#options-quick-reference
|
|
|
|
removeComments: true,
|
|
|
|
collapseWhitespace: true,
|
|
|
|
removeRedundantAttributes: true,
|
|
|
|
useShortDoctype: true,
|
|
|
|
removeEmptyAttributes: true,
|
|
|
|
removeStyleLinkTypeAttributes: true,
|
|
|
|
keepClosingSlash: true,
|
|
|
|
minifyJS: true,
|
|
|
|
minifyCSS: true,
|
|
|
|
minifyURLs: true
|
|
|
|
}
|
2020-05-27 01:31:31 +03:00
|
|
|
}),
|
|
|
|
new CopyPlugin({
|
|
|
|
patterns: [
|
|
|
|
{ from: 'public', to: 'public' }
|
|
|
|
],
|
2020-04-14 10:53:19 +03:00
|
|
|
})
|
|
|
|
],
|
|
|
|
module: {
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
test: /\.(js|jsx)$/,
|
|
|
|
exclude: /node_modules/,
|
|
|
|
use: ["babel-loader", "eslint-loader"]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /(\.css)$/,
|
|
|
|
use: [
|
|
|
|
MiniCssExtractPlugin.loader,
|
|
|
|
{
|
|
|
|
loader: "css-loader",
|
|
|
|
options: {
|
|
|
|
sourceMap: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
loader: "postcss-loader",
|
|
|
|
options: {
|
|
|
|
plugins: () => [require("cssnano")],
|
|
|
|
sourceMap: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}
|
|
|
|
};
|