hugo-theme-terminal/webpack.config.js

106 lines
2.5 KiB
JavaScript
Raw Normal View History

2019-01-28 00:11:02 +00:00
const Webpack = require("webpack");
2020-09-05 22:31:08 +00:00
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
2019-01-28 00:11:02 +00:00
const HtmlWebpackPlugin = require("html-webpack-plugin");
2021-03-22 03:36:29 +00:00
const TerserPlugin = require("terser-webpack-plugin");
2019-01-28 00:11:02 +00:00
const path = require("path");
const join = (...paths) => path.join(__dirname, ...paths);
2020-09-05 22:31:08 +00:00
module.exports = (env, { mode }) => ({
2019-01-28 00:11:02 +00:00
resolve: {
extensions: [".js", ".css"],
2020-09-05 22:31:08 +00:00
modules: ["assets", "node_modules"],
2019-01-28 00:11:02 +00:00
},
entry: {
main: join("assets", "js", "menu.js"),
languageSelector: join("assets", "js", "languageSelector.js"),
2020-09-05 22:31:08 +00:00
prism: join("assets", "js", "prism.js"),
style: join("assets", "css", "style.css"),
red: join("assets", "css", "color", "red.css"),
blue: join("assets", "css", "color", "blue.css"),
green: join("assets", "css", "color", "green.css"),
pink: join("assets", "css", "color", "pink.css"),
2019-01-28 00:11:02 +00:00
},
output: {
2020-09-05 22:31:08 +00:00
filename: "[name].js",
2019-01-28 00:11:02 +00:00
path: join("static/assets"),
publicPath: "",
},
performance: {
hints: false,
},
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: "babel-loader",
options: {
presets: ["@babel/preset-env"],
},
},
},
{
test: /\.(png|jpg|woff|woff2|ttf|eot|svg)$/,
use: [
{
loader: "url-loader",
options: {
limit: 8192,
},
},
],
},
{
test: /\.css$/,
2020-09-05 22:31:08 +00:00
use: [
MiniCssExtractPlugin.loader,
{
loader: "css-loader",
options: {
modules: {
2019-01-28 00:11:02 +00:00
localIdentName: "[local]",
},
2020-09-05 22:31:08 +00:00
import: true,
importLoaders: 1,
2019-01-28 00:11:02 +00:00
},
2020-09-05 22:31:08 +00:00
},
"postcss-loader",
2020-09-05 22:31:08 +00:00
],
2019-01-28 00:11:02 +00:00
},
],
},
optimization: {
splitChunks: {
name: "vendor",
minChunks: 2,
},
2021-03-22 03:36:29 +00:00
minimize: true,
2019-01-28 00:11:02 +00:00
minimizer: [
2021-03-22 03:36:29 +00:00
new TerserPlugin({
parallel: true,
2019-01-28 00:11:02 +00:00
}),
],
},
2020-09-05 22:31:08 +00:00
plugins: [
new CleanWebpackPlugin({
cleanOnceBeforeBuildPatterns: [join("static/assets")],
cleanAfterEveryBuildPatterns: [
join("static/assets/style.js"),
join("static/assets/blue.js"),
join("static/assets/green.js"),
join("static/assets/red.js"),
join("static/assets/pink.js"),
],
verbose: true,
}),
new MiniCssExtractPlugin({
filename: "[name].css",
chunkFilename: "[id].css",
}),
],
});