Comparing version 0.0.0-experimental-657428a9e-20240416 to 0.0.0-experimental-65903583-20240805
@@ -11,1260 +11,330 @@ /** | ||
'use strict'; | ||
if (process.env.NODE_ENV !== "production") { | ||
(function() { | ||
'use strict'; | ||
var React = require('react'); | ||
// ATTENTION | ||
// When adding new symbols to this file, | ||
// Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols' | ||
// The Symbol used to tag the ReactElement-like types. | ||
var REACT_ELEMENT_TYPE = Symbol.for('react.element'); | ||
var REACT_PORTAL_TYPE = Symbol.for('react.portal'); | ||
var REACT_FRAGMENT_TYPE = Symbol.for('react.fragment'); | ||
var REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode'); | ||
var REACT_PROFILER_TYPE = Symbol.for('react.profiler'); | ||
var REACT_PROVIDER_TYPE = Symbol.for('react.provider'); // TODO: Delete with enableRenderableContext | ||
var REACT_CONSUMER_TYPE = Symbol.for('react.consumer'); | ||
var REACT_CONTEXT_TYPE = Symbol.for('react.context'); | ||
var REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref'); | ||
var REACT_SUSPENSE_TYPE = Symbol.for('react.suspense'); | ||
var REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list'); | ||
var REACT_MEMO_TYPE = Symbol.for('react.memo'); | ||
var REACT_LAZY_TYPE = Symbol.for('react.lazy'); | ||
var REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen'); | ||
var MAYBE_ITERATOR_SYMBOL = Symbol.iterator; | ||
var FAUX_ITERATOR_SYMBOL = '@@iterator'; | ||
function getIteratorFn(maybeIterable) { | ||
if (maybeIterable === null || typeof maybeIterable !== 'object') { | ||
return null; | ||
} | ||
var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]; | ||
if (typeof maybeIterator === 'function') { | ||
return maybeIterator; | ||
} | ||
return null; | ||
} | ||
var ReactSharedInternals = React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE; | ||
function error(format) { | ||
{ | ||
{ | ||
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { | ||
args[_key2 - 1] = arguments[_key2]; | ||
"use strict"; | ||
"production" !== process.env.NODE_ENV && | ||
(function () { | ||
function getComponentNameFromType(type) { | ||
if (null == type) return null; | ||
if ("function" === typeof type) | ||
return type.$$typeof === REACT_CLIENT_REFERENCE | ||
? null | ||
: type.displayName || type.name || null; | ||
if ("string" === typeof type) return type; | ||
switch (type) { | ||
case REACT_FRAGMENT_TYPE: | ||
return "Fragment"; | ||
case REACT_PORTAL_TYPE: | ||
return "Portal"; | ||
case REACT_PROFILER_TYPE: | ||
return "Profiler"; | ||
case REACT_STRICT_MODE_TYPE: | ||
return "StrictMode"; | ||
case REACT_SUSPENSE_TYPE: | ||
return "Suspense"; | ||
case REACT_SUSPENSE_LIST_TYPE: | ||
return "SuspenseList"; | ||
} | ||
printWarning('error', format, args); | ||
} | ||
} | ||
} | ||
function printWarning(level, format, args) { | ||
// When changing this logic, you might want to also | ||
// update consoleWithStackDev.www.js as well. | ||
{ | ||
var stack = ReactSharedInternals.getStackAddendum(); | ||
if (stack !== '') { | ||
format += '%s'; | ||
args = args.concat([stack]); | ||
} // eslint-disable-next-line react-internal/safe-string-coercion | ||
var argsWithFormat = args.map(function (item) { | ||
return String(item); | ||
}); // Careful: RN currently depends on this prefix | ||
argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it | ||
// breaks IE9: https://github.com/facebook/react/issues/13610 | ||
// eslint-disable-next-line react-internal/no-production-logging | ||
Function.prototype.apply.call(console[level], console, argsWithFormat); | ||
} | ||
} | ||
// ----------------------------------------------------------------------------- | ||
var enableScopeAPI = false; // Experimental Create Event Handle API. | ||
var enableTransitionTracing = false; // No known bugs, but needs performance testing | ||
var enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber | ||
// as a normal prop instead of stripping it from the props object. | ||
// Passes `ref` as a normal prop instead of stripping it from the props object | ||
// during element creation. | ||
var enableRefAsProp = true; | ||
var enableRenderableContext = true; // Enables the `initialValue` option for `useDeferredValue` | ||
// stuff. Intended to enable React core members to more easily debug scheduling | ||
// issues in DEV builds. | ||
var enableDebugTracing = false; | ||
function getWrappedName(outerType, innerType, wrapperName) { | ||
var displayName = outerType.displayName; | ||
if (displayName) { | ||
return displayName; | ||
} | ||
var functionName = innerType.displayName || innerType.name || ''; | ||
return functionName !== '' ? wrapperName + "(" + functionName + ")" : wrapperName; | ||
} // Keep in sync with react-reconciler/getComponentNameFromFiber | ||
function getContextName(type) { | ||
return type.displayName || 'Context'; | ||
} | ||
var REACT_CLIENT_REFERENCE$2 = Symbol.for('react.client.reference'); // Note that the reconciler package should generally prefer to use getComponentNameFromFiber() instead. | ||
function getComponentNameFromType(type) { | ||
if (type == null) { | ||
// Host root, text node or just invalid type. | ||
return null; | ||
} | ||
if (typeof type === 'function') { | ||
if (type.$$typeof === REACT_CLIENT_REFERENCE$2) { | ||
// TODO: Create a convention for naming client references with debug info. | ||
if ("object" === typeof type) | ||
switch ( | ||
("number" === typeof type.tag && | ||
console.error( | ||
"Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue." | ||
), | ||
type.$$typeof) | ||
) { | ||
case REACT_CONTEXT_TYPE: | ||
return (type.displayName || "Context") + ".Provider"; | ||
case REACT_CONSUMER_TYPE: | ||
return (type._context.displayName || "Context") + ".Consumer"; | ||
case REACT_FORWARD_REF_TYPE: | ||
var innerType = type.render; | ||
type = type.displayName; | ||
type || | ||
((type = innerType.displayName || innerType.name || ""), | ||
(type = "" !== type ? "ForwardRef(" + type + ")" : "ForwardRef")); | ||
return type; | ||
case REACT_MEMO_TYPE: | ||
return ( | ||
(innerType = type.displayName || null), | ||
null !== innerType | ||
? innerType | ||
: getComponentNameFromType(type.type) || "Memo" | ||
); | ||
case REACT_LAZY_TYPE: | ||
innerType = type._payload; | ||
type = type._init; | ||
try { | ||
return getComponentNameFromType(type(innerType)); | ||
} catch (x) {} | ||
} | ||
return null; | ||
} | ||
return type.displayName || type.name || null; | ||
} | ||
if (typeof type === 'string') { | ||
return type; | ||
} | ||
switch (type) { | ||
case REACT_FRAGMENT_TYPE: | ||
return 'Fragment'; | ||
case REACT_PORTAL_TYPE: | ||
return 'Portal'; | ||
case REACT_PROFILER_TYPE: | ||
return 'Profiler'; | ||
case REACT_STRICT_MODE_TYPE: | ||
return 'StrictMode'; | ||
case REACT_SUSPENSE_TYPE: | ||
return 'Suspense'; | ||
case REACT_SUSPENSE_LIST_TYPE: | ||
return 'SuspenseList'; | ||
} | ||
if (typeof type === 'object') { | ||
{ | ||
if (typeof type.tag === 'number') { | ||
error('Received an unexpected object in getComponentNameFromType(). ' + 'This is likely a bug in React. Please file an issue.'); | ||
} | ||
function testStringCoercion(value) { | ||
return "" + value; | ||
} | ||
switch (type.$$typeof) { | ||
case REACT_PROVIDER_TYPE: | ||
{ | ||
return null; | ||
} | ||
case REACT_CONTEXT_TYPE: | ||
var context = type; | ||
{ | ||
return getContextName(context) + '.Provider'; | ||
} | ||
case REACT_CONSUMER_TYPE: | ||
{ | ||
var consumer = type; | ||
return getContextName(consumer._context) + '.Consumer'; | ||
} | ||
case REACT_FORWARD_REF_TYPE: | ||
return getWrappedName(type, type.render, 'ForwardRef'); | ||
case REACT_MEMO_TYPE: | ||
var outerName = type.displayName || null; | ||
if (outerName !== null) { | ||
return outerName; | ||
} | ||
return getComponentNameFromType(type.type) || 'Memo'; | ||
case REACT_LAZY_TYPE: | ||
{ | ||
var lazyComponent = type; | ||
var payload = lazyComponent._payload; | ||
var init = lazyComponent._init; | ||
try { | ||
return getComponentNameFromType(init(payload)); | ||
} catch (x) { | ||
return null; | ||
} | ||
} | ||
} | ||
} | ||
return null; | ||
} | ||
// $FlowFixMe[method-unbinding] | ||
var hasOwnProperty = Object.prototype.hasOwnProperty; | ||
var assign = Object.assign; | ||
/* | ||
* The `'' + value` pattern (used in perf-sensitive code) throws for Symbol | ||
* and Temporal.* types. See https://github.com/facebook/react/pull/22064. | ||
* | ||
* The functions in this module will throw an easier-to-understand, | ||
* easier-to-debug exception with a clear errors message message explaining the | ||
* problem. (Instead of a confusing exception thrown inside the implementation | ||
* of the `value` object). | ||
*/ | ||
// $FlowFixMe[incompatible-return] only called in DEV, so void return is not possible. | ||
function typeName(value) { | ||
{ | ||
// toStringTag is needed for namespaced types like Temporal.Instant | ||
var hasToStringTag = typeof Symbol === 'function' && Symbol.toStringTag; | ||
var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || 'Object'; // $FlowFixMe[incompatible-return] | ||
return type; | ||
} | ||
} // $FlowFixMe[incompatible-return] only called in DEV, so void return is not possible. | ||
function willCoercionThrow(value) { | ||
{ | ||
try { | ||
testStringCoercion(value); | ||
return false; | ||
} catch (e) { | ||
return true; | ||
} | ||
} | ||
} | ||
function testStringCoercion(value) { | ||
// If you ended up here by following an exception call stack, here's what's | ||
// happened: you supplied an object or symbol value to React (as a prop, key, | ||
// DOM attribute, CSS property, string ref, etc.) and when React tried to | ||
// coerce it to a string using `'' + value`, an exception was thrown. | ||
// | ||
// The most common types that will cause this exception are `Symbol` instances | ||
// and Temporal objects like `Temporal.Instant`. But any object that has a | ||
// `valueOf` or `[Symbol.toPrimitive]` method that throws will also cause this | ||
// exception. (Library authors do this to prevent users from using built-in | ||
// numeric operators like `+` or comparison operators like `>=` because custom | ||
// methods are needed to perform accurate arithmetic or comparison.) | ||
// | ||
// To fix the problem, coerce this object or symbol value to a string before | ||
// passing it to React. The most reliable way is usually `String(value)`. | ||
// | ||
// To find which value is throwing, check the browser or debugger console. | ||
// Before this exception was thrown, there should be `console.error` output | ||
// that shows the type (Symbol, Temporal.PlainDate, etc.) that caused the | ||
// problem and how that type was used: key, atrribute, input value prop, etc. | ||
// In most cases, this console output also shows the component and its | ||
// ancestor components where the exception happened. | ||
// | ||
// eslint-disable-next-line react-internal/safe-string-coercion | ||
return '' + value; | ||
} | ||
function checkKeyStringCoercion(value) { | ||
{ | ||
if (willCoercionThrow(value)) { | ||
error('The provided key is an unsupported type %s.' + ' This value must be coerced to a string before using it here.', typeName(value)); | ||
return testStringCoercion(value); // throw (to help callers find troubleshooting comments) | ||
} | ||
} | ||
} | ||
var REACT_CLIENT_REFERENCE$1 = Symbol.for('react.client.reference'); | ||
function isValidElementType(type) { | ||
if (typeof type === 'string' || typeof type === 'function') { | ||
return true; | ||
} // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill). | ||
if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableTransitionTracing ) { | ||
return true; | ||
} | ||
if (typeof type === 'object' && type !== null) { | ||
if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || !enableRenderableContext || type.$$typeof === REACT_CONSUMER_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object | ||
// types supported by any Flight configuration anywhere since | ||
// we don't know which Flight build this will end up being used | ||
// with. | ||
type.$$typeof === REACT_CLIENT_REFERENCE$1 || type.getModuleId !== undefined) { | ||
return true; | ||
} | ||
} | ||
return false; | ||
} | ||
var isArrayImpl = Array.isArray; // eslint-disable-next-line no-redeclare | ||
function isArray(a) { | ||
return isArrayImpl(a); | ||
} | ||
// Helpers to patch console.logs to avoid logging during side-effect free | ||
// replaying on render function. This currently only patches the object | ||
// lazily which won't cover if the log function was extracted eagerly. | ||
// We could also eagerly patch the method. | ||
var disabledDepth = 0; | ||
var prevLog; | ||
var prevInfo; | ||
var prevWarn; | ||
var prevError; | ||
var prevGroup; | ||
var prevGroupCollapsed; | ||
var prevGroupEnd; | ||
function disabledLog() {} | ||
disabledLog.__reactDisabledLog = true; | ||
function disableLogs() { | ||
{ | ||
if (disabledDepth === 0) { | ||
/* eslint-disable react-internal/no-production-logging */ | ||
prevLog = console.log; | ||
prevInfo = console.info; | ||
prevWarn = console.warn; | ||
prevError = console.error; | ||
prevGroup = console.group; | ||
prevGroupCollapsed = console.groupCollapsed; | ||
prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099 | ||
var props = { | ||
configurable: true, | ||
enumerable: true, | ||
value: disabledLog, | ||
writable: true | ||
}; // $FlowFixMe[cannot-write] Flow thinks console is immutable. | ||
Object.defineProperties(console, { | ||
info: props, | ||
log: props, | ||
warn: props, | ||
error: props, | ||
group: props, | ||
groupCollapsed: props, | ||
groupEnd: props | ||
}); | ||
/* eslint-enable react-internal/no-production-logging */ | ||
} | ||
disabledDepth++; | ||
} | ||
} | ||
function reenableLogs() { | ||
{ | ||
disabledDepth--; | ||
if (disabledDepth === 0) { | ||
/* eslint-disable react-internal/no-production-logging */ | ||
var props = { | ||
configurable: true, | ||
enumerable: true, | ||
writable: true | ||
}; // $FlowFixMe[cannot-write] Flow thinks console is immutable. | ||
Object.defineProperties(console, { | ||
log: assign({}, props, { | ||
value: prevLog | ||
}), | ||
info: assign({}, props, { | ||
value: prevInfo | ||
}), | ||
warn: assign({}, props, { | ||
value: prevWarn | ||
}), | ||
error: assign({}, props, { | ||
value: prevError | ||
}), | ||
group: assign({}, props, { | ||
value: prevGroup | ||
}), | ||
groupCollapsed: assign({}, props, { | ||
value: prevGroupCollapsed | ||
}), | ||
groupEnd: assign({}, props, { | ||
value: prevGroupEnd | ||
}) | ||
}); | ||
/* eslint-enable react-internal/no-production-logging */ | ||
} | ||
if (disabledDepth < 0) { | ||
error('disabledDepth fell below zero. ' + 'This is a bug in React. Please file an issue.'); | ||
} | ||
} | ||
} | ||
var prefix; | ||
function describeBuiltInComponentFrame(name) { | ||
{ | ||
if (prefix === undefined) { | ||
// Extract the VM specific prefix used by each line. | ||
function checkKeyStringCoercion(value) { | ||
try { | ||
throw Error(); | ||
} catch (x) { | ||
var match = x.stack.trim().match(/\n( *(at )?)/); | ||
prefix = match && match[1] || ''; | ||
testStringCoercion(value); | ||
var JSCompiler_inline_result = !1; | ||
} catch (e) { | ||
JSCompiler_inline_result = !0; | ||
} | ||
} // We use the prefix to ensure our stacks line up with native stack frames. | ||
return '\n' + prefix + name; | ||
} | ||
} | ||
var reentry = false; | ||
var componentFrameCache; | ||
{ | ||
var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map; | ||
componentFrameCache = new PossiblyWeakMap(); | ||
} | ||
/** | ||
* Leverages native browser/VM stack frames to get proper details (e.g. | ||
* filename, line + col number) for a single component in a component stack. We | ||
* do this by: | ||
* (1) throwing and catching an error in the function - this will be our | ||
* control error. | ||
* (2) calling the component which will eventually throw an error that we'll | ||
* catch - this will be our sample error. | ||
* (3) diffing the control and sample error stacks to find the stack frame | ||
* which represents our component. | ||
*/ | ||
function describeNativeComponentFrame(fn, construct) { | ||
// If something asked for a stack inside a fake render, it should get ignored. | ||
if (!fn || reentry) { | ||
return ''; | ||
} | ||
{ | ||
var frame = componentFrameCache.get(fn); | ||
if (frame !== undefined) { | ||
return frame; | ||
if (JSCompiler_inline_result) { | ||
JSCompiler_inline_result = console; | ||
var JSCompiler_temp_const = JSCompiler_inline_result.error; | ||
var JSCompiler_inline_result$jscomp$0 = | ||
("function" === typeof Symbol && | ||
Symbol.toStringTag && | ||
value[Symbol.toStringTag]) || | ||
value.constructor.name || | ||
"Object"; | ||
JSCompiler_temp_const.call( | ||
JSCompiler_inline_result, | ||
"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.", | ||
JSCompiler_inline_result$jscomp$0 | ||
); | ||
return testStringCoercion(value); | ||
} | ||
} | ||
} | ||
reentry = true; | ||
var previousPrepareStackTrace = Error.prepareStackTrace; // $FlowFixMe[incompatible-type] It does accept undefined. | ||
Error.prepareStackTrace = undefined; | ||
var previousDispatcher = null; | ||
{ | ||
previousDispatcher = ReactSharedInternals.H; // Set the dispatcher in DEV because this might be call in the render function | ||
// for warnings. | ||
ReactSharedInternals.H = null; | ||
disableLogs(); | ||
} | ||
/** | ||
* Finding a common stack frame between sample and control errors can be | ||
* tricky given the different types and levels of stack trace truncation from | ||
* different JS VMs. So instead we'll attempt to control what that common | ||
* frame should be through this object method: | ||
* Having both the sample and control errors be in the function under the | ||
* `DescribeNativeComponentFrameRoot` property, + setting the `name` and | ||
* `displayName` properties of the function ensures that a stack | ||
* frame exists that has the method name `DescribeNativeComponentFrameRoot` in | ||
* it for both control and sample stacks. | ||
*/ | ||
var RunInRootFrame = { | ||
DetermineComponentFrameRoot: function () { | ||
var control; | ||
function getTaskName(type) { | ||
if (type === REACT_FRAGMENT_TYPE) return "<>"; | ||
if ( | ||
"object" === typeof type && | ||
null !== type && | ||
type.$$typeof === REACT_LAZY_TYPE | ||
) | ||
return "<...>"; | ||
try { | ||
// This should throw. | ||
if (construct) { | ||
// Something should be setting the props in the constructor. | ||
var Fake = function () { | ||
throw Error(); | ||
}; // $FlowFixMe[prop-missing] | ||
Object.defineProperty(Fake.prototype, 'props', { | ||
set: function () { | ||
// We use a throwing setter instead of frozen or non-writable props | ||
// because that won't throw in a non-strict mode function. | ||
throw Error(); | ||
} | ||
}); | ||
if (typeof Reflect === 'object' && Reflect.construct) { | ||
// We construct a different control for this case to include any extra | ||
// frames added by the construct call. | ||
try { | ||
Reflect.construct(Fake, []); | ||
} catch (x) { | ||
control = x; | ||
} | ||
Reflect.construct(fn, [], Fake); | ||
} else { | ||
try { | ||
Fake.call(); | ||
} catch (x) { | ||
control = x; | ||
} // $FlowFixMe[prop-missing] found when upgrading Flow | ||
fn.call(Fake.prototype); | ||
} | ||
} else { | ||
try { | ||
throw Error(); | ||
} catch (x) { | ||
control = x; | ||
} // TODO(luna): This will currently only throw if the function component | ||
// tries to access React/ReactDOM/props. We should probably make this throw | ||
// in simple components too | ||
var maybePromise = fn(); // If the function component returns a promise, it's likely an async | ||
// component, which we don't yet support. Attach a noop catch handler to | ||
// silence the error. | ||
// TODO: Implement component stacks for async client components? | ||
if (maybePromise && typeof maybePromise.catch === 'function') { | ||
maybePromise.catch(function () {}); | ||
} | ||
} | ||
} catch (sample) { | ||
// This is inlined manually because closure doesn't do it for us. | ||
if (sample && control && typeof sample.stack === 'string') { | ||
return [sample.stack, control.stack]; | ||
} | ||
var name = getComponentNameFromType(type); | ||
return name ? "<" + name + ">" : "<...>"; | ||
} catch (x) { | ||
return "<...>"; | ||
} | ||
return [null, null]; | ||
} | ||
}; // $FlowFixMe[prop-missing] | ||
RunInRootFrame.DetermineComponentFrameRoot.displayName = 'DetermineComponentFrameRoot'; | ||
var namePropDescriptor = Object.getOwnPropertyDescriptor(RunInRootFrame.DetermineComponentFrameRoot, 'name'); // Before ES6, the `name` property was not configurable. | ||
if (namePropDescriptor && namePropDescriptor.configurable) { | ||
// V8 utilizes a function's `name` property when generating a stack trace. | ||
Object.defineProperty(RunInRootFrame.DetermineComponentFrameRoot, // Configurable properties can be updated even if its writable descriptor | ||
// is set to `false`. | ||
// $FlowFixMe[cannot-write] | ||
'name', { | ||
value: 'DetermineComponentFrameRoot' | ||
}); | ||
} | ||
try { | ||
var _RunInRootFrame$Deter = RunInRootFrame.DetermineComponentFrameRoot(), | ||
sampleStack = _RunInRootFrame$Deter[0], | ||
controlStack = _RunInRootFrame$Deter[1]; | ||
if (sampleStack && controlStack) { | ||
// This extracts the first frame from the sample that isn't also in the control. | ||
// Skipping one frame that we assume is the frame that calls the two. | ||
var sampleLines = sampleStack.split('\n'); | ||
var controlLines = controlStack.split('\n'); | ||
var s = 0; | ||
var c = 0; | ||
while (s < sampleLines.length && !sampleLines[s].includes('DetermineComponentFrameRoot')) { | ||
s++; | ||
} | ||
while (c < controlLines.length && !controlLines[c].includes('DetermineComponentFrameRoot')) { | ||
c++; | ||
} // We couldn't find our intentionally injected common root frame, attempt | ||
// to find another common root frame by search from the bottom of the | ||
// control stack... | ||
if (s === sampleLines.length || c === controlLines.length) { | ||
s = sampleLines.length - 1; | ||
c = controlLines.length - 1; | ||
while (s >= 1 && c >= 0 && sampleLines[s] !== controlLines[c]) { | ||
// We expect at least one stack frame to be shared. | ||
// Typically this will be the root most one. However, stack frames may be | ||
// cut off due to maximum stack limits. In this case, one maybe cut off | ||
// earlier than the other. We assume that the sample is longer or the same | ||
// and there for cut off earlier. So we should find the root most frame in | ||
// the sample somewhere in the control. | ||
c--; | ||
} | ||
} | ||
for (; s >= 1 && c >= 0; s--, c--) { | ||
// Next we find the first one that isn't the same which should be the | ||
// frame that called our sample function and the control. | ||
if (sampleLines[s] !== controlLines[c]) { | ||
// In V8, the first line is describing the message but other VMs don't. | ||
// If we're about to return the first line, and the control is also on the same | ||
// line, that's a pretty good indicator that our sample threw at same line as | ||
// the control. I.e. before we entered the sample frame. So we ignore this result. | ||
// This can happen if you passed a class to function component, or non-function. | ||
if (s !== 1 || c !== 1) { | ||
do { | ||
s--; | ||
c--; // We may still have similar intermediate frames from the construct call. | ||
// The next one that isn't the same should be our match though. | ||
if (c < 0 || sampleLines[s] !== controlLines[c]) { | ||
// V8 adds a "new" prefix for native classes. Let's remove it to make it prettier. | ||
var _frame = '\n' + sampleLines[s].replace(' at new ', ' at '); // If our component frame is labeled "<anonymous>" | ||
// but we have a user-provided "displayName" | ||
// splice it in to make the stack more readable. | ||
if (fn.displayName && _frame.includes('<anonymous>')) { | ||
_frame = _frame.replace('<anonymous>', fn.displayName); | ||
} | ||
if (true) { | ||
if (typeof fn === 'function') { | ||
componentFrameCache.set(fn, _frame); | ||
} | ||
} // Return the line we found. | ||
return _frame; | ||
} | ||
} while (s >= 1 && c >= 0); | ||
} | ||
break; | ||
} | ||
} | ||
function getOwner() { | ||
var dispatcher = ReactSharedInternals.A; | ||
return null === dispatcher ? null : dispatcher.getOwner(); | ||
} | ||
} finally { | ||
reentry = false; | ||
{ | ||
ReactSharedInternals.H = previousDispatcher; | ||
reenableLogs(); | ||
} | ||
Error.prepareStackTrace = previousPrepareStackTrace; | ||
} // Fallback to just using the name if we couldn't make it throw. | ||
var name = fn ? fn.displayName || fn.name : ''; | ||
var syntheticFrame = name ? describeBuiltInComponentFrame(name) : ''; | ||
{ | ||
if (typeof fn === 'function') { | ||
componentFrameCache.set(fn, syntheticFrame); | ||
} | ||
} | ||
return syntheticFrame; | ||
} | ||
function describeFunctionComponentFrame(fn) { | ||
{ | ||
return describeNativeComponentFrame(fn, false); | ||
} | ||
} | ||
function shouldConstruct(Component) { | ||
var prototype = Component.prototype; | ||
return !!(prototype && prototype.isReactComponent); | ||
} | ||
function describeUnknownElementTypeFrameInDEV(type) { | ||
if (type == null) { | ||
return ''; | ||
} | ||
if (typeof type === 'function') { | ||
{ | ||
return describeNativeComponentFrame(type, shouldConstruct(type)); | ||
} | ||
} | ||
if (typeof type === 'string') { | ||
return describeBuiltInComponentFrame(type); | ||
} | ||
switch (type) { | ||
case REACT_SUSPENSE_TYPE: | ||
return describeBuiltInComponentFrame('Suspense'); | ||
case REACT_SUSPENSE_LIST_TYPE: | ||
return describeBuiltInComponentFrame('SuspenseList'); | ||
} | ||
if (typeof type === 'object') { | ||
switch (type.$$typeof) { | ||
case REACT_FORWARD_REF_TYPE: | ||
return describeFunctionComponentFrame(type.render); | ||
case REACT_MEMO_TYPE: | ||
// Memo may contain any component type so we recursively resolve it. | ||
return describeUnknownElementTypeFrameInDEV(type.type); | ||
case REACT_LAZY_TYPE: | ||
{ | ||
var lazyComponent = type; | ||
var payload = lazyComponent._payload; | ||
var init = lazyComponent._init; | ||
try { | ||
// Lazy may contain any component type so we recursively resolve it. | ||
return describeUnknownElementTypeFrameInDEV(init(payload)); | ||
} catch (x) {} | ||
} | ||
} | ||
} | ||
return ''; | ||
} | ||
var REACT_CLIENT_REFERENCE = Symbol.for('react.client.reference'); | ||
var specialPropKeyWarningShown; | ||
var didWarnAboutElementRef; | ||
{ | ||
didWarnAboutElementRef = {}; | ||
} | ||
function hasValidRef(config) { | ||
{ | ||
if (hasOwnProperty.call(config, 'ref')) { | ||
var getter = Object.getOwnPropertyDescriptor(config, 'ref').get; | ||
if (getter && getter.isReactWarning) { | ||
return false; | ||
function hasValidRef(config) { | ||
if (hasOwnProperty.call(config, "ref")) { | ||
var getter = Object.getOwnPropertyDescriptor(config, "ref").get; | ||
if (getter && getter.isReactWarning) return !1; | ||
} | ||
return void 0 !== config.ref; | ||
} | ||
} | ||
return config.ref !== undefined; | ||
} | ||
function hasValidKey(config) { | ||
{ | ||
if (hasOwnProperty.call(config, 'key')) { | ||
var getter = Object.getOwnPropertyDescriptor(config, 'key').get; | ||
if (getter && getter.isReactWarning) { | ||
return false; | ||
function hasValidKey(config) { | ||
if (hasOwnProperty.call(config, "key")) { | ||
var getter = Object.getOwnPropertyDescriptor(config, "key").get; | ||
if (getter && getter.isReactWarning) return !1; | ||
} | ||
return void 0 !== config.key; | ||
} | ||
} | ||
return config.key !== undefined; | ||
} | ||
function defineKeyPropWarningGetter(props, displayName) { | ||
{ | ||
var warnAboutAccessingKey = function () { | ||
if (!specialPropKeyWarningShown) { | ||
specialPropKeyWarningShown = true; | ||
error('%s: `key` is not a prop. Trying to access it will result ' + 'in `undefined` being returned. If you need to access the same ' + 'value within the child component, you should pass it as a different ' + 'prop. (https://react.dev/link/special-props)', displayName); | ||
function defineKeyPropWarningGetter(props, displayName) { | ||
function warnAboutAccessingKey() { | ||
specialPropKeyWarningShown || | ||
((specialPropKeyWarningShown = !0), | ||
console.error( | ||
"%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)", | ||
displayName | ||
)); | ||
} | ||
}; | ||
warnAboutAccessingKey.isReactWarning = true; | ||
Object.defineProperty(props, 'key', { | ||
get: warnAboutAccessingKey, | ||
configurable: true | ||
}); | ||
} | ||
} | ||
function elementRefGetterWithDeprecationWarning() { | ||
{ | ||
var componentName = getComponentNameFromType(this.type); | ||
if (!didWarnAboutElementRef[componentName]) { | ||
didWarnAboutElementRef[componentName] = true; | ||
error('Accessing element.ref was removed in React 19. ref is now a ' + 'regular prop. It will be removed from the JSX Element ' + 'type in a future release.'); | ||
} // An undefined `element.ref` is coerced to `null` for | ||
// backwards compatibility. | ||
var refProp = this.props.ref; | ||
return refProp !== undefined ? refProp : null; | ||
} | ||
} | ||
/** | ||
* Factory method to create a new React element. This no longer adheres to | ||
* the class pattern, so do not use new to call it. Also, instanceof check | ||
* will not work. Instead test $$typeof field against Symbol.for('react.element') to check | ||
* if something is a React Element. | ||
* | ||
* @param {*} type | ||
* @param {*} props | ||
* @param {*} key | ||
* @param {string|object} ref | ||
* @param {*} owner | ||
* @param {*} self A *temporary* helper to detect places where `this` is | ||
* different from the `owner` when React.createElement is called, so that we | ||
* can warn. We want to get rid of owner and replace string `ref`s with arrow | ||
* functions, and as long as `this` and owner are the same, there will be no | ||
* change in behavior. | ||
* @param {*} source An annotation object (added by a transpiler or otherwise) | ||
* indicating filename, line number, and/or other information. | ||
* @internal | ||
*/ | ||
function ReactElement(type, key, _ref, self, source, owner, props) { | ||
var ref; | ||
{ | ||
// When enableRefAsProp is on, ignore whatever was passed as the ref | ||
// argument and treat `props.ref` as the source of truth. The only thing we | ||
// use this for is `element.ref`, which will log a deprecation warning on | ||
// access. In the next release, we can remove `element.ref` as well as the | ||
// `ref` argument. | ||
var refProp = props.ref; // An undefined `element.ref` is coerced to `null` for | ||
// backwards compatibility. | ||
ref = refProp !== undefined ? refProp : null; | ||
} | ||
var element; | ||
{ | ||
// In dev, make `ref` a non-enumerable property with a warning. It's non- | ||
// enumerable so that test matchers and serializers don't access it and | ||
// trigger the warning. | ||
// | ||
// `ref` will be removed from the element completely in a future release. | ||
element = { | ||
// This tag allows us to uniquely identify this as a React Element | ||
$$typeof: REACT_ELEMENT_TYPE, | ||
// Built-in properties that belong on the element | ||
type: type, | ||
key: key, | ||
props: props, | ||
// Record the component responsible for creating this element. | ||
_owner: owner | ||
}; | ||
if (ref !== null) { | ||
Object.defineProperty(element, 'ref', { | ||
enumerable: false, | ||
get: elementRefGetterWithDeprecationWarning | ||
warnAboutAccessingKey.isReactWarning = !0; | ||
Object.defineProperty(props, "key", { | ||
get: warnAboutAccessingKey, | ||
configurable: !0 | ||
}); | ||
} else { | ||
// Don't warn on access if a ref is not given. This reduces false | ||
// positives in cases where a test serializer uses | ||
// getOwnPropertyDescriptors to compare objects, like Jest does, which is | ||
// a problem because it bypasses non-enumerability. | ||
// | ||
// So unfortunately this will trigger a false positive warning in Jest | ||
// when the diff is printed: | ||
// | ||
// expect(<div ref={ref} />).toEqual(<span ref={ref} />); | ||
// | ||
// A bit sketchy, but this is what we've done for the `props.key` and | ||
// `props.ref` accessors for years, which implies it will be good enough | ||
// for `element.ref`, too. Let's see if anyone complains. | ||
Object.defineProperty(element, 'ref', { | ||
enumerable: false, | ||
} | ||
function elementRefGetterWithDeprecationWarning() { | ||
var componentName = getComponentNameFromType(this.type); | ||
didWarnAboutElementRef[componentName] || | ||
((didWarnAboutElementRef[componentName] = !0), | ||
console.error( | ||
"Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release." | ||
)); | ||
componentName = this.props.ref; | ||
return void 0 !== componentName ? componentName : null; | ||
} | ||
function ReactElement( | ||
type, | ||
key, | ||
_ref, | ||
self, | ||
source, | ||
owner, | ||
props, | ||
debugStack, | ||
debugTask | ||
) { | ||
_ref = props.ref; | ||
type = { | ||
$$typeof: REACT_ELEMENT_TYPE, | ||
type: type, | ||
key: key, | ||
props: props, | ||
_owner: owner | ||
}; | ||
null !== (void 0 !== _ref ? _ref : null) | ||
? Object.defineProperty(type, "ref", { | ||
enumerable: !1, | ||
get: elementRefGetterWithDeprecationWarning | ||
}) | ||
: Object.defineProperty(type, "ref", { enumerable: !1, value: null }); | ||
type._store = {}; | ||
Object.defineProperty(type._store, "validated", { | ||
configurable: !1, | ||
enumerable: !1, | ||
writable: !0, | ||
value: 0 | ||
}); | ||
Object.defineProperty(type, "_debugInfo", { | ||
configurable: !1, | ||
enumerable: !1, | ||
writable: !0, | ||
value: null | ||
}); | ||
Object.defineProperty(type, "_debugStack", { | ||
configurable: !1, | ||
enumerable: !1, | ||
writable: !0, | ||
value: debugStack | ||
}); | ||
Object.defineProperty(type, "_debugTask", { | ||
configurable: !1, | ||
enumerable: !1, | ||
writable: !0, | ||
value: debugTask | ||
}); | ||
Object.freeze && (Object.freeze(type.props), Object.freeze(type)); | ||
return type; | ||
} | ||
} | ||
{ | ||
// The validation flag is currently mutative. We put it on | ||
// an external backing store so that we can freeze the whole object. | ||
// This can be replaced with a WeakMap once they are implemented in | ||
// commonly used development environments. | ||
element._store = {}; // To make comparing ReactElements easier for testing purposes, we make | ||
// the validation flag non-enumerable (where possible, which should | ||
// include every environment we run tests in), so the test framework | ||
// ignores it. | ||
Object.defineProperty(element._store, 'validated', { | ||
configurable: false, | ||
enumerable: false, | ||
writable: true, | ||
value: false | ||
}); // debugInfo contains Server Component debug information. | ||
Object.defineProperty(element, '_debugInfo', { | ||
configurable: false, | ||
enumerable: false, | ||
writable: true, | ||
value: null | ||
}); | ||
if (Object.freeze) { | ||
Object.freeze(element.props); | ||
Object.freeze(element); | ||
} | ||
} | ||
return element; | ||
} | ||
var didWarnAboutKeySpread = {}; | ||
/** | ||
* https://github.com/reactjs/rfcs/pull/107 | ||
* @param {*} type | ||
* @param {object} props | ||
* @param {string} key | ||
*/ | ||
function jsxDEV$1(type, config, maybeKey, isStaticChildren, source, self) { | ||
{ | ||
if (!isValidElementType(type)) { | ||
// This is an invalid element type. | ||
// | ||
// We warn in this case but don't throw. We expect the element creation to | ||
// succeed and there will likely be errors in render. | ||
var info = ''; | ||
if (type === undefined || typeof type === 'object' && type !== null && Object.keys(type).length === 0) { | ||
info += ' You likely forgot to export your component from the file ' + "it's defined in, or you might have mixed up default and named imports."; | ||
} | ||
var typeString; | ||
if (type === null) { | ||
typeString = 'null'; | ||
} else if (isArray(type)) { | ||
typeString = 'array'; | ||
} else if (type !== undefined && type.$$typeof === REACT_ELEMENT_TYPE) { | ||
typeString = "<" + (getComponentNameFromType(type.type) || 'Unknown') + " />"; | ||
info = ' Did you accidentally export a JSX literal instead of a component?'; | ||
} else { | ||
typeString = typeof type; | ||
} | ||
error('React.jsx: type is invalid -- expected a string (for ' + 'built-in components) or a class/function (for composite ' + 'components) but got: %s.%s', typeString, info); | ||
} else { | ||
// This is a valid element type. | ||
// Skip key warning if the type isn't valid since our key validation logic | ||
// doesn't expect a non-string/function type and can throw confusing | ||
// errors. We don't want exception behavior to differ between dev and | ||
// prod. (Rendering will throw with a helpful message and as soon as the | ||
// type is fixed, the key warnings will appear.) | ||
function jsxDEVImpl( | ||
type, | ||
config, | ||
maybeKey, | ||
isStaticChildren, | ||
source, | ||
self, | ||
debugStack, | ||
debugTask | ||
) { | ||
var children = config.children; | ||
if (children !== undefined) { | ||
if (isStaticChildren) { | ||
if (isArray(children)) { | ||
for (var i = 0; i < children.length; i++) { | ||
validateChildKeys(children[i], type); | ||
} | ||
if (Object.freeze) { | ||
Object.freeze(children); | ||
} | ||
} else { | ||
error('React.jsx: Static children should always be an array. ' + 'You are likely explicitly calling React.jsxs or React.jsxDEV. ' + 'Use the Babel transform instead.'); | ||
} | ||
} else { | ||
validateChildKeys(children, type); | ||
} | ||
if (void 0 !== children) | ||
if (isStaticChildren) | ||
if (isArrayImpl(children)) { | ||
for ( | ||
isStaticChildren = 0; | ||
isStaticChildren < children.length; | ||
isStaticChildren++ | ||
) | ||
validateChildKeys(children[isStaticChildren]); | ||
Object.freeze && Object.freeze(children); | ||
} else | ||
console.error( | ||
"React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead." | ||
); | ||
else validateChildKeys(children); | ||
if (hasOwnProperty.call(config, "key")) { | ||
children = getComponentNameFromType(type); | ||
var keys = Object.keys(config).filter(function (k) { | ||
return "key" !== k; | ||
}); | ||
isStaticChildren = | ||
0 < keys.length | ||
? "{key: someKey, " + keys.join(": ..., ") + ": ...}" | ||
: "{key: someKey}"; | ||
didWarnAboutKeySpread[children + isStaticChildren] || | ||
((keys = | ||
0 < keys.length ? "{" + keys.join(": ..., ") + ": ...}" : "{}"), | ||
console.error( | ||
'A props object containing a "key" prop is being spread into JSX:\n let props = %s;\n <%s {...props} />\nReact keys must be passed directly to JSX without using spread:\n let props = %s;\n <%s key={someKey} {...props} />', | ||
isStaticChildren, | ||
children, | ||
keys, | ||
children | ||
), | ||
(didWarnAboutKeySpread[children + isStaticChildren] = !0)); | ||
} | ||
} // Warn about key spread regardless of whether the type is valid. | ||
if (hasOwnProperty.call(config, 'key')) { | ||
var componentName = getComponentNameFromType(type); | ||
var keys = Object.keys(config).filter(function (k) { | ||
return k !== 'key'; | ||
}); | ||
var beforeExample = keys.length > 0 ? '{key: someKey, ' + keys.join(': ..., ') + ': ...}' : '{key: someKey}'; | ||
if (!didWarnAboutKeySpread[componentName + beforeExample]) { | ||
var afterExample = keys.length > 0 ? '{' + keys.join(': ..., ') + ': ...}' : '{}'; | ||
error('A props object containing a "key" prop is being spread into JSX:\n' + ' let props = %s;\n' + ' <%s {...props} />\n' + 'React keys must be passed directly to JSX without using spread:\n' + ' let props = %s;\n' + ' <%s key={someKey} {...props} />', beforeExample, componentName, afterExample, componentName); | ||
didWarnAboutKeySpread[componentName + beforeExample] = true; | ||
} | ||
children = null; | ||
void 0 !== maybeKey && | ||
(checkKeyStringCoercion(maybeKey), (children = "" + maybeKey)); | ||
hasValidKey(config) && | ||
(checkKeyStringCoercion(config.key), (children = "" + config.key)); | ||
hasValidRef(config); | ||
if ("key" in config) { | ||
maybeKey = {}; | ||
for (var propName in config) | ||
"key" !== propName && (maybeKey[propName] = config[propName]); | ||
} else maybeKey = config; | ||
children && | ||
((config = | ||
"function" === typeof type | ||
? type.displayName || type.name || "Unknown" | ||
: type), | ||
children && defineKeyPropWarningGetter(maybeKey, config)); | ||
return ReactElement( | ||
type, | ||
children, | ||
null, | ||
self, | ||
source, | ||
getOwner(), | ||
maybeKey, | ||
debugStack, | ||
debugTask | ||
); | ||
} | ||
var key = null; | ||
var ref = null; // Currently, key can be spread in as a prop. This causes a potential | ||
// issue if key is also explicitly declared (ie. <div {...props} key="Hi" /> | ||
// or <div key="Hi" {...props} /> ). We want to deprecate key spread, | ||
// but as an intermediary step, we will use jsxDEV for everything except | ||
// <div {...props} key="Hi" />, because we aren't currently able to tell if | ||
// key is explicitly declared to be undefined or not. | ||
if (maybeKey !== undefined) { | ||
{ | ||
checkKeyStringCoercion(maybeKey); | ||
} | ||
key = '' + maybeKey; | ||
function validateChildKeys(node) { | ||
"object" === typeof node && | ||
null !== node && | ||
node.$$typeof === REACT_ELEMENT_TYPE && | ||
node._store && | ||
(node._store.validated = 1); | ||
} | ||
if (hasValidKey(config)) { | ||
{ | ||
checkKeyStringCoercion(config.key); | ||
} | ||
key = '' + config.key; | ||
} | ||
if (hasValidRef(config)) ; | ||
var props; | ||
if (!('key' in config)) { | ||
// If key was not spread in, we can reuse the original props object. This | ||
// only works for `jsx`, not `createElement`, because `jsx` is a compiler | ||
// target and the compiler always passes a new object. For `createElement`, | ||
// we can't assume a new object is passed every time because it can be | ||
// called manually. | ||
// | ||
// Spreading key is a warning in dev. In a future release, we will not | ||
// remove a spread key from the props object. (But we'll still warn.) We'll | ||
// always pass the object straight through. | ||
props = config; | ||
} else { | ||
// We need to remove reserved props (key, prop, ref). Create a fresh props | ||
// object and copy over all the non-reserved props. We don't use `delete` | ||
// because in V8 it will deopt the object to dictionary mode. | ||
props = {}; | ||
for (var propName in config) { | ||
// Skip over reserved prop names | ||
if (propName !== 'key' && (enableRefAsProp )) { | ||
{ | ||
props[propName] = config[propName]; | ||
} | ||
} | ||
} | ||
} | ||
if (key || !enableRefAsProp ) { | ||
var displayName = typeof type === 'function' ? type.displayName || type.name || 'Unknown' : type; | ||
if (key) { | ||
defineKeyPropWarningGetter(props, displayName); | ||
} | ||
} | ||
var element = ReactElement(type, key, ref, self, source, ReactSharedInternals.owner, props); | ||
if (type === REACT_FRAGMENT_TYPE) { | ||
validateFragmentProps(element); | ||
} | ||
return element; | ||
} | ||
} | ||
function getDeclarationErrorAddendum() { | ||
{ | ||
if (ReactSharedInternals.owner) { | ||
var name = getComponentNameFromType(ReactSharedInternals.owner.type); | ||
if (name) { | ||
return '\n\nCheck the render method of `' + name + '`.'; | ||
} | ||
} | ||
return ''; | ||
} | ||
} | ||
/** | ||
* Ensure that every element either is passed in a static location, in an | ||
* array with an explicit keys property defined, or in an object literal | ||
* with valid key property. | ||
* | ||
* @internal | ||
* @param {ReactNode} node Statically passed child of any type. | ||
* @param {*} parentType node's parent's type. | ||
*/ | ||
function validateChildKeys(node, parentType) { | ||
{ | ||
if (typeof node !== 'object' || !node) { | ||
return; | ||
} | ||
if (node.$$typeof === REACT_CLIENT_REFERENCE) ; else if (isArray(node)) { | ||
for (var i = 0; i < node.length; i++) { | ||
var child = node[i]; | ||
if (isValidElement(child)) { | ||
validateExplicitKey(child, parentType); | ||
} | ||
} | ||
} else if (isValidElement(node)) { | ||
// This element was passed in a valid location. | ||
if (node._store) { | ||
node._store.validated = true; | ||
} | ||
} else { | ||
var iteratorFn = getIteratorFn(node); | ||
if (typeof iteratorFn === 'function') { | ||
// Entry iterators used to provide implicit keys, | ||
// but now we print a separate warning for them later. | ||
if (iteratorFn !== node.entries) { | ||
var iterator = iteratorFn.call(node); | ||
var step; | ||
while (!(step = iterator.next()).done) { | ||
if (isValidElement(step.value)) { | ||
validateExplicitKey(step.value, parentType); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
/** | ||
* Verifies the object is a ReactElement. | ||
* See https://reactjs.org/docs/react-api.html#isvalidelement | ||
* @param {?object} object | ||
* @return {boolean} True if `object` is a ReactElement. | ||
* @final | ||
*/ | ||
function isValidElement(object) { | ||
return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; | ||
} | ||
var ownerHasKeyUseWarning = {}; | ||
/** | ||
* Warn if the element doesn't have an explicit key assigned to it. | ||
* This element is in an array. The array could grow and shrink or be | ||
* reordered. All children that haven't already been validated are required to | ||
* have a "key" property assigned to it. Error statuses are cached so a warning | ||
* will only be shown once. | ||
* | ||
* @internal | ||
* @param {ReactElement} element Element that requires a key. | ||
* @param {*} parentType element's parent's type. | ||
*/ | ||
function validateExplicitKey(element, parentType) { | ||
{ | ||
if (!element._store || element._store.validated || element.key != null) { | ||
return; | ||
} | ||
element._store.validated = true; | ||
var currentComponentErrorInfo = getCurrentComponentErrorInfo(parentType); | ||
if (ownerHasKeyUseWarning[currentComponentErrorInfo]) { | ||
return; | ||
} | ||
ownerHasKeyUseWarning[currentComponentErrorInfo] = true; // Usually the current owner is the offender, but if it accepts children as a | ||
// property, it may be the creator of the child that's responsible for | ||
// assigning it a key. | ||
var childOwner = ''; | ||
if (element && element._owner != null && element._owner !== ReactSharedInternals.owner) { | ||
var ownerName = null; | ||
if (typeof element._owner.tag === 'number') { | ||
ownerName = getComponentNameFromType(element._owner.type); | ||
} else if (typeof element._owner.name === 'string') { | ||
ownerName = element._owner.name; | ||
} // Give the component that originally created this child. | ||
childOwner = " It was passed a child from " + ownerName + "."; | ||
} | ||
setCurrentlyValidatingElement(element); | ||
error('Each child in a list should have a unique "key" prop.' + '%s%s See https://react.dev/link/warning-keys for more information.', currentComponentErrorInfo, childOwner); | ||
setCurrentlyValidatingElement(null); | ||
} | ||
} | ||
function setCurrentlyValidatingElement(element) { | ||
{ | ||
if (element) { | ||
var stack = describeUnknownElementTypeFrameInDEV(element.type); | ||
ReactSharedInternals.setExtraStackFrame(stack); | ||
} else { | ||
ReactSharedInternals.setExtraStackFrame(null); | ||
} | ||
} | ||
} | ||
function getCurrentComponentErrorInfo(parentType) { | ||
{ | ||
var info = getDeclarationErrorAddendum(); | ||
if (!info) { | ||
var parentName = getComponentNameFromType(parentType); | ||
if (parentName) { | ||
info = "\n\nCheck the top-level render call using <" + parentName + ">."; | ||
} | ||
} | ||
return info; | ||
} | ||
} | ||
/** | ||
* Given a fragment, validate that it can only be provided with fragment props | ||
* @param {ReactElement} fragment | ||
*/ | ||
function validateFragmentProps(fragment) { | ||
// TODO: Move this to render phase instead of at element creation. | ||
{ | ||
var keys = Object.keys(fragment.props); | ||
for (var i = 0; i < keys.length; i++) { | ||
var key = keys[i]; | ||
if (key !== 'children' && key !== 'key') { | ||
setCurrentlyValidatingElement(fragment); | ||
error('Invalid prop `%s` supplied to `React.Fragment`. ' + 'React.Fragment can only have `key` and `children` props.', key); | ||
setCurrentlyValidatingElement(null); | ||
break; | ||
} | ||
} | ||
} | ||
} | ||
var jsxDEV = jsxDEV$1 ; | ||
exports.Fragment = REACT_FRAGMENT_TYPE; | ||
exports.jsxDEV = jsxDEV; | ||
var React = require("react"), | ||
REACT_ELEMENT_TYPE = Symbol.for("react.transitional.element"), | ||
REACT_PORTAL_TYPE = Symbol.for("react.portal"), | ||
REACT_FRAGMENT_TYPE = Symbol.for("react.fragment"), | ||
REACT_STRICT_MODE_TYPE = Symbol.for("react.strict_mode"), | ||
REACT_PROFILER_TYPE = Symbol.for("react.profiler"); | ||
Symbol.for("react.provider"); | ||
var REACT_CONSUMER_TYPE = Symbol.for("react.consumer"), | ||
REACT_CONTEXT_TYPE = Symbol.for("react.context"), | ||
REACT_FORWARD_REF_TYPE = Symbol.for("react.forward_ref"), | ||
REACT_SUSPENSE_TYPE = Symbol.for("react.suspense"), | ||
REACT_SUSPENSE_LIST_TYPE = Symbol.for("react.suspense_list"), | ||
REACT_MEMO_TYPE = Symbol.for("react.memo"), | ||
REACT_LAZY_TYPE = Symbol.for("react.lazy"), | ||
REACT_CLIENT_REFERENCE = Symbol.for("react.client.reference"), | ||
ReactSharedInternals = | ||
React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE, | ||
hasOwnProperty = Object.prototype.hasOwnProperty, | ||
isArrayImpl = Array.isArray; | ||
new ("function" === typeof WeakMap ? WeakMap : Map)(); | ||
var createTask = console.createTask | ||
? console.createTask | ||
: function () { | ||
return null; | ||
}, | ||
specialPropKeyWarningShown; | ||
var didWarnAboutElementRef = {}; | ||
var didWarnAboutKeySpread = {}; | ||
exports.Fragment = REACT_FRAGMENT_TYPE; | ||
exports.jsxDEV = function ( | ||
type, | ||
config, | ||
maybeKey, | ||
isStaticChildren, | ||
source, | ||
self | ||
) { | ||
return jsxDEVImpl( | ||
type, | ||
config, | ||
maybeKey, | ||
isStaticChildren, | ||
source, | ||
self, | ||
Error("react-stack-top-frame"), | ||
createTask(getTaskName(type)) | ||
); | ||
}; | ||
})(); | ||
} |
/** | ||
* @license React | ||
* react-jsx-dev-runtime.production.min.js | ||
* react-jsx-dev-runtime.production.js | ||
* | ||
@@ -11,10 +11,5 @@ * Copyright (c) Meta Platforms, Inc. and affiliates. | ||
'use strict'; | ||
// ATTENTION | ||
const REACT_FRAGMENT_TYPE = Symbol.for('react.fragment'); | ||
const jsxDEV = undefined; | ||
"use strict"; | ||
var REACT_FRAGMENT_TYPE = Symbol.for("react.fragment"); | ||
exports.Fragment = REACT_FRAGMENT_TYPE; | ||
exports.jsxDEV = jsxDEV; | ||
exports.jsxDEV = void 0; |
/** | ||
* @license React | ||
* react-jsx-dev-runtime.profiling.min.js | ||
* react-jsx-dev-runtime.profiling.js | ||
* | ||
@@ -11,10 +11,5 @@ * Copyright (c) Meta Platforms, Inc. and affiliates. | ||
'use strict'; | ||
// ATTENTION | ||
const REACT_FRAGMENT_TYPE = Symbol.for('react.fragment'); | ||
const jsxDEV = undefined; | ||
"use strict"; | ||
var REACT_FRAGMENT_TYPE = Symbol.for("react.fragment"); | ||
exports.Fragment = REACT_FRAGMENT_TYPE; | ||
exports.jsxDEV = jsxDEV; | ||
exports.jsxDEV = void 0; |
@@ -11,1288 +11,335 @@ /** | ||
'use strict'; | ||
if (process.env.NODE_ENV !== "production") { | ||
(function() { | ||
'use strict'; | ||
var React = require('react'); | ||
// ATTENTION | ||
// When adding new symbols to this file, | ||
// Please consider also adding to 'react-devtools-shared/src/backend/ReactSymbols' | ||
// The Symbol used to tag the ReactElement-like types. | ||
var REACT_ELEMENT_TYPE = Symbol.for('react.element'); | ||
var REACT_PORTAL_TYPE = Symbol.for('react.portal'); | ||
var REACT_FRAGMENT_TYPE = Symbol.for('react.fragment'); | ||
var REACT_STRICT_MODE_TYPE = Symbol.for('react.strict_mode'); | ||
var REACT_PROFILER_TYPE = Symbol.for('react.profiler'); | ||
var REACT_PROVIDER_TYPE = Symbol.for('react.provider'); // TODO: Delete with enableRenderableContext | ||
var REACT_CONSUMER_TYPE = Symbol.for('react.consumer'); | ||
var REACT_CONTEXT_TYPE = Symbol.for('react.context'); | ||
var REACT_FORWARD_REF_TYPE = Symbol.for('react.forward_ref'); | ||
var REACT_SUSPENSE_TYPE = Symbol.for('react.suspense'); | ||
var REACT_SUSPENSE_LIST_TYPE = Symbol.for('react.suspense_list'); | ||
var REACT_MEMO_TYPE = Symbol.for('react.memo'); | ||
var REACT_LAZY_TYPE = Symbol.for('react.lazy'); | ||
var REACT_OFFSCREEN_TYPE = Symbol.for('react.offscreen'); | ||
var MAYBE_ITERATOR_SYMBOL = Symbol.iterator; | ||
var FAUX_ITERATOR_SYMBOL = '@@iterator'; | ||
function getIteratorFn(maybeIterable) { | ||
if (maybeIterable === null || typeof maybeIterable !== 'object') { | ||
return null; | ||
} | ||
var maybeIterator = MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]; | ||
if (typeof maybeIterator === 'function') { | ||
return maybeIterator; | ||
} | ||
return null; | ||
} | ||
var ReactSharedInternals = React.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE; | ||
function error(format) { | ||
{ | ||
{ | ||
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { | ||
args[_key2 - 1] = arguments[_key2]; | ||
"use strict"; | ||
"production" !== process.env.NODE_ENV && | ||
(function () { | ||
function getComponentNameFromType(type) { | ||
if (null == type) return null; | ||
if ("function" === typeof type) | ||
return type.$$typeof === REACT_CLIENT_REFERENCE | ||
? null | ||
: type.displayName || type.name || null; | ||
if ("string" === typeof type) return type; | ||
switch (type) { | ||
case REACT_FRAGMENT_TYPE: | ||
return "Fragment"; | ||
case REACT_PORTAL_TYPE: | ||
return "Portal"; | ||
case REACT_PROFILER_TYPE: | ||
return "Profiler"; | ||
case REACT_STRICT_MODE_TYPE: | ||
return "StrictMode"; | ||
case REACT_SUSPENSE_TYPE: | ||
return "Suspense"; | ||
case REACT_SUSPENSE_LIST_TYPE: | ||
return "SuspenseList"; | ||
} | ||
printWarning('error', format, args); | ||
} | ||
} | ||
} | ||
function printWarning(level, format, args) { | ||
// When changing this logic, you might want to also | ||
// update consoleWithStackDev.www.js as well. | ||
{ | ||
var stack = ReactSharedInternals.getStackAddendum(); | ||
if (stack !== '') { | ||
format += '%s'; | ||
args = args.concat([stack]); | ||
} // eslint-disable-next-line react-internal/safe-string-coercion | ||
var argsWithFormat = args.map(function (item) { | ||
return String(item); | ||
}); // Careful: RN currently depends on this prefix | ||
argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it | ||
// breaks IE9: https://github.com/facebook/react/issues/13610 | ||
// eslint-disable-next-line react-internal/no-production-logging | ||
Function.prototype.apply.call(console[level], console, argsWithFormat); | ||
} | ||
} | ||
// ----------------------------------------------------------------------------- | ||
var enableScopeAPI = false; // Experimental Create Event Handle API. | ||
var enableTransitionTracing = false; // No known bugs, but needs performance testing | ||
var enableLegacyHidden = false; // Enables unstable_avoidThisFallback feature in Fiber | ||
// as a normal prop instead of stripping it from the props object. | ||
// Passes `ref` as a normal prop instead of stripping it from the props object | ||
// during element creation. | ||
var enableRefAsProp = true; | ||
var enableRenderableContext = true; // Enables the `initialValue` option for `useDeferredValue` | ||
// stuff. Intended to enable React core members to more easily debug scheduling | ||
// issues in DEV builds. | ||
var enableDebugTracing = false; | ||
function getWrappedName(outerType, innerType, wrapperName) { | ||
var displayName = outerType.displayName; | ||
if (displayName) { | ||
return displayName; | ||
} | ||
var functionName = innerType.displayName || innerType.name || ''; | ||
return functionName !== '' ? wrapperName + "(" + functionName + ")" : wrapperName; | ||
} // Keep in sync with react-reconciler/getComponentNameFromFiber | ||
function getContextName(type) { | ||
return type.displayName || 'Context'; | ||
} | ||
var REACT_CLIENT_REFERENCE$2 = Symbol.for('react.client.reference'); // Note that the reconciler package should generally prefer to use getComponentNameFromFiber() instead. | ||
function getComponentNameFromType(type) { | ||
if (type == null) { | ||
// Host root, text node or just invalid type. | ||
return null; | ||
} | ||
if (typeof type === 'function') { | ||
if (type.$$typeof === REACT_CLIENT_REFERENCE$2) { | ||
// TODO: Create a convention for naming client references with debug info. | ||
if ("object" === typeof type) | ||
switch ( | ||
("number" === typeof type.tag && | ||
console.error( | ||
"Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue." | ||
), | ||
type.$$typeof) | ||
) { | ||
case REACT_CONTEXT_TYPE: | ||
return (type.displayName || "Context") + ".Provider"; | ||
case REACT_CONSUMER_TYPE: | ||
return (type._context.displayName || "Context") + ".Consumer"; | ||
case REACT_FORWARD_REF_TYPE: | ||
var innerType = type.render; | ||
type = type.displayName; | ||
type || | ||
((type = innerType.displayName || innerType.name || ""), | ||
(type = "" !== type ? "ForwardRef(" + type + ")" : "ForwardRef")); | ||
return type; | ||
case REACT_MEMO_TYPE: | ||
return ( | ||
(innerType = type.displayName || null), | ||
null !== innerType | ||
? innerType | ||
: getComponentNameFromType(type.type) || "Memo" | ||
); | ||
case REACT_LAZY_TYPE: | ||
innerType = type._payload; | ||
type = type._init; | ||
try { | ||
return getComponentNameFromType(type(innerType)); | ||
} catch (x) {} | ||
} | ||
return null; | ||
} | ||
return type.displayName || type.name || null; | ||
} | ||
if (typeof type === 'string') { | ||
return type; | ||
} | ||
switch (type) { | ||
case REACT_FRAGMENT_TYPE: | ||
return 'Fragment'; | ||
case REACT_PORTAL_TYPE: | ||
return 'Portal'; | ||
case REACT_PROFILER_TYPE: | ||
return 'Profiler'; | ||
case REACT_STRICT_MODE_TYPE: | ||
return 'StrictMode'; | ||
case REACT_SUSPENSE_TYPE: | ||
return 'Suspense'; | ||
case REACT_SUSPENSE_LIST_TYPE: | ||
return 'SuspenseList'; | ||
} | ||
if (typeof type === 'object') { | ||
{ | ||
if (typeof type.tag === 'number') { | ||
error('Received an unexpected object in getComponentNameFromType(). ' + 'This is likely a bug in React. Please file an issue.'); | ||
} | ||
function testStringCoercion(value) { | ||
return "" + value; | ||
} | ||
switch (type.$$typeof) { | ||
case REACT_PROVIDER_TYPE: | ||
{ | ||
return null; | ||
} | ||
case REACT_CONTEXT_TYPE: | ||
var context = type; | ||
{ | ||
return getContextName(context) + '.Provider'; | ||
} | ||
case REACT_CONSUMER_TYPE: | ||
{ | ||
var consumer = type; | ||
return getContextName(consumer._context) + '.Consumer'; | ||
} | ||
case REACT_FORWARD_REF_TYPE: | ||
return getWrappedName(type, type.render, 'ForwardRef'); | ||
case REACT_MEMO_TYPE: | ||
var outerName = type.displayName || null; | ||
if (outerName !== null) { | ||
return outerName; | ||
} | ||
return getComponentNameFromType(type.type) || 'Memo'; | ||
case REACT_LAZY_TYPE: | ||
{ | ||
var lazyComponent = type; | ||
var payload = lazyComponent._payload; | ||
var init = lazyComponent._init; | ||
try { | ||
return getComponentNameFromType(init(payload)); | ||
} catch (x) { | ||
return null; | ||
} | ||
} | ||
} | ||
} | ||
return null; | ||
} | ||
// $FlowFixMe[method-unbinding] | ||
var hasOwnProperty = Object.prototype.hasOwnProperty; | ||
var assign = Object.assign; | ||
/* | ||
* The `'' + value` pattern (used in perf-sensitive code) throws for Symbol | ||
* and Temporal.* types. See https://github.com/facebook/react/pull/22064. | ||
* | ||
* The functions in this module will throw an easier-to-understand, | ||
* easier-to-debug exception with a clear errors message message explaining the | ||
* problem. (Instead of a confusing exception thrown inside the implementation | ||
* of the `value` object). | ||
*/ | ||
// $FlowFixMe[incompatible-return] only called in DEV, so void return is not possible. | ||
function typeName(value) { | ||
{ | ||
// toStringTag is needed for namespaced types like Temporal.Instant | ||
var hasToStringTag = typeof Symbol === 'function' && Symbol.toStringTag; | ||
var type = hasToStringTag && value[Symbol.toStringTag] || value.constructor.name || 'Object'; // $FlowFixMe[incompatible-return] | ||
return type; | ||
} | ||
} // $FlowFixMe[incompatible-return] only called in DEV, so void return is not possible. | ||
function willCoercionThrow(value) { | ||
{ | ||
try { | ||
testStringCoercion(value); | ||
return false; | ||
} catch (e) { | ||
return true; | ||
} | ||
} | ||
} | ||
function testStringCoercion(value) { | ||
// If you ended up here by following an exception call stack, here's what's | ||
// happened: you supplied an object or symbol value to React (as a prop, key, | ||
// DOM attribute, CSS property, string ref, etc.) and when React tried to | ||
// coerce it to a string using `'' + value`, an exception was thrown. | ||
// | ||
// The most common types that will cause this exception are `Symbol` instances | ||
// and Temporal objects like `Temporal.Instant`. But any object that has a | ||
// `valueOf` or `[Symbol.toPrimitive]` method that throws will also cause this | ||
// exception. (Library authors do this to prevent users from using built-in | ||
// numeric operators like `+` or comparison operators like `>=` because custom | ||
// methods are needed to perform accurate arithmetic or comparison.) | ||
// | ||
// To fix the problem, coerce this object or symbol value to a string before | ||
// passing it to React. The most reliable way is usually `String(value)`. | ||
// | ||
// To find which value is throwing, check the browser or debugger console. | ||
// Before this exception was thrown, there should be `console.error` output | ||
// that shows the type (Symbol, Temporal.PlainDate, etc.) that caused the | ||
// problem and how that type was used: key, atrribute, input value prop, etc. | ||
// In most cases, this console output also shows the component and its | ||
// ancestor components where the exception happened. | ||
// | ||
// eslint-disable-next-line react-internal/safe-string-coercion | ||
return '' + value; | ||
} | ||
function checkKeyStringCoercion(value) { | ||
{ | ||
if (willCoercionThrow(value)) { | ||
error('The provided key is an unsupported type %s.' + ' This value must be coerced to a string before using it here.', typeName(value)); | ||
return testStringCoercion(value); // throw (to help callers find troubleshooting comments) | ||
} | ||
} | ||
} | ||
var REACT_CLIENT_REFERENCE$1 = Symbol.for('react.client.reference'); | ||
function isValidElementType(type) { | ||
if (typeof type === 'string' || typeof type === 'function') { | ||
return true; | ||
} // Note: typeof might be other than 'symbol' or 'number' (e.g. if it's a polyfill). | ||
if (type === REACT_FRAGMENT_TYPE || type === REACT_PROFILER_TYPE || enableDebugTracing || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || enableLegacyHidden || type === REACT_OFFSCREEN_TYPE || enableScopeAPI || enableTransitionTracing ) { | ||
return true; | ||
} | ||
if (typeof type === 'object' && type !== null) { | ||
if (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || !enableRenderableContext || type.$$typeof === REACT_CONSUMER_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || // This needs to include all possible module reference object | ||
// types supported by any Flight configuration anywhere since | ||
// we don't know which Flight build this will end up being used | ||
// with. | ||
type.$$typeof === REACT_CLIENT_REFERENCE$1 || type.getModuleId !== undefined) { | ||
return true; | ||
} | ||
} | ||
return false; | ||
} | ||
var isArrayImpl = Array.isArray; // eslint-disable-next-line no-redeclare | ||
function isArray(a) { | ||
return isArrayImpl(a); | ||
} | ||
// Helpers to patch console.logs to avoid logging during side-effect free | ||
// replaying on render function. This currently only patches the object | ||
// lazily which won't cover if the log function was extracted eagerly. | ||
// We could also eagerly patch the method. | ||
var disabledDepth = 0; | ||
var prevLog; | ||
var prevInfo; | ||
var prevWarn; | ||
var prevError; | ||
var prevGroup; | ||
var prevGroupCollapsed; | ||
var prevGroupEnd; | ||
function disabledLog() {} | ||
disabledLog.__reactDisabledLog = true; | ||
function disableLogs() { | ||
{ | ||
if (disabledDepth === 0) { | ||
/* eslint-disable react-internal/no-production-logging */ | ||
prevLog = console.log; | ||
prevInfo = console.info; | ||
prevWarn = console.warn; | ||
prevError = console.error; | ||
prevGroup = console.group; | ||
prevGroupCollapsed = console.groupCollapsed; | ||
prevGroupEnd = console.groupEnd; // https://github.com/facebook/react/issues/19099 | ||
var props = { | ||
configurable: true, | ||
enumerable: true, | ||
value: disabledLog, | ||
writable: true | ||
}; // $FlowFixMe[cannot-write] Flow thinks console is immutable. | ||
Object.defineProperties(console, { | ||
info: props, | ||
log: props, | ||
warn: props, | ||
error: props, | ||
group: props, | ||
groupCollapsed: props, | ||
groupEnd: props | ||
}); | ||
/* eslint-enable react-internal/no-production-logging */ | ||
} | ||
disabledDepth++; | ||
} | ||
} | ||
function reenableLogs() { | ||
{ | ||
disabledDepth--; | ||
if (disabledDepth === 0) { | ||
/* eslint-disable react-internal/no-production-logging */ | ||
var props = { | ||
configurable: true, | ||
enumerable: true, | ||
writable: true | ||
}; // $FlowFixMe[cannot-write] Flow thinks console is immutable. | ||
Object.defineProperties(console, { | ||
log: assign({}, props, { | ||
value: prevLog | ||
}), | ||
info: assign({}, props, { | ||
value: prevInfo | ||
}), | ||
warn: assign({}, props, { | ||
value: prevWarn | ||
}), | ||
error: assign({}, props, { | ||
value: prevError | ||
}), | ||
group: assign({}, props, { | ||
value: prevGroup | ||
}), | ||
groupCollapsed: assign({}, props, { | ||
value: prevGroupCollapsed | ||
}), | ||
groupEnd: assign({}, props, { | ||
value: prevGroupEnd | ||
}) | ||
}); | ||
/* eslint-enable react-internal/no-production-logging */ | ||
} | ||
if (disabledDepth < 0) { | ||
error('disabledDepth fell below zero. ' + 'This is a bug in React. Please file an issue.'); | ||
} | ||
} | ||
} | ||
var prefix; | ||
function describeBuiltInComponentFrame(name) { | ||
{ | ||
if (prefix === undefined) { | ||
// Extract the VM specific prefix used by each line. | ||
function checkKeyStringCoercion(value) { | ||
try { | ||
throw Error(); | ||
} catch (x) { | ||
var match = x.stack.trim().match(/\n( *(at )?)/); | ||
prefix = match && match[1] || ''; | ||
testStringCoercion(value); | ||
var JSCompiler_inline_result = !1; | ||
} catch (e) { | ||
JSCompiler_inline_result = !0; | ||
} | ||
} // We use the prefix to ensure our stacks line up with native stack frames. | ||
return '\n' + prefix + name; | ||
} | ||
} | ||
var reentry = false; | ||
var componentFrameCache; | ||
{ | ||
var PossiblyWeakMap = typeof WeakMap === 'function' ? WeakMap : Map; | ||
componentFrameCache = new PossiblyWeakMap(); | ||
} | ||
/** | ||
* Leverages native browser/VM stack frames to get proper details (e.g. | ||
* filename, line + col number) for a single component in a component stack. We | ||
* do this by: | ||
* (1) throwing and catching an error in the function - this will be our | ||
* control error. | ||
* (2) calling the component which will eventually throw an error that we'll | ||
* catch - this will be our sample error. | ||
* (3) diffing the control and sample error stacks to find the stack frame | ||
* which represents our component. | ||
*/ | ||
function describeNativeComponentFrame(fn, construct) { | ||
// If something asked for a stack inside a fake render, it should get ignored. | ||
if (!fn || reentry) { | ||
return ''; | ||
} | ||
{ | ||
var frame = componentFrameCache.get(fn); | ||
if (frame !== undefined) { | ||
return frame; | ||
if (JSCompiler_inline_result) { | ||
JSCompiler_inline_result = console; | ||
var JSCompiler_temp_const = JSCompiler_inline_result.error; | ||
var JSCompiler_inline_result$jscomp$0 = | ||
("function" === typeof Symbol && | ||
Symbol.toStringTag && | ||
value[Symbol.toStringTag]) || | ||
value.constructor.name || | ||
"Object"; | ||
JSCompiler_temp_const.call( | ||
JSCompiler_inline_result, | ||
"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.", | ||
JSCompiler_inline_result$jscomp$0 | ||
); | ||
return testStringCoercion(value); | ||