import webpack from 'webpack';
import HtmlWebpackPlugin from 'html-webpack-plugin';
import CopyWebpackPlugin from 'copy-webpack-plugin';
import MiniCssExtractPlugin from 'mini-css-extract-plugin';
import { SRC, BUILD, PUBLIC } from './constants';
module.exports = {
mode: 'production',
entry: {
index: [`${SRC}index.js`],
},
output: {
filename: '[name].[hash].js',
path: BUILD,
publicPath: './',
},
module: {
rules: [
{
test: /\.jsx?$/,
exclude: /node_modules/,
use: ['babel-loader'],
},
{
test: /\.less$/,
use: [
{
loader: MiniCssExtractPlugin.loader,
options: { publicPath: '../' },
},
{
loader: 'css-loader',
options: {
minimize: false,
},
},
{
loader: 'less-loader',
options: {
minimize: false,
},
},
],
},
{
test: /\.(png|gif|jpg)$/,
exclude: /(node_modules)/,
loader: 'file-loader',
query: {
outputPath: './images',
name: '[name].[hash].[ext]',
},
},
{
test: /\.(ttf|eot|svg|woff|woff2)$/,
loader: 'file-loader',
query: {
outputPath: './fonts',
name: '[name].[hash].[ext]',
},
},
{
type: 'javascript/auto',
test: /\.json/,
exclude: /(node_modules)/,
loader: 'file-loader',
query: {
outputPath: './data',
name: '[name].[hash].[ext]',
},
},
],
},
resolve: {
alias: {
public: PUBLIC,
},
modules: [SRC, 'node_modules'],
},
performance: {
hints: false,
},
plugins: [
new MiniCssExtractPlugin({
filename: 'css/[name].[hash].css',
}),
new HtmlWebpackPlugin({
chunks: ['index'],
template: `${SRC}index.html`,
filename: 'index.html',
inject: true,
favicon: `${SRC}images/favicon.ico`,
}),
new CopyWebpackPlugin([
{ from: `${PUBLIC}`, to: './' },
]),
new webpack.optimize.OccurrenceOrderPlugin(),
new webpack.NoEmitOnErrorsPlugin(),
new webpack.NamedModulesPlugin(),
],
};