const HtmlWebpackPlugin = require("html-webpack-plugin");
const path = require("path");

const src = path.resolve(__dirname, "src");
const dist = path.resolve(__dirname, "build");

const config = {
  entry: {
    content: path.join(src, "content"),
    settings: path.join(src, "settings"),
    background: path.join(src, "background"),
    console: path.join(src, "console"),
  },

  output: {
    path: dist,
    filename: "[name].js",
  },

  optimization: {
    minimize: false,
  },

  performance: {
    hints: false,
  },

  module: {
    rules: [
      {
        test: [/\.ts$/, /\.tsx$/],
        exclude: /node_modules/,
        use: ["ts-loader"],
      },
      {
        test: /\.css$/,
        use: ["style-loader", "css-loader"],
      },
    ],
  },

  resolve: {
    extensions: [".js", ".jsx", ".ts", ".tsx"],
    modules: [path.join(__dirname, "src"), "node_modules"],
  },

  plugins: [
    new HtmlWebpackPlugin({
      template: path.join(src, "console", "index.html"),
      filename: path.join(dist, "console.html"),
      inject: false,
    }),
    new HtmlWebpackPlugin({
      template: path.join(src, "settings", "index.html"),
      filename: path.join(dist, "settings.html"),
      inject: false,
    }),
  ],
};

module.exports = config;