/* eslint-disable import/no-extraneous-dependencies, prefer-destructuring */ const path = require('path'); const webpack = require('webpack'); // const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin; const CircularDependencyPlugin = require('circular-dependency-plugin'); const HtmlWebpackPlugin = require('html-webpack-plugin'); // const LodashModuleReplacementPlugin = require('lodash-webpack-plugin'); // const UglifyJsPlugin = require('uglifyjs-webpack-plugin'); // const OfflinePlugin = require('offline-plugin'); const getCSSModuleLocalIdent = require('./getCSSModuleLocalIdent'); const getClientEnvironment = require('./env'); const paths = require('./paths'); // Webpack uses `publicPath` to determine where the app is being served from. // In development, we always serve from the root. This makes config easier. const publicPath = '/'; // `publicUrl` is just like `publicPath`, but we will provide it to our app // as %PUBLIC_URL% in `index.html` and `process.env.PUBLIC_URL` in JavaScript. // Omit trailing slash as %PUBLIC_PATH%/xyz looks better than %PUBLIC_PATH%xyz. const publicUrl = ''; // Get environment variables to inject into our app. const env = getClientEnvironment(publicUrl); // style files regexes const cssRegex = /\.css$/; const cssModuleRegex = /\.module\.css$/; const sassRegex = /\.(scss|sass)$/; const sassModuleRegex = /\.module\.(scss|sass)$/; // const SharedCache = {}; const getCacheLoader = () => ({ loader: require.resolve('cache-loader'), options: { cacheDirectory: path.join(paths.buildCache, 'cache-loader') } }); // const getThreadLoader = () => ({ // loader: require.resolve('thread-loader'), // options: { // poolTimeout: Infinity // } // }); // common function to get style loaders const getStyleLoaders = (cssOptions, preProcessor) => { const loaders = [ getCacheLoader(), require.resolve('style-loader'), { loader: require.resolve('css-loader'), options: cssOptions } // , // { // // Options for PostCSS as we reference these options twice // // Adds vendor prefixing based on your specified browser support in // // package.json // loader: require.resolve('postcss-loader'), // options: { // // Necessary for external CSS imports to work // // https://github.com/facebook/create-react-app/issues/2677 // ident: 'postcss', // plugins: () => [ // require('postcss-flexbugs-fixes'), // autoprefixer({ // flexbox: 'no-2009' // }) // ] // } // } ]; if (preProcessor) { loaders.push(require.resolve(preProcessor)); } return loaders; }; // This is the development configuration. // It is focused on developer experience and fast rebuilds. // The production configuration is different and lives in a separate file. module.exports = { mode: 'development', // cache: SharedCache, // You may want 'eval' instead if you prefer to see the compiled output in DevTools. // See the discussion in https://github.com/facebook/create-react-app/issues/343. devtool: 'cheap-module-source-map', // These are the "entry points" to our application. // This means they will be the "root" imports that are included in JS bundle. // The first two entry points enable "hot" CSS and auto-refreshes for JS. entry: [ // We ship a few polyfills by default: require.resolve('./polyfills'), require.resolve('webpack-dev-server/client') + '?/', // eslint-disable-line require.resolve('webpack/hot/dev-server'), paths.appIndexJs // We include the app code last so that if there is a runtime error during // initialization, it doesn't blow up the WebpackDevServer client, and // changing JS code would still trigger a refresh. ], output: { // Add /* filename */ comments to generated require()s in the output. pathinfo: false, // This does not produce a real file. It's just the virtual path that is // served by WebpackDevServer in development. This is the JS bundle // containing code from all our entry points, and the Webpack runtime. filename: 'static/js/bundle.js', // There are also additional JS chunk files if you use code splitting. chunkFilename: 'static/js/[name].chunk.js', // This is the URL that app is served from. We use "/" in development. publicPath, // Point sourcemap entries to original disk location (format as URL on Windows) devtoolModuleFilenameTemplate: info => path.resolve(info.absoluteResourcePath).replace(/\\/g, '/') }, optimization: { splitChunks: false, runtimeChunk: true, removeAvailableModules: false, removeEmptyChunks: false }, resolve: { // This allows you to set a fallback for where Webpack should look for modules. // We placed these paths second because we want `node_modules` to "win" // if there are any conflicts. This matches Node resolution mechanism. // https://github.com/facebook/create-react-app/issues/253 modules: ['node_modules'].concat( // It is guaranteed to exist because we tweak it in `env.js` process.env.NODE_PATH.split(path.delimiter).filter(Boolean) ), // These are the reasonable defaults supported by the Node ecosystem. // We also include JSX as a common component filename extension to support // some tools, although we do not recommend using it, see: // https://github.com/facebook/create-react-app/issues/290 // `web` extension prefixes have been added for better support // for React Native Web. extensions: ['.web.js', '.mjs', '.js', '.json', '.web.jsx', '.jsx'], // alias: { // // Support React Native Web // // https://www.smashingmagazine.com/2016/08/a-glimpse-into-the-future-with-react-native-for-web/ // 'react-native': 'react-native-web' // }, // plugins: [ // // Prevents users from importing files from outside of src/ (or node_modules/). // // This often causes confusion because we only process files within src/ with babel. // // To fix this, we prevent you from importing files out of src/ -- if you'd like to, // // please link the files into your node_modules/ and let module-resolution kick in. // // Make sure your source files are compiled, as they will not be processed in any way. // // new ModuleScopePlugin(paths.appSrc, [paths.appPackageJson]), // ], unsafeCache: true, cacheWithContext: true }, module: { strictExportPresence: true, rules: [ // // Disable require.ensure as it's not a standard language feature. // { // parser: { // requireEnsure: false // } // }, // // First, run the linter. // // It's important to do this before Babel processes the JS. // { // test: /\.(js|jsx|mjs)$/, // enforce: 'pre', // use: [ // { // options: { // // formatter: eslintFormatter, // eslintPath: require.resolve('eslint'), // baseConfig: { // extends: [require.resolve('@cognistreamer/eslint-config')] // } // }, // loader: require.resolve('eslint-loader') // } // ], // include: paths.srcPaths, // exclude: [/[/\\\\]node_modules[/\\\\]/] // }, { // "oneOf" will traverse all following loaders until one will // match the requirements. When no loader matches it will fall // back to the "file" loader at the end of the loader list. oneOf: [ // "url" loader works like "file" loader except that it embeds assets // smaller than specified limit in bytes as data URLs to avoid requests. // A missing `test` is equivalent to a match. { test: [/\.bmp$/, /\.gif$/, /\.jpe?g$/, /\.png$/], use: [ getCacheLoader(), { loader: require.resolve('url-loader'), options: { limit: 10000, name: 'static/media/[name].[hash:8].[ext]' } } ] }, // Process application JS with Babel. { test: /\.(js|jsx|mjs)$/, include: paths.srcPaths, exclude: /node_modules/, use: [ { loader: require.resolve('babel-loader'), options: { babelrc: false, cacheDirectory: path.join(paths.buildCache, 'babel-loader'), presets: [ require.resolve('./babel-preset-react-app') ] } } ] }, // Process any JS outside of the app with Babel. // Unlike the application JS, we only compile the standard ES features. // { // test: /\.js$/, // use: [ // getCacheLoader(), // { // loader: require.resolve('babel-loader'), // options: { // babelrc: false, // compact: false, // presets: [ // require.resolve('./babel-preset-react-app-dependencies') // ], // cacheDirectory: true, // highlightCode: true // } // } // ] // }, // "postcss" loader applies autoprefixer to our CSS. // "css" loader resolves paths in CSS and adds assets as dependencies. // "style" loader turns CSS into JS modules that inject