// Template for webpack.config.js in Fable projects // In most cases, you'll only need to edit the CONFIG object (after dependencies) // See below if you need better fine-tuning of Webpack options var path = require("path"); var HtmlWebpackPlugin = require('html-webpack-plugin'); var CopyWebpackPlugin = require('copy-webpack-plugin'); var MiniCssExtractPlugin = require("mini-css-extract-plugin"); const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin'); const Dotenv = require('dotenv-webpack'); const {patchGracefulFileSystem} = require("./webpack.common.js"); patchGracefulFileSystem(); // If we're running the webpack-dev-server, assume we're in development mode var isProduction = !process.argv.find(v => v.indexOf('webpack-dev-server') !== -1); const isDevelopment = !isProduction && process.env.NODE_ENV !== 'production'; var CONFIG = { // The tags to include the generated JS and CSS will be automatically injected in the HTML template // See https://github.com/jantimon/html-webpack-plugin indexHtmlTemplate: "./src/index.html", fsharpEntry: "./src/Main.fs.js", outputDir: "./dist", assetsDir: "./public", devServerPort: 8080, // When using webpack-dev-server, you may need to redirect some calls // to a external API server. See https://webpack.js.org/configuration/dev-server/#devserver-proxy devServerProxy: { '/api/*': { // assuming the backend is running on port 5000 target: "http://localhost:5000", changeOrigin: true } }, // Use babel-preset-env to generate JS compatible with most-used browsers. // More info at https://babeljs.io/docs/en/next/babel-preset-env.html babel: { plugins: [isDevelopment && require.resolve('react-refresh/babel')].filter(Boolean), presets: ["@babel/preset-env", "@babel/preset-react"] } } console.log("Bundling for " + (isProduction ? "production" : "development") + "..."); // The HtmlWebpackPlugin allows us to use a template for the index.html page // and automatically injects