const path = require('path'); const glob = require('glob'); 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 ? '../priv/static_dev/js' : '../priv/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)$/, use: ['file-loader'], }, ] }, plugins: [ new MiniCssExtractPlugin({ filename: '../css/app.css' }), new MonacoWebpackPlugin({ languages: ['markdown'] }) ], optimization: { minimizer: [ '...', new CssMinimizerPlugin() ] }, } };