|
|
- 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: '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
- },
- },
- ]
- }
- ],
- },
- };
|