const { composePlugins, withNx } = require('@nrwl/webpack'); const { withReact } = require('@nrwl/react'); const webpack = require('webpack') const CopyPlugin = require("copy-webpack-plugin"); const version = require('../../package.json').version const fs = require('fs') const TerserPlugin = require("terser-webpack-plugin"); const CompressionPlugin = require("compression-webpack-plugin"); const CssMinimizerPlugin = require("css-minimizer-webpack-plugin"); const versionData = { version: version, timestamp: Date.now(), mode: process.env.NODE_ENV === 'production' ? 'production' : 'development' } fs.writeFileSync('./apps/remix-ide/src/assets/version.json', JSON.stringify(versionData)) // Nx plugins for webpack. module.exports = composePlugins(withNx(), withReact(), (config) => { // Update the webpack config as needed here. // e.g. `config.plugins.push(new MyPlugin())` // add fallback for node modules config.resolve.fallback = { ...config.resolve.fallback, "crypto": require.resolve("crypto-browserify"), "stream": require.resolve("stream-browserify"), "path": require.resolve("path-browserify"), "http": require.resolve("stream-http"), "https": require.resolve("https-browserify"), "constants": require.resolve("constants-browserify"), "os": false, //require.resolve("os-browserify/browser"), "timers": false, // require.resolve("timers-browserify"), "zlib": require.resolve("browserify-zlib"), "fs": false, "module": false, "tls": false, "net": false, "readline": false, "child_process": false, "buffer": require.resolve("buffer/"), "vm": require.resolve('vm-browserify'), } // add externals config.externals = { ...config.externals, solc: 'solc', } // add public path config.output.publicPath = '/' // set filename config.output.filename = `[name].${versionData.version}.${versionData.timestamp}.js` config.output.chunkFilename = `[name].${versionData.version}.${versionData.timestamp}.js` // add plugin // add copy plugin config.plugins.push( new CopyPlugin({ patterns: [ { from: '../../node_modules/monaco-editor/dev/vs', to: 'assets/js/monaco-editor/dev/vs' } ].filter(Boolean) }), new webpack.ProvidePlugin({ Buffer: ['buffer', 'Buffer'], url: ['url', 'URL'], process: 'process/browser', }) ) // set minimizer config.optimization.minimizer = [ new TerserPlugin({ parallel: true, minify: TerserPlugin.swcMinify, terserOptions: { compress: true, /* ecma: 2015, compress: true, format: { comments: false, }, */ }, //extractComments: false, }), new CssMinimizerPlugin(), ]; // add compression plugin /* config.plugins.push( new CompressionPlugin({ test: /\.js(\?.*)?$/i, filename: '[path][base].gz', }) )*/ console.log(config) return config; });