const glob = require('glob'); const path = require('path'); const CopyWebpackPlugin = require('copy-webpack-plugin'); const HtmlWebpackPlugin = require('html-webpack-plugin'); const MiniCssExtractPlugin = require('mini-css-extract-plugin'); // not sure why this 'entries' is post-specific; tried adding other paths and they failed; const entries = glob.sync(path.resolve(__dirname, 'src/assets/images/posts/*.{png,gif,jpg,jpeg}')); entries.push(path.resolve(__dirname, 'src/assets/styles/main.css')); // TODO: Remove if the blog does not need syntax highlight entries.push(path.resolve(__dirname, 'src/assets/styles/prism-atom-dark.css')); let cssFileName = 'styles/[name].css'; if (process.env.NODE_ENV === 'production') { cssFileName = 'styles/[name].[contenthash].css'; } module.exports = { mode: 'development', entry: entries, output: { path: path.resolve(__dirname, '_site/assets'), publicPath: '/', }, plugins: [ new CopyWebpackPlugin({ patterns: [{ from: path.resolve(__dirname, 'public'), to: path.resolve(__dirname, '_site') }], }), new MiniCssExtractPlugin({ filename: cssFileName, }), new HtmlWebpackPlugin({ template: path.resolve(__dirname, 'webpack.html'), filename: path.resolve(__dirname, 'src/_includes/layouts/webpack.ejs'), inject: false, }), ], module: { rules: [ { test: /\.css$/, exclude: /node_modules/, use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader'], }, { test: /\.(gif|png|jpg|jpeg)$/i, use: [ { loader: 'file-loader', options: { name: 'images/[name].[ext]', }, }, { loader: 'file-loader', options: { name: 'images/screenshots/[name].[ext]', }, }, { loader: 'file-loader', options: { name: 'images/systems/[name].[ext]', }, }, { loader: 'file-loader', options: { name: 'images/products/icons/[name].[ext]', }, }, { loader: 'file-loader', options: { name: 'images/products/heros/[name].[ext]', }, }, { loader: 'image-webpack-loader', options: { mozjpeg: { progressive: true, quality: 65, }, // optipng.enabled: false will disable optipng optipng: { enabled: false, }, pngquant: { quality: [0.65, 0.9], speed: 4, }, gifsicle: { interlaced: true, }, }, }, ], }, { test: /\.svg$/, use: [ { loader: 'svg-url-loader', options: { limit: 10000, }, }, ], }, { test: /\.(png|jpg|gif)$/i, use: [ { loader: 'url-loader', options: { name: 'images/[name].[ext]', limit: 10000, esModule: false }, }, ] } ], }, };