const path = require("path"); const CircularDependencyPlugin = require("circular-dependency-plugin"); const TerserPlugin = require("terser-webpack-plugin"); module.exports = { mode: "development", target: "node", devtool: "eval-cheap-source-map", entry: "./src/index.js", output: { filename: "remote.js", path: path.resolve(__dirname, "dist") }, externals: { electron: `require("electron")`, fs: `require("fs")`, path: `require("path")`, request: `require("request")`, events: `require("events")`, rimraf: `require("rimraf")`, yauzl: `require("yauzl")`, mkdirp: `require("mkdirp")` }, resolve: { extensions: [".js", ".jsx"], modules: [ path.resolve("src", "builtins"), path.resolve("src", "data"), path.resolve("src", "modules") ] }, module: { rules: [ { test: /.jsx?$/, loader: "babel-loader", exclude: /node_modules/, query: { presets: [["@babel/env", { targets: { node: "12.8.1", chrome: "78" } }], "@babel/react"] } }, { test: /\.css$/i, use: ["css-loader"], } ] }, plugins: [ new CircularDependencyPlugin({ // exclude detection of files based on a RegExp exclude: /a\.js|node_modules/, // add errors to webpack instead of warnings // failOnError: true, // set the current working directory for displaying module paths cwd: process.cwd(), }) ], optimization: { minimizer: [ new TerserPlugin({ terserOptions: { compress: {drop_debugger:false} } }) ] } };