`options` given to react-refresh/runtime is undefined, leaving `originalFactory` undefined & crashing app
See original GitHub issueI’m at my second attempt at upgrading from Webpack 4 to 5, and even though I have double and triple checked my configuration, there’s no way to be sure whether I got it all correct. I’ve finally made webpack-dev-server compile my app, but it crashes runtime.
In case there are any common and easily identifiable mistakes, I’m pasting in what I think is the relevant bits and pieces:
package.json
"devDependencies": {
"webpack": "latest",
"webpack-cli": "^4.5.0",
"webpack-dev-server": "^3.11.2",
"@pmmmwh/react-refresh-webpack-plugin": "^0.4.3",
"react-refresh": "^0.9.0"
},
"dependencies": {
"@babel/runtime": "^7.13.10",
"@babel/runtime-corejs3": "^7.13.10",
"@hot-loader/react-dom": "17",
"core-js": "3",
"react": "^17.0.1",
"react-dom": "npm:@hot-loader/react-dom",
},
"engines": {
"node": "14.x",
"yarn": "2.4.x"
}
webpack.common.js
const { ContextReplacementPlugin, DefinePlugin } = require('webpack')
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
const excludeNodeModulesExcept = require('babel-loader-exclude-node-modules-except')
const WebpackBar = require('webpackbar')
const { dateFnsLocales, ie11, transpile } = require('./package.json')
module.exports = (env, argv, mode) => ({
mode,
entry: [
...ie11,
`${__dirname}/src/index.js`
],
module: {
rules: [
{
test: /\.js$/,
exclude: excludeNodeModulesExcept(transpile),
use: [
'thread-loader',
{
loader: 'babel-loader',
options: {
cacheDirectory: true
}
}
]
},
{
test: /\.(ttf|woff|woff2)$/,
exclude: /node_modules/,
loader: 'base64-inline-loader'
},
{
test: /\.(png|svg|jpg|jpeg|gif|ico)$/,
exclude: /node_modules/,
use: [{
loader: 'file-loader',
options: {
name: '[name].[fullhash].[ext]',
outputPath: 'static/gfx/'
}
}]
},
{
test: /\.csvg$/,
loader: '@svgr/webpack'
},
{
test: /\.ucsvg$/,
use: [{
loader: '@svgr/webpack',
options: {
svgo: false
}
}]
},
{
test: /\.md$/,
loader: 'raw-loader'
},
{
test: /\.js.flow$/,
loader: 'ignore-loader'
}
]
},
plugins: [
new CleanWebpackPlugin(),
new ContextReplacementPlugin(
/date-fns[/\\]locale$/,
new RegExp(`[/\\\\](${dateFnsLocales.join('|')})[/\\\\]`)
),
new WebpackBar(),
new DefinePlugin({
process: JSON.stringify({
env: {
NODE_ENV: mode
}
})
})
],
resolve: {
modules: [`${__dirname}/src`, 'node_modules'],
extensions: ['*', '.js', '.jsx'],
alias: {
'react-dom': '@hot-loader/react-dom',
package: `${__dirname}/package.json`
},
fallback: {
crypto: require.resolve('crypto-js'),
// Thinking maybe one of these might have to be polyfilled?
// Haven’t seen that documented anywhere, though.
process: false,
buffer: false,
stream: false,
fs: false,
zlib: false,
http: false,
https: false
}
},
output: {
path: `${__dirname}/dist`,
filename: '[name].[fullhash].bundle.js',
chunkFilename: '[name].[fullhash].bundle.js',
publicPath: '/'
}
})
webpack.dev.js
module.exports = (env, argv) => merge(common(env, argv, 'development'), {
devtool: 'inline-source-map',
plugins: [
new HotModuleReplacementPlugin(),
new ReactRefreshWebpackPlugin({
include: /\.js$/i,
overlay: false
}),
new HtmlPlugin({
favicon: `${__dirname}/src/static/gfx/favicon.dev.ico`,
template: `${__dirname}/src/index.html`
})
],
devServer: {
contentBase: 'src',
host: '0.0.0.0',
port: 7070,
hot: true,
disableHostCheck: true,
historyApiFallback: true,
clientLogLevel: 'warn',
stats: 'minimal',
proxy: { … }
}
})
babel.config.js
const excludeNodeModulesExcept = require('babel-loader-exclude-node-modules-except')
const { transpile } = require('./package.json')
module.exports = api => {
api.cache.using(() => process.env.NODE_ENV)
return {
presets: [
['@babel/preset-env', {
useBuiltIns: 'usage',
corejs: {
version: 3,
proposals: true
},
targets: {
node: 'current',
ie: 11
}
}],
'@babel/preset-react'
],
plugins: [
['@babel/plugin-transform-runtime', { corejs: 3 }],
'@babel/plugin-syntax-dynamic-import',
'@babel/plugin-transform-arrow-functions',
'@babel/plugin-proposal-class-properties',
'@babel/plugin-proposal-optional-chaining',
'@babel/plugin-transform-template-literals',
'@babel/plugin-proposal-nullish-coalescing-operator',
],
env: {
development: {
plugins: [
'react-refresh/babel',
['babel-plugin-styled-components', {
ssr: false,
transpileTemplateLiterals: true,
displayName: true
}]
]
}
},
overrides: [{
exclude: excludeNodeModulesExcept(transpile),
plugins: ['@babel/plugin-transform-modules-commonjs']
}]
}
}
Any input welcome – so far I’m lost on how to go about debugging this. I’m not sure whether it originates in code outside my control, or that I configured something wrong, but in any case I would need an explanation, in the long term preferrably as a warning from the code.
Issue Analytics
- State:
- Created 3 years ago
- Reactions:1
- Comments:9 (4 by maintainers)
Top Results From Across the Web
react-resfresh : OriginalFactory is undefined | Cannot read ...
While trying to use moduleFederationPlugin from webpack, we are getting below error: ` Cannot read properties of undefined (reading 'call').
Read more >Eight Practices in React That Will Crash Your App in the Future
The creepy part is, the app will not crash until a part of your code attempts to do a property lookup with that...
Read more >How to use the react-refresh/runtime.register function in ... - Snyk
To help you get started, we've selected a few react-refresh/runtime.register examples, based on popular ways it is used in public projects.
Read more >React Native: How to Fix IOS App Crashes
Now open your app and see the log you will get the crash error in the console window or you can search it...
Read more >Realm: Create reactive mobile apps in a fraction of the time
Add Realm to dependencies in android/app/build.gradle : Copy to clipboard ... To use a default value, leave the property unspecified during object creation....
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
Yes this is a Webpack bug so unfortunately until they fix it we can’t do much about it.
I have chipped away at my project, and this issue persists even after having removed everything Fast Refresh related.
Still haven’t got it working – here’s my repro if anyone’s interested: https://github.com/Haraldson/refresh-minimal-repro