aboutsummaryrefslogblamecommitdiff
path: root/webpack.config.js
blob: 49261a0525a783fa34efc168063703964160549f (plain) (tree)
1
2
3


                                                         





















































                                                                                              
const path = require("path");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const CopyWebpackPlugin = require('copy-webpack-plugin');
module.exports = (env, argv) => {
    const prodMode = argv.mode == 'production';
    return {
        entry: {
            index: "./src/index.js",
            background: "./src/background.js",
            popup: "./src/popup.js"
        },
        output: {
            path: path.join(__dirname, "/dist"),
            filename: "[name].js"
        },
        module: {
            rules: [
                {
                    test: /\.js$/,
                    exclude: /node_modules/,
                    use: ['babel-loader', 'eslint-loader']
                },
                {
                    test: /\.css$/,
                    use: ["style-loader", "css-loader"]
                },
                { test: /\.(png|woff|woff2|eot|ttf|svg)$/, loader: 'url-loader?limit=100000' }
            ]
        },
        plugins: [
            new HtmlWebpackPlugin({
                chunks: ['index'],
                template: "./src/index.html",
                filename: "./index.html"
            }),
            new HtmlWebpackPlugin({
                chunks: ['popup'],
                template: "./src/index.html",
                filename: "./popup.html"
            }),
            new CopyWebpackPlugin([
                {from:'./public/', to:'./'}
            ]),
            new CopyWebpackPlugin([
                {
                    from: prodMode ? './manifest.prod.json' : './manifest.dev.json',
                    to: './manifest.json'
                }
            ]),
        ],
        //optimization: prodMode ? ({
        //    splitChunks: {
        //        chunks: 'all'
        //    }
        //}) : {}
    };
};