12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- const path = require("path");
- const MiniCssExtractPlugin = require("mini-css-extract-plugin");
- const RemoveEmptyScriptsPlugin = require("webpack-remove-empty-scripts");
- const CopyPlugin = require("copy-webpack-plugin");
- module.exports = {
- mode: process.env.NODE_ENV,
- entry: {
- index: path.resolve(__dirname, "resources/src/styles/index.scss"),
- },
- output: {
- path: path.resolve(__dirname, "resources/public"),
- },
- plugins: [
- new RemoveEmptyScriptsPlugin(),
- new MiniCssExtractPlugin({
- filename: "styles/[name].css",
- }),
- new CopyPlugin({
- patterns: [
- {
- from: path.resolve(__dirname, "resources/src/icons"),
- to: "icons",
- },
- {
- from: path.resolve(__dirname, "resources/src/index.html"),
- to: "index.html",
- },
- ],
- }),
- ],
- module: {
- rules: [
- {
- test: /\.scss$/i,
- exclude: /node_modules/,
- use: [
- MiniCssExtractPlugin.loader,
- {
- loader: "css-loader",
- options: {
- importLoaders: 1,
- },
- },
- "postcss-loader",
- "sass-loader",
- ],
- },
- {
- test: /\.(woff|woff2|eot|ttf|otf)$/i,
- type: "asset/resource",
- generator: {
- filename: "fonts/[hash][ext][query]",
- },
- },
- ],
- },
- };
|