import type { Configuration } from 'webpack'; import ReactRefreshPlugin = require('@pmmmwh/react-refresh-webpack-plugin'); import { NormalizedWebpackExecutorOptions } from '@nrwl/webpack'; import { ExecutorContext } from 'nx/src/config/misc-interfaces'; // Add React-specific configuration export function withReact() { return function configure( config: Configuration, _ctx?: { options: NormalizedWebpackExecutorOptions; context: ExecutorContext; } ): Configuration { config.module.rules.push({ test: /\.svg$/, issuer: /\.(js|ts|md)x?$/, use: [ { loader: require.resolve('@svgr/webpack'), options: { svgo: false, titleProp: true, ref: true, }, }, { loader: require.resolve('file-loader'), options: { name: '[name].[hash].[ext]', }, }, ], }); if (config.mode === 'development' && config['devServer']?.hot) { // add `react-refresh/babel` to babel loader plugin const babelLoader = config.module.rules.find( (rule) => typeof rule !== 'string' && rule.loader?.toString().includes('babel-loader') ); if (babelLoader && typeof babelLoader !== 'string') { babelLoader.options['plugins'] = [ ...(babelLoader.options['plugins'] || []), [ require.resolve('react-refresh/babel'), { skipEnvCheck: true, }, ], ]; } // add https://github.com/pmmmwh/react-refresh-webpack-plugin to webpack plugin config.plugins.push(new ReactRefreshPlugin()); } // enable webpack node api config.node = { __dirname: true, __filename: true, }; return config; }; } // Support existing default exports as well as new named export. const legacyExport: any = withReact(); legacyExport.withReact = withReact; /** @deprecated use `import { withReact } from '@nrwl/react'` */ // This is here for backward compatibility if anyone imports {getWebpackConfig} directly. // TODO(jack): Remove in Nx 16 legacyExport.getWebpackConfig = withReact(); module.exports = legacyExport;