const path = require("path"); const glob = require("glob"); const webpack = require("webpack"); const MiniCssExtractPlugin = require("mini-css-extract-plugin"); const CssMinimizerPlugin = require("css-minimizer-webpack-plugin"); const MonacoWebpackPlugin = require("monaco-editor-webpack-plugin"); // Make sure NODE_ENV is set, so that @tailwindcss/jit is in watch mode in development. process.env.NODE_ENV = process.env.NODE_ENV || "development"; module.exports = (env, options) => { const devMode = options.mode !== "production"; return { mode: options.mode || "production", entry: { app: glob.sync("./vendor/**/*.js").concat(["./js/app.js"]), }, output: { filename: "[name].js", path: path.resolve( __dirname, devMode ? "../tmp/static_dev/js" : "../static/js" ), publicPath: "/js/", }, devtool: devMode ? "eval-cheap-module-source-map" : undefined, module: { rules: [ { test: /\.js$/, exclude: /node_modules/, use: { loader: "babel-loader", }, }, { test: /\.[s]?css$/, use: [MiniCssExtractPlugin.loader, "css-loader", "postcss-loader"], }, { test: /\.(ttf|woff|woff2|eot|svg)$/, type: "asset/resource", }, { test: /\.html$/i, loader: "html-loader", }, ], }, plugins: [ // Polyfill the global "process" variable required by "remark" internals new webpack.ProvidePlugin({ process: "process/browser.js", }), new MiniCssExtractPlugin({ filename: "../css/app.css" }), new MonacoWebpackPlugin({ languages: ["markdown", "elixir", "xml", "json", "sql"], }), ], optimization: { minimizer: ["...", new CssMinimizerPlugin()], splitChunks: { cacheGroups: { // Chunk splitting is by default enabled for all async chunks, // so for the dynamically loaded js/vega_lite/vega.js Webpack // would produce one almost empty chunk and then a vendor chunk // with "vega" and "vega-embed". We want to dynamically load all // of it at once, so we disable the default vendors chunk defaultVendors: false } } }, resolve: { fallback: { // The crypto-js package relies no the crypto module, but it has // fine support in browsers, so we don't provide polyfills crypto: false, // Polyfill the assert module required by "remark" internals assert: require.resolve("assert"), }, }, }; };