56 lines
1.3 KiB
JavaScript
56 lines
1.3 KiB
JavaScript
const path = require('path');
|
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
|
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
|
|
const CopyPlugin = require('copy-webpack-plugin');
|
|
|
|
module.exports = {
|
|
entry: ['./src/index.js'],
|
|
mode: "production",
|
|
target: "web",
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.s[ac]ss$/i,
|
|
use: [MiniCssExtractPlugin.loader, "css-loader", "sass-loader"],
|
|
},
|
|
{
|
|
test: /\.css$/i,
|
|
use: [MiniCssExtractPlugin.loader, "css-loader"],
|
|
}
|
|
],
|
|
},
|
|
plugins: [new HtmlWebpackPlugin({
|
|
template: path.resolve("src", "index.html"),
|
|
templateParameters: {
|
|
'favicon': '/assets/logo.png',
|
|
'manifest': '/assets/manifest.json'
|
|
},
|
|
}), new MiniCssExtractPlugin(),new CopyPlugin({
|
|
patterns: [
|
|
{ from: "src/assets", to: "assets" }
|
|
],
|
|
})],
|
|
output: {
|
|
path: path.resolve(__dirname, 'build'),
|
|
filename: '[name].d3v4pp.bundle.js',
|
|
publicPath: "/"
|
|
|
|
},
|
|
devServer: {
|
|
client: {
|
|
progress: true,
|
|
reconnect: true,
|
|
overlay: {
|
|
errors: true,
|
|
warnings: false,
|
|
},
|
|
},
|
|
historyApiFallback: true,
|
|
open: true,
|
|
static: {
|
|
directory: path.join(__dirname, 'src'),
|
|
},
|
|
compress: true,
|
|
port: 9000
|
|
}
|
|
}; |