diff --git a/packages/react-refresh/src/ReactFreshBabelPlugin.js b/packages/react-refresh/src/ReactFreshBabelPlugin.js index ff41422ca8120..f1a92e9da8e07 100644 --- a/packages/react-refresh/src/ReactFreshBabelPlugin.js +++ b/packages/react-refresh/src/ReactFreshBabelPlugin.js @@ -7,7 +7,7 @@ 'use strict'; -export default function(babel, opts) { +export default function(babel, opts = {}) { if (typeof babel.getEnv === 'function') { // Only available in Babel 7. const env = babel.getEnv(); @@ -300,7 +300,20 @@ export default function(babel, opts) { } }); - const args = [node, t.stringLiteral(key)]; + let finalKey = key; + if (typeof require === 'function' && !opts.emitFullSignatures) { + // Prefer to hash when we can (e.g. outside of ASTExplorer). + // This makes it deterministically compact, even if there's + // e.g. a useState ininitalizer with some code inside. + // We also need it for www that has transforms like cx() + // that don't understand if something is part of a string. + finalKey = require('crypto') + .createHash('sha1') + .update(key) + .digest('base64'); + } + + const args = [node, t.stringLiteral(finalKey)]; if (forceReset || customHooksInScope.length > 0) { args.push(t.booleanLiteral(forceReset)); } diff --git a/packages/react-refresh/src/__tests__/ReactFreshBabelPlugin-test.js b/packages/react-refresh/src/__tests__/ReactFreshBabelPlugin-test.js index 7544d4eea7a2b..ed7bd8cd15c45 100644 --- a/packages/react-refresh/src/__tests__/ReactFreshBabelPlugin-test.js +++ b/packages/react-refresh/src/__tests__/ReactFreshBabelPlugin-test.js @@ -19,7 +19,14 @@ function transform(input, options = {}) { plugins: [ '@babel/syntax-jsx', '@babel/syntax-dynamic-import', - [freshPlugin, {skipEnvCheck: true}], + [ + freshPlugin, + { + skipEnvCheck: true, + // To simplify debugging tests: + emitFullSignatures: true, + }, + ], ...(options.plugins || []), ], }).code,