2017-11-15 09:05:34 -08:00
/ * *
2018-09-10 14:42:08 -07:00
* Copyright ( c ) Facebook , Inc . and its affiliates .
2017-11-15 09:05:34 -08:00
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree .
*
* @ noflow
2018-05-15 13:08:47 -07:00
* @ providesModule ReactNativeRenderer - prod
2017-11-15 09:05:34 -08:00
* @ preventMunge
2018-05-15 13:08:47 -07:00
* @ generated
2017-11-15 09:05:34 -08:00
* /
"use strict" ;
require ( "InitializeCore" ) ;
2018-07-24 14:45:35 -07:00
var ReactNativeViewConfigRegistry = require ( "ReactNativeViewConfigRegistry" ) ,
2017-11-15 09:05:34 -08:00
UIManager = require ( "UIManager" ) ,
2018-02-28 19:16:47 -08:00
RCTEventEmitter = require ( "RCTEventEmitter" ) ,
React = require ( "react" ) ,
2018-05-15 13:08:47 -07:00
deepDiffer = require ( "deepDiffer" ) ,
flattenStyle = require ( "flattenStyle" ) ,
2018-09-10 14:42:08 -07:00
TextInputState = require ( "TextInputState" ) ;
var ExceptionsManager = require ( "ExceptionsManager" ) ;
2018-07-24 14:45:35 -07:00
function invariant ( condition , format , a , b , c , d , e , f ) {
if ( ! condition ) {
condition = void 0 ;
if ( void 0 === format )
condition = Error (
"Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings."
) ;
else {
var args = [ a , b , c , d , e , f ] ,
argIndex = 0 ;
condition = Error (
format . replace ( /%s/g , function ( ) {
return args [ argIndex ++ ] ;
} )
) ;
condition . name = "Invariant Violation" ;
}
condition . framesToPop = 1 ;
throw condition ;
}
}
2018-09-10 14:42:08 -07:00
function invokeGuardedCallbackImpl ( name , func , context , a , b , c , d , e , f ) {
2017-11-15 09:05:34 -08:00
var funcArgs = Array . prototype . slice . call ( arguments , 3 ) ;
try {
func . apply ( context , funcArgs ) ;
} catch ( error ) {
2018-09-10 14:42:08 -07:00
this . onError ( error ) ;
2017-11-15 09:05:34 -08:00
}
}
2018-09-10 14:42:08 -07:00
var hasError = ! 1 ,
caughtError = null ,
hasRethrowError = ! 1 ,
rethrowError = null ,
reporter = {
onError : function ( error ) {
hasError = ! 0 ;
caughtError = error ;
2018-01-29 14:17:07 -08:00
}
2018-09-10 14:42:08 -07:00
} ;
function invokeGuardedCallback ( name , func , context , a , b , c , d , e , f ) {
hasError = ! 1 ;
caughtError = null ;
invokeGuardedCallbackImpl . apply ( reporter , arguments ) ;
}
function invokeGuardedCallbackAndCatchFirstError (
name ,
func ,
context ,
a ,
b ,
c ,
d ,
e ,
f
) {
invokeGuardedCallback . apply ( this , arguments ) ;
if ( hasError ) {
if ( hasError ) {
var error = caughtError ;
hasError = ! 1 ;
caughtError = null ;
} else
invariant (
! 1 ,
"clearCaughtError was called but no error was captured. This error is likely caused by a bug in React. Please file an issue."
) ,
( error = void 0 ) ;
hasRethrowError || ( ( hasRethrowError = ! 0 ) , ( rethrowError = error ) ) ;
2017-11-15 09:05:34 -08:00
}
}
var eventPluginOrder = null ,
namesToPlugins = { } ;
function recomputePluginOrdering ( ) {
if ( eventPluginOrder )
for ( var pluginName in namesToPlugins ) {
var pluginModule = namesToPlugins [ pluginName ] ,
pluginIndex = eventPluginOrder . indexOf ( pluginName ) ;
invariant (
- 1 < pluginIndex ,
"EventPluginRegistry: Cannot inject event plugins that do not exist in the plugin ordering, `%s`." ,
pluginName
) ;
if ( ! plugins [ pluginIndex ] ) {
invariant (
pluginModule . extractEvents ,
"EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `%s` does not." ,
pluginName
) ;
plugins [ pluginIndex ] = pluginModule ;
pluginIndex = pluginModule . eventTypes ;
for ( var eventName in pluginIndex ) {
var JSCompiler _inline _result = void 0 ;
var dispatchConfig = pluginIndex [ eventName ] ,
pluginModule$jscomp$0 = pluginModule ,
eventName$jscomp$0 = eventName ;
invariant (
! eventNameDispatchConfigs . hasOwnProperty ( eventName$jscomp$0 ) ,
"EventPluginHub: More than one plugin attempted to publish the same event name, `%s`." ,
eventName$jscomp$0
) ;
eventNameDispatchConfigs [ eventName$jscomp$0 ] = dispatchConfig ;
var phasedRegistrationNames = dispatchConfig . phasedRegistrationNames ;
if ( phasedRegistrationNames ) {
for ( JSCompiler _inline _result in phasedRegistrationNames )
phasedRegistrationNames . hasOwnProperty (
JSCompiler _inline _result
) &&
publishRegistrationName (
phasedRegistrationNames [ JSCompiler _inline _result ] ,
pluginModule$jscomp$0 ,
eventName$jscomp$0
) ;
JSCompiler _inline _result = ! 0 ;
} else
dispatchConfig . registrationName
? ( publishRegistrationName (
dispatchConfig . registrationName ,
pluginModule$jscomp$0 ,
eventName$jscomp$0
) ,
( JSCompiler _inline _result = ! 0 ) )
: ( JSCompiler _inline _result = ! 1 ) ;
invariant (
JSCompiler _inline _result ,
"EventPluginRegistry: Failed to publish event `%s` for plugin `%s`." ,
eventName ,
pluginName
) ;
}
}
}
}
function publishRegistrationName ( registrationName , pluginModule ) {
invariant (
! registrationNameModules [ registrationName ] ,
"EventPluginHub: More than one plugin attempted to publish the same registration name, `%s`." ,
registrationName
) ;
registrationNameModules [ registrationName ] = pluginModule ;
}
var plugins = [ ] ,
eventNameDispatchConfigs = { } ,
registrationNameModules = { } ,
getFiberCurrentPropsFromNode = null ,
getInstanceFromNode = null ,
getNodeFromInstance = null ;
function executeDispatch ( event , simulated , listener , inst ) {
simulated = event . type || "unknown-event" ;
event . currentTarget = getNodeFromInstance ( inst ) ;
2018-09-10 14:42:08 -07:00
invokeGuardedCallbackAndCatchFirstError ( simulated , listener , void 0 , event ) ;
2017-11-15 09:05:34 -08:00
event . currentTarget = null ;
}
function executeDirectDispatch ( event ) {
var dispatchListener = event . _dispatchListeners ,
dispatchInstance = event . _dispatchInstances ;
invariant (
! Array . isArray ( dispatchListener ) ,
"executeDirectDispatch(...): Invalid `event`."
) ;
event . currentTarget = dispatchListener
? getNodeFromInstance ( dispatchInstance )
: null ;
dispatchListener = dispatchListener ? dispatchListener ( event ) : null ;
event . currentTarget = null ;
event . _dispatchListeners = null ;
event . _dispatchInstances = null ;
return dispatchListener ;
}
function accumulateInto ( current , next ) {
invariant (
null != next ,
"accumulateInto(...): Accumulated items must not be null or undefined."
) ;
if ( null == current ) return next ;
if ( Array . isArray ( current ) ) {
if ( Array . isArray ( next ) ) return current . push . apply ( current , next ) , current ;
current . push ( next ) ;
return current ;
}
return Array . isArray ( next ) ? [ current ] . concat ( next ) : [ current , next ] ;
}
function forEachAccumulated ( arr , cb , scope ) {
Array . isArray ( arr ) ? arr . forEach ( cb , scope ) : arr && cb . call ( scope , arr ) ;
}
var eventQueue = null ;
function executeDispatchesAndReleaseTopLevel ( e ) {
if ( e ) {
var dispatchListeners = e . _dispatchListeners ,
dispatchInstances = e . _dispatchInstances ;
if ( Array . isArray ( dispatchListeners ) )
for (
var i = 0 ;
i < dispatchListeners . length && ! e . isPropagationStopped ( ) ;
i ++
)
executeDispatch ( e , ! 1 , dispatchListeners [ i ] , dispatchInstances [ i ] ) ;
else
dispatchListeners &&
executeDispatch ( e , ! 1 , dispatchListeners , dispatchInstances ) ;
e . _dispatchListeners = null ;
e . _dispatchInstances = null ;
e . isPersistent ( ) || e . constructor . release ( e ) ;
}
}
var injection = {
injectEventPluginOrder : function ( injectedEventPluginOrder ) {
invariant (
! eventPluginOrder ,
"EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React."
) ;
eventPluginOrder = Array . prototype . slice . call ( injectedEventPluginOrder ) ;
recomputePluginOrdering ( ) ;
} ,
injectEventPluginsByName : function ( injectedNamesToPlugins ) {
var isOrderingDirty = ! 1 ,
pluginName ;
for ( pluginName in injectedNamesToPlugins )
if ( injectedNamesToPlugins . hasOwnProperty ( pluginName ) ) {
var pluginModule = injectedNamesToPlugins [ pluginName ] ;
( namesToPlugins . hasOwnProperty ( pluginName ) &&
namesToPlugins [ pluginName ] === pluginModule ) ||
( invariant (
! namesToPlugins [ pluginName ] ,
"EventPluginRegistry: Cannot inject two different event plugins using the same name, `%s`." ,
pluginName
) ,
( namesToPlugins [ pluginName ] = pluginModule ) ,
( isOrderingDirty = ! 0 ) ) ;
}
isOrderingDirty && recomputePluginOrdering ( ) ;
}
} ;
function getListener ( inst , registrationName ) {
var listener = inst . stateNode ;
if ( ! listener ) return null ;
var props = getFiberCurrentPropsFromNode ( listener ) ;
if ( ! props ) return null ;
listener = props [ registrationName ] ;
a : switch ( registrationName ) {
case "onClick" :
case "onClickCapture" :
case "onDoubleClick" :
case "onDoubleClickCapture" :
case "onMouseDown" :
case "onMouseDownCapture" :
case "onMouseMove" :
case "onMouseMoveCapture" :
case "onMouseUp" :
case "onMouseUpCapture" :
( props = ! props . disabled ) ||
( ( inst = inst . type ) ,
( props = ! (
"button" === inst ||
"input" === inst ||
"select" === inst ||
"textarea" === inst
) ) ) ;
inst = ! props ;
break a ;
default :
inst = ! 1 ;
}
if ( inst ) return null ;
invariant (
! listener || "function" === typeof listener ,
"Expected `%s` listener to be a function, instead got a value of `%s` type." ,
registrationName ,
typeof listener
) ;
return listener ;
}
function getParent ( inst ) {
2018-05-15 13:08:47 -07:00
do inst = inst . return ;
2018-09-10 14:42:08 -07:00
while ( inst && 7 !== inst . tag ) ;
2017-11-15 09:05:34 -08:00
return inst ? inst : null ;
}
function traverseTwoPhase ( inst , fn , arg ) {
for ( var path = [ ] ; inst ; ) path . push ( inst ) , ( inst = getParent ( inst ) ) ;
for ( inst = path . length ; 0 < inst -- ; ) fn ( path [ inst ] , "captured" , arg ) ;
for ( inst = 0 ; inst < path . length ; inst ++ ) fn ( path [ inst ] , "bubbled" , arg ) ;
}
function accumulateDirectionalDispatches ( inst , phase , event ) {
if (
( phase = getListener (
inst ,
event . dispatchConfig . phasedRegistrationNames [ phase ]
) )
)
( event . _dispatchListeners = accumulateInto (
event . _dispatchListeners ,
phase
) ) ,
( event . _dispatchInstances = accumulateInto (
event . _dispatchInstances ,
inst
) ) ;
}
function accumulateTwoPhaseDispatchesSingle ( event ) {
event &&
event . dispatchConfig . phasedRegistrationNames &&
traverseTwoPhase ( event . _targetInst , accumulateDirectionalDispatches , event ) ;
}
function accumulateTwoPhaseDispatchesSingleSkipTarget ( event ) {
if ( event && event . dispatchConfig . phasedRegistrationNames ) {
var targetInst = event . _targetInst ;
targetInst = targetInst ? getParent ( targetInst ) : null ;
traverseTwoPhase ( targetInst , accumulateDirectionalDispatches , event ) ;
}
}
function accumulateDirectDispatchesSingle ( event ) {
if ( event && event . dispatchConfig . registrationName ) {
var inst = event . _targetInst ;
if ( inst && event && event . dispatchConfig . registrationName ) {
var listener = getListener ( inst , event . dispatchConfig . registrationName ) ;
listener &&
( ( event . _dispatchListeners = accumulateInto (
event . _dispatchListeners ,
listener
) ) ,
( event . _dispatchInstances = accumulateInto (
event . _dispatchInstances ,
inst
) ) ) ;
}
}
}
2018-06-16 00:38:41 -07:00
function functionThatReturnsTrue ( ) {
return ! 0 ;
}
function functionThatReturnsFalse ( ) {
return ! 1 ;
}
2017-11-15 09:05:34 -08:00
function SyntheticEvent (
dispatchConfig ,
targetInst ,
nativeEvent ,
nativeEventTarget
) {
this . dispatchConfig = dispatchConfig ;
this . _targetInst = targetInst ;
this . nativeEvent = nativeEvent ;
dispatchConfig = this . constructor . Interface ;
for ( var propName in dispatchConfig )
dispatchConfig . hasOwnProperty ( propName ) &&
( ( targetInst = dispatchConfig [ propName ] )
? ( this [ propName ] = targetInst ( nativeEvent ) )
: "target" === propName
? ( this . target = nativeEventTarget )
: ( this [ propName ] = nativeEvent [ propName ] ) ) ;
this . isDefaultPrevented = ( null != nativeEvent . defaultPrevented
? nativeEvent . defaultPrevented
: ! 1 === nativeEvent . returnValue )
2018-06-16 00:38:41 -07:00
? functionThatReturnsTrue
: functionThatReturnsFalse ;
this . isPropagationStopped = functionThatReturnsFalse ;
2017-11-15 09:05:34 -08:00
return this ;
}
Object . assign ( SyntheticEvent . prototype , {
preventDefault : function ( ) {
this . defaultPrevented = ! 0 ;
var event = this . nativeEvent ;
event &&
( event . preventDefault
? event . preventDefault ( )
: "unknown" !== typeof event . returnValue && ( event . returnValue = ! 1 ) ,
2018-06-16 00:38:41 -07:00
( this . isDefaultPrevented = functionThatReturnsTrue ) ) ;
2017-11-15 09:05:34 -08:00
} ,
stopPropagation : function ( ) {
var event = this . nativeEvent ;
event &&
( event . stopPropagation
? event . stopPropagation ( )
: "unknown" !== typeof event . cancelBubble && ( event . cancelBubble = ! 0 ) ,
2018-06-16 00:38:41 -07:00
( this . isPropagationStopped = functionThatReturnsTrue ) ) ;
2017-11-15 09:05:34 -08:00
} ,
persist : function ( ) {
2018-06-16 00:38:41 -07:00
this . isPersistent = functionThatReturnsTrue ;
2017-11-15 09:05:34 -08:00
} ,
2018-06-16 00:38:41 -07:00
isPersistent : functionThatReturnsFalse ,
2017-11-15 09:05:34 -08:00
destructor : function ( ) {
var Interface = this . constructor . Interface ,
propName ;
for ( propName in Interface ) this [ propName ] = null ;
2018-07-24 14:45:35 -07:00
this . nativeEvent = this . _targetInst = this . dispatchConfig = null ;
this . isPropagationStopped = this . isDefaultPrevented = functionThatReturnsFalse ;
this . _dispatchInstances = this . _dispatchListeners = null ;
2017-11-15 09:05:34 -08:00
}
} ) ;
2018-06-16 00:38:41 -07:00
SyntheticEvent . Interface = {
type : null ,
target : null ,
currentTarget : function ( ) {
return null ;
} ,
eventPhase : null ,
bubbles : null ,
cancelable : null ,
timeStamp : function ( event ) {
return event . timeStamp || Date . now ( ) ;
} ,
defaultPrevented : null ,
isTrusted : null
} ;
2018-01-29 14:17:07 -08:00
SyntheticEvent . extend = function ( Interface ) {
2017-11-15 09:05:34 -08:00
function E ( ) { }
2018-01-29 14:17:07 -08:00
function Class ( ) {
return Super . apply ( this , arguments ) ;
}
var Super = this ;
E . prototype = Super . prototype ;
2017-11-15 09:05:34 -08:00
var prototype = new E ( ) ;
Object . assign ( prototype , Class . prototype ) ;
Class . prototype = prototype ;
Class . prototype . constructor = Class ;
2018-01-29 14:17:07 -08:00
Class . Interface = Object . assign ( { } , Super . Interface , Interface ) ;
Class . extend = Super . extend ;
2017-11-15 09:05:34 -08:00
addEventPoolingTo ( Class ) ;
2018-01-29 14:17:07 -08:00
return Class ;
2017-11-15 09:05:34 -08:00
} ;
addEventPoolingTo ( SyntheticEvent ) ;
function getPooledEvent ( dispatchConfig , targetInst , nativeEvent , nativeInst ) {
if ( this . eventPool . length ) {
var instance = this . eventPool . pop ( ) ;
this . call ( instance , dispatchConfig , targetInst , nativeEvent , nativeInst ) ;
return instance ;
}
return new this ( dispatchConfig , targetInst , nativeEvent , nativeInst ) ;
}
function releasePooledEvent ( event ) {
invariant (
event instanceof this ,
2018-07-24 14:45:35 -07:00
"Trying to release an event instance into a pool of a different type."
2017-11-15 09:05:34 -08:00
) ;
event . destructor ( ) ;
10 > this . eventPool . length && this . eventPool . push ( event ) ;
}
function addEventPoolingTo ( EventConstructor ) {
EventConstructor . eventPool = [ ] ;
EventConstructor . getPooled = getPooledEvent ;
EventConstructor . release = releasePooledEvent ;
}
2018-01-29 14:17:07 -08:00
var ResponderSyntheticEvent = SyntheticEvent . extend ( {
2018-05-15 16:35:11 -07:00
touchHistory : function ( ) {
return null ;
}
} ) ;
function isStartish ( topLevelType ) {
return "topTouchStart" === topLevelType ;
}
function isMoveish ( topLevelType ) {
return "topTouchMove" === topLevelType ;
}
var startDependencies = [ "topTouchStart" ] ,
moveDependencies = [ "topTouchMove" ] ,
endDependencies = [ "topTouchCancel" , "topTouchEnd" ] ,
2018-01-29 14:17:07 -08:00
touchBank = [ ] ,
2017-11-15 09:05:34 -08:00
touchHistory = {
touchBank : touchBank ,
numberActiveTouches : 0 ,
indexOfSingleActiveTouch : - 1 ,
mostRecentTimeStamp : 0
} ;
function timestampForTouch ( touch ) {
return touch . timeStamp || touch . timestamp ;
}
function getTouchIdentifier ( _ref ) {
_ref = _ref . identifier ;
invariant ( null != _ref , "Touch object is missing identifier." ) ;
return _ref ;
}
function recordTouchStart ( touch ) {
var identifier = getTouchIdentifier ( touch ) ,
touchRecord = touchBank [ identifier ] ;
touchRecord
? ( ( touchRecord . touchActive = ! 0 ) ,
( touchRecord . startPageX = touch . pageX ) ,
( touchRecord . startPageY = touch . pageY ) ,
( touchRecord . startTimeStamp = timestampForTouch ( touch ) ) ,
( touchRecord . currentPageX = touch . pageX ) ,
( touchRecord . currentPageY = touch . pageY ) ,
( touchRecord . currentTimeStamp = timestampForTouch ( touch ) ) ,
( touchRecord . previousPageX = touch . pageX ) ,
( touchRecord . previousPageY = touch . pageY ) ,
( touchRecord . previousTimeStamp = timestampForTouch ( touch ) ) )
: ( ( touchRecord = {
touchActive : ! 0 ,
startPageX : touch . pageX ,
startPageY : touch . pageY ,
startTimeStamp : timestampForTouch ( touch ) ,
currentPageX : touch . pageX ,
currentPageY : touch . pageY ,
currentTimeStamp : timestampForTouch ( touch ) ,
previousPageX : touch . pageX ,
previousPageY : touch . pageY ,
previousTimeStamp : timestampForTouch ( touch )
} ) ,
( touchBank [ identifier ] = touchRecord ) ) ;
touchHistory . mostRecentTimeStamp = timestampForTouch ( touch ) ;
}
function recordTouchMove ( touch ) {
var touchRecord = touchBank [ getTouchIdentifier ( touch ) ] ;
touchRecord
? ( ( touchRecord . touchActive = ! 0 ) ,
( touchRecord . previousPageX = touchRecord . currentPageX ) ,
( touchRecord . previousPageY = touchRecord . currentPageY ) ,
( touchRecord . previousTimeStamp = touchRecord . currentTimeStamp ) ,
( touchRecord . currentPageX = touch . pageX ) ,
( touchRecord . currentPageY = touch . pageY ) ,
( touchRecord . currentTimeStamp = timestampForTouch ( touch ) ) ,
( touchHistory . mostRecentTimeStamp = timestampForTouch ( touch ) ) )
: console . error (
"Cannot record touch move without a touch start.\nTouch Move: %s\n" ,
"Touch Bank: %s" ,
printTouch ( touch ) ,
printTouchBank ( )
) ;
}
function recordTouchEnd ( touch ) {
var touchRecord = touchBank [ getTouchIdentifier ( touch ) ] ;
touchRecord
? ( ( touchRecord . touchActive = ! 1 ) ,
( touchRecord . previousPageX = touchRecord . currentPageX ) ,
( touchRecord . previousPageY = touchRecord . currentPageY ) ,
( touchRecord . previousTimeStamp = touchRecord . currentTimeStamp ) ,
( touchRecord . currentPageX = touch . pageX ) ,
( touchRecord . currentPageY = touch . pageY ) ,
( touchRecord . currentTimeStamp = timestampForTouch ( touch ) ) ,
( touchHistory . mostRecentTimeStamp = timestampForTouch ( touch ) ) )
: console . error (
"Cannot record touch end without a touch start.\nTouch End: %s\n" ,
"Touch Bank: %s" ,
printTouch ( touch ) ,
printTouchBank ( )
) ;
}
function printTouch ( touch ) {
return JSON . stringify ( {
identifier : touch . identifier ,
pageX : touch . pageX ,
pageY : touch . pageY ,
timestamp : timestampForTouch ( touch )
} ) ;
}
function printTouchBank ( ) {
var printed = JSON . stringify ( touchBank . slice ( 0 , 20 ) ) ;
20 < touchBank . length &&
( printed += " (original size: " + touchBank . length + ")" ) ;
return printed ;
}
var ResponderTouchHistoryStore = {
recordTouchTrack : function ( topLevelType , nativeEvent ) {
if ( isMoveish ( topLevelType ) )
nativeEvent . changedTouches . forEach ( recordTouchMove ) ;
else if ( isStartish ( topLevelType ) )
nativeEvent . changedTouches . forEach ( recordTouchStart ) ,
( touchHistory . numberActiveTouches = nativeEvent . touches . length ) ,
1 === touchHistory . numberActiveTouches &&
( touchHistory . indexOfSingleActiveTouch =
nativeEvent . touches [ 0 ] . identifier ) ;
else if (
2018-05-15 16:35:11 -07:00
"topTouchEnd" === topLevelType ||
"topTouchCancel" === topLevelType
2017-11-15 09:05:34 -08:00
)
2018-05-15 16:35:11 -07:00
if (
( nativeEvent . changedTouches . forEach ( recordTouchEnd ) ,
( touchHistory . numberActiveTouches = nativeEvent . touches . length ) ,
1 === touchHistory . numberActiveTouches )
)
for ( topLevelType = 0 ; topLevelType < touchBank . length ; topLevelType ++ )
if (
( ( nativeEvent = touchBank [ topLevelType ] ) ,
null != nativeEvent && nativeEvent . touchActive )
) {
touchHistory . indexOfSingleActiveTouch = topLevelType ;
break ;
}
2017-11-15 09:05:34 -08:00
} ,
touchHistory : touchHistory
} ;
function accumulate ( current , next ) {
invariant (
null != next ,
"accumulate(...): Accumulated items must be not be null or undefined."
) ;
return null == current
? next
: Array . isArray ( current )
? current . concat ( next )
2018-07-24 14:45:35 -07:00
: Array . isArray ( next )
? [ current ] . concat ( next )
: [ current , next ] ;
2017-11-15 09:05:34 -08:00
}
var responderInst = null ,
2018-05-15 16:35:11 -07:00
trackedTouchCount = 0 ;
2017-11-15 09:05:34 -08:00
function changeResponder ( nextResponderInst , blockHostResponder ) {
var oldResponderInst = responderInst ;
responderInst = nextResponderInst ;
if ( null !== ResponderEventPlugin . GlobalResponderHandler )
ResponderEventPlugin . GlobalResponderHandler . onChange (
oldResponderInst ,
nextResponderInst ,
blockHostResponder
) ;
}
2018-04-10 15:19:57 -07:00
var eventTypes$1 = {
2017-11-15 09:05:34 -08:00
startShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onStartShouldSetResponder" ,
captured : "onStartShouldSetResponderCapture"
2018-05-15 16:35:11 -07:00
} ,
dependencies : startDependencies
2017-11-15 09:05:34 -08:00
} ,
scrollShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onScrollShouldSetResponder" ,
captured : "onScrollShouldSetResponderCapture"
2018-05-15 16:35:11 -07:00
} ,
dependencies : [ "topScroll" ]
2017-11-15 09:05:34 -08:00
} ,
selectionChangeShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onSelectionChangeShouldSetResponder" ,
captured : "onSelectionChangeShouldSetResponderCapture"
2018-05-15 16:35:11 -07:00
} ,
dependencies : [ "topSelectionChange" ]
2017-11-15 09:05:34 -08:00
} ,
moveShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onMoveShouldSetResponder" ,
captured : "onMoveShouldSetResponderCapture"
2018-05-15 16:35:11 -07:00
} ,
dependencies : moveDependencies
} ,
responderStart : {
registrationName : "onResponderStart" ,
dependencies : startDependencies
} ,
responderMove : {
registrationName : "onResponderMove" ,
dependencies : moveDependencies
} ,
responderEnd : {
registrationName : "onResponderEnd" ,
dependencies : endDependencies
} ,
responderRelease : {
registrationName : "onResponderRelease" ,
dependencies : endDependencies
2017-11-15 09:05:34 -08:00
} ,
responderTerminationRequest : {
2018-05-15 16:35:11 -07:00
registrationName : "onResponderTerminationRequest" ,
dependencies : [ ]
} ,
responderGrant : { registrationName : "onResponderGrant" , dependencies : [ ] } ,
responderReject : {
registrationName : "onResponderReject" ,
dependencies : [ ]
2017-11-15 09:05:34 -08:00
} ,
2018-05-15 16:35:11 -07:00
responderTerminate : {
registrationName : "onResponderTerminate" ,
dependencies : [ ]
}
2017-11-15 09:05:34 -08:00
} ,
ResponderEventPlugin = {
_getResponder : function ( ) {
return responderInst ;
} ,
2018-04-10 15:19:57 -07:00
eventTypes : eventTypes$1 ,
2017-11-15 09:05:34 -08:00
extractEvents : function (
topLevelType ,
targetInst ,
nativeEvent ,
nativeEventTarget
) {
if ( isStartish ( topLevelType ) ) trackedTouchCount += 1 ;
2018-05-15 16:35:11 -07:00
else if (
"topTouchEnd" === topLevelType ||
"topTouchCancel" === topLevelType
)
2017-11-15 09:05:34 -08:00
if ( 0 <= trackedTouchCount ) -- trackedTouchCount ;
else
return (
console . error (
"Ended a touch event which was not counted in `trackedTouchCount`."
) ,
null
) ;
ResponderTouchHistoryStore . recordTouchTrack ( topLevelType , nativeEvent ) ;
if (
targetInst &&
( ( "topScroll" === topLevelType && ! nativeEvent . responderIgnoreScroll ) ||
( 0 < trackedTouchCount && "topSelectionChange" === topLevelType ) ||
isStartish ( topLevelType ) ||
isMoveish ( topLevelType ) )
) {
2018-01-29 14:17:07 -08:00
var JSCompiler _temp = isStartish ( topLevelType )
2018-04-10 15:19:57 -07:00
? eventTypes$1 . startShouldSetResponder
2017-11-15 09:05:34 -08:00
: isMoveish ( topLevelType )
2018-04-10 15:19:57 -07:00
? eventTypes$1 . moveShouldSetResponder
2017-11-15 09:05:34 -08:00
: "topSelectionChange" === topLevelType
2018-04-10 15:19:57 -07:00
? eventTypes$1 . selectionChangeShouldSetResponder
: eventTypes$1 . scrollShouldSetResponder ;
2017-11-15 09:05:34 -08:00
if ( responderInst )
b : {
2018-01-29 14:17:07 -08:00
var JSCompiler _temp$jscomp$0 = responderInst ;
2017-11-15 09:05:34 -08:00
for (
2018-01-29 14:17:07 -08:00
var depthA = 0 , tempA = JSCompiler _temp$jscomp$0 ;
2017-11-15 09:05:34 -08:00
tempA ;
tempA = getParent ( tempA )
)
depthA ++ ;
tempA = 0 ;
for ( var tempB = targetInst ; tempB ; tempB = getParent ( tempB ) )
tempA ++ ;
for ( ; 0 < depthA - tempA ; )
2018-01-29 14:17:07 -08:00
( JSCompiler _temp$jscomp$0 = getParent ( JSCompiler _temp$jscomp$0 ) ) ,
depthA -- ;
2017-11-15 09:05:34 -08:00
for ( ; 0 < tempA - depthA ; )
( targetInst = getParent ( targetInst ) ) , tempA -- ;
for ( ; depthA -- ; ) {
if (
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 === targetInst ||
JSCompiler _temp$jscomp$0 === targetInst . alternate
2017-11-15 09:05:34 -08:00
)
break b ;
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 = getParent ( JSCompiler _temp$jscomp$0 ) ;
2017-11-15 09:05:34 -08:00
targetInst = getParent ( targetInst ) ;
}
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 = null ;
2017-11-15 09:05:34 -08:00
}
2018-01-29 14:17:07 -08:00
else JSCompiler _temp$jscomp$0 = targetInst ;
targetInst = JSCompiler _temp$jscomp$0 === responderInst ;
JSCompiler _temp$jscomp$0 = ResponderSyntheticEvent . getPooled (
2017-11-15 09:05:34 -08:00
JSCompiler _temp ,
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 ,
2017-11-15 09:05:34 -08:00
nativeEvent ,
nativeEventTarget
) ;
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 . touchHistory =
ResponderTouchHistoryStore . touchHistory ;
2017-11-15 09:05:34 -08:00
targetInst
? forEachAccumulated (
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 ,
2017-11-15 09:05:34 -08:00
accumulateTwoPhaseDispatchesSingleSkipTarget
)
: forEachAccumulated (
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 ,
2017-11-15 09:05:34 -08:00
accumulateTwoPhaseDispatchesSingle
) ;
b : {
2018-01-29 14:17:07 -08:00
JSCompiler _temp = JSCompiler _temp$jscomp$0 . _dispatchListeners ;
targetInst = JSCompiler _temp$jscomp$0 . _dispatchInstances ;
if ( Array . isArray ( JSCompiler _temp ) )
2017-11-15 09:05:34 -08:00
for (
depthA = 0 ;
2018-01-29 14:17:07 -08:00
depthA < JSCompiler _temp . length &&
! JSCompiler _temp$jscomp$0 . isPropagationStopped ( ) ;
2017-11-15 09:05:34 -08:00
depthA ++
) {
if (
2018-01-29 14:17:07 -08:00
JSCompiler _temp [ depthA ] (
JSCompiler _temp$jscomp$0 ,
targetInst [ depthA ]
)
2017-11-15 09:05:34 -08:00
) {
2018-01-29 14:17:07 -08:00
JSCompiler _temp = targetInst [ depthA ] ;
2017-11-15 09:05:34 -08:00
break b ;
}
}
else if (
2018-01-29 14:17:07 -08:00
JSCompiler _temp &&
JSCompiler _temp ( JSCompiler _temp$jscomp$0 , targetInst )
2017-11-15 09:05:34 -08:00
) {
2018-01-29 14:17:07 -08:00
JSCompiler _temp = targetInst ;
2017-11-15 09:05:34 -08:00
break b ;
}
2018-01-29 14:17:07 -08:00
JSCompiler _temp = null ;
2017-11-15 09:05:34 -08:00
}
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 . _dispatchInstances = null ;
JSCompiler _temp$jscomp$0 . _dispatchListeners = null ;
JSCompiler _temp$jscomp$0 . isPersistent ( ) ||
JSCompiler _temp$jscomp$0 . constructor . release (
JSCompiler _temp$jscomp$0
) ;
JSCompiler _temp && JSCompiler _temp !== responderInst
? ( ( JSCompiler _temp$jscomp$0 = void 0 ) ,
( targetInst = ResponderSyntheticEvent . getPooled (
2018-04-10 15:19:57 -07:00
eventTypes$1 . responderGrant ,
2018-01-29 14:17:07 -08:00
JSCompiler _temp ,
2017-11-15 09:05:34 -08:00
nativeEvent ,
nativeEventTarget
) ) ,
2018-01-29 14:17:07 -08:00
( targetInst . touchHistory = ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( targetInst , accumulateDirectDispatchesSingle ) ,
( depthA = ! 0 === executeDirectDispatch ( targetInst ) ) ,
responderInst
? ( ( tempA = ResponderSyntheticEvent . getPooled (
2018-04-10 15:19:57 -07:00
eventTypes$1 . responderTerminationRequest ,
2018-01-29 14:17:07 -08:00
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
( tempA . touchHistory = ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( tempA , accumulateDirectDispatchesSingle ) ,
( tempB =
! tempA . _dispatchListeners || executeDirectDispatch ( tempA ) ) ,
tempA . isPersistent ( ) || tempA . constructor . release ( tempA ) ,
tempB
? ( ( tempA = ResponderSyntheticEvent . getPooled (
2018-04-10 15:19:57 -07:00
eventTypes$1 . responderTerminate ,
2018-01-29 14:17:07 -08:00
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
( tempA . touchHistory =
ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( tempA , accumulateDirectDispatchesSingle ) ,
( JSCompiler _temp$jscomp$0 = accumulate (
JSCompiler _temp$jscomp$0 ,
[ targetInst , tempA ]
) ) ,
changeResponder ( JSCompiler _temp , depthA ) )
: ( ( JSCompiler _temp = ResponderSyntheticEvent . getPooled (
2018-04-10 15:19:57 -07:00
eventTypes$1 . responderReject ,
2018-01-29 14:17:07 -08:00
JSCompiler _temp ,
nativeEvent ,
nativeEventTarget
) ) ,
( JSCompiler _temp . touchHistory =
ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated (
JSCompiler _temp ,
accumulateDirectDispatchesSingle
) ,
( JSCompiler _temp$jscomp$0 = accumulate (
JSCompiler _temp$jscomp$0 ,
JSCompiler _temp
) ) ) )
: ( ( JSCompiler _temp$jscomp$0 = accumulate (
2017-11-15 09:05:34 -08:00
JSCompiler _temp$jscomp$0 ,
2018-01-29 14:17:07 -08:00
targetInst
) ) ,
changeResponder ( JSCompiler _temp , depthA ) ) ,
( JSCompiler _temp = JSCompiler _temp$jscomp$0 ) )
: ( JSCompiler _temp = null ) ;
} else JSCompiler _temp = null ;
JSCompiler _temp$jscomp$0 = responderInst && isStartish ( topLevelType ) ;
targetInst = responderInst && isMoveish ( topLevelType ) ;
2018-05-15 16:35:11 -07:00
depthA =
responderInst &&
( "topTouchEnd" === topLevelType || "topTouchCancel" === topLevelType ) ;
2017-11-15 09:05:34 -08:00
if (
2018-01-29 14:17:07 -08:00
( JSCompiler _temp$jscomp$0 = JSCompiler _temp$jscomp$0
2018-04-10 15:19:57 -07:00
? eventTypes$1 . responderStart
2018-01-29 14:17:07 -08:00
: targetInst
2018-04-10 15:19:57 -07:00
? eventTypes$1 . responderMove
2018-07-24 14:45:35 -07:00
: depthA
? eventTypes$1 . responderEnd
: null )
2017-11-15 09:05:34 -08:00
)
2018-01-29 14:17:07 -08:00
( JSCompiler _temp$jscomp$0 = ResponderSyntheticEvent . getPooled (
JSCompiler _temp$jscomp$0 ,
2017-11-15 09:05:34 -08:00
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
2018-01-29 14:17:07 -08:00
( JSCompiler _temp$jscomp$0 . touchHistory =
2017-11-15 09:05:34 -08:00
ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated (
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 ,
2017-11-15 09:05:34 -08:00
accumulateDirectDispatchesSingle
) ,
2018-01-29 14:17:07 -08:00
( JSCompiler _temp = accumulate (
JSCompiler _temp ,
JSCompiler _temp$jscomp$0
2017-11-15 09:05:34 -08:00
) ) ;
2018-01-29 14:17:07 -08:00
JSCompiler _temp$jscomp$0 =
responderInst && "topTouchCancel" === topLevelType ;
2017-11-15 09:05:34 -08:00
if (
( topLevelType =
2018-05-15 16:35:11 -07:00
responderInst &&
! JSCompiler _temp$jscomp$0 &&
( "topTouchEnd" === topLevelType || "topTouchCancel" === topLevelType ) )
2017-11-15 09:05:34 -08:00
)
a : {
if ( ( topLevelType = nativeEvent . touches ) && 0 !== topLevelType . length )
2018-01-29 14:17:07 -08:00
for ( targetInst = 0 ; targetInst < topLevelType . length ; targetInst ++ )
2017-11-15 09:05:34 -08:00
if (
2018-01-29 14:17:07 -08:00
( ( depthA = topLevelType [ targetInst ] . target ) ,
null !== depthA && void 0 !== depthA && 0 !== depthA )
2017-11-15 09:05:34 -08:00
) {
2018-01-29 14:17:07 -08:00
tempA = getInstanceFromNode ( depthA ) ;
2017-11-15 09:05:34 -08:00
b : {
2018-01-29 14:17:07 -08:00
for ( depthA = responderInst ; tempA ; ) {
if ( depthA === tempA || depthA === tempA . alternate ) {
depthA = ! 0 ;
2017-11-15 09:05:34 -08:00
break b ;
}
2018-01-29 14:17:07 -08:00
tempA = getParent ( tempA ) ;
2017-11-15 09:05:34 -08:00
}
2018-01-29 14:17:07 -08:00
depthA = ! 1 ;
2017-11-15 09:05:34 -08:00
}
2018-01-29 14:17:07 -08:00
if ( depthA ) {
2017-11-15 09:05:34 -08:00
topLevelType = ! 1 ;
break a ;
}
}
topLevelType = ! 0 ;
}
if (
2018-01-29 14:17:07 -08:00
( topLevelType = JSCompiler _temp$jscomp$0
2018-04-10 15:19:57 -07:00
? eventTypes$1 . responderTerminate
2018-07-24 14:45:35 -07:00
: topLevelType
? eventTypes$1 . responderRelease
: null )
2017-11-15 09:05:34 -08:00
)
( nativeEvent = ResponderSyntheticEvent . getPooled (
topLevelType ,
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
( nativeEvent . touchHistory = ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( nativeEvent , accumulateDirectDispatchesSingle ) ,
2018-01-29 14:17:07 -08:00
( JSCompiler _temp = accumulate ( JSCompiler _temp , nativeEvent ) ) ,
2017-11-15 09:05:34 -08:00
changeResponder ( null ) ;
2018-01-29 14:17:07 -08:00
return JSCompiler _temp ;
2017-11-15 09:05:34 -08:00
} ,
GlobalResponderHandler : null ,
injection : {
injectGlobalResponderHandler : function ( GlobalResponderHandler ) {
ResponderEventPlugin . GlobalResponderHandler = GlobalResponderHandler ;
}
}
} ,
2018-04-10 15:19:57 -07:00
customBubblingEventTypes$1 =
ReactNativeViewConfigRegistry . customBubblingEventTypes ,
customDirectEventTypes$1 =
ReactNativeViewConfigRegistry . customDirectEventTypes ,
2017-11-15 09:05:34 -08:00
ReactNativeBridgeEventPlugin = {
2018-04-10 15:19:57 -07:00
eventTypes : ReactNativeViewConfigRegistry . eventTypes ,
2017-11-15 09:05:34 -08:00
extractEvents : function (
topLevelType ,
targetInst ,
nativeEvent ,
nativeEventTarget
) {
2018-02-28 19:16:47 -08:00
if ( null == targetInst ) return null ;
2018-04-10 15:19:57 -07:00
var bubbleDispatchConfig = customBubblingEventTypes$1 [ topLevelType ] ,
directDispatchConfig = customDirectEventTypes$1 [ topLevelType ] ;
2017-11-15 09:05:34 -08:00
invariant (
bubbleDispatchConfig || directDispatchConfig ,
'Unsupported top level event type "%s" dispatched' ,
topLevelType
) ;
topLevelType = SyntheticEvent . getPooled (
bubbleDispatchConfig || directDispatchConfig ,
targetInst ,
nativeEvent ,
nativeEventTarget
) ;
if ( bubbleDispatchConfig )
forEachAccumulated ( topLevelType , accumulateTwoPhaseDispatchesSingle ) ;
else if ( directDispatchConfig )
forEachAccumulated ( topLevelType , accumulateDirectDispatchesSingle ) ;
else return null ;
return topLevelType ;
}
2018-06-16 00:38:41 -07:00
} ;
2018-02-28 19:16:47 -08:00
injection . injectEventPluginOrder ( [
"ResponderEventPlugin" ,
"ReactNativeBridgeEventPlugin"
] ) ;
injection . injectEventPluginsByName ( {
ResponderEventPlugin : ResponderEventPlugin ,
ReactNativeBridgeEventPlugin : ReactNativeBridgeEventPlugin
} ) ;
2018-06-16 00:38:41 -07:00
var instanceCache = { } ,
instanceProps = { } ;
function getInstanceFromTag ( tag ) {
return instanceCache [ tag ] || null ;
}
2018-09-10 14:42:08 -07:00
var restoreTarget = null ,
2017-11-15 09:05:34 -08:00
restoreQueue = null ;
function restoreStateOfTarget ( target ) {
if ( ( target = getInstanceFromNode ( target ) ) ) {
invariant (
2018-09-10 14:42:08 -07:00
! 1 ,
"setRestoreImplementation() needs to be called to handle a target for controlled events. This error is likely caused by a bug in React. Please file an issue."
2017-11-15 09:05:34 -08:00
) ;
var props = getFiberCurrentPropsFromNode ( target . stateNode ) ;
2018-09-10 14:42:08 -07:00
null ( target . stateNode , target . type , props ) ;
2017-11-15 09:05:34 -08:00
}
}
2018-09-10 14:42:08 -07:00
function _batchedUpdatesImpl ( fn , bookkeeping ) {
2017-11-15 09:05:34 -08:00
return fn ( bookkeeping ) ;
}
2018-09-10 14:42:08 -07:00
function _flushInteractiveUpdatesImpl ( ) { }
2018-02-01 13:33:12 -08:00
var isBatching = ! 1 ;
2017-11-15 09:05:34 -08:00
function batchedUpdates ( fn , bookkeeping ) {
2018-02-01 13:33:12 -08:00
if ( isBatching ) return fn ( bookkeeping ) ;
isBatching = ! 0 ;
2017-11-15 09:05:34 -08:00
try {
2018-09-10 14:42:08 -07:00
return _batchedUpdatesImpl ( fn , bookkeeping ) ;
2017-11-15 09:05:34 -08:00
} finally {
2018-02-01 13:33:12 -08:00
if ( ( ( isBatching = ! 1 ) , null !== restoreTarget || null !== restoreQueue ) )
if (
2018-09-10 14:42:08 -07:00
( _flushInteractiveUpdatesImpl ( ) ,
2018-02-01 13:33:12 -08:00
restoreTarget &&
( ( bookkeeping = restoreTarget ) ,
( fn = restoreQueue ) ,
( restoreQueue = restoreTarget = null ) ,
restoreStateOfTarget ( bookkeeping ) ,
fn ) )
)
for ( bookkeeping = 0 ; bookkeeping < fn . length ; bookkeeping ++ )
restoreStateOfTarget ( fn [ bookkeeping ] ) ;
2017-11-15 09:05:34 -08:00
}
}
2018-04-10 15:19:57 -07:00
var EMPTY _NATIVE _EVENT = { } ;
2017-11-15 09:05:34 -08:00
function _receiveRootNodeIDEvent ( rootNodeID , topLevelType , nativeEventParam ) {
var nativeEvent = nativeEventParam || EMPTY _NATIVE _EVENT ,
inst = getInstanceFromTag ( rootNodeID ) ;
batchedUpdates ( function ( ) {
2018-01-29 14:17:07 -08:00
var events = nativeEvent . target ;
for ( var events$jscomp$0 = null , i = 0 ; i < plugins . length ; i ++ ) {
var possiblePlugin = plugins [ i ] ;
possiblePlugin &&
( possiblePlugin = possiblePlugin . extractEvents (
topLevelType ,
inst ,
nativeEvent ,
events
) ) &&
( events$jscomp$0 = accumulateInto ( events$jscomp$0 , possiblePlugin ) ) ;
}
events = events$jscomp$0 ;
null !== events && ( eventQueue = accumulateInto ( eventQueue , events ) ) ;
events = eventQueue ;
eventQueue = null ;
2018-09-10 14:42:08 -07:00
if (
events &&
2018-01-29 14:17:07 -08:00
( forEachAccumulated ( events , executeDispatchesAndReleaseTopLevel ) ,
invariant (
! eventQueue ,
"processEventQueue(): Additional events were enqueued while processing an event queue. Support for this has not yet been implemented."
) ,
2018-09-10 14:42:08 -07:00
hasRethrowError )
)
throw ( ( events = rethrowError ) ,
( hasRethrowError = ! 1 ) ,
( rethrowError = null ) ,
events ) ;
2017-11-15 09:05:34 -08:00
} ) ;
}
2018-06-16 00:38:41 -07:00
RCTEventEmitter . register ( {
2017-11-15 09:05:34 -08:00
getListener : getListener ,
registrationNames : registrationNameModules ,
_receiveRootNodeIDEvent : _receiveRootNodeIDEvent ,
receiveEvent : function ( rootNodeID , topLevelType , nativeEventParam ) {
_receiveRootNodeIDEvent ( rootNodeID , topLevelType , nativeEventParam ) ;
} ,
receiveTouches : function ( eventTopLevelType , touches , changedIndices ) {
if (
"topTouchEnd" === eventTopLevelType ||
"topTouchCancel" === eventTopLevelType
) {
var JSCompiler _temp = [ ] ;
for ( var i = 0 ; i < changedIndices . length ; i ++ ) {
var index = changedIndices [ i ] ;
JSCompiler _temp . push ( touches [ index ] ) ;
touches [ index ] = null ;
}
for ( i = changedIndices = 0 ; i < touches . length ; i ++ )
( index = touches [ i ] ) ,
null !== index && ( touches [ changedIndices ++ ] = index ) ;
touches . length = changedIndices ;
} else
for ( JSCompiler _temp = [ ] , i = 0 ; i < changedIndices . length ; i ++ )
JSCompiler _temp . push ( touches [ changedIndices [ i ] ] ) ;
for (
changedIndices = 0 ;
changedIndices < JSCompiler _temp . length ;
changedIndices ++
) {
i = JSCompiler _temp [ changedIndices ] ;
i . changedTouches = JSCompiler _temp ;
i . touches = touches ;
index = null ;
var target = i . target ;
2018-04-10 15:19:57 -07:00
null === target || void 0 === target || 1 > target || ( index = target ) ;
2017-11-15 09:05:34 -08:00
_receiveRootNodeIDEvent ( index , eventTopLevelType , i ) ;
}
2018-01-29 14:17:07 -08:00
}
2017-11-15 09:05:34 -08:00
} ) ;
2018-09-10 14:42:08 -07:00
getFiberCurrentPropsFromNode = function ( stateNode ) {
return instanceProps [ stateNode . _nativeTag ] || null ;
} ;
getInstanceFromNode = getInstanceFromTag ;
getNodeFromInstance = function ( inst ) {
var tag = inst . stateNode . _nativeTag ;
void 0 === tag && ( tag = inst . stateNode . canonical . _nativeTag ) ;
invariant ( tag , "All native instances should have a tag." ) ;
return tag ;
} ;
2018-06-16 00:38:41 -07:00
ResponderEventPlugin . injection . injectGlobalResponderHandler ( {
onChange : function ( from , to , blockNativeResponder ) {
null !== to
? UIManager . setJSResponder ( to . stateNode . _nativeTag , blockNativeResponder )
: UIManager . clearJSResponder ( ) ;
}
} ) ;
2018-07-24 14:45:35 -07:00
var ReactSharedInternals =
React . _ _SECRET _INTERNALS _DO _NOT _USE _OR _YOU _WILL _BE _FIRED ,
2018-05-15 13:08:47 -07:00
hasSymbol = "function" === typeof Symbol && Symbol . for ,
REACT _ELEMENT _TYPE = hasSymbol ? Symbol . for ( "react.element" ) : 60103 ,
REACT _PORTAL _TYPE = hasSymbol ? Symbol . for ( "react.portal" ) : 60106 ,
REACT _FRAGMENT _TYPE = hasSymbol ? Symbol . for ( "react.fragment" ) : 60107 ,
REACT _STRICT _MODE _TYPE = hasSymbol ? Symbol . for ( "react.strict_mode" ) : 60108 ,
2018-05-18 20:17:11 -07:00
REACT _PROFILER _TYPE = hasSymbol ? Symbol . for ( "react.profiler" ) : 60114 ,
2018-05-15 13:08:47 -07:00
REACT _PROVIDER _TYPE = hasSymbol ? Symbol . for ( "react.provider" ) : 60109 ,
REACT _CONTEXT _TYPE = hasSymbol ? Symbol . for ( "react.context" ) : 60110 ,
REACT _ASYNC _MODE _TYPE = hasSymbol ? Symbol . for ( "react.async_mode" ) : 60111 ,
REACT _FORWARD _REF _TYPE = hasSymbol ? Symbol . for ( "react.forward_ref" ) : 60112 ,
2018-07-24 14:45:35 -07:00
REACT _PLACEHOLDER _TYPE = hasSymbol ? Symbol . for ( "react.placeholder" ) : 60113 ,
2017-11-29 10:12:57 -08:00
MAYBE _ITERATOR _SYMBOL = "function" === typeof Symbol && Symbol . iterator ;
function getIteratorFn ( maybeIterable ) {
2018-09-10 14:42:08 -07:00
if ( null === maybeIterable || "object" !== typeof maybeIterable ) return null ;
2017-11-29 10:12:57 -08:00
maybeIterable =
( MAYBE _ITERATOR _SYMBOL && maybeIterable [ MAYBE _ITERATOR _SYMBOL ] ) ||
maybeIterable [ "@@iterator" ] ;
return "function" === typeof maybeIterable ? maybeIterable : null ;
}
2018-07-24 14:45:35 -07:00
function getComponentName ( type ) {
if ( null == type ) return null ;
if ( "function" === typeof type ) return type . displayName || type . name || null ;
2018-05-15 13:08:47 -07:00
if ( "string" === typeof type ) return type ;
switch ( type ) {
case REACT _ASYNC _MODE _TYPE :
return "AsyncMode" ;
2018-04-05 17:33:08 -07:00
case REACT _FRAGMENT _TYPE :
2018-07-24 14:45:35 -07:00
return "Fragment" ;
2018-04-05 17:33:08 -07:00
case REACT _PORTAL _TYPE :
2018-07-24 14:45:35 -07:00
return "Portal" ;
2018-05-15 13:08:47 -07:00
case REACT _PROFILER _TYPE :
2018-07-24 14:45:35 -07:00
return "Profiler" ;
2018-05-15 13:08:47 -07:00
case REACT _STRICT _MODE _TYPE :
return "StrictMode" ;
2018-07-24 14:45:35 -07:00
case REACT _PLACEHOLDER _TYPE :
return "Placeholder" ;
2018-04-05 17:33:08 -07:00
}
2018-09-10 14:42:08 -07:00
if ( "object" === typeof type ) {
2018-05-15 13:08:47 -07:00
switch ( type . $$typeof ) {
2018-07-24 14:45:35 -07:00
case REACT _CONTEXT _TYPE :
return "Context.Consumer" ;
case REACT _PROVIDER _TYPE :
return "Context.Provider" ;
2018-04-18 14:59:57 -07:00
case REACT _FORWARD _REF _TYPE :
return (
2018-07-24 14:45:35 -07:00
( type = type . render ) ,
( type = type . displayName || type . name || "" ) ,
"" !== type ? "ForwardRef(" + type + ")" : "ForwardRef"
2018-04-18 14:59:57 -07:00
) ;
}
2018-09-10 14:42:08 -07:00
if (
"function" === typeof type . then &&
( type = 1 === type . _reactStatus ? type . _reactResult : null )
)
return getComponentName ( type ) ;
}
2018-04-05 17:33:08 -07:00
return null ;
}
2018-05-15 13:08:47 -07:00
function isFiberMountedImpl ( fiber ) {
var node = fiber ;
if ( fiber . alternate ) for ( ; node . return ; ) node = node . return ;
else {
if ( 0 !== ( node . effectTag & 2 ) ) return 1 ;
for ( ; node . return ; )
if ( ( ( node = node . return ) , 0 !== ( node . effectTag & 2 ) ) ) return 1 ;
}
2018-09-10 14:42:08 -07:00
return 5 === node . tag ? 2 : 3 ;
2018-04-05 17:33:08 -07:00
}
2018-05-15 13:08:47 -07:00
function assertIsMounted ( fiber ) {
invariant (
2 === isFiberMountedImpl ( fiber ) ,
"Unable to find node on an unmounted component."
) ;
}
function findCurrentFiberUsingSlowPath ( fiber ) {
var alternate = fiber . alternate ;
if ( ! alternate )
return (
( alternate = isFiberMountedImpl ( fiber ) ) ,
invariant (
3 !== alternate ,
"Unable to find node on an unmounted component."
) ,
1 === alternate ? null : fiber
) ;
for ( var a = fiber , b = alternate ; ; ) {
var parentA = a . return ,
parentB = parentA ? parentA . alternate : null ;
if ( ! parentA || ! parentB ) break ;
if ( parentA . child === parentB . child ) {
for ( var child = parentA . child ; child ; ) {
if ( child === a ) return assertIsMounted ( parentA ) , fiber ;
if ( child === b ) return assertIsMounted ( parentA ) , alternate ;
child = child . sibling ;
}
invariant ( ! 1 , "Unable to find node on an unmounted component." ) ;
}
if ( a . return !== b . return ) ( a = parentA ) , ( b = parentB ) ;
else {
child = ! 1 ;
for ( var _child = parentA . child ; _child ; ) {
if ( _child === a ) {
child = ! 0 ;
a = parentA ;
b = parentB ;
break ;
}
if ( _child === b ) {
child = ! 0 ;
b = parentA ;
a = parentB ;
break ;
}
_child = _child . sibling ;
}
if ( ! child ) {
for ( _child = parentB . child ; _child ; ) {
if ( _child === a ) {
child = ! 0 ;
a = parentB ;
b = parentA ;
break ;
}
if ( _child === b ) {
child = ! 0 ;
b = parentB ;
a = parentA ;
break ;
2017-11-15 09:05:34 -08:00
}
2018-05-15 13:08:47 -07:00
_child = _child . sibling ;
2017-11-15 09:05:34 -08:00
}
2018-05-15 13:08:47 -07:00
invariant (
child ,
"Child was not found in either parent set. This indicates a bug in React related to the return pointer. Please file an issue."
) ;
2017-11-15 09:05:34 -08:00
}
2018-05-15 13:08:47 -07:00
}
invariant (
a . alternate === b ,
"Return fibers should always be each others' alternates. This error is likely caused by a bug in React. Please file an issue."
) ;
2017-11-15 09:05:34 -08:00
}
2018-09-10 14:42:08 -07:00
invariant ( 5 === a . tag , "Unable to find node on an unmounted component." ) ;
2018-05-15 13:08:47 -07:00
return a . stateNode . current === a ? fiber : alternate ;
2017-11-15 09:05:34 -08:00
}
2018-05-15 13:08:47 -07:00
function findCurrentHostFiber ( parent ) {
parent = findCurrentFiberUsingSlowPath ( parent ) ;
if ( ! parent ) return null ;
for ( var node = parent ; ; ) {
2018-09-10 14:42:08 -07:00
if ( 7 === node . tag || 8 === node . tag ) return node ;
2018-05-15 13:08:47 -07:00
if ( node . child ) ( node . child . return = node ) , ( node = node . child ) ;
else {
if ( node === parent ) break ;
for ( ; ! node . sibling ; ) {
if ( ! node . return || node . return === parent ) return null ;
node = node . return ;
}
node . sibling . return = node . return ;
node = node . sibling ;
}
}
return null ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
var emptyObject = { } ,
2018-06-16 00:38:41 -07:00
removedKeys = null ,
removedKeyCount = 0 ;
function restoreDeletedValuesInNestedArray (
updatePayload ,
node ,
validAttributes
) {
if ( Array . isArray ( node ) )
for ( var i = node . length ; i -- && 0 < removedKeyCount ; )
restoreDeletedValuesInNestedArray (
updatePayload ,
node [ i ] ,
validAttributes
) ;
else if ( node && 0 < removedKeyCount )
for ( i in removedKeys )
if ( removedKeys [ i ] ) {
2018-09-10 14:42:08 -07:00
var nextProp = node [ i ] ;
if ( void 0 !== nextProp ) {
2018-06-16 00:38:41 -07:00
var attributeConfig = validAttributes [ i ] ;
if ( attributeConfig ) {
2018-09-10 14:42:08 -07:00
"function" === typeof nextProp && ( nextProp = ! 0 ) ;
"undefined" === typeof nextProp && ( nextProp = null ) ;
2018-06-16 00:38:41 -07:00
if ( "object" !== typeof attributeConfig )
2018-09-10 14:42:08 -07:00
updatePayload [ i ] = nextProp ;
2018-06-16 00:38:41 -07:00
else if (
"function" === typeof attributeConfig . diff ||
"function" === typeof attributeConfig . process
)
2018-09-10 14:42:08 -07:00
( nextProp =
2018-06-16 00:38:41 -07:00
"function" === typeof attributeConfig . process
2018-09-10 14:42:08 -07:00
? attributeConfig . process ( nextProp )
: nextProp ) ,
( updatePayload [ i ] = nextProp ) ;
2018-06-16 00:38:41 -07:00
removedKeys [ i ] = ! 1 ;
removedKeyCount -- ;
2018-01-29 14:17:07 -08:00
}
2018-05-18 20:17:11 -07:00
}
2018-06-16 00:38:41 -07:00
}
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
function diffNestedProperty (
updatePayload ,
prevProp ,
nextProp ,
validAttributes
) {
if ( ! updatePayload && prevProp === nextProp ) return updatePayload ;
if ( ! prevProp || ! nextProp )
return nextProp
? addNestedProperty ( updatePayload , nextProp , validAttributes )
: prevProp
? clearNestedProperty ( updatePayload , prevProp , validAttributes )
: updatePayload ;
if ( ! Array . isArray ( prevProp ) && ! Array . isArray ( nextProp ) )
return diffProperties ( updatePayload , prevProp , nextProp , validAttributes ) ;
if ( Array . isArray ( prevProp ) && Array . isArray ( nextProp ) ) {
var minLength =
prevProp . length < nextProp . length ? prevProp . length : nextProp . length ,
i ;
for ( i = 0 ; i < minLength ; i ++ )
updatePayload = diffNestedProperty (
updatePayload ,
prevProp [ i ] ,
nextProp [ i ] ,
validAttributes
) ;
for ( ; i < prevProp . length ; i ++ )
updatePayload = clearNestedProperty (
updatePayload ,
prevProp [ i ] ,
validAttributes
) ;
for ( ; i < nextProp . length ; i ++ )
updatePayload = addNestedProperty (
updatePayload ,
nextProp [ i ] ,
validAttributes
) ;
return updatePayload ;
}
return Array . isArray ( prevProp )
? diffProperties (
updatePayload ,
flattenStyle ( prevProp ) ,
nextProp ,
validAttributes
)
: diffProperties (
updatePayload ,
prevProp ,
flattenStyle ( nextProp ) ,
validAttributes
) ;
}
function addNestedProperty ( updatePayload , nextProp , validAttributes ) {
if ( ! nextProp ) return updatePayload ;
if ( ! Array . isArray ( nextProp ) )
return diffProperties (
updatePayload ,
2018-07-24 14:45:35 -07:00
emptyObject ,
2018-06-16 00:38:41 -07:00
nextProp ,
validAttributes
) ;
for ( var i = 0 ; i < nextProp . length ; i ++ )
updatePayload = addNestedProperty (
updatePayload ,
nextProp [ i ] ,
validAttributes
) ;
return updatePayload ;
}
function clearNestedProperty ( updatePayload , prevProp , validAttributes ) {
if ( ! prevProp ) return updatePayload ;
if ( ! Array . isArray ( prevProp ) )
return diffProperties (
updatePayload ,
prevProp ,
2018-07-24 14:45:35 -07:00
emptyObject ,
2018-06-16 00:38:41 -07:00
validAttributes
) ;
for ( var i = 0 ; i < prevProp . length ; i ++ )
updatePayload = clearNestedProperty (
updatePayload ,
prevProp [ i ] ,
validAttributes
) ;
return updatePayload ;
}
function diffProperties ( updatePayload , prevProps , nextProps , validAttributes ) {
var attributeConfig , propKey ;
for ( propKey in nextProps )
if ( ( attributeConfig = validAttributes [ propKey ] ) ) {
var prevProp = prevProps [ propKey ] ;
var nextProp = nextProps [ propKey ] ;
"function" === typeof nextProp &&
( ( nextProp = ! 0 ) , "function" === typeof prevProp && ( prevProp = ! 0 ) ) ;
"undefined" === typeof nextProp &&
( ( nextProp = null ) ,
"undefined" === typeof prevProp && ( prevProp = null ) ) ;
removedKeys && ( removedKeys [ propKey ] = ! 1 ) ;
if ( updatePayload && void 0 !== updatePayload [ propKey ] )
if ( "object" !== typeof attributeConfig )
updatePayload [ propKey ] = nextProp ;
else {
if (
"function" === typeof attributeConfig . diff ||
"function" === typeof attributeConfig . process
)
( attributeConfig =
"function" === typeof attributeConfig . process
? attributeConfig . process ( nextProp )
: nextProp ) ,
( updatePayload [ propKey ] = attributeConfig ) ;
}
else if ( prevProp !== nextProp )
if ( "object" !== typeof attributeConfig )
( "object" !== typeof nextProp ||
null === nextProp ||
deepDiffer ( prevProp , nextProp ) ) &&
( ( updatePayload || ( updatePayload = { } ) ) [ propKey ] = nextProp ) ;
else if (
"function" === typeof attributeConfig . diff ||
"function" === typeof attributeConfig . process
) {
if (
void 0 === prevProp ||
( "function" === typeof attributeConfig . diff
? attributeConfig . diff ( prevProp , nextProp )
: "object" !== typeof nextProp ||
null === nextProp ||
deepDiffer ( prevProp , nextProp ) )
)
( attributeConfig =
"function" === typeof attributeConfig . process
? attributeConfig . process ( nextProp )
: nextProp ) ,
( ( updatePayload || ( updatePayload = { } ) ) [
propKey
] = attributeConfig ) ;
} else
( removedKeys = null ) ,
( removedKeyCount = 0 ) ,
( updatePayload = diffNestedProperty (
updatePayload ,
prevProp ,
nextProp ,
attributeConfig
) ) ,
0 < removedKeyCount &&
updatePayload &&
( restoreDeletedValuesInNestedArray (
updatePayload ,
nextProp ,
attributeConfig
) ,
( removedKeys = null ) ) ;
}
for ( var _propKey in prevProps )
void 0 === nextProps [ _propKey ] &&
( ! ( attributeConfig = validAttributes [ _propKey ] ) ||
( updatePayload && void 0 !== updatePayload [ _propKey ] ) ||
( ( prevProp = prevProps [ _propKey ] ) ,
void 0 !== prevProp &&
( "object" !== typeof attributeConfig ||
"function" === typeof attributeConfig . diff ||
"function" === typeof attributeConfig . process
? ( ( ( updatePayload || ( updatePayload = { } ) ) [ _propKey ] = null ) ,
removedKeys || ( removedKeys = { } ) ,
removedKeys [ _propKey ] ||
( ( removedKeys [ _propKey ] = ! 0 ) , removedKeyCount ++ ) )
: ( updatePayload = clearNestedProperty (
updatePayload ,
prevProp ,
attributeConfig
) ) ) ) ) ;
return updatePayload ;
}
2018-09-10 14:42:08 -07:00
function mountSafeCallback _NOT _REALLY _SAFE ( context , callback ) {
2018-06-16 00:38:41 -07:00
return function ( ) {
2018-09-10 14:42:08 -07:00
if (
callback &&
( "boolean" !== typeof context . _ _isMounted || context . _ _isMounted )
)
2018-06-16 00:38:41 -07:00
return callback . apply ( context , arguments ) ;
} ;
}
var ReactNativeFiberHostComponent = ( function ( ) {
function ReactNativeFiberHostComponent ( tag , viewConfig ) {
if ( ! ( this instanceof ReactNativeFiberHostComponent ) )
throw new TypeError ( "Cannot call a class as a function" ) ;
this . _nativeTag = tag ;
this . _children = [ ] ;
this . viewConfig = viewConfig ;
}
ReactNativeFiberHostComponent . prototype . blur = function ( ) {
TextInputState . blurTextInput ( this . _nativeTag ) ;
} ;
ReactNativeFiberHostComponent . prototype . focus = function ( ) {
TextInputState . focusTextInput ( this . _nativeTag ) ;
} ;
ReactNativeFiberHostComponent . prototype . measure = function ( callback ) {
2018-09-10 14:42:08 -07:00
UIManager . measure (
this . _nativeTag ,
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
) ;
2018-06-16 00:38:41 -07:00
} ;
ReactNativeFiberHostComponent . prototype . measureInWindow = function (
callback
) {
UIManager . measureInWindow (
this . _nativeTag ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
2018-06-16 00:38:41 -07:00
) ;
} ;
ReactNativeFiberHostComponent . prototype . measureLayout = function (
relativeToNativeNode ,
onSuccess ,
onFail
) {
UIManager . measureLayout (
this . _nativeTag ,
relativeToNativeNode ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , onFail ) ,
mountSafeCallback _NOT _REALLY _SAFE ( this , onSuccess )
2018-06-16 00:38:41 -07:00
) ;
} ;
ReactNativeFiberHostComponent . prototype . setNativeProps = function (
nativeProps
) {
nativeProps = diffProperties (
null ,
2018-07-24 14:45:35 -07:00
emptyObject ,
2018-06-16 00:38:41 -07:00
nativeProps ,
this . viewConfig . validAttributes
) ;
null != nativeProps &&
UIManager . updateView (
this . _nativeTag ,
this . viewConfig . uiViewClassName ,
nativeProps
) ;
} ;
return ReactNativeFiberHostComponent ;
} ) ( ) ,
now$1 =
"object" === typeof performance && "function" === typeof performance . now
? function ( ) {
return performance . now ( ) ;
}
: function ( ) {
return Date . now ( ) ;
} ,
scheduledCallback = null ,
frameDeadline = 0 ,
frameDeadlineObject = {
timeRemaining : function ( ) {
return frameDeadline - now$1 ( ) ;
} ,
didTimeout : ! 1
} ;
function setTimeoutCallback ( ) {
frameDeadline = now$1 ( ) + 5 ;
var callback = scheduledCallback ;
scheduledCallback = null ;
null !== callback && callback ( frameDeadlineObject ) ;
}
function shim$1 ( ) {
invariant (
! 1 ,
"The current renderer does not support hyration. This error is likely caused by a bug in React. Please file an issue."
) ;
}
2018-07-24 14:45:35 -07:00
var UPDATE _SIGNAL = { } ,
nextReactTag = 3 ;
2018-06-16 00:38:41 -07:00
function allocateTag ( ) {
var tag = nextReactTag ;
1 === tag % 10 && ( tag += 2 ) ;
nextReactTag = tag + 2 ;
return tag ;
}
function recursivelyUncacheFiberNode ( node ) {
2018-09-10 14:42:08 -07:00
if ( "number" === typeof node )
delete instanceCache [ node ] , delete instanceProps [ node ] ;
else {
var tag = node . _nativeTag ;
delete instanceCache [ tag ] ;
delete instanceProps [ tag ] ;
node . _children . forEach ( recursivelyUncacheFiberNode ) ;
}
2018-06-16 00:38:41 -07:00
}
function finalizeInitialChildren ( parentInstance ) {
if ( 0 === parentInstance . _children . length ) return ! 1 ;
var nativeTags = parentInstance . _children . map ( function ( child ) {
return "number" === typeof child ? child : child . _nativeTag ;
} ) ;
UIManager . setChildren ( parentInstance . _nativeTag , nativeTags ) ;
return ! 1 ;
}
2018-09-10 14:42:08 -07:00
var BEFORE _SLASH _RE = /^(.*)[\\\/]/ ;
2018-07-24 14:45:35 -07:00
function getStackByFiberInDevAndProd ( workInProgress ) {
2018-05-15 13:08:47 -07:00
var info = "" ;
do {
a : switch ( workInProgress . tag ) {
2018-09-10 14:42:08 -07:00
case 4 :
2018-05-15 13:08:47 -07:00
case 0 :
case 1 :
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
case 7 :
case 10 :
2018-05-15 13:08:47 -07:00
var owner = workInProgress . _debugOwner ,
2018-09-10 14:42:08 -07:00
source = workInProgress . _debugSource ,
name = getComponentName ( workInProgress . type ) ;
var JSCompiler _inline _result = null ;
owner && ( JSCompiler _inline _result = getComponentName ( owner . type ) ) ;
owner = name ;
name = "" ;
source
? ( name =
" (at " +
source . fileName . replace ( BEFORE _SLASH _RE , "" ) +
2018-05-15 13:08:47 -07:00
":" +
2018-09-10 14:42:08 -07:00
source . lineNumber +
")" )
: JSCompiler _inline _result &&
( name = " (created by " + JSCompiler _inline _result + ")" ) ;
JSCompiler _inline _result = "\n in " + ( owner || "Unknown" ) + name ;
2018-05-15 13:08:47 -07:00
break a ;
default :
JSCompiler _inline _result = "" ;
}
info += JSCompiler _inline _result ;
workInProgress = workInProgress . return ;
} while ( workInProgress ) ;
return info ;
}
2018-06-16 00:38:41 -07:00
new Set ( ) ;
var valueStack = [ ] ,
index = - 1 ;
function pop ( cursor ) {
0 > index ||
( ( cursor . current = valueStack [ index ] ) , ( valueStack [ index ] = null ) , index -- ) ;
}
function push ( cursor , value ) {
index ++ ;
valueStack [ index ] = cursor . current ;
cursor . current = value ;
}
2018-07-24 14:45:35 -07:00
var emptyContextObject = { } ,
contextStackCursor = { current : emptyContextObject } ,
didPerformWorkStackCursor = { current : ! 1 } ,
previousContext = emptyContextObject ;
2018-06-16 00:38:41 -07:00
function getMaskedContext ( workInProgress , unmaskedContext ) {
var contextTypes = workInProgress . type . contextTypes ;
2018-07-24 14:45:35 -07:00
if ( ! contextTypes ) return emptyContextObject ;
2018-06-16 00:38:41 -07:00
var instance = workInProgress . stateNode ;
if (
instance &&
instance . _ _reactInternalMemoizedUnmaskedChildContext === unmaskedContext
)
return instance . _ _reactInternalMemoizedMaskedChildContext ;
var context = { } ,
key ;
for ( key in contextTypes ) context [ key ] = unmaskedContext [ key ] ;
instance &&
( ( workInProgress = workInProgress . stateNode ) ,
( workInProgress . _ _reactInternalMemoizedUnmaskedChildContext = unmaskedContext ) ,
( workInProgress . _ _reactInternalMemoizedMaskedChildContext = context ) ) ;
return context ;
}
2018-09-10 14:42:08 -07:00
function isContextProvider ( type ) {
type = type . childContextTypes ;
return null !== type && void 0 !== type ;
2018-06-16 00:38:41 -07:00
}
2018-09-10 14:42:08 -07:00
function popContext ( fiber ) {
pop ( didPerformWorkStackCursor , fiber ) ;
pop ( contextStackCursor , fiber ) ;
2018-06-16 00:38:41 -07:00
}
function popTopLevelContextObject ( fiber ) {
pop ( didPerformWorkStackCursor , fiber ) ;
pop ( contextStackCursor , fiber ) ;
}
function pushTopLevelContextObject ( fiber , context , didChange ) {
invariant (
2018-07-24 14:45:35 -07:00
contextStackCursor . current === emptyContextObject ,
2018-06-16 00:38:41 -07:00
"Unexpected context found on stack. This error is likely caused by a bug in React. Please file an issue."
) ;
push ( contextStackCursor , context , fiber ) ;
push ( didPerformWorkStackCursor , didChange , fiber ) ;
}
2018-09-10 14:42:08 -07:00
function processChildContext ( fiber , type , parentContext ) {
2018-07-24 14:45:35 -07:00
var instance = fiber . stateNode ;
2018-09-10 14:42:08 -07:00
fiber = type . childContextTypes ;
2018-06-16 00:38:41 -07:00
if ( "function" !== typeof instance . getChildContext ) return parentContext ;
instance = instance . getChildContext ( ) ;
for ( var contextKey in instance )
invariant (
2018-09-10 14:42:08 -07:00
contextKey in fiber ,
2018-06-16 00:38:41 -07:00
'%s.getChildContext(): key "%s" is not defined in childContextTypes.' ,
2018-09-10 14:42:08 -07:00
getComponentName ( type ) || "Unknown" ,
2018-06-16 00:38:41 -07:00
contextKey
) ;
return Object . assign ( { } , parentContext , instance ) ;
}
function pushContextProvider ( workInProgress ) {
var instance = workInProgress . stateNode ;
instance =
( instance && instance . _ _reactInternalMemoizedMergedChildContext ) ||
2018-07-24 14:45:35 -07:00
emptyContextObject ;
2018-06-16 00:38:41 -07:00
previousContext = contextStackCursor . current ;
push ( contextStackCursor , instance , workInProgress ) ;
push (
didPerformWorkStackCursor ,
didPerformWorkStackCursor . current ,
workInProgress
) ;
return ! 0 ;
}
2018-09-10 14:42:08 -07:00
function invalidateContextProvider ( workInProgress , type , didChange ) {
2018-06-16 00:38:41 -07:00
var instance = workInProgress . stateNode ;
invariant (
instance ,
"Expected to have an instance by this point. This error is likely caused by a bug in React. Please file an issue."
) ;
2018-09-10 14:42:08 -07:00
didChange
? ( ( type = processChildContext ( workInProgress , type , previousContext ) ) ,
( instance . _ _reactInternalMemoizedMergedChildContext = type ) ,
pop ( didPerformWorkStackCursor , workInProgress ) ,
pop ( contextStackCursor , workInProgress ) ,
push ( contextStackCursor , type , workInProgress ) )
: pop ( didPerformWorkStackCursor , workInProgress ) ;
2018-06-16 00:38:41 -07:00
push ( didPerformWorkStackCursor , didChange , workInProgress ) ;
}
2018-07-24 14:45:35 -07:00
var onCommitFiberRoot = null ,
onCommitFiberUnmount = null ;
function catchErrors ( fn ) {
return function ( arg ) {
try {
return fn ( arg ) ;
} catch ( err ) { }
} ;
}
function injectInternals ( internals ) {
if ( "undefined" === typeof _ _REACT _DEVTOOLS _GLOBAL _HOOK _ _ ) return ! 1 ;
var hook = _ _REACT _DEVTOOLS _GLOBAL _HOOK _ _ ;
if ( hook . isDisabled || ! hook . supportsFiber ) return ! 0 ;
try {
var rendererID = hook . inject ( internals ) ;
onCommitFiberRoot = catchErrors ( function ( root ) {
return hook . onCommitFiberRoot ( rendererID , root ) ;
} ) ;
onCommitFiberUnmount = catchErrors ( function ( fiber ) {
return hook . onCommitFiberUnmount ( rendererID , fiber ) ;
} ) ;
} catch ( err ) { }
return ! 0 ;
}
2018-06-16 00:38:41 -07:00
function FiberNode ( tag , pendingProps , key , mode ) {
this . tag = tag ;
this . key = key ;
this . sibling = this . child = this . return = this . stateNode = this . type = null ;
this . index = 0 ;
this . ref = null ;
this . pendingProps = pendingProps ;
2018-07-24 14:45:35 -07:00
this . firstContextDependency = this . memoizedState = this . updateQueue = this . memoizedProps = null ;
2018-06-16 00:38:41 -07:00
this . mode = mode ;
this . effectTag = 0 ;
this . lastEffect = this . firstEffect = this . nextEffect = null ;
2018-07-24 14:45:35 -07:00
this . childExpirationTime = this . expirationTime = 0 ;
2018-06-16 00:38:41 -07:00
this . alternate = null ;
}
2018-09-10 14:42:08 -07:00
function shouldConstruct ( Component ) {
Component = Component . prototype ;
return ! ( ! Component || ! Component . isReactComponent ) ;
}
2018-06-16 00:38:41 -07:00
function createWorkInProgress ( current , pendingProps , expirationTime ) {
var workInProgress = current . alternate ;
null === workInProgress
? ( ( workInProgress = new FiberNode (
current . tag ,
pendingProps ,
current . key ,
current . mode
) ) ,
( workInProgress . type = current . type ) ,
( workInProgress . stateNode = current . stateNode ) ,
( workInProgress . alternate = current ) ,
( current . alternate = workInProgress ) )
: ( ( workInProgress . pendingProps = pendingProps ) ,
( workInProgress . effectTag = 0 ) ,
( workInProgress . nextEffect = null ) ,
( workInProgress . firstEffect = null ) ,
( workInProgress . lastEffect = null ) ) ;
2018-07-24 14:45:35 -07:00
workInProgress . childExpirationTime = current . childExpirationTime ;
workInProgress . expirationTime =
pendingProps !== current . pendingProps
? expirationTime
: current . expirationTime ;
2018-06-16 00:38:41 -07:00
workInProgress . child = current . child ;
workInProgress . memoizedProps = current . memoizedProps ;
workInProgress . memoizedState = current . memoizedState ;
workInProgress . updateQueue = current . updateQueue ;
2018-07-24 14:45:35 -07:00
workInProgress . firstContextDependency = current . firstContextDependency ;
2018-06-16 00:38:41 -07:00
workInProgress . sibling = current . sibling ;
workInProgress . index = current . index ;
workInProgress . ref = current . ref ;
return workInProgress ;
}
function createFiberFromElement ( element , mode , expirationTime ) {
var type = element . type ,
key = element . key ;
element = element . props ;
2018-09-10 14:42:08 -07:00
var fiberTag = void 0 ;
if ( "function" === typeof type ) fiberTag = shouldConstruct ( type ) ? 2 : 4 ;
else if ( "string" === typeof type ) fiberTag = 7 ;
2018-06-16 00:38:41 -07:00
else
2018-09-10 14:42:08 -07:00
a : switch ( type ) {
2018-06-16 00:38:41 -07:00
case REACT _FRAGMENT _TYPE :
return createFiberFromFragment (
element . children ,
mode ,
expirationTime ,
key
) ;
case REACT _ASYNC _MODE _TYPE :
2018-09-10 14:42:08 -07:00
fiberTag = 10 ;
2018-06-16 00:38:41 -07:00
mode |= 3 ;
break ;
case REACT _STRICT _MODE _TYPE :
2018-09-10 14:42:08 -07:00
fiberTag = 10 ;
2018-06-16 00:38:41 -07:00
mode |= 2 ;
break ;
case REACT _PROFILER _TYPE :
return (
( type = new FiberNode ( 15 , element , key , mode | 4 ) ) ,
( type . type = REACT _PROFILER _TYPE ) ,
( type . expirationTime = expirationTime ) ,
type
) ;
2018-07-24 14:45:35 -07:00
case REACT _PLACEHOLDER _TYPE :
2018-06-16 00:38:41 -07:00
fiberTag = 16 ;
break ;
default :
2018-09-10 14:42:08 -07:00
if ( "object" === typeof type && null !== type )
switch ( type . $$typeof ) {
2018-06-16 00:38:41 -07:00
case REACT _PROVIDER _TYPE :
2018-09-10 14:42:08 -07:00
fiberTag = 12 ;
2018-06-16 00:38:41 -07:00
break a ;
case REACT _CONTEXT _TYPE :
2018-09-10 14:42:08 -07:00
fiberTag = 11 ;
2018-06-16 00:38:41 -07:00
break a ;
case REACT _FORWARD _REF _TYPE :
2018-09-10 14:42:08 -07:00
fiberTag = 13 ;
2018-06-16 00:38:41 -07:00
break a ;
default :
2018-09-10 14:42:08 -07:00
if ( "function" === typeof type . then ) {
fiberTag = 4 ;
break a ;
}
2018-06-16 00:38:41 -07:00
}
2018-09-10 14:42:08 -07:00
invariant (
! 1 ,
"Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s" ,
null == type ? type : typeof type ,
""
) ;
2018-06-16 00:38:41 -07:00
}
mode = new FiberNode ( fiberTag , element , key , mode ) ;
mode . type = type ;
mode . expirationTime = expirationTime ;
return mode ;
}
function createFiberFromFragment ( elements , mode , expirationTime , key ) {
2018-09-10 14:42:08 -07:00
elements = new FiberNode ( 9 , elements , key , mode ) ;
2018-06-16 00:38:41 -07:00
elements . expirationTime = expirationTime ;
return elements ;
}
function createFiberFromText ( content , mode , expirationTime ) {
2018-09-10 14:42:08 -07:00
content = new FiberNode ( 8 , content , null , mode ) ;
2018-06-16 00:38:41 -07:00
content . expirationTime = expirationTime ;
return content ;
}
function createFiberFromPortal ( portal , mode , expirationTime ) {
mode = new FiberNode (
2018-09-10 14:42:08 -07:00
6 ,
2018-06-16 00:38:41 -07:00
null !== portal . children ? portal . children : [ ] ,
portal . key ,
mode
) ;
mode . expirationTime = expirationTime ;
mode . stateNode = {
containerInfo : portal . containerInfo ,
pendingChildren : null ,
implementation : portal . implementation
2018-05-15 13:08:47 -07:00
} ;
2018-06-16 00:38:41 -07:00
return mode ;
}
function markPendingPriorityLevel ( root , expirationTime ) {
root . didError = ! 1 ;
var earliestPendingTime = root . earliestPendingTime ;
0 === earliestPendingTime
? ( root . earliestPendingTime = root . latestPendingTime = expirationTime )
: earliestPendingTime > expirationTime
? ( root . earliestPendingTime = expirationTime )
: root . latestPendingTime < expirationTime &&
( root . latestPendingTime = expirationTime ) ;
2018-07-24 14:45:35 -07:00
findNextExpirationTimeToWorkOn ( expirationTime , root ) ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
function findNextExpirationTimeToWorkOn ( completedExpirationTime , root ) {
2018-06-16 00:38:41 -07:00
var earliestSuspendedTime = root . earliestSuspendedTime ,
2018-07-24 14:45:35 -07:00
latestSuspendedTime = root . latestSuspendedTime ,
earliestPendingTime = root . earliestPendingTime ,
latestPingedTime = root . latestPingedTime ;
earliestPendingTime =
0 !== earliestPendingTime ? earliestPendingTime : latestPingedTime ;
0 === earliestPendingTime &&
( 0 === completedExpirationTime ||
latestSuspendedTime > completedExpirationTime ) &&
( earliestPendingTime = latestSuspendedTime ) ;
completedExpirationTime = earliestPendingTime ;
0 !== completedExpirationTime &&
0 !== earliestSuspendedTime &&
earliestSuspendedTime < completedExpirationTime &&
( completedExpirationTime = earliestSuspendedTime ) ;
root . nextExpirationTimeToWorkOn = earliestPendingTime ;
root . expirationTime = completedExpirationTime ;
2018-05-15 13:08:47 -07:00
}
var hasForceUpdate = ! 1 ;
2017-11-15 09:05:34 -08:00
function createUpdateQueue ( baseState ) {
return {
2018-05-15 13:08:47 -07:00
baseState : baseState ,
firstUpdate : null ,
lastUpdate : null ,
firstCapturedUpdate : null ,
lastCapturedUpdate : null ,
firstEffect : null ,
lastEffect : null ,
firstCapturedEffect : null ,
lastCapturedEffect : null
} ;
}
function cloneUpdateQueue ( currentQueue ) {
return {
baseState : currentQueue . baseState ,
firstUpdate : currentQueue . firstUpdate ,
lastUpdate : currentQueue . lastUpdate ,
firstCapturedUpdate : null ,
lastCapturedUpdate : null ,
firstEffect : null ,
lastEffect : null ,
firstCapturedEffect : null ,
lastCapturedEffect : null
2017-11-15 09:05:34 -08:00
} ;
}
2018-05-15 13:08:47 -07:00
function createUpdate ( expirationTime ) {
return {
expirationTime : expirationTime ,
tag : 0 ,
payload : null ,
callback : null ,
next : null ,
nextEffect : null
} ;
}
2018-07-24 14:45:35 -07:00
function appendUpdateToQueue ( queue , update ) {
2018-05-15 13:08:47 -07:00
null === queue . lastUpdate
? ( queue . firstUpdate = queue . lastUpdate = update )
: ( ( queue . lastUpdate . next = update ) , ( queue . lastUpdate = update ) ) ;
}
2018-07-24 14:45:35 -07:00
function enqueueUpdate ( fiber , update ) {
2018-05-15 13:08:47 -07:00
var alternate = fiber . alternate ;
if ( null === alternate ) {
var queue1 = fiber . updateQueue ;
var queue2 = null ;
null === queue1 &&
( queue1 = fiber . updateQueue = createUpdateQueue ( fiber . memoizedState ) ) ;
} else
( queue1 = fiber . updateQueue ) ,
( queue2 = alternate . updateQueue ) ,
null === queue1
? null === queue2
? ( ( queue1 = fiber . updateQueue = createUpdateQueue (
fiber . memoizedState
) ) ,
( queue2 = alternate . updateQueue = createUpdateQueue (
alternate . memoizedState
) ) )
: ( queue1 = fiber . updateQueue = cloneUpdateQueue ( queue2 ) )
: null === queue2 &&
( queue2 = alternate . updateQueue = cloneUpdateQueue ( queue1 ) ) ;
null === queue2 || queue1 === queue2
2018-07-24 14:45:35 -07:00
? appendUpdateToQueue ( queue1 , update )
2018-05-15 13:08:47 -07:00
: null === queue1 . lastUpdate || null === queue2 . lastUpdate
2018-07-24 14:45:35 -07:00
? ( appendUpdateToQueue ( queue1 , update ) ,
appendUpdateToQueue ( queue2 , update ) )
: ( appendUpdateToQueue ( queue1 , update ) , ( queue2 . lastUpdate = update ) ) ;
2018-05-15 13:08:47 -07:00
}
2018-07-24 14:45:35 -07:00
function enqueueCapturedUpdate ( workInProgress , update ) {
2018-05-15 13:08:47 -07:00
var workInProgressQueue = workInProgress . updateQueue ;
workInProgressQueue =
null === workInProgressQueue
? ( workInProgress . updateQueue = createUpdateQueue (
workInProgress . memoizedState
) )
: ensureWorkInProgressQueueIsAClone ( workInProgress , workInProgressQueue ) ;
null === workInProgressQueue . lastCapturedUpdate
? ( workInProgressQueue . firstCapturedUpdate = workInProgressQueue . lastCapturedUpdate = update )
: ( ( workInProgressQueue . lastCapturedUpdate . next = update ) ,
( workInProgressQueue . lastCapturedUpdate = update ) ) ;
2018-02-28 19:16:47 -08:00
}
2018-05-15 13:08:47 -07:00
function ensureWorkInProgressQueueIsAClone ( workInProgress , queue ) {
var current = workInProgress . alternate ;
null !== current &&
queue === current . updateQueue &&
( queue = workInProgress . updateQueue = cloneUpdateQueue ( queue ) ) ;
return queue ;
2018-05-11 12:09:48 -07:00
}
2018-05-15 13:08:47 -07:00
function getStateFromUpdate (
workInProgress ,
queue ,
update ,
prevState ,
nextProps ,
instance
) {
switch ( update . tag ) {
case 1 :
return (
( workInProgress = update . payload ) ,
"function" === typeof workInProgress
? workInProgress . call ( instance , prevState , nextProps )
: workInProgress
) ;
case 3 :
workInProgress . effectTag = ( workInProgress . effectTag & - 1025 ) | 64 ;
case 0 :
workInProgress = update . payload ;
nextProps =
"function" === typeof workInProgress
? workInProgress . call ( instance , prevState , nextProps )
: workInProgress ;
if ( null === nextProps || void 0 === nextProps ) break ;
return Object . assign ( { } , prevState , nextProps ) ;
case 2 :
hasForceUpdate = ! 0 ;
}
return prevState ;
2017-11-15 09:05:34 -08:00
}
function processUpdateQueue (
workInProgress ,
queue ,
2018-05-11 12:09:48 -07:00
props ,
2018-05-15 13:08:47 -07:00
instance ,
2017-11-15 09:05:34 -08:00
renderExpirationTime
) {
2018-05-15 13:08:47 -07:00
hasForceUpdate = ! 1 ;
2018-07-24 14:45:35 -07:00
queue = ensureWorkInProgressQueueIsAClone ( workInProgress , queue ) ;
for (
var newBaseState = queue . baseState ,
newFirstUpdate = null ,
newExpirationTime = 0 ,
update = queue . firstUpdate ,
resultState = newBaseState ;
null !== update ;
2018-05-15 13:08:47 -07:00
2018-07-24 14:45:35 -07:00
) {
var updateExpirationTime = update . expirationTime ;
if ( updateExpirationTime > renderExpirationTime ) {
if (
( null === newFirstUpdate &&
( ( newFirstUpdate = update ) , ( newBaseState = resultState ) ) ,
0 === newExpirationTime || newExpirationTime > updateExpirationTime )
)
newExpirationTime = updateExpirationTime ;
} else
( resultState = getStateFromUpdate (
workInProgress ,
queue ,
update ,
resultState ,
props ,
instance
) ) ,
null !== update . callback &&
( ( workInProgress . effectTag |= 32 ) ,
( update . nextEffect = null ) ,
null === queue . lastEffect
? ( queue . firstEffect = queue . lastEffect = update )
: ( ( queue . lastEffect . nextEffect = update ) ,
( queue . lastEffect = update ) ) ) ;
update = update . next ;
}
updateExpirationTime = null ;
for ( update = queue . firstCapturedUpdate ; null !== update ; ) {
var _updateExpirationTime = update . expirationTime ;
if ( _updateExpirationTime > renderExpirationTime ) {
if (
( null === updateExpirationTime &&
( ( updateExpirationTime = update ) ,
null === newFirstUpdate && ( newBaseState = resultState ) ) ,
0 === newExpirationTime || newExpirationTime > _updateExpirationTime )
)
newExpirationTime = _updateExpirationTime ;
} else
( resultState = getStateFromUpdate (
workInProgress ,
queue ,
update ,
resultState ,
props ,
instance
) ) ,
null !== update . callback &&
( ( workInProgress . effectTag |= 32 ) ,
( update . nextEffect = null ) ,
null === queue . lastCapturedEffect
? ( queue . firstCapturedEffect = queue . lastCapturedEffect = update )
: ( ( queue . lastCapturedEffect . nextEffect = update ) ,
( queue . lastCapturedEffect = update ) ) ) ;
update = update . next ;
2018-05-07 11:06:52 -07:00
}
2018-07-24 14:45:35 -07:00
null === newFirstUpdate && ( queue . lastUpdate = null ) ;
null === updateExpirationTime
? ( queue . lastCapturedUpdate = null )
: ( workInProgress . effectTag |= 32 ) ;
null === newFirstUpdate &&
null === updateExpirationTime &&
( newBaseState = resultState ) ;
queue . baseState = newBaseState ;
queue . firstUpdate = newFirstUpdate ;
queue . firstCapturedUpdate = updateExpirationTime ;
workInProgress . expirationTime = newExpirationTime ;
workInProgress . memoizedState = resultState ;
2018-05-07 11:06:52 -07:00
}
2018-05-15 13:08:47 -07:00
function commitUpdateQueue ( finishedWork , finishedQueue , instance ) {
null !== finishedQueue . firstCapturedUpdate &&
( null !== finishedQueue . lastUpdate &&
( ( finishedQueue . lastUpdate . next = finishedQueue . firstCapturedUpdate ) ,
( finishedQueue . lastUpdate = finishedQueue . lastCapturedUpdate ) ) ,
( finishedQueue . firstCapturedUpdate = finishedQueue . lastCapturedUpdate = null ) ) ;
2018-09-10 14:42:08 -07:00
commitUpdateEffects ( finishedQueue . firstEffect , instance ) ;
finishedQueue . firstEffect = finishedQueue . lastEffect = null ;
commitUpdateEffects ( finishedQueue . firstCapturedEffect , instance ) ;
finishedQueue . firstCapturedEffect = finishedQueue . lastCapturedEffect = null ;
}
function commitUpdateEffects ( effect , instance ) {
for ( ; null !== effect ; ) {
var _callback3 = effect . callback ;
if ( null !== _callback3 ) {
effect . callback = null ;
var context = instance ;
invariant (
"function" === typeof _callback3 ,
"Invalid argument passed as callback. Expected a function. Instead received: %s" ,
_callback3
) ;
_callback3 . call ( context ) ;
}
effect = effect . nextEffect ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
}
function createCapturedValue ( value , source ) {
return {
value : value ,
source : source ,
2018-07-24 14:45:35 -07:00
stack : getStackByFiberInDevAndProd ( source )
2018-06-16 00:38:41 -07:00
} ;
}
2018-07-24 14:45:35 -07:00
var valueCursor = { current : null } ,
currentlyRenderingFiber = null ,
lastContextDependency = null ,
lastContextWithAllBitsObserved = null ;
2018-09-10 14:42:08 -07:00
function pushProvider ( providerFiber , nextValue ) {
2018-06-16 00:38:41 -07:00
var context = providerFiber . type . _context ;
push ( valueCursor , context . _currentValue , providerFiber ) ;
2018-09-10 14:42:08 -07:00
context . _currentValue = nextValue ;
2018-06-16 00:38:41 -07:00
}
function popProvider ( providerFiber ) {
2018-09-10 14:42:08 -07:00
var currentValue = valueCursor . current ;
2018-06-16 00:38:41 -07:00
pop ( valueCursor , providerFiber ) ;
2018-09-10 14:42:08 -07:00
providerFiber . type . _context . _currentValue = currentValue ;
2018-07-24 14:45:35 -07:00
}
2018-09-10 14:42:08 -07:00
function prepareToReadContext ( workInProgress ) {
2018-07-24 14:45:35 -07:00
currentlyRenderingFiber = workInProgress ;
lastContextWithAllBitsObserved = lastContextDependency = null ;
2018-09-10 14:42:08 -07:00
workInProgress . firstContextDependency = null ;
2018-07-24 14:45:35 -07:00
}
function readContext ( context , observedBits ) {
if (
lastContextWithAllBitsObserved !== context &&
! 1 !== observedBits &&
0 !== observedBits
) {
if ( "number" !== typeof observedBits || 1073741823 === observedBits )
( lastContextWithAllBitsObserved = context ) , ( observedBits = 1073741823 ) ;
observedBits = { context : context , observedBits : observedBits , next : null } ;
null === lastContextDependency
? ( invariant (
null !== currentlyRenderingFiber ,
"Context.unstable_read(): Context can only be read while React is rendering, e.g. inside the render method or getDerivedStateFromProps."
) ,
( currentlyRenderingFiber . firstContextDependency = lastContextDependency = observedBits ) )
: ( lastContextDependency = lastContextDependency . next = observedBits ) ;
}
return context . _currentValue ;
}
2018-06-16 00:38:41 -07:00
var NO _CONTEXT = { } ,
2018-07-24 14:45:35 -07:00
contextStackCursor$1 = { current : NO _CONTEXT } ,
contextFiberStackCursor = { current : NO _CONTEXT } ,
rootInstanceStackCursor = { current : NO _CONTEXT } ;
2018-06-16 00:38:41 -07:00
function requiredContext ( c ) {
invariant (
c !== NO _CONTEXT ,
"Expected host context to exist. This error is likely caused by a bug in React. Please file an issue."
) ;
return c ;
}
function pushHostContainer ( fiber , nextRootInstance ) {
push ( rootInstanceStackCursor , nextRootInstance , fiber ) ;
push ( contextFiberStackCursor , fiber , fiber ) ;
push ( contextStackCursor$1 , NO _CONTEXT , fiber ) ;
pop ( contextStackCursor$1 , fiber ) ;
push ( contextStackCursor$1 , { isInAParentText : ! 1 } , fiber ) ;
}
function popHostContainer ( fiber ) {
pop ( contextStackCursor$1 , fiber ) ;
pop ( contextFiberStackCursor , fiber ) ;
pop ( rootInstanceStackCursor , fiber ) ;
}
2018-07-24 14:45:35 -07:00
function pushHostContext ( fiber ) {
requiredContext ( rootInstanceStackCursor . current ) ;
var context = requiredContext ( contextStackCursor$1 . current ) ;
var nextContext = fiber . type ;
nextContext =
"AndroidTextInput" === nextContext ||
"RCTMultilineTextInputView" === nextContext ||
"RCTSinglelineTextInputView" === nextContext ||
"RCTText" === nextContext ||
"RCTVirtualText" === nextContext ;
nextContext =
context . isInAParentText !== nextContext
? { isInAParentText : nextContext }
: context ;
context !== nextContext &&
( push ( contextFiberStackCursor , fiber , fiber ) ,
push ( contextStackCursor$1 , nextContext , fiber ) ) ;
}
2018-06-16 00:38:41 -07:00
function popHostContext ( fiber ) {
contextFiberStackCursor . current === fiber &&
( pop ( contextStackCursor$1 , fiber ) , pop ( contextFiberStackCursor , fiber ) ) ;
}
var hasOwnProperty = Object . prototype . hasOwnProperty ;
function is ( x , y ) {
return x === y ? 0 !== x || 0 !== y || 1 / x === 1 / y : x !== x && y !== y ;
}
function shallowEqual ( objA , objB ) {
if ( is ( objA , objB ) ) return ! 0 ;
if (
"object" !== typeof objA ||
null === objA ||
"object" !== typeof objB ||
null === objB
)
return ! 1 ;
var keysA = Object . keys ( objA ) ,
keysB = Object . keys ( objB ) ;
if ( keysA . length !== keysB . length ) return ! 1 ;
for ( keysB = 0 ; keysB < keysA . length ; keysB ++ )
if (
! hasOwnProperty . call ( objB , keysA [ keysB ] ) ||
! is ( objA [ keysA [ keysB ] ] , objB [ keysA [ keysB ] ] )
)
return ! 1 ;
return ! 0 ;
2018-05-15 13:08:47 -07:00
}
2018-07-24 14:45:35 -07:00
var emptyRefsObject = new React . Component ( ) . refs ;
2018-05-15 13:08:47 -07:00
function applyDerivedStateFromProps (
workInProgress ,
2018-09-10 14:42:08 -07:00
ctor ,
2018-05-15 13:08:47 -07:00
getDerivedStateFromProps ,
nextProps
) {
2018-09-10 14:42:08 -07:00
ctor = workInProgress . memoizedState ;
getDerivedStateFromProps = getDerivedStateFromProps ( nextProps , ctor ) ;
getDerivedStateFromProps =
2018-05-15 13:08:47 -07:00
null === getDerivedStateFromProps || void 0 === getDerivedStateFromProps
2018-09-10 14:42:08 -07:00
? ctor
: Object . assign ( { } , ctor , getDerivedStateFromProps ) ;
workInProgress . memoizedState = getDerivedStateFromProps ;
nextProps = workInProgress . updateQueue ;
null !== nextProps &&
2018-05-15 13:08:47 -07:00
0 === workInProgress . expirationTime &&
2018-09-10 14:42:08 -07:00
( nextProps . baseState = getDerivedStateFromProps ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
var classComponentUpdater = {
isMounted : function ( component ) {
return ( component = component . _reactInternalFiber )
? 2 === isFiberMountedImpl ( component )
: ! 1 ;
} ,
enqueueSetState : function ( inst , payload , callback ) {
inst = inst . _reactInternalFiber ;
2018-07-24 14:45:35 -07:00
var currentTime = requestCurrentTime ( ) ;
2018-06-16 00:38:41 -07:00
currentTime = computeExpirationForFiber ( currentTime , inst ) ;
var update = createUpdate ( currentTime ) ;
update . payload = payload ;
void 0 !== callback && null !== callback && ( update . callback = callback ) ;
2018-07-24 14:45:35 -07:00
enqueueUpdate ( inst , update ) ;
2018-06-16 00:38:41 -07:00
scheduleWork ( inst , currentTime ) ;
} ,
enqueueReplaceState : function ( inst , payload , callback ) {
inst = inst . _reactInternalFiber ;
2018-07-24 14:45:35 -07:00
var currentTime = requestCurrentTime ( ) ;
2018-06-16 00:38:41 -07:00
currentTime = computeExpirationForFiber ( currentTime , inst ) ;
var update = createUpdate ( currentTime ) ;
update . tag = 1 ;
update . payload = payload ;
void 0 !== callback && null !== callback && ( update . callback = callback ) ;
2018-07-24 14:45:35 -07:00
enqueueUpdate ( inst , update ) ;
2018-06-16 00:38:41 -07:00
scheduleWork ( inst , currentTime ) ;
} ,
enqueueForceUpdate : function ( inst , callback ) {
inst = inst . _reactInternalFiber ;
2018-07-24 14:45:35 -07:00
var currentTime = requestCurrentTime ( ) ;
2018-06-16 00:38:41 -07:00
currentTime = computeExpirationForFiber ( currentTime , inst ) ;
var update = createUpdate ( currentTime ) ;
update . tag = 2 ;
void 0 !== callback && null !== callback && ( update . callback = callback ) ;
2018-07-24 14:45:35 -07:00
enqueueUpdate ( inst , update ) ;
2018-06-16 00:38:41 -07:00
scheduleWork ( inst , currentTime ) ;
2018-01-29 14:17:07 -08:00
}
2018-06-16 00:38:41 -07:00
} ;
function checkShouldComponentUpdate (
workInProgress ,
2018-09-10 14:42:08 -07:00
ctor ,
2018-06-16 00:38:41 -07:00
oldProps ,
newProps ,
oldState ,
newState ,
2018-07-24 14:45:35 -07:00
nextLegacyContext
2018-06-16 00:38:41 -07:00
) {
2018-09-10 14:42:08 -07:00
workInProgress = workInProgress . stateNode ;
return "function" === typeof workInProgress . shouldComponentUpdate
? workInProgress . shouldComponentUpdate (
newProps ,
newState ,
nextLegacyContext
)
: ctor . prototype && ctor . prototype . isPureReactComponent
2018-06-16 00:38:41 -07:00
? ! shallowEqual ( oldProps , newProps ) || ! shallowEqual ( oldState , newState )
: ! 0 ;
}
function callComponentWillReceiveProps (
workInProgress ,
instance ,
newProps ,
2018-07-24 14:45:35 -07:00
nextLegacyContext
2018-06-16 00:38:41 -07:00
) {
workInProgress = instance . state ;
"function" === typeof instance . componentWillReceiveProps &&
2018-07-24 14:45:35 -07:00
instance . componentWillReceiveProps ( newProps , nextLegacyContext ) ;
2018-06-16 00:38:41 -07:00
"function" === typeof instance . UNSAFE _componentWillReceiveProps &&
2018-07-24 14:45:35 -07:00
instance . UNSAFE _componentWillReceiveProps ( newProps , nextLegacyContext ) ;
2018-06-16 00:38:41 -07:00
instance . state !== workInProgress &&
classComponentUpdater . enqueueReplaceState ( instance , instance . state , null ) ;
}
2018-09-10 14:42:08 -07:00
function mountClassInstance (
workInProgress ,
ctor ,
newProps ,
renderExpirationTime
) {
var instance = workInProgress . stateNode ,
unmaskedContext = isContextProvider ( ctor )
? previousContext
: contextStackCursor . current ;
instance . props = newProps ;
2018-06-16 00:38:41 -07:00
instance . state = workInProgress . memoizedState ;
2018-07-24 14:45:35 -07:00
instance . refs = emptyRefsObject ;
2018-06-16 00:38:41 -07:00
instance . context = getMaskedContext ( workInProgress , unmaskedContext ) ;
unmaskedContext = workInProgress . updateQueue ;
null !== unmaskedContext &&
( processUpdateQueue (
2017-11-15 09:05:34 -08:00
workInProgress ,
2018-06-16 00:38:41 -07:00
unmaskedContext ,
2018-09-10 14:42:08 -07:00
newProps ,
2018-06-16 00:38:41 -07:00
instance ,
2017-11-15 09:05:34 -08:00
renderExpirationTime
2018-06-16 00:38:41 -07:00
) ,
( instance . state = workInProgress . memoizedState ) ) ;
2018-07-24 14:45:35 -07:00
unmaskedContext = ctor . getDerivedStateFromProps ;
2018-06-16 00:38:41 -07:00
"function" === typeof unmaskedContext &&
2018-09-10 14:42:08 -07:00
( applyDerivedStateFromProps (
workInProgress ,
ctor ,
unmaskedContext ,
newProps
) ,
2018-06-16 00:38:41 -07:00
( instance . state = workInProgress . memoizedState ) ) ;
"function" === typeof ctor . getDerivedStateFromProps ||
"function" === typeof instance . getSnapshotBeforeUpdate ||
( "function" !== typeof instance . UNSAFE _componentWillMount &&
"function" !== typeof instance . componentWillMount ) ||
( ( ctor = instance . state ) ,
"function" === typeof instance . componentWillMount &&
instance . componentWillMount ( ) ,
"function" === typeof instance . UNSAFE _componentWillMount &&
instance . UNSAFE _componentWillMount ( ) ,
ctor !== instance . state &&
classComponentUpdater . enqueueReplaceState ( instance , instance . state , null ) ,
( unmaskedContext = workInProgress . updateQueue ) ,
null !== unmaskedContext &&
( processUpdateQueue (
workInProgress ,
unmaskedContext ,
2018-09-10 14:42:08 -07:00
newProps ,
2018-06-16 00:38:41 -07:00
instance ,
renderExpirationTime
) ,
( instance . state = workInProgress . memoizedState ) ) ) ;
"function" === typeof instance . componentDidMount &&
( workInProgress . effectTag |= 4 ) ;
2017-11-15 09:05:34 -08:00
}
2017-11-29 10:12:57 -08:00
var isArray$1 = Array . isArray ;
2018-07-24 14:45:35 -07:00
function coerceRef ( returnFiber , current$$1 , element ) {
2018-02-09 16:01:29 -08:00
returnFiber = element . ref ;
if (
null !== returnFiber &&
"function" !== typeof returnFiber &&
"object" !== typeof returnFiber
) {
2017-11-15 09:05:34 -08:00
if ( element . _owner ) {
element = element . _owner ;
var inst = void 0 ;
element &&
( invariant (
2018-09-10 14:42:08 -07:00
2 === element . tag || 3 === element . tag ,
2017-11-15 09:05:34 -08:00
"Stateless function components cannot have refs."
) ,
( inst = element . stateNode ) ) ;
invariant (
inst ,
"Missing owner for string ref %s. This error is likely caused by a bug in React. Please file an issue." ,
2018-02-09 16:01:29 -08:00
returnFiber
2017-11-15 09:05:34 -08:00
) ;
2018-02-09 16:01:29 -08:00
var stringRef = "" + returnFiber ;
2017-11-15 09:05:34 -08:00
if (
2018-07-24 14:45:35 -07:00
null !== current$$1 &&
null !== current$$1 . ref &&
"function" === typeof current$$1 . ref &&
current$$1 . ref . _stringRef === stringRef
2017-11-15 09:05:34 -08:00
)
2018-07-24 14:45:35 -07:00
return current$$1 . ref ;
current$$1 = function ( value ) {
var refs = inst . refs ;
refs === emptyRefsObject && ( refs = inst . refs = { } ) ;
2017-11-15 09:05:34 -08:00
null === value ? delete refs [ stringRef ] : ( refs [ stringRef ] = value ) ;
} ;
2018-07-24 14:45:35 -07:00
current$$1 . _stringRef = stringRef ;
return current$$1 ;
2017-11-15 09:05:34 -08:00
}
invariant (
2018-02-09 16:01:29 -08:00
"string" === typeof returnFiber ,
2018-09-10 14:42:08 -07:00
"Expected ref to be a function, a string, an object returned by React.createRef(), or null."
2017-11-15 09:05:34 -08:00
) ;
invariant (
element . _owner ,
2018-01-29 14:17:07 -08:00
"Element ref was specified as a string (%s) but no owner was set. This could happen for one of the following reasons:\n1. You may be adding a ref to a functional component\n2. You may be adding a ref to a component that was not created inside a component's render method\n3. You have multiple copies of React loaded\nSee https://fb.me/react-refs-must-have-owner for more information." ,
2018-02-09 16:01:29 -08:00
returnFiber
2017-11-15 09:05:34 -08:00
) ;
}
2018-02-09 16:01:29 -08:00
return returnFiber ;
2017-11-15 09:05:34 -08:00
}
function throwOnInvalidObjectType ( returnFiber , newChild ) {
"textarea" !== returnFiber . type &&
invariant (
! 1 ,
"Objects are not valid as a React child (found: %s).%s" ,
"[object Object]" === Object . prototype . toString . call ( newChild )
? "object with keys {" + Object . keys ( newChild ) . join ( ", " ) + "}"
: newChild ,
""
) ;
}
2017-11-29 10:12:57 -08:00
function ChildReconciler ( shouldTrackSideEffects ) {
2017-11-15 09:05:34 -08:00
function deleteChild ( returnFiber , childToDelete ) {
if ( shouldTrackSideEffects ) {
var last = returnFiber . lastEffect ;
null !== last
? ( ( last . nextEffect = childToDelete ) ,
( returnFiber . lastEffect = childToDelete ) )
: ( returnFiber . firstEffect = returnFiber . lastEffect = childToDelete ) ;
childToDelete . nextEffect = null ;
childToDelete . effectTag = 8 ;
}
}
function deleteRemainingChildren ( returnFiber , currentFirstChild ) {
if ( ! shouldTrackSideEffects ) return null ;
for ( ; null !== currentFirstChild ; )
deleteChild ( returnFiber , currentFirstChild ) ,
( currentFirstChild = currentFirstChild . sibling ) ;
return null ;
}
function mapRemainingChildren ( returnFiber , currentFirstChild ) {
for ( returnFiber = new Map ( ) ; null !== currentFirstChild ; )
null !== currentFirstChild . key
? returnFiber . set ( currentFirstChild . key , currentFirstChild )
: returnFiber . set ( currentFirstChild . index , currentFirstChild ) ,
( currentFirstChild = currentFirstChild . sibling ) ;
return returnFiber ;
}
function useFiber ( fiber , pendingProps , expirationTime ) {
2017-11-29 10:12:57 -08:00
fiber = createWorkInProgress ( fiber , pendingProps , expirationTime ) ;
2017-11-15 09:05:34 -08:00
fiber . index = 0 ;
fiber . sibling = null ;
return fiber ;
}
function placeChild ( newFiber , lastPlacedIndex , newIndex ) {
newFiber . index = newIndex ;
if ( ! shouldTrackSideEffects ) return lastPlacedIndex ;
newIndex = newFiber . alternate ;
if ( null !== newIndex )
return (
( newIndex = newIndex . index ) ,
newIndex < lastPlacedIndex
? ( ( newFiber . effectTag = 2 ) , lastPlacedIndex )
: newIndex
) ;
newFiber . effectTag = 2 ;
return lastPlacedIndex ;
}
function placeSingleChild ( newFiber ) {
shouldTrackSideEffects &&
null === newFiber . alternate &&
( newFiber . effectTag = 2 ) ;
return newFiber ;
}
2018-07-24 14:45:35 -07:00
function updateTextNode (
returnFiber ,
current$$1 ,
textContent ,
expirationTime
) {
2018-09-10 14:42:08 -07:00
if ( null === current$$1 || 8 !== current$$1 . tag )
2017-11-15 09:05:34 -08:00
return (
2018-07-24 14:45:35 -07:00
( current$$1 = createFiberFromText (
2017-11-15 09:05:34 -08:00
textContent ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ) ,
2018-07-24 14:45:35 -07:00
( current$$1 . return = returnFiber ) ,
current$$1
2017-11-15 09:05:34 -08:00
) ;
2018-07-24 14:45:35 -07:00
current$$1 = useFiber ( current$$1 , textContent , expirationTime ) ;
current$$1 . return = returnFiber ;
return current$$1 ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
function updateElement ( returnFiber , current$$1 , element , expirationTime ) {
if ( null !== current$$1 && current$$1 . type === element . type )
2017-11-15 09:05:34 -08:00
return (
2018-07-24 14:45:35 -07:00
( expirationTime = useFiber ( current$$1 , element . props , expirationTime ) ) ,
( expirationTime . ref = coerceRef ( returnFiber , current$$1 , element ) ) ,
2018-05-15 13:08:47 -07:00
( expirationTime . return = returnFiber ) ,
2017-11-15 09:05:34 -08:00
expirationTime
) ;
expirationTime = createFiberFromElement (
element ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ;
2018-07-24 14:45:35 -07:00
expirationTime . ref = coerceRef ( returnFiber , current$$1 , element ) ;
2018-05-15 13:08:47 -07:00
expirationTime . return = returnFiber ;
2017-11-15 09:05:34 -08:00
return expirationTime ;
}
2018-07-24 14:45:35 -07:00
function updatePortal ( returnFiber , current$$1 , portal , expirationTime ) {
2017-11-15 09:05:34 -08:00
if (
2018-07-24 14:45:35 -07:00
null === current$$1 ||
2018-09-10 14:42:08 -07:00
6 !== current$$1 . tag ||
2018-07-24 14:45:35 -07:00
current$$1 . stateNode . containerInfo !== portal . containerInfo ||
current$$1 . stateNode . implementation !== portal . implementation
2017-11-15 09:05:34 -08:00
)
return (
2018-07-24 14:45:35 -07:00
( current$$1 = createFiberFromPortal (
2017-11-15 09:05:34 -08:00
portal ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ) ,
2018-07-24 14:45:35 -07:00
( current$$1 . return = returnFiber ) ,
current$$1
2017-11-15 09:05:34 -08:00
) ;
2018-07-24 14:45:35 -07:00
current$$1 = useFiber ( current$$1 , portal . children || [ ] , expirationTime ) ;
current$$1 . return = returnFiber ;
return current$$1 ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
function updateFragment (
returnFiber ,
current$$1 ,
fragment ,
expirationTime ,
key
) {
2018-09-10 14:42:08 -07:00
if ( null === current$$1 || 9 !== current$$1 . tag )
2017-11-15 09:05:34 -08:00
return (
2018-07-24 14:45:35 -07:00
( current$$1 = createFiberFromFragment (
2017-11-15 09:05:34 -08:00
fragment ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime ,
key
) ) ,
2018-07-24 14:45:35 -07:00
( current$$1 . return = returnFiber ) ,
current$$1
2017-11-15 09:05:34 -08:00
) ;
2018-07-24 14:45:35 -07:00
current$$1 = useFiber ( current$$1 , fragment , expirationTime ) ;
current$$1 . return = returnFiber ;
return current$$1 ;
2017-11-15 09:05:34 -08:00
}
function createChild ( returnFiber , newChild , expirationTime ) {
if ( "string" === typeof newChild || "number" === typeof newChild )
return (
( newChild = createFiberFromText (
"" + newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ) ,
2018-05-15 13:08:47 -07:00
( newChild . return = returnFiber ) ,
2017-11-15 09:05:34 -08:00
newChild
) ;
if ( "object" === typeof newChild && null !== newChild ) {
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
return (
2018-01-29 14:17:07 -08:00
( expirationTime = createFiberFromElement (
2017-11-15 09:05:34 -08:00
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ) ,
2018-02-09 16:01:29 -08:00
( expirationTime . ref = coerceRef ( returnFiber , null , newChild ) ) ,
2018-05-15 13:08:47 -07:00
( expirationTime . return = returnFiber ) ,
2017-11-15 09:05:34 -08:00
expirationTime
) ;
case REACT _PORTAL _TYPE :
return (
( newChild = createFiberFromPortal (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ) ,
2018-05-15 13:08:47 -07:00
( newChild . return = returnFiber ) ,
2017-11-15 09:05:34 -08:00
newChild
) ;
}
if ( isArray$1 ( newChild ) || getIteratorFn ( newChild ) )
return (
( newChild = createFiberFromFragment (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime ,
null
) ) ,
2018-05-15 13:08:47 -07:00
( newChild . return = returnFiber ) ,
2017-11-15 09:05:34 -08:00
newChild
) ;
throwOnInvalidObjectType ( returnFiber , newChild ) ;
}
return null ;
}
function updateSlot ( returnFiber , oldFiber , newChild , expirationTime ) {
var key = null !== oldFiber ? oldFiber . key : null ;
if ( "string" === typeof newChild || "number" === typeof newChild )
return null !== key
? null
: updateTextNode ( returnFiber , oldFiber , "" + newChild , expirationTime ) ;
if ( "object" === typeof newChild && null !== newChild ) {
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
return newChild . key === key
? newChild . type === REACT _FRAGMENT _TYPE
? updateFragment (
returnFiber ,
oldFiber ,
newChild . props . children ,
expirationTime ,
key
)
: updateElement ( returnFiber , oldFiber , newChild , expirationTime )
: null ;
case REACT _PORTAL _TYPE :
return newChild . key === key
? updatePortal ( returnFiber , oldFiber , newChild , expirationTime )
: null ;
}
if ( isArray$1 ( newChild ) || getIteratorFn ( newChild ) )
return null !== key
? null
: updateFragment (
returnFiber ,
oldFiber ,
newChild ,
expirationTime ,
null
) ;
throwOnInvalidObjectType ( returnFiber , newChild ) ;
}
return null ;
}
function updateFromMap (
existingChildren ,
returnFiber ,
newIdx ,
newChild ,
expirationTime
) {
if ( "string" === typeof newChild || "number" === typeof newChild )
return (
( existingChildren = existingChildren . get ( newIdx ) || null ) ,
updateTextNode (
returnFiber ,
existingChildren ,
"" + newChild ,
expirationTime
)
) ;
if ( "object" === typeof newChild && null !== newChild ) {
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
return (
( existingChildren =
existingChildren . get (
null === newChild . key ? newIdx : newChild . key
) || null ) ,
newChild . type === REACT _FRAGMENT _TYPE
? updateFragment (
returnFiber ,
existingChildren ,
newChild . props . children ,
expirationTime ,
newChild . key
)
: updateElement (
returnFiber ,
existingChildren ,
newChild ,
expirationTime
)
) ;
case REACT _PORTAL _TYPE :
return (
( existingChildren =
existingChildren . get (
null === newChild . key ? newIdx : newChild . key
) || null ) ,
updatePortal (
returnFiber ,
existingChildren ,
newChild ,
expirationTime
)
) ;
}
if ( isArray$1 ( newChild ) || getIteratorFn ( newChild ) )
return (
( existingChildren = existingChildren . get ( newIdx ) || null ) ,
updateFragment (
returnFiber ,
existingChildren ,
newChild ,
expirationTime ,
null
)
) ;
throwOnInvalidObjectType ( returnFiber , newChild ) ;
}
return null ;
}
function reconcileChildrenArray (
returnFiber ,
currentFirstChild ,
newChildren ,
expirationTime
) {
for (
var resultingFirstChild = null ,
previousNewFiber = null ,
oldFiber = currentFirstChild ,
newIdx = ( currentFirstChild = 0 ) ,
nextOldFiber = null ;
null !== oldFiber && newIdx < newChildren . length ;
newIdx ++
) {
oldFiber . index > newIdx
? ( ( nextOldFiber = oldFiber ) , ( oldFiber = null ) )
: ( nextOldFiber = oldFiber . sibling ) ;
var newFiber = updateSlot (
returnFiber ,
oldFiber ,
newChildren [ newIdx ] ,
expirationTime
) ;
if ( null === newFiber ) {
null === oldFiber && ( oldFiber = nextOldFiber ) ;
break ;
}
shouldTrackSideEffects &&
oldFiber &&
null === newFiber . alternate &&
deleteChild ( returnFiber , oldFiber ) ;
currentFirstChild = placeChild ( newFiber , currentFirstChild , newIdx ) ;
null === previousNewFiber
? ( resultingFirstChild = newFiber )
: ( previousNewFiber . sibling = newFiber ) ;
previousNewFiber = newFiber ;
oldFiber = nextOldFiber ;
}
if ( newIdx === newChildren . length )
return (
deleteRemainingChildren ( returnFiber , oldFiber ) , resultingFirstChild
) ;
if ( null === oldFiber ) {
for ( ; newIdx < newChildren . length ; newIdx ++ )
if (
( oldFiber = createChild (
returnFiber ,
newChildren [ newIdx ] ,
expirationTime
) )
)
( currentFirstChild = placeChild ( oldFiber , currentFirstChild , newIdx ) ) ,
null === previousNewFiber
? ( resultingFirstChild = oldFiber )
: ( previousNewFiber . sibling = oldFiber ) ,
( previousNewFiber = oldFiber ) ;
return resultingFirstChild ;
}
for (
oldFiber = mapRemainingChildren ( returnFiber , oldFiber ) ;
newIdx < newChildren . length ;
newIdx ++
)
if (
( nextOldFiber = updateFromMap (
oldFiber ,
returnFiber ,
newIdx ,
newChildren [ newIdx ] ,
expirationTime
) )
2018-05-15 13:08:47 -07:00
)
shouldTrackSideEffects &&
null !== nextOldFiber . alternate &&
oldFiber . delete (
2017-11-15 09:05:34 -08:00
null === nextOldFiber . key ? newIdx : nextOldFiber . key
2018-05-15 13:08:47 -07:00
) ,
( currentFirstChild = placeChild (
nextOldFiber ,
currentFirstChild ,
newIdx
) ) ,
null === previousNewFiber
? ( resultingFirstChild = nextOldFiber )
: ( previousNewFiber . sibling = nextOldFiber ) ,
( previousNewFiber = nextOldFiber ) ;
2017-11-15 09:05:34 -08:00
shouldTrackSideEffects &&
oldFiber . forEach ( function ( child ) {
return deleteChild ( returnFiber , child ) ;
} ) ;
return resultingFirstChild ;
}
function reconcileChildrenIterator (
returnFiber ,
currentFirstChild ,
newChildrenIterable ,
expirationTime
) {
var iteratorFn = getIteratorFn ( newChildrenIterable ) ;
invariant (
"function" === typeof iteratorFn ,
"An object is not an iterable. This error is likely caused by a bug in React. Please file an issue."
) ;
newChildrenIterable = iteratorFn . call ( newChildrenIterable ) ;
invariant (
null != newChildrenIterable ,
"An iterable object provided no iterator."
) ;
for (
var previousNewFiber = ( iteratorFn = null ) ,
oldFiber = currentFirstChild ,
newIdx = ( currentFirstChild = 0 ) ,
nextOldFiber = null ,
step = newChildrenIterable . next ( ) ;
null !== oldFiber && ! step . done ;
newIdx ++ , step = newChildrenIterable . next ( )
) {
oldFiber . index > newIdx
? ( ( nextOldFiber = oldFiber ) , ( oldFiber = null ) )
: ( nextOldFiber = oldFiber . sibling ) ;
var newFiber = updateSlot (
returnFiber ,
oldFiber ,
step . value ,
expirationTime
) ;
if ( null === newFiber ) {
oldFiber || ( oldFiber = nextOldFiber ) ;
break ;
}
shouldTrackSideEffects &&
oldFiber &&
null === newFiber . alternate &&
deleteChild ( returnFiber , oldFiber ) ;
currentFirstChild = placeChild ( newFiber , currentFirstChild , newIdx ) ;
null === previousNewFiber
? ( iteratorFn = newFiber )
: ( previousNewFiber . sibling = newFiber ) ;
previousNewFiber = newFiber ;
oldFiber = nextOldFiber ;
}
if ( step . done )
return deleteRemainingChildren ( returnFiber , oldFiber ) , iteratorFn ;
if ( null === oldFiber ) {
for ( ; ! step . done ; newIdx ++ , step = newChildrenIterable . next ( ) )
( step = createChild ( returnFiber , step . value , expirationTime ) ) ,
null !== step &&
( ( currentFirstChild = placeChild ( step , currentFirstChild , newIdx ) ) ,
null === previousNewFiber
? ( iteratorFn = step )
: ( previousNewFiber . sibling = step ) ,
( previousNewFiber = step ) ) ;
return iteratorFn ;
}
for (
oldFiber = mapRemainingChildren ( returnFiber , oldFiber ) ;
! step . done ;
newIdx ++ , step = newChildrenIterable . next ( )
)
2018-05-15 13:08:47 -07:00
( step = updateFromMap (
oldFiber ,
returnFiber ,
newIdx ,
step . value ,
expirationTime
) ) ,
null !== step &&
( shouldTrackSideEffects &&
null !== step . alternate &&
oldFiber . delete ( null === step . key ? newIdx : step . key ) ,
( currentFirstChild = placeChild ( step , currentFirstChild , newIdx ) ) ,
null === previousNewFiber
? ( iteratorFn = step )
: ( previousNewFiber . sibling = step ) ,
( previousNewFiber = step ) ) ;
2017-11-15 09:05:34 -08:00
shouldTrackSideEffects &&
oldFiber . forEach ( function ( child ) {
return deleteChild ( returnFiber , child ) ;
} ) ;
return iteratorFn ;
}
return function ( returnFiber , currentFirstChild , newChild , expirationTime ) {
2018-06-16 00:38:41 -07:00
var isUnkeyedTopLevelFragment =
"object" === typeof newChild &&
2017-11-29 10:12:57 -08:00
null !== newChild &&
newChild . type === REACT _FRAGMENT _TYPE &&
2018-06-16 00:38:41 -07:00
null === newChild . key ;
isUnkeyedTopLevelFragment && ( newChild = newChild . props . children ) ;
2017-11-15 09:05:34 -08:00
var isObject = "object" === typeof newChild && null !== newChild ;
if ( isObject )
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
a : {
2018-06-16 00:38:41 -07:00
isObject = newChild . key ;
for (
isUnkeyedTopLevelFragment = currentFirstChild ;
null !== isUnkeyedTopLevelFragment ;
) {
if ( isUnkeyedTopLevelFragment . key === isObject )
2017-11-15 09:05:34 -08:00
if (
2018-09-10 14:42:08 -07:00
9 === isUnkeyedTopLevelFragment . tag
2017-11-15 09:05:34 -08:00
? newChild . type === REACT _FRAGMENT _TYPE
2018-06-16 00:38:41 -07:00
: isUnkeyedTopLevelFragment . type === newChild . type
2017-11-15 09:05:34 -08:00
) {
2018-06-16 00:38:41 -07:00
deleteRemainingChildren (
returnFiber ,
isUnkeyedTopLevelFragment . sibling
) ;
2017-11-15 09:05:34 -08:00
currentFirstChild = useFiber (
2018-06-16 00:38:41 -07:00
isUnkeyedTopLevelFragment ,
2017-11-15 09:05:34 -08:00
newChild . type === REACT _FRAGMENT _TYPE
? newChild . props . children
: newChild . props ,
expirationTime
) ;
2018-02-09 16:01:29 -08:00
currentFirstChild . ref = coerceRef (
returnFiber ,
2018-06-16 00:38:41 -07:00
isUnkeyedTopLevelFragment ,
2018-02-09 16:01:29 -08:00
newChild
) ;
2018-05-15 13:08:47 -07:00
currentFirstChild . return = returnFiber ;
2017-11-15 09:05:34 -08:00
returnFiber = currentFirstChild ;
break a ;
} else {
2018-06-16 00:38:41 -07:00
deleteRemainingChildren (
returnFiber ,
isUnkeyedTopLevelFragment
) ;
2017-11-15 09:05:34 -08:00
break ;
}
2018-06-16 00:38:41 -07:00
else deleteChild ( returnFiber , isUnkeyedTopLevelFragment ) ;
isUnkeyedTopLevelFragment = isUnkeyedTopLevelFragment . sibling ;
2017-11-15 09:05:34 -08:00
}
newChild . type === REACT _FRAGMENT _TYPE
2017-11-29 10:12:57 -08:00
? ( ( currentFirstChild = createFiberFromFragment (
2017-11-15 09:05:34 -08:00
newChild . props . children ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime ,
newChild . key
) ) ,
2018-05-15 13:08:47 -07:00
( currentFirstChild . return = returnFiber ) ,
2017-11-29 10:12:57 -08:00
( returnFiber = currentFirstChild ) )
2018-01-29 14:17:07 -08:00
: ( ( expirationTime = createFiberFromElement (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
2018-01-29 14:17:07 -08:00
) ) ,
2018-02-09 16:01:29 -08:00
( expirationTime . ref = coerceRef (
returnFiber ,
currentFirstChild ,
newChild
) ) ,
2018-05-15 13:08:47 -07:00
( expirationTime . return = returnFiber ) ,
2018-01-29 14:17:07 -08:00
( returnFiber = expirationTime ) ) ;
2017-11-15 09:05:34 -08:00
}
return placeSingleChild ( returnFiber ) ;
case REACT _PORTAL _TYPE :
a : {
2018-06-16 00:38:41 -07:00
for (
isUnkeyedTopLevelFragment = newChild . key ;
null !== currentFirstChild ;
) {
if ( currentFirstChild . key === isUnkeyedTopLevelFragment )
2017-11-15 09:05:34 -08:00
if (
2018-09-10 14:42:08 -07:00
6 === currentFirstChild . tag &&
2017-11-15 09:05:34 -08:00
currentFirstChild . stateNode . containerInfo ===
newChild . containerInfo &&
currentFirstChild . stateNode . implementation ===
newChild . implementation
) {
deleteRemainingChildren (
returnFiber ,
currentFirstChild . sibling
) ;
2017-11-29 10:12:57 -08:00
currentFirstChild = useFiber (
2017-11-15 09:05:34 -08:00
currentFirstChild ,
newChild . children || [ ] ,
expirationTime
) ;
2018-05-15 13:08:47 -07:00
currentFirstChild . return = returnFiber ;
2017-11-29 10:12:57 -08:00
returnFiber = currentFirstChild ;
2017-11-15 09:05:34 -08:00
break a ;
} else {
deleteRemainingChildren ( returnFiber , currentFirstChild ) ;
break ;
}
else deleteChild ( returnFiber , currentFirstChild ) ;
currentFirstChild = currentFirstChild . sibling ;
}
2017-11-29 10:12:57 -08:00
currentFirstChild = createFiberFromPortal (
2017-11-15 09:05:34 -08:00
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
) ;
2018-05-15 13:08:47 -07:00
currentFirstChild . return = returnFiber ;
2017-11-29 10:12:57 -08:00
returnFiber = currentFirstChild ;
2017-11-15 09:05:34 -08:00
}
return placeSingleChild ( returnFiber ) ;
}
if ( "string" === typeof newChild || "number" === typeof newChild )
return (
( newChild = "" + newChild ) ,
2018-09-10 14:42:08 -07:00
null !== currentFirstChild && 8 === currentFirstChild . tag
2017-11-15 09:05:34 -08:00
? ( deleteRemainingChildren ( returnFiber , currentFirstChild . sibling ) ,
2017-11-29 10:12:57 -08:00
( currentFirstChild = useFiber (
currentFirstChild ,
newChild ,
expirationTime
2018-04-18 14:59:57 -07:00
) ) ,
2018-05-15 13:08:47 -07:00
( currentFirstChild . return = returnFiber ) ,
2018-04-18 14:59:57 -07:00
( returnFiber = currentFirstChild ) )
2017-11-15 09:05:34 -08:00
: ( deleteRemainingChildren ( returnFiber , currentFirstChild ) ,
2017-11-29 10:12:57 -08:00
( currentFirstChild = createFiberFromText (
2017-11-15 09:05:34 -08:00
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2017-11-15 09:05:34 -08:00
expirationTime
2018-04-18 14:59:57 -07:00
) ) ,
2018-05-15 13:08:47 -07:00
( currentFirstChild . return = returnFiber ) ,
2018-04-18 14:59:57 -07:00
( returnFiber = currentFirstChild ) ) ,
2017-11-15 09:05:34 -08:00
placeSingleChild ( returnFiber )
) ;
if ( isArray$1 ( newChild ) )
return reconcileChildrenArray (
returnFiber ,
currentFirstChild ,
newChild ,
expirationTime
) ;
if ( getIteratorFn ( newChild ) )
return reconcileChildrenIterator (
returnFiber ,
currentFirstChild ,
newChild ,
expirationTime
) ;
isObject && throwOnInvalidObjectType ( returnFiber , newChild ) ;
2018-06-16 00:38:41 -07:00
if ( "undefined" === typeof newChild && ! isUnkeyedTopLevelFragment )
2017-11-15 09:05:34 -08:00
switch ( returnFiber . tag ) {
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
case 0 :
2017-11-29 10:12:57 -08:00
( expirationTime = returnFiber . type ) ,
2017-11-15 09:05:34 -08:00
invariant (
! 1 ,
"%s(...): Nothing was returned from render. This usually means a return statement is missing. Or, to render nothing, return null." ,
2017-11-29 10:12:57 -08:00
expirationTime . displayName || expirationTime . name || "Component"
2017-11-15 09:05:34 -08:00
) ;
}
return deleteRemainingChildren ( returnFiber , currentFirstChild ) ;
} ;
}
2017-11-29 10:12:57 -08:00
var reconcileChildFibers = ChildReconciler ( ! 0 ) ,
2018-06-16 00:38:41 -07:00
mountChildFibers = ChildReconciler ( ! 1 ) ,
hydrationParentFiber = null ,
nextHydratableInstance = null ,
isHydrating = ! 1 ;
function tryHydrate ( fiber , nextInstance ) {
switch ( fiber . tag ) {
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
return (
( nextInstance = shim$1 ( nextInstance , fiber . type , fiber . pendingProps ) ) ,
null !== nextInstance ? ( ( fiber . stateNode = nextInstance ) , ! 0 ) : ! 1
) ;
2018-09-10 14:42:08 -07:00
case 8 :
2018-06-16 00:38:41 -07:00
return (
( nextInstance = shim$1 ( nextInstance , fiber . pendingProps ) ) ,
null !== nextInstance ? ( ( fiber . stateNode = nextInstance ) , ! 0 ) : ! 1
) ;
default :
return ! 1 ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
}
function tryToClaimNextHydratableInstance ( fiber$jscomp$0 ) {
if ( isHydrating ) {
var nextInstance = nextHydratableInstance ;
if ( nextInstance ) {
var firstAttemptedInstance = nextInstance ;
if ( ! tryHydrate ( fiber$jscomp$0 , nextInstance ) ) {
nextInstance = shim$1 ( firstAttemptedInstance ) ;
if ( ! nextInstance || ! tryHydrate ( fiber$jscomp$0 , nextInstance ) ) {
fiber$jscomp$0 . effectTag |= 2 ;
isHydrating = ! 1 ;
hydrationParentFiber = fiber$jscomp$0 ;
return ;
}
var returnFiber = hydrationParentFiber ,
2018-09-10 14:42:08 -07:00
fiber = new FiberNode ( 7 , null , null , 0 ) ;
2018-06-16 00:38:41 -07:00
fiber . type = "DELETED" ;
fiber . stateNode = firstAttemptedInstance ;
fiber . return = returnFiber ;
fiber . effectTag = 8 ;
null !== returnFiber . lastEffect
? ( ( returnFiber . lastEffect . nextEffect = fiber ) ,
( returnFiber . lastEffect = fiber ) )
: ( returnFiber . firstEffect = returnFiber . lastEffect = fiber ) ;
}
hydrationParentFiber = fiber$jscomp$0 ;
nextHydratableInstance = shim$1 ( nextInstance ) ;
} else
( fiber$jscomp$0 . effectTag |= 2 ) ,
( isHydrating = ! 1 ) ,
( hydrationParentFiber = fiber$jscomp$0 ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
}
2018-09-10 14:42:08 -07:00
function readLazyComponentType ( thenable ) {
switch ( thenable . _reactStatus ) {
case 1 :
return thenable . _reactResult ;
case 2 :
throw thenable . _reactResult ;
case 0 :
throw thenable ;
default :
throw ( ( thenable . _reactStatus = 0 ) ,
thenable . then (
function ( resolvedValue ) {
if ( 0 === thenable . _reactStatus ) {
thenable . _reactStatus = 1 ;
if ( "object" === typeof resolvedValue && null !== resolvedValue ) {
var defaultExport = resolvedValue . default ;
resolvedValue =
void 0 !== defaultExport && null !== defaultExport
? defaultExport
: resolvedValue ;
}
thenable . _reactResult = resolvedValue ;
}
} ,
function ( error ) {
0 === thenable . _reactStatus &&
( ( thenable . _reactStatus = 2 ) , ( thenable . _reactResult = error ) ) ;
}
) ,
thenable ) ;
}
}
2018-07-24 14:45:35 -07:00
var ReactCurrentOwner$3 = ReactSharedInternals . ReactCurrentOwner ;
function reconcileChildren (
current$$1 ,
2018-06-16 00:38:41 -07:00
workInProgress ,
nextChildren ,
renderExpirationTime
) {
workInProgress . child =
2018-07-24 14:45:35 -07:00
null === current$$1
2018-06-16 00:38:41 -07:00
? mountChildFibers (
workInProgress ,
null ,
nextChildren ,
renderExpirationTime
)
: reconcileChildFibers (
workInProgress ,
2018-07-24 14:45:35 -07:00
current$$1 . child ,
2018-06-16 00:38:41 -07:00
nextChildren ,
renderExpirationTime
) ;
}
2018-09-10 14:42:08 -07:00
function updateForwardRef (
current$$1 ,
workInProgress ,
type ,
nextProps ,
renderExpirationTime
) {
type = type . render ;
var ref = workInProgress . ref ;
if (
! didPerformWorkStackCursor . current &&
workInProgress . memoizedProps === nextProps &&
ref === ( null !== current$$1 ? current$$1 . ref : null )
)
return bailoutOnAlreadyFinishedWork (
current$$1 ,
workInProgress ,
renderExpirationTime
) ;
type = type ( nextProps , ref ) ;
reconcileChildren ( current$$1 , workInProgress , type , renderExpirationTime ) ;
workInProgress . memoizedProps = nextProps ;
return workInProgress . child ;
}
2018-07-24 14:45:35 -07:00
function markRef ( current$$1 , workInProgress ) {
2018-06-16 00:38:41 -07:00
var ref = workInProgress . ref ;
if (
2018-07-24 14:45:35 -07:00
( null === current$$1 && null !== ref ) ||
( null !== current$$1 && current$$1 . ref !== ref )
2018-06-16 00:38:41 -07:00
)
workInProgress . effectTag |= 128 ;
}
2018-09-10 14:42:08 -07:00
function updateFunctionalComponent (
current$$1 ,
workInProgress ,
Component ,
nextProps ,
renderExpirationTime
) {
var unmaskedContext = isContextProvider ( Component )
? previousContext
: contextStackCursor . current ;
unmaskedContext = getMaskedContext ( workInProgress , unmaskedContext ) ;
prepareToReadContext ( workInProgress , renderExpirationTime ) ;
Component = Component ( nextProps , unmaskedContext ) ;
workInProgress . effectTag |= 1 ;
reconcileChildren (
current$$1 ,
workInProgress ,
Component ,
renderExpirationTime
) ;
workInProgress . memoizedProps = nextProps ;
return workInProgress . child ;
}
function updateClassComponent (
current$$1 ,
workInProgress ,
Component ,
nextProps ,
renderExpirationTime
) {
if ( isContextProvider ( Component ) ) {
var hasContext = ! 0 ;
pushContextProvider ( workInProgress ) ;
} else hasContext = ! 1 ;
prepareToReadContext ( workInProgress , renderExpirationTime ) ;
if ( null === current$$1 )
if ( null === workInProgress . stateNode ) {
var unmaskedContext = isContextProvider ( Component )
? previousContext
: contextStackCursor . current ,
contextTypes = Component . contextTypes ,
isContextConsumer = null !== contextTypes && void 0 !== contextTypes ;
contextTypes = isContextConsumer
? getMaskedContext ( workInProgress , unmaskedContext )
: emptyContextObject ;
var instance = new Component ( nextProps , contextTypes ) ;
workInProgress . memoizedState =
null !== instance . state && void 0 !== instance . state
? instance . state
: null ;
instance . updater = classComponentUpdater ;
workInProgress . stateNode = instance ;
instance . _reactInternalFiber = workInProgress ;
isContextConsumer &&
( ( isContextConsumer = workInProgress . stateNode ) ,
( isContextConsumer . _ _reactInternalMemoizedUnmaskedChildContext = unmaskedContext ) ,
( isContextConsumer . _ _reactInternalMemoizedMaskedChildContext = contextTypes ) ) ;
mountClassInstance (
workInProgress ,
Component ,
nextProps ,
renderExpirationTime
) ;
nextProps = ! 0 ;
} else {
unmaskedContext = workInProgress . stateNode ;
contextTypes = workInProgress . memoizedProps ;
unmaskedContext . props = contextTypes ;
var oldContext = unmaskedContext . context ;
isContextConsumer = isContextProvider ( Component )
? previousContext
: contextStackCursor . current ;
isContextConsumer = getMaskedContext ( workInProgress , isContextConsumer ) ;
var getDerivedStateFromProps = Component . getDerivedStateFromProps ;
( instance =
"function" === typeof getDerivedStateFromProps ||
"function" === typeof unmaskedContext . getSnapshotBeforeUpdate ) ||
( "function" !==
typeof unmaskedContext . UNSAFE _componentWillReceiveProps &&
"function" !== typeof unmaskedContext . componentWillReceiveProps ) ||
( ( contextTypes !== nextProps || oldContext !== isContextConsumer ) &&
callComponentWillReceiveProps (
workInProgress ,
unmaskedContext ,
nextProps ,
isContextConsumer
) ) ;
hasForceUpdate = ! 1 ;
var oldState = workInProgress . memoizedState ;
oldContext = unmaskedContext . state = oldState ;
var updateQueue = workInProgress . updateQueue ;
null !== updateQueue &&
( processUpdateQueue (
workInProgress ,
updateQueue ,
nextProps ,
unmaskedContext ,
renderExpirationTime
) ,
( oldContext = workInProgress . memoizedState ) ) ;
contextTypes !== nextProps ||
oldState !== oldContext ||
didPerformWorkStackCursor . current ||
hasForceUpdate
? ( "function" === typeof getDerivedStateFromProps &&
( applyDerivedStateFromProps (
workInProgress ,
Component ,
getDerivedStateFromProps ,
nextProps
) ,
( oldContext = workInProgress . memoizedState ) ) ,
( contextTypes =
hasForceUpdate ||
checkShouldComponentUpdate (
workInProgress ,
Component ,
contextTypes ,
nextProps ,
oldState ,
oldContext ,
isContextConsumer
) )
? ( instance ||
( "function" !==
typeof unmaskedContext . UNSAFE _componentWillMount &&
"function" !== typeof unmaskedContext . componentWillMount ) ||
( "function" === typeof unmaskedContext . componentWillMount &&
unmaskedContext . componentWillMount ( ) ,
"function" ===
typeof unmaskedContext . UNSAFE _componentWillMount &&
unmaskedContext . UNSAFE _componentWillMount ( ) ) ,
"function" === typeof unmaskedContext . componentDidMount &&
( workInProgress . effectTag |= 4 ) )
: ( "function" === typeof unmaskedContext . componentDidMount &&
( workInProgress . effectTag |= 4 ) ,
( workInProgress . memoizedProps = nextProps ) ,
( workInProgress . memoizedState = oldContext ) ) ,
( unmaskedContext . props = nextProps ) ,
( unmaskedContext . state = oldContext ) ,
( unmaskedContext . context = isContextConsumer ) ,
( nextProps = contextTypes ) )
: ( "function" === typeof unmaskedContext . componentDidMount &&
( workInProgress . effectTag |= 4 ) ,
( nextProps = ! 1 ) ) ;
}
else
( unmaskedContext = workInProgress . stateNode ) ,
( contextTypes = workInProgress . memoizedProps ) ,
( unmaskedContext . props = contextTypes ) ,
( oldContext = unmaskedContext . context ) ,
( isContextConsumer = isContextProvider ( Component )
? previousContext
: contextStackCursor . current ) ,
( isContextConsumer = getMaskedContext ( workInProgress , isContextConsumer ) ) ,
( getDerivedStateFromProps = Component . getDerivedStateFromProps ) ,
( instance =
"function" === typeof getDerivedStateFromProps ||
"function" === typeof unmaskedContext . getSnapshotBeforeUpdate ) ||
( "function" !==
typeof unmaskedContext . UNSAFE _componentWillReceiveProps &&
"function" !== typeof unmaskedContext . componentWillReceiveProps ) ||
( ( contextTypes !== nextProps || oldContext !== isContextConsumer ) &&
callComponentWillReceiveProps (
workInProgress ,
unmaskedContext ,
nextProps ,
isContextConsumer
) ) ,
( hasForceUpdate = ! 1 ) ,
( oldContext = workInProgress . memoizedState ) ,
( oldState = unmaskedContext . state = oldContext ) ,
( updateQueue = workInProgress . updateQueue ) ,
null !== updateQueue &&
( processUpdateQueue (
workInProgress ,
updateQueue ,
nextProps ,
unmaskedContext ,
renderExpirationTime
) ,
( oldState = workInProgress . memoizedState ) ) ,
contextTypes !== nextProps ||
oldContext !== oldState ||
didPerformWorkStackCursor . current ||
hasForceUpdate
? ( "function" === typeof getDerivedStateFromProps &&
( applyDerivedStateFromProps (
workInProgress ,
Component ,
getDerivedStateFromProps ,
nextProps
) ,
( oldState = workInProgress . memoizedState ) ) ,
( getDerivedStateFromProps =
hasForceUpdate ||
checkShouldComponentUpdate (
workInProgress ,
Component ,
contextTypes ,
nextProps ,
oldContext ,
oldState ,
isContextConsumer
) )
? ( instance ||
( "function" !==
typeof unmaskedContext . UNSAFE _componentWillUpdate &&
"function" !== typeof unmaskedContext . componentWillUpdate ) ||
( "function" === typeof unmaskedContext . componentWillUpdate &&
unmaskedContext . componentWillUpdate (
nextProps ,
oldState ,
isContextConsumer
) ,
"function" ===
typeof unmaskedContext . UNSAFE _componentWillUpdate &&
unmaskedContext . UNSAFE _componentWillUpdate (
nextProps ,
oldState ,
isContextConsumer
) ) ,
"function" === typeof unmaskedContext . componentDidUpdate &&
( workInProgress . effectTag |= 4 ) ,
"function" === typeof unmaskedContext . getSnapshotBeforeUpdate &&
( workInProgress . effectTag |= 256 ) )
: ( "function" !== typeof unmaskedContext . componentDidUpdate ||
( contextTypes === current$$1 . memoizedProps &&
oldContext === current$$1 . memoizedState ) ||
( workInProgress . effectTag |= 4 ) ,
"function" !== typeof unmaskedContext . getSnapshotBeforeUpdate ||
( contextTypes === current$$1 . memoizedProps &&
oldContext === current$$1 . memoizedState ) ||
( workInProgress . effectTag |= 256 ) ,
( workInProgress . memoizedProps = nextProps ) ,
( workInProgress . memoizedState = oldState ) ) ,
( unmaskedContext . props = nextProps ) ,
( unmaskedContext . state = oldState ) ,
( unmaskedContext . context = isContextConsumer ) ,
( nextProps = getDerivedStateFromProps ) )
: ( "function" !== typeof unmaskedContext . componentDidUpdate ||
( contextTypes === current$$1 . memoizedProps &&
oldContext === current$$1 . memoizedState ) ||
( workInProgress . effectTag |= 4 ) ,
"function" !== typeof unmaskedContext . getSnapshotBeforeUpdate ||
( contextTypes === current$$1 . memoizedProps &&
oldContext === current$$1 . memoizedState ) ||
( workInProgress . effectTag |= 256 ) ,
( nextProps = ! 1 ) ) ;
return finishClassComponent (
current$$1 ,
workInProgress ,
Component ,
nextProps ,
hasContext ,
renderExpirationTime
) ;
}
2018-06-16 00:38:41 -07:00
function finishClassComponent (
2018-07-24 14:45:35 -07:00
current$$1 ,
2018-06-16 00:38:41 -07:00
workInProgress ,
2018-09-10 14:42:08 -07:00
Component ,
2018-06-16 00:38:41 -07:00
shouldUpdate ,
hasContext ,
renderExpirationTime
) {
2018-07-24 14:45:35 -07:00
markRef ( current$$1 , workInProgress ) ;
2018-06-16 00:38:41 -07:00
var didCaptureError = 0 !== ( workInProgress . effectTag & 64 ) ;
if ( ! shouldUpdate && ! didCaptureError )
return (
2018-09-10 14:42:08 -07:00
hasContext && invalidateContextProvider ( workInProgress , Component , ! 1 ) ,
2018-07-24 14:45:35 -07:00
bailoutOnAlreadyFinishedWork (
current$$1 ,
workInProgress ,
renderExpirationTime
)
2018-06-16 00:38:41 -07:00
) ;
shouldUpdate = workInProgress . stateNode ;
2018-07-24 14:45:35 -07:00
ReactCurrentOwner$3 . current = workInProgress ;
2018-06-16 00:38:41 -07:00
var nextChildren = didCaptureError ? null : shouldUpdate . render ( ) ;
workInProgress . effectTag |= 1 ;
2018-07-24 14:45:35 -07:00
null !== current$$1 &&
didCaptureError &&
( reconcileChildren ( current$$1 , workInProgress , null , renderExpirationTime ) ,
2018-06-16 00:38:41 -07:00
( workInProgress . child = null ) ) ;
2018-07-24 14:45:35 -07:00
reconcileChildren (
current$$1 ,
2018-02-01 13:33:12 -08:00
workInProgress ,
2018-06-16 00:38:41 -07:00
nextChildren ,
2018-02-01 13:33:12 -08:00
renderExpirationTime
2018-06-16 00:38:41 -07:00
) ;
workInProgress . memoizedState = shouldUpdate . state ;
workInProgress . memoizedProps = shouldUpdate . props ;
2018-09-10 14:42:08 -07:00
hasContext && invalidateContextProvider ( workInProgress , Component , ! 0 ) ;
2018-06-16 00:38:41 -07:00
return workInProgress . child ;
}
function pushHostRootContext ( workInProgress ) {
var root = workInProgress . stateNode ;
root . pendingContext
? pushTopLevelContextObject (
workInProgress ,
root . pendingContext ,
root . pendingContext !== root . context
)
: root . context &&
pushTopLevelContextObject ( workInProgress , root . context , ! 1 ) ;
pushHostContainer ( workInProgress , root . containerInfo ) ;
}
2018-09-10 14:42:08 -07:00
function resolveDefaultProps ( Component , baseProps ) {
if ( Component && Component . defaultProps ) {
baseProps = Object . assign ( { } , baseProps ) ;
Component = Component . defaultProps ;
for ( var propName in Component )
void 0 === baseProps [ propName ] &&
( baseProps [ propName ] = Component [ propName ] ) ;
}
return baseProps ;
}
function mountIndeterminateComponent (
2018-07-24 14:45:35 -07:00
current$$1 ,
2018-06-16 00:38:41 -07:00
workInProgress ,
2018-09-10 14:42:08 -07:00
Component ,
2018-06-16 00:38:41 -07:00
renderExpirationTime
) {
invariant (
2018-09-10 14:42:08 -07:00
null === current$$1 ,
"An indeterminate component should never have mounted. This error is likely caused by a bug in React. Please file an issue."
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
var props = workInProgress . pendingProps ;
if (
"object" === typeof Component &&
null !== Component &&
"function" === typeof Component . then
) {
Component = readLazyComponentType ( Component ) ;
var JSCompiler _inline _result = Component ;
JSCompiler _inline _result =
"function" === typeof JSCompiler _inline _result
? shouldConstruct ( JSCompiler _inline _result )
? 3
: 1
: void 0 !== JSCompiler _inline _result &&
null !== JSCompiler _inline _result &&
JSCompiler _inline _result . $$typeof
? 14
: 4 ;
JSCompiler _inline _result = workInProgress . tag = JSCompiler _inline _result ;
var resolvedProps = resolveDefaultProps ( Component , props ) ;
switch ( JSCompiler _inline _result ) {
case 1 :
return updateFunctionalComponent (
current$$1 ,
workInProgress ,
Component ,
resolvedProps ,
renderExpirationTime
) ;
case 3 :
return updateClassComponent (
current$$1 ,
workInProgress ,
Component ,
resolvedProps ,
renderExpirationTime
) ;
case 14 :
return updateForwardRef (
current$$1 ,
workInProgress ,
Component ,
resolvedProps ,
renderExpirationTime
) ;
default :
invariant (
! 1 ,
"Element type is invalid. Received a promise that resolves to: %s. Promise elements must resolve to a class or function." ,
Component
) ;
}
}
JSCompiler _inline _result = getMaskedContext (
workInProgress ,
contextStackCursor . current
) ;
prepareToReadContext ( workInProgress , renderExpirationTime ) ;
JSCompiler _inline _result = Component ( props , JSCompiler _inline _result ) ;
workInProgress . effectTag |= 1 ;
if (
"object" === typeof JSCompiler _inline _result &&
null !== JSCompiler _inline _result &&
"function" === typeof JSCompiler _inline _result . render &&
void 0 === JSCompiler _inline _result . $$typeof
) {
workInProgress . tag = 2 ;
isContextProvider ( Component )
? ( ( resolvedProps = ! 0 ) , pushContextProvider ( workInProgress ) )
: ( resolvedProps = ! 1 ) ;
workInProgress . memoizedState =
null !== JSCompiler _inline _result . state &&
void 0 !== JSCompiler _inline _result . state
? JSCompiler _inline _result . state
: null ;
var getDerivedStateFromProps = Component . getDerivedStateFromProps ;
"function" === typeof getDerivedStateFromProps &&
applyDerivedStateFromProps (
workInProgress ,
Component ,
getDerivedStateFromProps ,
props
) ;
JSCompiler _inline _result . updater = classComponentUpdater ;
workInProgress . stateNode = JSCompiler _inline _result ;
JSCompiler _inline _result . _reactInternalFiber = workInProgress ;
mountClassInstance ( workInProgress , Component , props , renderExpirationTime ) ;
return finishClassComponent (
current$$1 ,
workInProgress ,
Component ,
! 0 ,
resolvedProps ,
renderExpirationTime
) ;
}
workInProgress . tag = 0 ;
reconcileChildren (
current$$1 ,
workInProgress ,
JSCompiler _inline _result ,
renderExpirationTime
) ;
workInProgress . memoizedProps = props ;
return workInProgress . child ;
}
function bailoutOnAlreadyFinishedWork (
current$$1 ,
workInProgress ,
renderExpirationTime
) {
null !== current$$1 &&
( workInProgress . firstContextDependency = current$$1 . firstContextDependency ) ;
var childExpirationTime = workInProgress . childExpirationTime ;
if ( 0 === childExpirationTime || childExpirationTime > renderExpirationTime )
return null ;
invariant (
null === current$$1 || workInProgress . child === current$$1 . child ,
"Resuming work not yet implemented."
) ;
if ( null !== workInProgress . child ) {
current$$1 = workInProgress . child ;
renderExpirationTime = createWorkInProgress (
current$$1 ,
current$$1 . pendingProps ,
current$$1 . expirationTime
) ;
workInProgress . child = renderExpirationTime ;
for (
2018-07-24 14:45:35 -07:00
renderExpirationTime . return = workInProgress ;
null !== current$$1 . sibling ;
)
( current$$1 = current$$1 . sibling ) ,
( renderExpirationTime = renderExpirationTime . sibling = createWorkInProgress (
current$$1 ,
current$$1 . pendingProps ,
current$$1 . expirationTime
2018-06-16 00:38:41 -07:00
) ) ,
2018-07-24 14:45:35 -07:00
( renderExpirationTime . return = workInProgress ) ;
renderExpirationTime . sibling = null ;
2018-06-16 00:38:41 -07:00
}
return workInProgress . child ;
}
2018-07-24 14:45:35 -07:00
function beginWork ( current$$1 , workInProgress , renderExpirationTime ) {
var updateExpirationTime = workInProgress . expirationTime ;
2018-06-16 00:38:41 -07:00
if (
2018-07-24 14:45:35 -07:00
! didPerformWorkStackCursor . current &&
( 0 === updateExpirationTime || updateExpirationTime > renderExpirationTime )
2018-06-16 00:38:41 -07:00
) {
switch ( workInProgress . tag ) {
2018-09-10 14:42:08 -07:00
case 5 :
2018-06-16 00:38:41 -07:00
pushHostRootContext ( workInProgress ) ;
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-07-24 14:45:35 -07:00
pushHostContext ( workInProgress ) ;
break ;
2018-06-16 00:38:41 -07:00
case 2 :
2018-09-10 14:42:08 -07:00
isContextProvider ( workInProgress . type ) &&
pushContextProvider ( workInProgress ) ;
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 3 :
isContextProvider ( workInProgress . type . _reactResult ) &&
pushContextProvider ( workInProgress ) ;
break ;
case 6 :
2018-06-16 00:38:41 -07:00
pushHostContainer (
2018-03-14 08:47:36 -07:00
workInProgress ,
2018-06-16 00:38:41 -07:00
workInProgress . stateNode . containerInfo
2018-03-14 08:47:36 -07:00
) ;
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 12 :
pushProvider ( workInProgress , workInProgress . memoizedProps . value ) ;
2018-03-14 08:47:36 -07:00
}
2018-07-24 14:45:35 -07:00
return bailoutOnAlreadyFinishedWork (
current$$1 ,
workInProgress ,
renderExpirationTime
) ;
2018-03-14 08:47:36 -07:00
}
2018-07-24 14:45:35 -07:00
workInProgress . expirationTime = 0 ;
2018-06-16 00:38:41 -07:00
switch ( workInProgress . tag ) {
2018-09-10 14:42:08 -07:00
case 4 :
return mountIndeterminateComponent (
current$$1 ,
workInProgress ,
workInProgress . type ,
renderExpirationTime
) ;
2018-06-16 00:38:41 -07:00
case 0 :
2018-09-10 14:42:08 -07:00
return updateFunctionalComponent (
current$$1 ,
workInProgress ,
workInProgress . type ,
workInProgress . pendingProps ,
renderExpirationTime
2017-11-15 09:05:34 -08:00
) ;
2018-06-16 00:38:41 -07:00
case 1 :
2018-09-10 14:42:08 -07:00
var _Component5 = workInProgress . type . _reactResult ;
updateExpirationTime = workInProgress . pendingProps ;
current$$1 = updateFunctionalComponent (
current$$1 ,
workInProgress ,
_Component5 ,
resolveDefaultProps ( _Component5 , updateExpirationTime ) ,
renderExpirationTime
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
workInProgress . memoizedProps = updateExpirationTime ;
return current$$1 ;
2018-06-16 00:38:41 -07:00
case 2 :
2018-09-10 14:42:08 -07:00
return updateClassComponent (
2018-07-24 14:45:35 -07:00
current$$1 ,
2018-06-16 00:38:41 -07:00
workInProgress ,
2018-09-10 14:42:08 -07:00
workInProgress . type ,
workInProgress . pendingProps ,
2018-06-16 00:38:41 -07:00
renderExpirationTime
) ;
case 3 :
2018-09-10 14:42:08 -07:00
return (
( _Component5 = workInProgress . type . _reactResult ) ,
( updateExpirationTime = workInProgress . pendingProps ) ,
( current$$1 = updateClassComponent (
current$$1 ,
workInProgress ,
_Component5 ,
resolveDefaultProps ( _Component5 , updateExpirationTime ) ,
renderExpirationTime
) ) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
current$$1
) ;
case 5 :
2018-06-16 00:38:41 -07:00
return (
pushHostRootContext ( workInProgress ) ,
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . updateQueue ) ,
invariant (
null !== updateExpirationTime ,
"If the root does not have an updateQueue, we should have already bailed out. This error is likely caused by a bug in React. Please file an issue."
) ,
2018-09-10 14:42:08 -07:00
( _Component5 = workInProgress . memoizedState ) ,
( _Component5 = null !== _Component5 ? _Component5 . element : null ) ,
2018-07-24 14:45:35 -07:00
processUpdateQueue (
workInProgress ,
updateExpirationTime ,
workInProgress . pendingProps ,
null ,
renderExpirationTime
) ,
( updateExpirationTime = workInProgress . memoizedState . element ) ,
2018-09-10 14:42:08 -07:00
updateExpirationTime === _Component5
? ( workInProgress = bailoutOnAlreadyFinishedWork (
2018-07-24 14:45:35 -07:00
current$$1 ,
2017-11-15 09:05:34 -08:00
workInProgress ,
2018-07-24 14:45:35 -07:00
renderExpirationTime
) )
: ( reconcileChildren (
current$$1 ,
workInProgress ,
updateExpirationTime ,
2018-06-16 00:38:41 -07:00
renderExpirationTime
2017-11-29 10:12:57 -08:00
) ,
2018-09-10 14:42:08 -07:00
( workInProgress = workInProgress . child ) ) ,
workInProgress
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
return (
2018-07-24 14:45:35 -07:00
pushHostContext ( workInProgress ) ,
null === current$$1 && tryToClaimNextHydratableInstance ( workInProgress ) ,
( updateExpirationTime = workInProgress . pendingProps ) ,
2018-09-10 14:42:08 -07:00
( _Component5 = updateExpirationTime . children ) ,
2018-07-24 14:45:35 -07:00
markRef ( current$$1 , workInProgress ) ,
2018-09-10 14:42:08 -07:00
reconcileChildren (
current$$1 ,
workInProgress ,
_Component5 ,
renderExpirationTime
) ,
2018-07-24 14:45:35 -07:00
( workInProgress . memoizedProps = updateExpirationTime ) ,
2018-09-10 14:42:08 -07:00
( workInProgress = workInProgress . child ) ,
workInProgress
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 8 :
2018-06-16 00:38:41 -07:00
return (
2018-07-24 14:45:35 -07:00
null === current$$1 && tryToClaimNextHydratableInstance ( workInProgress ) ,
2018-06-16 00:38:41 -07:00
( workInProgress . memoizedProps = workInProgress . pendingProps ) ,
null
) ;
case 16 :
return null ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
return (
pushHostContainer (
workInProgress ,
workInProgress . stateNode . containerInfo
) ,
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps ) ,
null === current$$1
? ( workInProgress . child = reconcileChildFibers (
workInProgress ,
null ,
updateExpirationTime ,
renderExpirationTime
) )
: reconcileChildren (
current$$1 ,
workInProgress ,
updateExpirationTime ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
workInProgress . child
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 13 :
return updateForwardRef (
current$$1 ,
workInProgress ,
workInProgress . type ,
workInProgress . pendingProps ,
renderExpirationTime
) ;
2018-06-16 00:38:41 -07:00
case 14 :
return (
2018-09-10 14:42:08 -07:00
( _Component5 = workInProgress . type . _reactResult ) ,
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps ) ,
2018-09-10 14:42:08 -07:00
( current$$1 = updateForwardRef (
current$$1 ,
workInProgress ,
_Component5 ,
resolveDefaultProps ( _Component5 , updateExpirationTime ) ,
renderExpirationTime
) ) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
2018-07-24 14:45:35 -07:00
current$$1
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 9 :
2018-06-16 00:38:41 -07:00
return (
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps ) ,
reconcileChildren (
current$$1 ,
workInProgress ,
updateExpirationTime ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
workInProgress . child
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 10 :
2018-06-16 00:38:41 -07:00
return (
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps . children ) ,
reconcileChildren (
current$$1 ,
workInProgress ,
updateExpirationTime ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
workInProgress . child
2018-06-16 00:38:41 -07:00
) ;
case 15 :
return (
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps ) ,
reconcileChildren (
current$$1 ,
workInProgress ,
updateExpirationTime . children ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = updateExpirationTime ) ,
workInProgress . child
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 12 :
2018-07-24 14:45:35 -07:00
a : {
updateExpirationTime = workInProgress . type . _context ;
2018-09-10 14:42:08 -07:00
_Component5 = workInProgress . pendingProps ;
var oldProps = workInProgress . memoizedProps ,
newValue = _Component5 . value ;
workInProgress . memoizedProps = _Component5 ;
pushProvider ( workInProgress , newValue ) ;
if ( null !== oldProps ) {
var oldValue = oldProps . value ;
newValue =
( oldValue === newValue &&
( 0 !== oldValue || 1 / oldValue === 1 / newValue ) ) ||
( oldValue !== oldValue && newValue !== newValue )
? 0
: ( "function" ===
typeof updateExpirationTime . _calculateChangedBits
? updateExpirationTime . _calculateChangedBits (
oldValue ,
newValue
)
: 1073741823 ) | 0 ;
if ( 0 === newValue ) {
if (
oldProps . children === _Component5 . children &&
! didPerformWorkStackCursor . current
) {
workInProgress = bailoutOnAlreadyFinishedWork (
current$$1 ,
workInProgress ,
renderExpirationTime
) ;
break a ;
}
} else
for (
oldProps = workInProgress . child ,
null !== oldProps && ( oldProps . return = workInProgress ) ;
null !== oldProps ;
) {
oldValue = oldProps . firstContextDependency ;
if ( null !== oldValue ) {
do {
if (
oldValue . context === updateExpirationTime &&
0 !== ( oldValue . observedBits & newValue )
) {
if ( 2 === oldProps . tag || 3 === oldProps . tag ) {
var nextFiber = createUpdate ( renderExpirationTime ) ;
nextFiber . tag = 2 ;
enqueueUpdate ( oldProps , nextFiber ) ;
}
if (
0 === oldProps . expirationTime ||
oldProps . expirationTime > renderExpirationTime
)
oldProps . expirationTime = renderExpirationTime ;
nextFiber = oldProps . alternate ;
null !== nextFiber &&
( 0 === nextFiber . expirationTime ||
nextFiber . expirationTime > renderExpirationTime ) &&
( nextFiber . expirationTime = renderExpirationTime ) ;
for ( var node = oldProps . return ; null !== node ; ) {
nextFiber = node . alternate ;
if (
0 === node . childExpirationTime ||
node . childExpirationTime > renderExpirationTime
)
( node . childExpirationTime = renderExpirationTime ) ,
null !== nextFiber &&
( 0 === nextFiber . childExpirationTime ||
nextFiber . childExpirationTime >
renderExpirationTime ) &&
( nextFiber . childExpirationTime = renderExpirationTime ) ;
else if (
null !== nextFiber &&
( 0 === nextFiber . childExpirationTime ||
nextFiber . childExpirationTime > renderExpirationTime )
)
nextFiber . childExpirationTime = renderExpirationTime ;
else break ;
node = node . return ;
}
}
nextFiber = oldProps . child ;
oldValue = oldValue . next ;
} while ( null !== oldValue ) ;
} else
nextFiber =
12 === oldProps . tag
? oldProps . type === workInProgress . type
? null
: oldProps . child
: oldProps . child ;
if ( null !== nextFiber ) nextFiber . return = oldProps ;
else
for ( nextFiber = oldProps ; null !== nextFiber ; ) {
if ( nextFiber === workInProgress ) {
nextFiber = null ;
break ;
}
oldProps = nextFiber . sibling ;
if ( null !== oldProps ) {
oldProps . return = nextFiber . return ;
nextFiber = oldProps ;
break ;
}
nextFiber = nextFiber . return ;
}
oldProps = nextFiber ;
}
}
2018-07-24 14:45:35 -07:00
reconcileChildren (
current$$1 ,
workInProgress ,
2018-09-10 14:42:08 -07:00
_Component5 . children ,
2018-07-24 14:45:35 -07:00
renderExpirationTime
) ;
2018-09-10 14:42:08 -07:00
workInProgress = workInProgress . child ;
2018-07-24 14:45:35 -07:00
}
2018-09-10 14:42:08 -07:00
return workInProgress ;
case 11 :
2018-07-24 14:45:35 -07:00
return (
2018-09-10 14:42:08 -07:00
( newValue = workInProgress . type ) ,
2018-07-24 14:45:35 -07:00
( updateExpirationTime = workInProgress . pendingProps ) ,
2018-09-10 14:42:08 -07:00
( _Component5 = updateExpirationTime . children ) ,
2018-07-24 14:45:35 -07:00
prepareToReadContext ( workInProgress , renderExpirationTime ) ,
2018-09-10 14:42:08 -07:00
( newValue = readContext (
newValue ,
2018-07-24 14:45:35 -07:00
updateExpirationTime . unstable _observedBits
) ) ,
2018-09-10 14:42:08 -07:00
( _Component5 = _Component5 ( newValue ) ) ,
2018-07-24 14:45:35 -07:00
( workInProgress . effectTag |= 1 ) ,
2018-09-10 14:42:08 -07:00
reconcileChildren (
current$$1 ,
workInProgress ,
_Component5 ,
renderExpirationTime
) ,
2018-07-24 14:45:35 -07:00
( workInProgress . memoizedProps = updateExpirationTime ) ,
workInProgress . child
) ;
2018-06-16 00:38:41 -07:00
default :
invariant (
! 1 ,
"Unknown unit of work tag. This error is likely caused by a bug in React. Please file an issue."
) ;
}
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
var updateHostContainer = void 0 ,
updateHostComponent$1 = void 0 ,
updateHostText$1 = void 0 ;
updateHostContainer = function ( ) { } ;
2018-09-10 14:42:08 -07:00
updateHostComponent$1 = function ( current , workInProgress , type , newProps ) {
current . memoizedProps !== newProps &&
( requiredContext ( contextStackCursor$1 . current ) ,
( workInProgress . updateQueue = UPDATE _SIGNAL ) ) &&
( workInProgress . effectTag |= 4 ) ;
2018-06-16 00:38:41 -07:00
} ;
updateHostText$1 = function ( current , workInProgress , oldText , newText ) {
oldText !== newText && ( workInProgress . effectTag |= 4 ) ;
} ;
2018-09-10 14:42:08 -07:00
function logCapturedError ( capturedError ) {
var componentStack = capturedError . componentStack ,
error = capturedError . error ;
if ( error instanceof Error ) {
capturedError = error . message ;
var name = error . name ;
try {
error . message =
( capturedError ? name + ": " + capturedError : name ) +
"\n\nThis error is located at:" +
componentStack ;
} catch ( e ) { }
} else
error =
"string" === typeof error
? Error ( error + "\n\nThis error is located at:" + componentStack )
: Error ( "Unspecified error at:" + componentStack ) ;
ExceptionsManager . handleException ( error , ! 1 ) ;
}
2018-02-28 19:16:47 -08:00
function logError ( boundary , errorInfo ) {
var source = errorInfo . source ,
stack = errorInfo . stack ;
2018-05-18 20:17:11 -07:00
null === stack &&
null !== source &&
2018-07-24 14:45:35 -07:00
( stack = getStackByFiberInDevAndProd ( source ) ) ;
2018-09-10 14:42:08 -07:00
errorInfo = {
componentName : null !== source ? getComponentName ( source . type ) : null ,
componentStack : null !== stack ? stack : "" ,
error : errorInfo . value ,
errorBoundary : null ,
errorBoundaryName : null ,
errorBoundaryFound : ! 1 ,
willRetry : ! 1
} ;
null !== boundary &&
2 === boundary . tag &&
( ( errorInfo . errorBoundary = boundary . stateNode ) ,
( errorInfo . errorBoundaryName = getComponentName ( boundary . type ) ) ,
( errorInfo . errorBoundaryFound = ! 0 ) ,
( errorInfo . willRetry = ! 0 ) ) ;
2018-02-28 19:16:47 -08:00
try {
2018-09-10 14:42:08 -07:00
logCapturedError ( errorInfo ) ;
2018-06-16 00:38:41 -07:00
} catch ( e ) {
2018-09-10 14:42:08 -07:00
setTimeout ( function ( ) {
throw e ;
} ) ;
2018-06-16 00:38:41 -07:00
}
}
2018-07-24 14:45:35 -07:00
function safelyDetachRef ( current$$1 ) {
var ref = current$$1 . ref ;
2018-06-16 00:38:41 -07:00
if ( null !== ref )
if ( "function" === typeof ref )
try {
ref ( null ) ;
} catch ( refError ) {
2018-07-24 14:45:35 -07:00
captureCommitPhaseError ( current$$1 , refError ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
else ref . current = null ;
}
2018-07-24 14:45:35 -07:00
function commitUnmount ( current$$1 ) {
"function" === typeof onCommitFiberUnmount &&
onCommitFiberUnmount ( current$$1 ) ;
switch ( current$$1 . tag ) {
2018-06-16 00:38:41 -07:00
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-07-24 14:45:35 -07:00
safelyDetachRef ( current$$1 ) ;
var instance = current$$1 . stateNode ;
2018-06-16 00:38:41 -07:00
if ( "function" === typeof instance . componentWillUnmount )
try {
2018-07-24 14:45:35 -07:00
( instance . props = current$$1 . memoizedProps ) ,
( instance . state = current$$1 . memoizedState ) ,
2018-06-16 00:38:41 -07:00
instance . componentWillUnmount ( ) ;
} catch ( unmountError ) {
2018-07-24 14:45:35 -07:00
captureCommitPhaseError ( current$$1 , unmountError ) ;
2018-06-16 00:38:41 -07:00
}
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-07-24 14:45:35 -07:00
safelyDetachRef ( current$$1 ) ;
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-07-24 14:45:35 -07:00
unmountHostComponents ( current$$1 ) ;
2018-06-16 00:38:41 -07:00
}
}
function isHostParent ( fiber ) {
2018-09-10 14:42:08 -07:00
return 7 === fiber . tag || 5 === fiber . tag || 6 === fiber . tag ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
function commitPlacement ( finishedWork ) {
a : {
for ( var parent = finishedWork . return ; null !== parent ; ) {
if ( isHostParent ( parent ) ) {
var parentFiber = parent ;
break a ;
}
parent = parent . return ;
}
2017-11-15 09:05:34 -08:00
invariant (
2018-06-16 00:38:41 -07:00
! 1 ,
"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue."
2017-11-15 09:05:34 -08:00
) ;
2018-06-16 00:38:41 -07:00
parentFiber = void 0 ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
var isContainer = ( parent = void 0 ) ;
switch ( parentFiber . tag ) {
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
parent = parentFiber . stateNode ;
isContainer = ! 1 ;
break ;
2018-09-10 14:42:08 -07:00
case 5 :
2018-06-16 00:38:41 -07:00
parent = parentFiber . stateNode . containerInfo ;
isContainer = ! 0 ;
break ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
parent = parentFiber . stateNode . containerInfo ;
isContainer = ! 0 ;
break ;
default :
invariant (
! 1 ,
"Invalid host parent fiber. This error is likely caused by a bug in React. Please file an issue."
) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
parentFiber . effectTag & 16 && ( parentFiber . effectTag &= - 17 ) ;
a : b : for ( parentFiber = finishedWork ; ; ) {
for ( ; null === parentFiber . sibling ; ) {
if ( null === parentFiber . return || isHostParent ( parentFiber . return ) ) {
parentFiber = null ;
break a ;
}
parentFiber = parentFiber . return ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
parentFiber . sibling . return = parentFiber . return ;
2017-11-15 09:05:34 -08:00
for (
2018-06-16 00:38:41 -07:00
parentFiber = parentFiber . sibling ;
2018-09-10 14:42:08 -07:00
7 !== parentFiber . tag && 8 !== parentFiber . tag ;
2017-11-15 09:05:34 -08:00
2018-06-16 00:38:41 -07:00
) {
if ( parentFiber . effectTag & 2 ) continue b ;
2018-09-10 14:42:08 -07:00
if ( null === parentFiber . child || 6 === parentFiber . tag ) continue b ;
2018-06-16 00:38:41 -07:00
else
( parentFiber . child . return = parentFiber ) ,
( parentFiber = parentFiber . child ) ;
}
if ( ! ( parentFiber . effectTag & 2 ) ) {
parentFiber = parentFiber . stateNode ;
break a ;
}
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
for ( var node = finishedWork ; ; ) {
2018-09-10 14:42:08 -07:00
if ( 7 === node . tag || 8 === node . tag )
2018-06-16 00:38:41 -07:00
if ( parentFiber )
if ( isContainer )
invariant (
"number" !== typeof parent ,
"Container does not support insertBefore operation"
) ;
else {
var parentInstance = parent ,
child = node . stateNode ,
beforeChild = parentFiber ,
children = parentInstance . _children ,
index = children . indexOf ( child ) ;
0 <= index
? ( children . splice ( index , 1 ) ,
( beforeChild = children . indexOf ( beforeChild ) ) ,
children . splice ( beforeChild , 0 , child ) ,
UIManager . manageChildren (
parentInstance . _nativeTag ,
[ index ] ,
[ beforeChild ] ,
[ ] ,
[ ] ,
[ ]
) )
: ( ( index = children . indexOf ( beforeChild ) ) ,
children . splice ( index , 0 , child ) ,
UIManager . manageChildren (
parentInstance . _nativeTag ,
[ ] ,
[ ] ,
[ "number" === typeof child ? child : child . _nativeTag ] ,
[ index ] ,
[ ]
) ) ;
}
else
isContainer
? ( ( parentInstance = node . stateNode ) ,
UIManager . setChildren ( parent , [
"number" === typeof parentInstance
? parentInstance
: parentInstance . _nativeTag
] ) )
: ( ( parentInstance = parent ) ,
( child = node . stateNode ) ,
( children = "number" === typeof child ? child : child . _nativeTag ) ,
( index = parentInstance . _children ) ,
( beforeChild = index . indexOf ( child ) ) ,
0 <= beforeChild
? ( index . splice ( beforeChild , 1 ) ,
index . push ( child ) ,
UIManager . manageChildren (
parentInstance . _nativeTag ,
[ beforeChild ] ,
[ index . length - 1 ] ,
[ ] ,
[ ] ,
[ ]
) )
: ( index . push ( child ) ,
UIManager . manageChildren (
parentInstance . _nativeTag ,
[ ] ,
[ ] ,
[ children ] ,
[ index . length - 1 ] ,
[ ]
) ) ) ;
2018-09-10 14:42:08 -07:00
else if ( 6 !== node . tag && null !== node . child ) {
2018-06-16 00:38:41 -07:00
node . child . return = node ;
node = node . child ;
continue ;
}
if ( node === finishedWork ) break ;
for ( ; null === node . sibling ; ) {
if ( null === node . return || node . return === finishedWork ) return ;
node = node . return ;
}
node . sibling . return = node . return ;
node = node . sibling ;
}
}
2018-07-24 14:45:35 -07:00
function unmountHostComponents ( current$$1 ) {
2018-06-16 00:38:41 -07:00
for (
2018-07-24 14:45:35 -07:00
var node = current$$1 ,
2018-06-16 00:38:41 -07:00
currentParentIsValid = ! 1 ,
currentParent = void 0 ,
currentParentIsContainer = void 0 ;
;
) {
if ( ! currentParentIsValid ) {
currentParentIsValid = node . return ;
a : for ( ; ; ) {
2017-11-15 09:05:34 -08:00
invariant (
2018-06-16 00:38:41 -07:00
null !== currentParentIsValid ,
"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue."
2017-11-15 09:05:34 -08:00
) ;
2018-06-16 00:38:41 -07:00
switch ( currentParentIsValid . tag ) {
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
currentParent = currentParentIsValid . stateNode ;
currentParentIsContainer = ! 1 ;
break a ;
2018-09-10 14:42:08 -07:00
case 5 :
2018-06-16 00:38:41 -07:00
currentParent = currentParentIsValid . stateNode . containerInfo ;
currentParentIsContainer = ! 0 ;
break a ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
currentParent = currentParentIsValid . stateNode . containerInfo ;
currentParentIsContainer = ! 0 ;
break a ;
}
currentParentIsValid = currentParentIsValid . return ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
currentParentIsValid = ! 0 ;
}
2018-09-10 14:42:08 -07:00
if ( 7 === node . tag || 8 === node . tag ) {
2018-06-16 00:38:41 -07:00
a : for ( var root = node , node$jscomp$0 = root ; ; )
if (
( commitUnmount ( node$jscomp$0 ) ,
2018-09-10 14:42:08 -07:00
null !== node$jscomp$0 . child && 6 !== node$jscomp$0 . tag )
2018-06-16 00:38:41 -07:00
)
( node$jscomp$0 . child . return = node$jscomp$0 ) ,
( node$jscomp$0 = node$jscomp$0 . child ) ;
else {
if ( node$jscomp$0 === root ) break ;
for ( ; null === node$jscomp$0 . sibling ; ) {
if ( null === node$jscomp$0 . return || node$jscomp$0 . return === root )
break a ;
node$jscomp$0 = node$jscomp$0 . return ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
node$jscomp$0 . sibling . return = node$jscomp$0 . return ;
node$jscomp$0 = node$jscomp$0 . sibling ;
}
if ( currentParentIsContainer )
( root = currentParent ) ,
recursivelyUncacheFiberNode ( node . stateNode ) ,
UIManager . manageChildren ( root , [ ] , [ ] , [ ] , [ ] , [ 0 ] ) ;
else {
root = currentParent ;
var child = node . stateNode ;
recursivelyUncacheFiberNode ( child ) ;
node$jscomp$0 = root . _children ;
child = node$jscomp$0 . indexOf ( child ) ;
node$jscomp$0 . splice ( child , 1 ) ;
UIManager . manageChildren ( root . _nativeTag , [ ] , [ ] , [ ] , [ ] , [ child ] ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
} else if (
2018-09-10 14:42:08 -07:00
( 6 === node . tag
2018-07-24 14:45:35 -07:00
? ( ( currentParent = node . stateNode . containerInfo ) ,
( currentParentIsContainer = ! 0 ) )
2018-06-16 00:38:41 -07:00
: commitUnmount ( node ) ,
null !== node . child )
2017-11-15 09:05:34 -08:00
) {
2018-06-16 00:38:41 -07:00
node . child . return = node ;
node = node . child ;
continue ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
if ( node === current$$1 ) break ;
2018-06-16 00:38:41 -07:00
for ( ; null === node . sibling ; ) {
2018-07-24 14:45:35 -07:00
if ( null === node . return || node . return === current$$1 ) return ;
2018-06-16 00:38:41 -07:00
node = node . return ;
2018-09-10 14:42:08 -07:00
6 === node . tag && ( currentParentIsValid = ! 1 ) ;
2018-06-16 00:38:41 -07:00
}
node . sibling . return = node . return ;
node = node . sibling ;
2018-03-20 17:03:06 -07:00
}
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
function commitWork ( current$$1 , finishedWork ) {
2018-06-16 00:38:41 -07:00
switch ( finishedWork . tag ) {
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
var instance = finishedWork . stateNode ;
if ( null != instance ) {
var newProps = finishedWork . memoizedProps ;
2018-07-24 14:45:35 -07:00
current$$1 = null !== current$$1 ? current$$1 . memoizedProps : newProps ;
2018-06-16 00:38:41 -07:00
var updatePayload = finishedWork . updateQueue ;
finishedWork . updateQueue = null ;
null !== updatePayload &&
( ( finishedWork = instance . viewConfig ) ,
( instanceProps [ instance . _nativeTag ] = newProps ) ,
( newProps = diffProperties (
null ,
2018-07-24 14:45:35 -07:00
current$$1 ,
2018-06-16 00:38:41 -07:00
newProps ,
finishedWork . validAttributes
) ) ,
null != newProps &&
UIManager . updateView (
instance . _nativeTag ,
finishedWork . uiViewClassName ,
newProps
) ) ;
}
break ;
2018-09-10 14:42:08 -07:00
case 8 :
2018-03-20 17:03:06 -07:00
invariant (
2018-06-16 00:38:41 -07:00
null !== finishedWork . stateNode ,
"This should have a text node initialized. This error is likely caused by a bug in React. Please file an issue."
2018-03-20 17:03:06 -07:00
) ;
2018-06-16 00:38:41 -07:00
UIManager . updateView ( finishedWork . stateNode , "RCTRawText" , {
text : finishedWork . memoizedProps
} ) ;
break ;
2018-09-10 14:42:08 -07:00
case 5 :
2018-06-16 00:38:41 -07:00
break ;
case 15 :
break ;
case 16 :
break ;
default :
2018-03-20 17:03:06 -07:00
invariant (
2018-06-16 00:38:41 -07:00
! 1 ,
"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue."
2018-03-20 17:03:06 -07:00
) ;
2018-06-16 00:38:41 -07:00
}
2018-03-20 17:03:06 -07:00
}
2018-06-16 00:38:41 -07:00
function createRootErrorUpdate ( fiber , errorInfo , expirationTime ) {
expirationTime = createUpdate ( expirationTime ) ;
expirationTime . tag = 3 ;
expirationTime . payload = { element : null } ;
var error = errorInfo . value ;
expirationTime . callback = function ( ) {
onUncaughtError ( error ) ;
logError ( fiber , errorInfo ) ;
2018-03-20 17:03:06 -07:00
} ;
2018-06-16 00:38:41 -07:00
return expirationTime ;
2018-03-20 17:03:06 -07:00
}
2018-06-16 00:38:41 -07:00
function createClassErrorUpdate ( fiber , errorInfo , expirationTime ) {
expirationTime = createUpdate ( expirationTime ) ;
expirationTime . tag = 3 ;
var inst = fiber . stateNode ;
null !== inst &&
"function" === typeof inst . componentDidCatch &&
( expirationTime . callback = function ( ) {
null === legacyErrorBoundariesThatAlreadyFailed
? ( legacyErrorBoundariesThatAlreadyFailed = new Set ( [ this ] ) )
: legacyErrorBoundariesThatAlreadyFailed . add ( this ) ;
var error = errorInfo . value ,
stack = errorInfo . stack ;
logError ( fiber , errorInfo ) ;
this . componentDidCatch ( error , {
componentStack : null !== stack ? stack : ""
} ) ;
} ) ;
return expirationTime ;
2018-03-20 17:03:06 -07:00
}
2018-06-16 00:38:41 -07:00
function unwindWork ( workInProgress ) {
switch ( workInProgress . tag ) {
case 2 :
2018-09-10 14:42:08 -07:00
isContextProvider ( workInProgress . type ) && popContext ( workInProgress ) ;
2018-06-16 00:38:41 -07:00
var effectTag = workInProgress . effectTag ;
return effectTag & 1024
? ( ( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress )
: null ;
case 3 :
2018-09-10 14:42:08 -07:00
return (
isContextProvider ( workInProgress . type . _reactResult ) &&
popContext ( workInProgress ) ,
( effectTag = workInProgress . effectTag ) ,
effectTag & 1024
? ( ( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress )
: null
) ;
case 5 :
2018-06-16 00:38:41 -07:00
return (
popHostContainer ( workInProgress ) ,
popTopLevelContextObject ( workInProgress ) ,
( effectTag = workInProgress . effectTag ) ,
2018-07-24 14:45:35 -07:00
invariant (
0 === ( effectTag & 64 ) ,
"The root failed to unmount after an error. This is likely a bug in React. Please file an issue."
) ,
( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
return popHostContext ( workInProgress ) , null ;
case 16 :
return (
( effectTag = workInProgress . effectTag ) ,
effectTag & 1024
? ( ( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress )
: null
) ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
return popHostContainer ( workInProgress ) , null ;
2018-09-10 14:42:08 -07:00
case 12 :
2018-06-16 00:38:41 -07:00
return popProvider ( workInProgress ) , null ;
default :
return null ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
var Dispatcher = { readContext : readContext } ,
ReactCurrentOwner$2 = ReactSharedInternals . ReactCurrentOwner ,
2018-06-16 00:38:41 -07:00
isWorking = ! 1 ,
nextUnitOfWork = null ,
nextRoot = null ,
nextRenderExpirationTime = 0 ,
nextRenderDidError = ! 1 ,
nextEffect = null ,
isCommitting$1 = ! 1 ,
legacyErrorBoundariesThatAlreadyFailed = null ;
function resetStack ( ) {
if ( null !== nextUnitOfWork )
for (
var interruptedWork = nextUnitOfWork . return ;
null !== interruptedWork ;
) {
var interruptedWork$jscomp$0 = interruptedWork ;
switch ( interruptedWork$jscomp$0 . tag ) {
case 2 :
2018-09-10 14:42:08 -07:00
var childContextTypes =
interruptedWork$jscomp$0 . type . childContextTypes ;
null !== childContextTypes &&
void 0 !== childContextTypes &&
popContext ( interruptedWork$jscomp$0 ) ;
2018-02-28 19:16:47 -08:00
break ;
2018-06-16 00:38:41 -07:00
case 3 :
2018-09-10 14:42:08 -07:00
childContextTypes =
interruptedWork$jscomp$0 . type . _reactResult . childContextTypes ;
null !== childContextTypes &&
void 0 !== childContextTypes &&
popContext ( interruptedWork$jscomp$0 ) ;
break ;
case 5 :
2018-06-16 00:38:41 -07:00
popHostContainer ( interruptedWork$jscomp$0 ) ;
popTopLevelContextObject ( interruptedWork$jscomp$0 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
popHostContext ( interruptedWork$jscomp$0 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
popHostContainer ( interruptedWork$jscomp$0 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 12 :
2018-06-16 00:38:41 -07:00
popProvider ( interruptedWork$jscomp$0 ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
interruptedWork = interruptedWork . return ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
nextRoot = null ;
nextRenderExpirationTime = 0 ;
nextRenderDidError = ! 1 ;
nextUnitOfWork = null ;
}
2018-07-24 14:45:35 -07:00
function completeUnitOfWork ( workInProgress ) {
2018-06-16 00:38:41 -07:00
for ( ; ; ) {
2018-07-24 14:45:35 -07:00
var current$$1 = workInProgress . alternate ,
returnFiber = workInProgress . return ,
siblingFiber = workInProgress . sibling ;
if ( 0 === ( workInProgress . effectTag & 512 ) ) {
var current = current$$1 ;
current$$1 = workInProgress ;
var newProps = current$$1 . pendingProps ;
switch ( current$$1 . tag ) {
2018-09-10 14:42:08 -07:00
case 0 :
2018-07-24 14:45:35 -07:00
case 1 :
break ;
case 2 :
2018-09-10 14:42:08 -07:00
isContextProvider ( current$$1 . type ) && popContext ( current$$1 ) ;
2018-07-24 14:45:35 -07:00
break ;
case 3 :
2018-09-10 14:42:08 -07:00
isContextProvider ( current$$1 . type . _reactResult ) &&
popContext ( current$$1 ) ;
break ;
case 5 :
2018-07-24 14:45:35 -07:00
popHostContainer ( current$$1 ) ;
popTopLevelContextObject ( current$$1 ) ;
newProps = current$$1 . stateNode ;
newProps . pendingContext &&
( ( newProps . context = newProps . pendingContext ) ,
( newProps . pendingContext = null ) ) ;
if ( null === current || null === current . child )
current$$1 . effectTag &= - 3 ;
updateHostContainer ( current$$1 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-07-24 14:45:35 -07:00
popHostContext ( current$$1 ) ;
var rootContainerInstance = requiredContext (
rootInstanceStackCursor . current
) ,
type = current$$1 . type ;
2018-09-10 14:42:08 -07:00
if ( null !== current && null != current$$1 . stateNode )
2018-07-24 14:45:35 -07:00
updateHostComponent$1 (
current ,
current$$1 ,
type ,
newProps ,
2018-09-10 14:42:08 -07:00
rootContainerInstance
) ,
current . ref !== current$$1 . ref && ( current$$1 . effectTag |= 128 ) ;
else if ( newProps ) {
2018-07-24 14:45:35 -07:00
current = requiredContext ( contextStackCursor$1 . current ) ;
2018-09-10 14:42:08 -07:00
var internalInstanceHandle = current$$1 ,
tag = allocateTag ( ) ,
viewConfig = ReactNativeViewConfigRegistry . get ( type ) ;
2018-07-24 14:45:35 -07:00
invariant (
2018-09-10 14:42:08 -07:00
"RCTView" !== type || ! current . isInAParentText ,
2018-07-24 14:45:35 -07:00
"Nesting of <View> within <Text> is not currently supported."
) ;
2018-09-10 14:42:08 -07:00
var updatePayload = diffProperties (
2018-07-24 14:45:35 -07:00
null ,
emptyObject ,
2018-09-10 14:42:08 -07:00
newProps ,
2018-07-24 14:45:35 -07:00
viewConfig . validAttributes
) ;
UIManager . createView (
tag ,
viewConfig . uiViewClassName ,
2018-09-10 14:42:08 -07:00
rootContainerInstance ,
updatePayload
2018-07-24 14:45:35 -07:00
) ;
2018-09-10 14:42:08 -07:00
viewConfig = new ReactNativeFiberHostComponent ( tag , viewConfig ) ;
instanceCache [ tag ] = internalInstanceHandle ;
instanceProps [ tag ] = newProps ;
2018-07-24 14:45:35 -07:00
a : for (
2018-09-10 14:42:08 -07:00
internalInstanceHandle = viewConfig ,
2018-07-24 14:45:35 -07:00
tag = current$$1 ,
2018-09-10 14:42:08 -07:00
updatePayload = tag . child ;
null !== updatePayload ;
2018-07-24 14:45:35 -07:00
) {
2018-09-10 14:42:08 -07:00
if ( 7 === updatePayload . tag || 8 === updatePayload . tag )
internalInstanceHandle . _children . push ( updatePayload . stateNode ) ;
2018-07-24 14:45:35 -07:00
else if (
2018-09-10 14:42:08 -07:00
6 !== updatePayload . tag &&
null !== updatePayload . child
2018-07-24 14:45:35 -07:00
) {
2018-09-10 14:42:08 -07:00
updatePayload . child . return = updatePayload ;
updatePayload = updatePayload . child ;
2018-07-24 14:45:35 -07:00
continue ;
}
2018-09-10 14:42:08 -07:00
if ( updatePayload === tag ) break ;
for ( ; null === updatePayload . sibling ; ) {
2018-07-24 14:45:35 -07:00
if (
2018-09-10 14:42:08 -07:00
null === updatePayload . return ||
updatePayload . return === tag
2018-07-24 14:45:35 -07:00
)
break a ;
2018-09-10 14:42:08 -07:00
updatePayload = updatePayload . return ;
2018-07-24 14:45:35 -07:00
}
2018-09-10 14:42:08 -07:00
updatePayload . sibling . return = updatePayload . return ;
updatePayload = updatePayload . sibling ;
2018-07-24 14:45:35 -07:00
}
finalizeInitialChildren (
2018-09-10 14:42:08 -07:00
viewConfig ,
2018-07-24 14:45:35 -07:00
type ,
newProps ,
rootContainerInstance ,
current
) && ( current$$1 . effectTag |= 4 ) ;
2018-09-10 14:42:08 -07:00
current$$1 . stateNode = viewConfig ;
2018-07-24 14:45:35 -07:00
null !== current$$1 . ref && ( current$$1 . effectTag |= 128 ) ;
} else
invariant (
null !== current$$1 . stateNode ,
"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue."
) ;
break ;
2018-09-10 14:42:08 -07:00
case 8 :
2018-07-24 14:45:35 -07:00
current && null != current$$1 . stateNode
2018-09-10 14:42:08 -07:00
? updateHostText$1 (
current ,
current$$1 ,
current . memoizedProps ,
newProps
)
: ( "string" !== typeof newProps &&
2018-07-24 14:45:35 -07:00
invariant (
null !== current$$1 . stateNode ,
"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue."
) ,
( current = requiredContext ( rootInstanceStackCursor . current ) ) ,
2018-09-10 14:42:08 -07:00
( type = requiredContext ( contextStackCursor$1 . current ) ) ,
( rootContainerInstance = current$$1 ) ,
2018-07-24 14:45:35 -07:00
invariant (
2018-09-10 14:42:08 -07:00
type . isInAParentText ,
2018-07-24 14:45:35 -07:00
"Text strings must be rendered within a <Text> component."
) ,
2018-09-10 14:42:08 -07:00
( type = allocateTag ( ) ) ,
UIManager . createView ( type , "RCTRawText" , current , {
text : newProps
} ) ,
( instanceCache [ type ] = current$$1 ) ,
( rootContainerInstance . stateNode = type ) ) ;
2018-07-24 14:45:35 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 13 :
2018-07-24 14:45:35 -07:00
case 14 :
break ;
case 16 :
break ;
2018-09-10 14:42:08 -07:00
case 9 :
2018-07-24 14:45:35 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 10 :
2018-07-24 14:45:35 -07:00
break ;
case 15 :
break ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-07-24 14:45:35 -07:00
popHostContainer ( current$$1 ) ;
updateHostContainer ( current$$1 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 12 :
2018-07-24 14:45:35 -07:00
popProvider ( current$$1 ) ;
break ;
2018-09-10 14:42:08 -07:00
case 11 :
2018-07-24 14:45:35 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 4 :
2018-07-24 14:45:35 -07:00
invariant (
! 1 ,
"An indeterminate component should have become determinate before completing. This error is likely caused by a bug in React. Please file an issue."
) ;
default :
invariant (
! 1 ,
"Unknown unit of work tag. This error is likely caused by a bug in React. Please file an issue."
) ;
}
current$$1 = nextUnitOfWork = null ;
newProps = workInProgress ;
2018-06-16 00:38:41 -07:00
if (
1073741823 === nextRenderExpirationTime ||
2018-07-24 14:45:35 -07:00
1073741823 !== newProps . childExpirationTime
2018-06-16 00:38:41 -07:00
) {
2018-07-24 14:45:35 -07:00
rootContainerInstance = 0 ;
for ( type = newProps . child ; null !== type ; ) {
current = type . expirationTime ;
2018-09-10 14:42:08 -07:00
viewConfig = type . childExpirationTime ;
2018-07-24 14:45:35 -07:00
if (
0 === rootContainerInstance ||
( 0 !== current && current < rootContainerInstance )
)
rootContainerInstance = current ;
if (
0 === rootContainerInstance ||
2018-09-10 14:42:08 -07:00
( 0 !== viewConfig && viewConfig < rootContainerInstance )
2018-07-24 14:45:35 -07:00
)
2018-09-10 14:42:08 -07:00
rootContainerInstance = viewConfig ;
2018-07-24 14:45:35 -07:00
type = type . sibling ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
newProps . childExpirationTime = rootContainerInstance ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
if ( null !== current$$1 ) return current$$1 ;
2018-06-16 00:38:41 -07:00
null !== returnFiber &&
0 === ( returnFiber . effectTag & 512 ) &&
( null === returnFiber . firstEffect &&
2018-07-24 14:45:35 -07:00
( returnFiber . firstEffect = workInProgress . firstEffect ) ,
null !== workInProgress . lastEffect &&
2018-06-16 00:38:41 -07:00
( null !== returnFiber . lastEffect &&
2018-07-24 14:45:35 -07:00
( returnFiber . lastEffect . nextEffect = workInProgress . firstEffect ) ,
( returnFiber . lastEffect = workInProgress . lastEffect ) ) ,
1 < workInProgress . effectTag &&
2018-06-16 00:38:41 -07:00
( null !== returnFiber . lastEffect
2018-07-24 14:45:35 -07:00
? ( returnFiber . lastEffect . nextEffect = workInProgress )
: ( returnFiber . firstEffect = workInProgress ) ,
( returnFiber . lastEffect = workInProgress ) ) ) ;
2018-06-16 00:38:41 -07:00
} else {
2018-07-24 14:45:35 -07:00
workInProgress = unwindWork ( workInProgress , nextRenderExpirationTime ) ;
if ( null !== workInProgress )
return ( workInProgress . effectTag &= 511 ) , workInProgress ;
2018-06-16 00:38:41 -07:00
null !== returnFiber &&
( ( returnFiber . firstEffect = returnFiber . lastEffect = null ) ,
( returnFiber . effectTag |= 512 ) ) ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
if ( null !== siblingFiber ) return siblingFiber ;
2018-07-24 14:45:35 -07:00
if ( null !== returnFiber ) workInProgress = returnFiber ;
2018-06-16 00:38:41 -07:00
else break ;
2018-05-11 12:09:48 -07:00
}
2018-06-16 00:38:41 -07:00
return null ;
}
function performUnitOfWork ( workInProgress ) {
var next = beginWork (
workInProgress . alternate ,
workInProgress ,
nextRenderExpirationTime
) ;
null === next && ( next = completeUnitOfWork ( workInProgress ) ) ;
2018-07-24 14:45:35 -07:00
ReactCurrentOwner$2 . current = null ;
2018-06-16 00:38:41 -07:00
return next ;
}
2018-07-24 14:45:35 -07:00
function renderRoot ( root , isYieldy , isExpired ) {
2018-06-16 00:38:41 -07:00
invariant (
! isWorking ,
"renderRoot was called recursively. This error is likely caused by a bug in React. Please file an issue."
) ;
isWorking = ! 0 ;
2018-07-24 14:45:35 -07:00
ReactCurrentOwner$2 . currentDispatcher = Dispatcher ;
var expirationTime = root . nextExpirationTimeToWorkOn ;
2018-06-16 00:38:41 -07:00
if (
expirationTime !== nextRenderExpirationTime ||
2018-07-24 14:45:35 -07:00
root !== nextRoot ||
2018-06-16 00:38:41 -07:00
null === nextUnitOfWork
)
resetStack ( ) ,
2018-07-24 14:45:35 -07:00
( nextRoot = root ) ,
2018-06-16 00:38:41 -07:00
( nextRenderExpirationTime = expirationTime ) ,
( nextUnitOfWork = createWorkInProgress (
nextRoot . current ,
null ,
nextRenderExpirationTime
) ) ,
2018-07-24 14:45:35 -07:00
( root . pendingCommitExpirationTime = 0 ) ;
2018-06-16 00:38:41 -07:00
var didFatal = ! 1 ;
do {
try {
if ( isYieldy )
for ( ; null !== nextUnitOfWork && ! shouldYield ( ) ; )
nextUnitOfWork = performUnitOfWork ( nextUnitOfWork ) ;
else
for ( ; null !== nextUnitOfWork ; )
nextUnitOfWork = performUnitOfWork ( nextUnitOfWork ) ;
} catch ( thrownValue ) {
if ( null === nextUnitOfWork )
( didFatal = ! 0 ) , onUncaughtError ( thrownValue ) ;
else {
invariant (
null !== nextUnitOfWork ,
"Failed to replay rendering after an error. This is likely caused by a bug in React. Please file an issue with a reproducing case to help us find it."
) ;
2018-07-24 14:45:35 -07:00
var sourceFiber = nextUnitOfWork ,
returnFiber = sourceFiber . return ;
if ( null === returnFiber ) ( didFatal = ! 0 ) , onUncaughtError ( thrownValue ) ;
else {
a : {
var returnFiber$jscomp$0 = returnFiber ,
sourceFiber$jscomp$0 = sourceFiber ,
value = thrownValue ;
returnFiber = nextRenderExpirationTime ;
sourceFiber$jscomp$0 . effectTag |= 512 ;
sourceFiber$jscomp$0 . firstEffect = sourceFiber$jscomp$0 . lastEffect = null ;
nextRenderDidError = ! 0 ;
value = createCapturedValue ( value , sourceFiber$jscomp$0 ) ;
2018-06-16 00:38:41 -07:00
do {
2018-07-24 14:45:35 -07:00
switch ( returnFiber$jscomp$0 . tag ) {
2018-09-10 14:42:08 -07:00
case 5 :
2018-07-24 14:45:35 -07:00
returnFiber$jscomp$0 . effectTag |= 1024 ;
returnFiber$jscomp$0 . expirationTime = returnFiber ;
returnFiber = createRootErrorUpdate (
returnFiber$jscomp$0 ,
value ,
returnFiber
) ;
enqueueCapturedUpdate ( returnFiber$jscomp$0 , returnFiber ) ;
2018-06-16 00:38:41 -07:00
break a ;
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-07-24 14:45:35 -07:00
sourceFiber$jscomp$0 = value ;
var instance = returnFiber$jscomp$0 . stateNode ;
2018-06-16 00:38:41 -07:00
if (
2018-07-24 14:45:35 -07:00
0 === ( returnFiber$jscomp$0 . effectTag & 64 ) &&
null !== instance &&
"function" === typeof instance . componentDidCatch &&
( null === legacyErrorBoundariesThatAlreadyFailed ||
! legacyErrorBoundariesThatAlreadyFailed . has ( instance ) )
2018-06-16 00:38:41 -07:00
) {
2018-07-24 14:45:35 -07:00
returnFiber$jscomp$0 . effectTag |= 1024 ;
returnFiber$jscomp$0 . expirationTime = returnFiber ;
returnFiber = createClassErrorUpdate (
2018-06-16 00:38:41 -07:00
returnFiber$jscomp$0 ,
2018-07-24 14:45:35 -07:00
sourceFiber$jscomp$0 ,
2018-06-16 00:38:41 -07:00
returnFiber
) ;
2018-07-24 14:45:35 -07:00
enqueueCapturedUpdate ( returnFiber$jscomp$0 , returnFiber ) ;
2018-06-16 00:38:41 -07:00
break a ;
}
}
2018-07-24 14:45:35 -07:00
returnFiber$jscomp$0 = returnFiber$jscomp$0 . return ;
} while ( null !== returnFiber$jscomp$0 ) ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
nextUnitOfWork = completeUnitOfWork ( sourceFiber ) ;
continue ;
2018-06-16 00:38:41 -07:00
}
}
}
break ;
} while ( 1 ) ;
isWorking = ! 1 ;
2018-07-24 14:45:35 -07:00
lastContextWithAllBitsObserved = lastContextDependency = currentlyRenderingFiber = ReactCurrentOwner$2 . currentDispatcher = null ;
if ( didFatal ) ( nextRoot = null ) , ( root . finishedWork = null ) ;
else if ( null !== nextUnitOfWork ) root . finishedWork = null ;
else {
isYieldy = root . current . alternate ;
invariant (
null !== isYieldy ,
"Finished root should have a work-in-progress. This error is likely caused by a bug in React. Please file an issue."
) ;
nextRoot = null ;
if ( nextRenderDidError ) {
didFatal = root . latestPendingTime ;
sourceFiber = root . latestSuspendedTime ;
returnFiber = root . latestPingedTime ;
if (
( 0 !== didFatal && didFatal > expirationTime ) ||
( 0 !== sourceFiber && sourceFiber > expirationTime ) ||
( 0 !== returnFiber && returnFiber > expirationTime )
) {
root . didError = ! 1 ;
isExpired = root . latestPingedTime ;
0 !== isExpired &&
isExpired <= expirationTime &&
( root . latestPingedTime = 0 ) ;
isExpired = root . earliestPendingTime ;
isYieldy = root . latestPendingTime ;
isExpired === expirationTime
? ( root . earliestPendingTime =
isYieldy === expirationTime
? ( root . latestPendingTime = 0 )
: isYieldy )
: isYieldy === expirationTime && ( root . latestPendingTime = isExpired ) ;
isExpired = root . earliestSuspendedTime ;
isYieldy = root . latestSuspendedTime ;
0 === isExpired
? ( root . earliestSuspendedTime = root . latestSuspendedTime = expirationTime )
: isExpired > expirationTime
? ( root . earliestSuspendedTime = expirationTime )
: isYieldy < expirationTime &&
( root . latestSuspendedTime = expirationTime ) ;
findNextExpirationTimeToWorkOn ( expirationTime , root ) ;
root . expirationTime = root . expirationTime ;
return ;
}
if ( ! root . didError && ! isExpired ) {
root . didError = ! 0 ;
root . nextExpirationTimeToWorkOn = expirationTime ;
root . expirationTime = 1 ;
return ;
}
}
root . pendingCommitExpirationTime = expirationTime ;
root . finishedWork = isYieldy ;
}
2018-06-16 00:38:41 -07:00
}
function captureCommitPhaseError ( fiber , error ) {
var JSCompiler _inline _result ;
a : {
invariant (
! isWorking || isCommitting$1 ,
"dispatch: Cannot dispatch during the render phase."
) ;
for (
JSCompiler _inline _result = fiber . return ;
null !== JSCompiler _inline _result ;
2018-05-15 13:08:47 -07:00
2018-06-16 00:38:41 -07:00
) {
switch ( JSCompiler _inline _result . tag ) {
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-06-16 00:38:41 -07:00
var instance = JSCompiler _inline _result . stateNode ;
if (
"function" ===
typeof JSCompiler _inline _result . type . getDerivedStateFromCatch ||
( "function" === typeof instance . componentDidCatch &&
( null === legacyErrorBoundariesThatAlreadyFailed ||
! legacyErrorBoundariesThatAlreadyFailed . has ( instance ) ) )
) {
2018-05-15 13:08:47 -07:00
fiber = createCapturedValue ( error , fiber ) ;
2018-06-16 00:38:41 -07:00
fiber = createClassErrorUpdate ( JSCompiler _inline _result , fiber , 1 ) ;
2018-07-24 14:45:35 -07:00
enqueueUpdate ( JSCompiler _inline _result , fiber ) ;
2018-05-15 13:08:47 -07:00
scheduleWork ( JSCompiler _inline _result , 1 ) ;
JSCompiler _inline _result = void 0 ;
2017-11-15 09:05:34 -08:00
break a ;
2018-06-16 00:38:41 -07:00
}
break ;
2018-09-10 14:42:08 -07:00
case 5 :
2018-06-16 00:38:41 -07:00
fiber = createCapturedValue ( error , fiber ) ;
fiber = createRootErrorUpdate ( JSCompiler _inline _result , fiber , 1 ) ;
2018-07-24 14:45:35 -07:00
enqueueUpdate ( JSCompiler _inline _result , fiber ) ;
2018-06-16 00:38:41 -07:00
scheduleWork ( JSCompiler _inline _result , 1 ) ;
JSCompiler _inline _result = void 0 ;
break a ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
JSCompiler _inline _result = JSCompiler _inline _result . return ;
2017-11-29 10:12:57 -08:00
}
2018-09-10 14:42:08 -07:00
5 === fiber . tag &&
2018-06-16 00:38:41 -07:00
( ( JSCompiler _inline _result = createCapturedValue ( error , fiber ) ) ,
( JSCompiler _inline _result = createRootErrorUpdate (
fiber ,
JSCompiler _inline _result ,
1
) ) ,
2018-07-24 14:45:35 -07:00
enqueueUpdate ( fiber , JSCompiler _inline _result ) ,
2018-06-16 00:38:41 -07:00
scheduleWork ( fiber , 1 ) ) ;
JSCompiler _inline _result = void 0 ;
2017-11-29 10:12:57 -08:00
}
2018-06-16 00:38:41 -07:00
return JSCompiler _inline _result ;
}
function computeExpirationForFiber ( currentTime , fiber ) {
2018-09-10 14:42:08 -07:00
isWorking
? ( currentTime = isCommitting$1 ? 1 : nextRenderExpirationTime )
: fiber . mode & 1
? ( ( currentTime = isBatchingInteractiveUpdates
? 2 + 10 * ( ( ( ( currentTime - 2 + 15 ) / 10 ) | 0 ) + 1 )
: 2 + 25 * ( ( ( ( currentTime - 2 + 500 ) / 25 ) | 0 ) + 1 ) ) ,
null !== nextRoot &&
currentTime === nextRenderExpirationTime &&
( currentTime += 1 ) )
: ( currentTime = 1 ) ;
2018-06-16 00:38:41 -07:00
isBatchingInteractiveUpdates &&
2018-09-10 14:42:08 -07:00
( 0 === lowestPriorityPendingInteractiveExpirationTime ||
currentTime > lowestPriorityPendingInteractiveExpirationTime ) &&
( lowestPriorityPendingInteractiveExpirationTime = currentTime ) ;
2018-06-16 00:38:41 -07:00
return currentTime ;
}
function scheduleWork ( fiber , expirationTime ) {
2018-07-24 14:45:35 -07:00
a : {
2018-06-16 00:38:41 -07:00
if ( 0 === fiber . expirationTime || fiber . expirationTime > expirationTime )
fiber . expirationTime = expirationTime ;
2018-07-24 14:45:35 -07:00
var alternate = fiber . alternate ;
null !== alternate &&
( 0 === alternate . expirationTime ||
alternate . expirationTime > expirationTime ) &&
( alternate . expirationTime = expirationTime ) ;
var node = fiber . return ;
2018-09-10 14:42:08 -07:00
if ( null === node && 5 === fiber . tag ) fiber = fiber . stateNode ;
2018-07-24 14:45:35 -07:00
else {
for ( ; null !== node ; ) {
alternate = node . alternate ;
if (
0 === node . childExpirationTime ||
node . childExpirationTime > expirationTime
)
node . childExpirationTime = expirationTime ;
null !== alternate &&
( 0 === alternate . childExpirationTime ||
alternate . childExpirationTime > expirationTime ) &&
( alternate . childExpirationTime = expirationTime ) ;
2018-09-10 14:42:08 -07:00
if ( null === node . return && 5 === node . tag ) {
2018-07-24 14:45:35 -07:00
fiber = node . stateNode ;
break a ;
}
node = node . return ;
}
fiber = null ;
}
2017-11-15 09:05:34 -08:00
}
2018-09-10 14:42:08 -07:00
if ( null !== fiber ) {
! isWorking &&
2018-07-24 14:45:35 -07:00
0 !== nextRenderExpirationTime &&
expirationTime < nextRenderExpirationTime &&
2018-09-10 14:42:08 -07:00
resetStack ( ) ;
markPendingPriorityLevel ( fiber , expirationTime ) ;
if ( ! isWorking || isCommitting$1 || nextRoot !== fiber ) {
expirationTime = fiber ;
fiber = fiber . expirationTime ;
if ( null === expirationTime . nextScheduledRoot )
( expirationTime . expirationTime = fiber ) ,
null === lastScheduledRoot
? ( ( firstScheduledRoot = lastScheduledRoot = expirationTime ) ,
( expirationTime . nextScheduledRoot = expirationTime ) )
: ( ( lastScheduledRoot = lastScheduledRoot . nextScheduledRoot = expirationTime ) ,
( lastScheduledRoot . nextScheduledRoot = firstScheduledRoot ) ) ;
else if (
( ( alternate = expirationTime . expirationTime ) ,
0 === alternate || fiber < alternate )
)
expirationTime . expirationTime = fiber ;
isRendering ||
( isBatchingUpdates
? isUnbatchingUpdates &&
( ( nextFlushedRoot = expirationTime ) ,
( nextFlushedExpirationTime = 1 ) ,
performWorkOnRoot ( expirationTime , 1 , ! 0 ) )
: 1 === fiber
? performWork ( 1 , null )
: scheduleCallbackWithExpirationTime ( expirationTime , fiber ) ) ;
}
2018-07-24 14:45:35 -07:00
nestedUpdateCount > NESTED _UPDATE _LIMIT &&
( ( nestedUpdateCount = 0 ) ,
invariant (
! 1 ,
"Maximum update depth exceeded. This can happen when a component repeatedly calls setState inside componentWillUpdate or componentDidUpdate. React limits the number of nested updates to prevent infinite loops."
2018-09-10 14:42:08 -07:00
) ) ;
2017-11-29 10:12:57 -08:00
}
2018-06-16 00:38:41 -07:00
}
var firstScheduledRoot = null ,
lastScheduledRoot = null ,
callbackExpirationTime = 0 ,
callbackID = void 0 ,
isRendering = ! 1 ,
nextFlushedRoot = null ,
nextFlushedExpirationTime = 0 ,
2018-09-10 14:42:08 -07:00
lowestPriorityPendingInteractiveExpirationTime = 0 ,
2018-06-16 00:38:41 -07:00
deadlineDidExpire = ! 1 ,
hasUnhandledError = ! 1 ,
unhandledError = null ,
deadline = null ,
isBatchingUpdates = ! 1 ,
isUnbatchingUpdates = ! 1 ,
isBatchingInteractiveUpdates = ! 1 ,
completedBatches = null ,
2018-07-24 14:45:35 -07:00
originalStartTimeMs = now$1 ( ) ,
currentRendererTime = ( ( originalStartTimeMs / 10 ) | 0 ) + 2 ,
currentSchedulerTime = currentRendererTime ,
NESTED _UPDATE _LIMIT = 50 ,
2018-06-16 00:38:41 -07:00
nestedUpdateCount = 0 ,
2018-07-24 14:45:35 -07:00
lastCommittedRootDuringThisBatch = null ,
2018-06-16 00:38:41 -07:00
timeHeuristicForUnitOfWork = 1 ;
2018-07-24 14:45:35 -07:00
function recomputeCurrentRendererTime ( ) {
currentRendererTime = ( ( ( now$1 ( ) - originalStartTimeMs ) / 10 ) | 0 ) + 2 ;
}
2018-09-10 14:42:08 -07:00
function scheduleCallbackWithExpirationTime ( root , expirationTime ) {
2018-06-16 00:38:41 -07:00
if ( 0 !== callbackExpirationTime ) {
if ( expirationTime > callbackExpirationTime ) return ;
2018-09-10 14:42:08 -07:00
null !== callbackID &&
( ( root = callbackID ) , ( scheduledCallback = null ) , clearTimeout ( root ) ) ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
callbackExpirationTime = expirationTime ;
now$1 ( ) ;
scheduledCallback = performAsyncWork ;
callbackID = setTimeout ( setTimeoutCallback , 1 ) ;
}
2018-07-24 14:45:35 -07:00
function requestCurrentTime ( ) {
if ( isRendering ) return currentSchedulerTime ;
findHighestPriorityRoot ( ) ;
if (
0 === nextFlushedExpirationTime ||
1073741823 === nextFlushedExpirationTime
)
recomputeCurrentRendererTime ( ) ,
( currentSchedulerTime = currentRendererTime ) ;
return currentSchedulerTime ;
2018-06-16 00:38:41 -07:00
}
function findHighestPriorityRoot ( ) {
var highestPriorityWork = 0 ,
highestPriorityRoot = null ;
if ( null !== lastScheduledRoot )
for (
var previousScheduledRoot = lastScheduledRoot , root = firstScheduledRoot ;
null !== root ;
2018-02-28 19:16:47 -08:00
2018-06-16 00:38:41 -07:00
) {
var remainingExpirationTime = root . expirationTime ;
if ( 0 === remainingExpirationTime ) {
invariant (
null !== previousScheduledRoot && null !== lastScheduledRoot ,
"Should have a previous and last root. This error is likely caused by a bug in React. Please file an issue."
) ;
if ( root === root . nextScheduledRoot ) {
firstScheduledRoot = lastScheduledRoot = root . nextScheduledRoot = null ;
break ;
} else if ( root === firstScheduledRoot )
( firstScheduledRoot = remainingExpirationTime =
root . nextScheduledRoot ) ,
( lastScheduledRoot . nextScheduledRoot = remainingExpirationTime ) ,
( root . nextScheduledRoot = null ) ;
else if ( root === lastScheduledRoot ) {
lastScheduledRoot = previousScheduledRoot ;
lastScheduledRoot . nextScheduledRoot = firstScheduledRoot ;
root . nextScheduledRoot = null ;
break ;
} else
( previousScheduledRoot . nextScheduledRoot = root . nextScheduledRoot ) ,
( root . nextScheduledRoot = null ) ;
root = previousScheduledRoot . nextScheduledRoot ;
} else {
if (
0 === highestPriorityWork ||
remainingExpirationTime < highestPriorityWork
)
( highestPriorityWork = remainingExpirationTime ) ,
( highestPriorityRoot = root ) ;
if ( root === lastScheduledRoot ) break ;
2018-09-10 14:42:08 -07:00
if ( 1 === highestPriorityWork ) break ;
2018-06-16 00:38:41 -07:00
previousScheduledRoot = root ;
root = root . nextScheduledRoot ;
2017-11-29 10:12:57 -08:00
}
}
2018-06-16 00:38:41 -07:00
nextFlushedRoot = highestPriorityRoot ;
nextFlushedExpirationTime = highestPriorityWork ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
function performAsyncWork ( dl ) {
2018-09-10 14:42:08 -07:00
if ( dl . didTimeout && null !== firstScheduledRoot ) {
recomputeCurrentRendererTime ( ) ;
var root = firstScheduledRoot ;
do {
var expirationTime = root . expirationTime ;
0 !== expirationTime &&
currentRendererTime >= expirationTime &&
( root . nextExpirationTimeToWorkOn = currentRendererTime ) ;
root = root . nextScheduledRoot ;
} while ( root !== firstScheduledRoot ) ;
}
2018-06-16 00:38:41 -07:00
performWork ( 0 , dl ) ;
}
function performWork ( minExpirationTime , dl ) {
deadline = dl ;
findHighestPriorityRoot ( ) ;
if ( null !== deadline )
for (
2018-07-24 14:45:35 -07:00
recomputeCurrentRendererTime ( ) ,
currentSchedulerTime = currentRendererTime ;
2018-06-16 00:38:41 -07:00
null !== nextFlushedRoot &&
0 !== nextFlushedExpirationTime &&
( 0 === minExpirationTime ||
minExpirationTime >= nextFlushedExpirationTime ) &&
2018-07-24 14:45:35 -07:00
( ! deadlineDidExpire || currentRendererTime >= nextFlushedExpirationTime ) ;
2018-06-16 00:38:41 -07:00
)
2018-07-24 14:45:35 -07:00
performWorkOnRoot (
nextFlushedRoot ,
nextFlushedExpirationTime ,
currentRendererTime >= nextFlushedExpirationTime
) ,
findHighestPriorityRoot ( ) ,
recomputeCurrentRendererTime ( ) ,
( currentSchedulerTime = currentRendererTime ) ;
2018-06-16 00:38:41 -07:00
else
for (
;
null !== nextFlushedRoot &&
0 !== nextFlushedExpirationTime &&
( 0 === minExpirationTime ||
minExpirationTime >= nextFlushedExpirationTime ) ;
)
2018-07-24 14:45:35 -07:00
performWorkOnRoot ( nextFlushedRoot , nextFlushedExpirationTime , ! 0 ) ,
2018-06-16 00:38:41 -07:00
findHighestPriorityRoot ( ) ;
null !== deadline && ( ( callbackExpirationTime = 0 ) , ( callbackID = null ) ) ;
0 !== nextFlushedExpirationTime &&
2018-09-10 14:42:08 -07:00
scheduleCallbackWithExpirationTime (
nextFlushedRoot ,
nextFlushedExpirationTime
) ;
2018-06-16 00:38:41 -07:00
deadline = null ;
deadlineDidExpire = ! 1 ;
nestedUpdateCount = 0 ;
2018-07-24 14:45:35 -07:00
lastCommittedRootDuringThisBatch = null ;
if ( null !== completedBatches )
for (
minExpirationTime = completedBatches , completedBatches = null , dl = 0 ;
dl < minExpirationTime . length ;
dl ++
) {
var batch = minExpirationTime [ dl ] ;
2018-06-16 00:38:41 -07:00
try {
batch . _onComplete ( ) ;
} catch ( error ) {
hasUnhandledError ||
( ( hasUnhandledError = ! 0 ) , ( unhandledError = error ) ) ;
2017-11-15 09:05:34 -08:00
}
}
2018-06-16 00:38:41 -07:00
if ( hasUnhandledError )
2018-07-24 14:45:35 -07:00
throw ( ( minExpirationTime = unhandledError ) ,
2018-06-16 00:38:41 -07:00
( unhandledError = null ) ,
( hasUnhandledError = ! 1 ) ,
2018-07-24 14:45:35 -07:00
minExpirationTime ) ;
2017-11-15 09:05:34 -08:00
}
2018-07-24 14:45:35 -07:00
function performWorkOnRoot ( root , expirationTime , isExpired ) {
2018-06-16 00:38:41 -07:00
invariant (
! isRendering ,
"performWorkOnRoot was called recursively. This error is likely caused by a bug in React. Please file an issue."
) ;
isRendering = ! 0 ;
2018-07-24 14:45:35 -07:00
if ( null === deadline || isExpired ) {
var finishedWork = root . finishedWork ;
null !== finishedWork
? completeRoot ( root , finishedWork , expirationTime )
: ( ( root . finishedWork = null ) ,
renderRoot ( root , ! 1 , isExpired ) ,
( finishedWork = root . finishedWork ) ,
null !== finishedWork &&
completeRoot ( root , finishedWork , expirationTime ) ) ;
} else
( finishedWork = root . finishedWork ) ,
null !== finishedWork
? completeRoot ( root , finishedWork , expirationTime )
2018-06-16 00:38:41 -07:00
: ( ( root . finishedWork = null ) ,
2018-07-24 14:45:35 -07:00
renderRoot ( root , ! 0 , isExpired ) ,
( finishedWork = root . finishedWork ) ,
null !== finishedWork &&
2018-06-16 00:38:41 -07:00
( shouldYield ( )
2018-07-24 14:45:35 -07:00
? ( root . finishedWork = finishedWork )
: completeRoot ( root , finishedWork , expirationTime ) ) ) ;
2018-06-16 00:38:41 -07:00
isRendering = ! 1 ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
function completeRoot ( root , finishedWork$jscomp$0 , expirationTime ) {
var firstBatch = root . firstBatch ;
if (
null !== firstBatch &&
firstBatch . _expirationTime <= expirationTime &&
( null === completedBatches
? ( completedBatches = [ firstBatch ] )
: completedBatches . push ( firstBatch ) ,
firstBatch . _defer )
) {
root . finishedWork = finishedWork$jscomp$0 ;
root . expirationTime = 0 ;
return ;
}
root . finishedWork = null ;
2018-07-24 14:45:35 -07:00
root === lastCommittedRootDuringThisBatch
? nestedUpdateCount ++
: ( ( lastCommittedRootDuringThisBatch = root ) , ( nestedUpdateCount = 0 ) ) ;
2018-06-16 00:38:41 -07:00
isCommitting$1 = isWorking = ! 0 ;
invariant (
root . current !== finishedWork$jscomp$0 ,
"Cannot commit the same tree as before. This is probably a bug related to the return field. This error is likely caused by a bug in React. Please file an issue."
) ;
expirationTime = root . pendingCommitExpirationTime ;
invariant (
0 !== expirationTime ,
"Cannot commit an incomplete root. This error is likely caused by a bug in React. Please file an issue."
) ;
root . pendingCommitExpirationTime = 0 ;
firstBatch = finishedWork$jscomp$0 . expirationTime ;
2018-07-24 14:45:35 -07:00
var childExpirationTimeBeforeCommit =
finishedWork$jscomp$0 . childExpirationTime ;
firstBatch =
0 === firstBatch ||
( 0 !== childExpirationTimeBeforeCommit &&
childExpirationTimeBeforeCommit < firstBatch )
? childExpirationTimeBeforeCommit
: firstBatch ;
2018-06-16 00:38:41 -07:00
root . didError = ! 1 ;
2018-07-24 14:45:35 -07:00
0 === firstBatch
? ( ( root . earliestPendingTime = 0 ) ,
2018-06-16 00:38:41 -07:00
( root . latestPendingTime = 0 ) ,
( root . earliestSuspendedTime = 0 ) ,
( root . latestSuspendedTime = 0 ) ,
2018-07-24 14:45:35 -07:00
( root . latestPingedTime = 0 ) )
: ( ( childExpirationTimeBeforeCommit = root . latestPendingTime ) ,
0 !== childExpirationTimeBeforeCommit &&
( childExpirationTimeBeforeCommit < firstBatch
? ( root . earliestPendingTime = root . latestPendingTime = 0 )
: root . earliestPendingTime < firstBatch &&
( root . earliestPendingTime = root . latestPendingTime ) ) ,
( childExpirationTimeBeforeCommit = root . earliestSuspendedTime ) ,
0 === childExpirationTimeBeforeCommit
? markPendingPriorityLevel ( root , firstBatch )
: firstBatch > root . latestSuspendedTime
? ( ( root . earliestSuspendedTime = 0 ) ,
( root . latestSuspendedTime = 0 ) ,
( root . latestPingedTime = 0 ) ,
markPendingPriorityLevel ( root , firstBatch ) )
: firstBatch < childExpirationTimeBeforeCommit &&
markPendingPriorityLevel ( root , firstBatch ) ) ;
findNextExpirationTimeToWorkOn ( 0 , root ) ;
ReactCurrentOwner$2 . current = null ;
2018-06-16 00:38:41 -07:00
1 < finishedWork$jscomp$0 . effectTag
? null !== finishedWork$jscomp$0 . lastEffect
? ( ( finishedWork$jscomp$0 . lastEffect . nextEffect = finishedWork$jscomp$0 ) ,
( firstBatch = finishedWork$jscomp$0 . firstEffect ) )
: ( firstBatch = finishedWork$jscomp$0 )
: ( firstBatch = finishedWork$jscomp$0 . firstEffect ) ;
for ( nextEffect = firstBatch ; null !== nextEffect ; ) {
2018-07-24 14:45:35 -07:00
childExpirationTimeBeforeCommit = ! 1 ;
2018-06-16 00:38:41 -07:00
var error = void 0 ;
try {
for ( ; null !== nextEffect ; ) {
if ( nextEffect . effectTag & 256 ) {
2018-09-10 14:42:08 -07:00
var current$$1 = nextEffect . alternate ;
a : {
var finishedWork = nextEffect ;
switch ( finishedWork . tag ) {
case 2 :
case 3 :
if ( finishedWork . effectTag & 256 && null !== current$$1 ) {
var prevProps = current$$1 . memoizedProps ,
prevState = current$$1 . memoizedState ,
instance = finishedWork . stateNode ;
instance . props = finishedWork . memoizedProps ;
instance . state = finishedWork . memoizedState ;
var snapshot = instance . getSnapshotBeforeUpdate (
prevProps ,
prevState
) ;
instance . _ _reactInternalSnapshotBeforeUpdate = snapshot ;
}
break a ;
case 5 :
case 7 :
case 8 :
case 6 :
break a ;
default :
invariant (
! 1 ,
"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue."
2018-06-16 00:38:41 -07:00
) ;
2018-09-10 14:42:08 -07:00
}
2018-05-15 13:08:47 -07:00
}
}
2018-06-16 00:38:41 -07:00
nextEffect = nextEffect . nextEffect ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
} catch ( e ) {
2018-07-24 14:45:35 -07:00
( childExpirationTimeBeforeCommit = ! 0 ) , ( error = e ) ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
childExpirationTimeBeforeCommit &&
2018-06-16 00:38:41 -07:00
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
captureCommitPhaseError ( nextEffect , error ) ,
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
for ( nextEffect = firstBatch ; null !== nextEffect ; ) {
2018-07-24 14:45:35 -07:00
current$$1 = ! 1 ;
2018-06-16 00:38:41 -07:00
prevProps = void 0 ;
try {
for ( ; null !== nextEffect ; ) {
var effectTag = nextEffect . effectTag ;
if ( effectTag & 128 ) {
2018-07-24 14:45:35 -07:00
var current$$1$jscomp$0 = nextEffect . alternate ;
if ( null !== current$$1$jscomp$0 ) {
var currentRef = current$$1$jscomp$0 . ref ;
2018-06-16 00:38:41 -07:00
null !== currentRef &&
( "function" === typeof currentRef
? currentRef ( null )
: ( currentRef . current = null ) ) ;
}
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
switch ( effectTag & 14 ) {
case 2 :
commitPlacement ( nextEffect ) ;
nextEffect . effectTag &= - 3 ;
break ;
case 6 :
commitPlacement ( nextEffect ) ;
nextEffect . effectTag &= - 3 ;
commitWork ( nextEffect . alternate , nextEffect ) ;
break ;
case 4 :
commitWork ( nextEffect . alternate , nextEffect ) ;
break ;
case 8 :
( prevState = nextEffect ) ,
unmountHostComponents ( prevState ) ,
( prevState . return = null ) ,
( prevState . child = null ) ,
prevState . alternate &&
( ( prevState . alternate . child = null ) ,
( prevState . alternate . return = null ) ) ;
}
nextEffect = nextEffect . nextEffect ;
}
} catch ( e ) {
2018-07-24 14:45:35 -07:00
( current$$1 = ! 0 ) , ( prevProps = e ) ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
current$$1 &&
2018-06-16 00:38:41 -07:00
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
captureCommitPhaseError ( nextEffect , prevProps ) ,
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
}
root . current = finishedWork$jscomp$0 ;
for ( nextEffect = firstBatch ; null !== nextEffect ; ) {
effectTag = ! 1 ;
2018-07-24 14:45:35 -07:00
current$$1$jscomp$0 = void 0 ;
2018-06-16 00:38:41 -07:00
try {
for ( currentRef = expirationTime ; null !== nextEffect ; ) {
var effectTag$jscomp$0 = nextEffect . effectTag ;
if ( effectTag$jscomp$0 & 36 ) {
2018-07-24 14:45:35 -07:00
var current$$1$jscomp$1 = nextEffect . alternate ;
current$$1 = nextEffect ;
2018-06-16 00:38:41 -07:00
prevProps = currentRef ;
2018-07-24 14:45:35 -07:00
switch ( current$$1 . tag ) {
2018-06-16 00:38:41 -07:00
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-07-24 14:45:35 -07:00
var instance$jscomp$0 = current$$1 . stateNode ;
if ( current$$1 . effectTag & 4 )
if ( null === current$$1$jscomp$1 )
( instance$jscomp$0 . props = current$$1 . memoizedProps ) ,
( instance$jscomp$0 . state = current$$1 . memoizedState ) ,
2018-06-16 00:38:41 -07:00
instance$jscomp$0 . componentDidMount ( ) ;
else {
2018-07-24 14:45:35 -07:00
var prevProps$jscomp$0 = current$$1$jscomp$1 . memoizedProps ,
prevState$jscomp$0 = current$$1$jscomp$1 . memoizedState ;
instance$jscomp$0 . props = current$$1 . memoizedProps ;
instance$jscomp$0 . state = current$$1 . memoizedState ;
2018-06-16 00:38:41 -07:00
instance$jscomp$0 . componentDidUpdate (
prevProps$jscomp$0 ,
prevState$jscomp$0 ,
instance$jscomp$0 . _ _reactInternalSnapshotBeforeUpdate
) ;
}
2018-07-24 14:45:35 -07:00
var updateQueue = current$$1 . updateQueue ;
2018-06-16 00:38:41 -07:00
null !== updateQueue &&
2018-07-24 14:45:35 -07:00
( ( instance$jscomp$0 . props = current$$1 . memoizedProps ) ,
( instance$jscomp$0 . state = current$$1 . memoizedState ) ,
2018-06-16 00:38:41 -07:00
commitUpdateQueue (
2018-07-24 14:45:35 -07:00
current$$1 ,
2018-06-16 00:38:41 -07:00
updateQueue ,
instance$jscomp$0 ,
prevProps
) ) ;
break ;
2018-09-10 14:42:08 -07:00
case 5 :
2018-07-24 14:45:35 -07:00
var _updateQueue = current$$1 . updateQueue ;
2018-06-16 00:38:41 -07:00
if ( null !== _updateQueue ) {
prevState = null ;
2018-07-24 14:45:35 -07:00
if ( null !== current$$1 . child )
switch ( current$$1 . child . tag ) {
2018-09-10 14:42:08 -07:00
case 7 :
2018-07-24 14:45:35 -07:00
prevState = current$$1 . child . stateNode ;
2018-06-16 00:38:41 -07:00
break ;
case 2 :
2018-09-10 14:42:08 -07:00
case 3 :
2018-07-24 14:45:35 -07:00
prevState = current$$1 . child . stateNode ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
commitUpdateQueue (
current$$1 ,
_updateQueue ,
prevState ,
prevProps
) ;
2018-06-16 00:38:41 -07:00
}
break ;
2018-09-10 14:42:08 -07:00
case 7 :
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 8 :
2018-06-16 00:38:41 -07:00
break ;
2018-09-10 14:42:08 -07:00
case 6 :
2018-06-16 00:38:41 -07:00
break ;
case 15 :
break ;
case 16 :
break ;
default :
invariant (
! 1 ,
"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue."
) ;
}
}
if ( effectTag$jscomp$0 & 128 ) {
var ref = nextEffect . ref ;
if ( null !== ref ) {
var instance$jscomp$1 = nextEffect . stateNode ;
switch ( nextEffect . tag ) {
2018-09-10 14:42:08 -07:00
case 7 :
var instanceToUse = instance$jscomp$1 ;
2018-06-16 00:38:41 -07:00
break ;
default :
2018-09-10 14:42:08 -07:00
instanceToUse = instance$jscomp$1 ;
2018-06-16 00:38:41 -07:00
}
2018-07-24 14:45:35 -07:00
"function" === typeof ref
2018-09-10 14:42:08 -07:00
? ref ( instanceToUse )
: ( ref . current = instanceToUse ) ;
2018-06-16 00:38:41 -07:00
}
}
var next = nextEffect . nextEffect ;
nextEffect . nextEffect = null ;
nextEffect = next ;
}
} catch ( e ) {
2018-07-24 14:45:35 -07:00
( effectTag = ! 0 ) , ( current$$1$jscomp$0 = e ) ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
effectTag &&
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
2018-07-24 14:45:35 -07:00
captureCommitPhaseError ( nextEffect , current$$1$jscomp$0 ) ,
2018-06-16 00:38:41 -07:00
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
}
isWorking = isCommitting$1 = ! 1 ;
2018-07-24 14:45:35 -07:00
"function" === typeof onCommitFiberRoot &&
onCommitFiberRoot ( finishedWork$jscomp$0 . stateNode ) ;
effectTag$jscomp$0 = finishedWork$jscomp$0 . expirationTime ;
finishedWork$jscomp$0 = finishedWork$jscomp$0 . childExpirationTime ;
finishedWork$jscomp$0 =
0 === effectTag$jscomp$0 ||
( 0 !== finishedWork$jscomp$0 && finishedWork$jscomp$0 < effectTag$jscomp$0 )
? finishedWork$jscomp$0
: effectTag$jscomp$0 ;
2018-06-16 00:38:41 -07:00
0 === finishedWork$jscomp$0 &&
( legacyErrorBoundariesThatAlreadyFailed = null ) ;
root . expirationTime = finishedWork$jscomp$0 ;
root . finishedWork = null ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
function shouldYield ( ) {
2018-07-24 14:45:35 -07:00
return deadlineDidExpire
? ! 0
: null === deadline || deadline . timeRemaining ( ) > timeHeuristicForUnitOfWork
? ! 1
: ( deadlineDidExpire = ! 0 ) ;
2018-05-15 13:08:47 -07:00
}
2018-06-16 00:38:41 -07:00
function onUncaughtError ( error ) {
invariant (
null !== nextFlushedRoot ,
"Should be working on a root. This error is likely caused by a bug in React. Please file an issue."
) ;
nextFlushedRoot . expirationTime = 0 ;
hasUnhandledError || ( ( hasUnhandledError = ! 0 ) , ( unhandledError = error ) ) ;
}
2018-09-10 14:42:08 -07:00
function getContextForSubtree ( parentComponent ) {
if ( ! parentComponent ) return emptyContextObject ;
parentComponent = parentComponent . _reactInternalFiber ;
a : {
invariant (
2 === isFiberMountedImpl ( parentComponent ) &&
( 2 === parentComponent . tag || 3 === parentComponent . tag ) ,
"Expected subtree parent to be a mounted class component. This error is likely caused by a bug in React. Please file an issue."
) ;
var parentContext = parentComponent ;
do {
switch ( parentContext . tag ) {
case 5 :
parentContext = parentContext . stateNode . context ;
break a ;
case 2 :
if ( isContextProvider ( parentContext . type ) ) {
parentContext =
parentContext . stateNode . _ _reactInternalMemoizedMergedChildContext ;
break a ;
}
break ;
case 3 :
if ( isContextProvider ( parentContext . type . _reactResult ) ) {
parentContext =
parentContext . stateNode . _ _reactInternalMemoizedMergedChildContext ;
break a ;
}
2018-06-16 00:38:41 -07:00
}
2018-09-10 14:42:08 -07:00
parentContext = parentContext . return ;
} while ( null !== parentContext ) ;
invariant (
! 1 ,
"Found unexpected detached subtree parent. This error is likely caused by a bug in React. Please file an issue."
) ;
parentContext = void 0 ;
}
if ( 2 === parentComponent . tag ) {
var Component = parentComponent . type ;
if ( isContextProvider ( Component ) )
return processChildContext ( parentComponent , Component , parentContext ) ;
} else if (
3 === parentComponent . tag &&
( ( Component = parentComponent . type . _reactResult ) ,
isContextProvider ( Component ) )
)
return processChildContext ( parentComponent , Component , parentContext ) ;
return parentContext ;
2017-11-15 09:05:34 -08:00
}
2018-06-16 00:38:41 -07:00
function findHostInstance$1 ( component ) {
var fiber = component . _reactInternalFiber ;
void 0 === fiber &&
( "function" === typeof component . render
? invariant ( ! 1 , "Unable to find node on an unmounted component." )
: invariant (
! 1 ,
"Argument appears to not be a ReactComponent. Keys: %s" ,
Object . keys ( component )
) ) ;
component = findCurrentHostFiber ( fiber ) ;
return null === component ? null : component . stateNode ;
2018-04-10 15:19:57 -07:00
}
2018-06-16 00:38:41 -07:00
function updateContainer ( element , container , parentComponent , callback ) {
2018-07-24 14:45:35 -07:00
var current$$1 = container . current ,
currentTime = requestCurrentTime ( ) ;
current$$1 = computeExpirationForFiber ( currentTime , current$$1 ) ;
2018-09-10 14:42:08 -07:00
currentTime = container . current ;
parentComponent = getContextForSubtree ( parentComponent ) ;
null === container . context
? ( container . context = parentComponent )
: ( container . pendingContext = parentComponent ) ;
container = callback ;
callback = createUpdate ( current$$1 ) ;
callback . payload = { element : element } ;
container = void 0 === container ? null : container ;
null !== container && ( callback . callback = container ) ;
enqueueUpdate ( currentTime , callback ) ;
scheduleWork ( currentTime , current$$1 ) ;
return current$$1 ;
2018-06-16 00:38:41 -07:00
}
function createPortal ( children , containerInfo , implementation ) {
var key =
3 < arguments . length && void 0 !== arguments [ 3 ] ? arguments [ 3 ] : null ;
return {
$$typeof : REACT _PORTAL _TYPE ,
key : null == key ? null : "" + key ,
children : children ,
containerInfo : containerInfo ,
implementation : implementation
} ;
}
2018-05-15 13:08:47 -07:00
function _inherits ( subClass , superClass ) {
if ( "function" !== typeof superClass && null !== superClass )
throw new TypeError (
"Super expression must either be null or a function, not " +
typeof superClass
) ;
subClass . prototype = Object . create ( superClass && superClass . prototype , {
constructor : {
value : subClass ,
enumerable : ! 1 ,
writable : ! 0 ,
configurable : ! 0
2018-01-29 14:17:07 -08:00
}
2018-05-15 13:08:47 -07:00
} ) ;
superClass &&
( Object . setPrototypeOf
? Object . setPrototypeOf ( subClass , superClass )
: ( subClass . _ _proto _ _ = superClass ) ) ;
}
var getInspectorDataForViewTag = void 0 ;
2018-01-29 14:17:07 -08:00
getInspectorDataForViewTag = function ( ) {
invariant ( ! 1 , "getInspectorDataForViewTag() is not available in production" ) ;
} ;
2018-04-10 15:19:57 -07:00
function findNodeHandle ( componentOrHandle ) {
if ( null == componentOrHandle ) return null ;
if ( "number" === typeof componentOrHandle ) return componentOrHandle ;
if ( componentOrHandle . _nativeTag ) return componentOrHandle . _nativeTag ;
if ( componentOrHandle . canonical && componentOrHandle . canonical . _nativeTag )
return componentOrHandle . canonical . _nativeTag ;
2018-06-16 00:38:41 -07:00
componentOrHandle = findHostInstance$1 ( componentOrHandle ) ;
2018-04-10 15:19:57 -07:00
return null == componentOrHandle
? componentOrHandle
: componentOrHandle . canonical
? componentOrHandle . canonical . _nativeTag
: componentOrHandle . _nativeTag ;
}
2018-09-10 14:42:08 -07:00
_batchedUpdatesImpl = function ( fn , a ) {
var previousIsBatchingUpdates = isBatchingUpdates ;
isBatchingUpdates = ! 0 ;
try {
return fn ( a ) ;
} finally {
( isBatchingUpdates = previousIsBatchingUpdates ) ||
isRendering ||
performWork ( 1 , null ) ;
}
} ;
_flushInteractiveUpdatesImpl = function ( ) {
isRendering ||
0 === lowestPriorityPendingInteractiveExpirationTime ||
( performWork ( lowestPriorityPendingInteractiveExpirationTime , null ) ,
( lowestPriorityPendingInteractiveExpirationTime = 0 ) ) ;
} ;
2018-01-29 14:17:07 -08:00
var roots = new Map ( ) ,
ReactNativeRenderer = {
2018-04-10 15:19:57 -07:00
NativeComponent : ( function ( findNodeHandle , findHostInstance ) {
return ( function ( _React$Component ) {
function ReactNativeComponent ( ) {
if ( ! ( this instanceof ReactNativeComponent ) )
throw new TypeError ( "Cannot call a class as a function" ) ;
var call = _React$Component . apply ( this , arguments ) ;
if ( ! this )
throw new ReferenceError (
"this hasn't been initialised - super() hasn't been called"
) ;
return ! call ||
( "object" !== typeof call && "function" !== typeof call )
? this
: call ;
}
_inherits ( ReactNativeComponent , _React$Component ) ;
ReactNativeComponent . prototype . blur = function ( ) {
TextInputState . blurTextInput ( findNodeHandle ( this ) ) ;
} ;
ReactNativeComponent . prototype . focus = function ( ) {
TextInputState . focusTextInput ( findNodeHandle ( this ) ) ;
} ;
ReactNativeComponent . prototype . measure = function ( callback ) {
UIManager . measure (
findNodeHandle ( this ) ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
2018-04-10 15:19:57 -07:00
) ;
} ;
ReactNativeComponent . prototype . measureInWindow = function ( callback ) {
UIManager . measureInWindow (
findNodeHandle ( this ) ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
2018-04-10 15:19:57 -07:00
) ;
} ;
ReactNativeComponent . prototype . measureLayout = function (
relativeToNativeNode ,
onSuccess ,
onFail
) {
UIManager . measureLayout (
findNodeHandle ( this ) ,
relativeToNativeNode ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , onFail ) ,
mountSafeCallback _NOT _REALLY _SAFE ( this , onSuccess )
2018-04-10 15:19:57 -07:00
) ;
} ;
ReactNativeComponent . prototype . setNativeProps = function ( nativeProps ) {
var maybeInstance = void 0 ;
try {
maybeInstance = findHostInstance ( this ) ;
} catch ( error ) { }
if ( null != maybeInstance ) {
var viewConfig =
maybeInstance . viewConfig || maybeInstance . canonical . viewConfig ;
nativeProps = diffProperties (
null ,
2018-07-24 14:45:35 -07:00
emptyObject ,
2018-04-10 15:19:57 -07:00
nativeProps ,
viewConfig . validAttributes
) ;
null != nativeProps &&
UIManager . updateView (
maybeInstance . _nativeTag ,
viewConfig . uiViewClassName ,
nativeProps
) ;
}
} ;
return ReactNativeComponent ;
} ) ( React . Component ) ;
2018-06-16 00:38:41 -07:00
} ) ( findNodeHandle , findHostInstance$1 ) ,
2018-04-10 15:19:57 -07:00
findNodeHandle : findNodeHandle ,
2018-01-29 14:17:07 -08:00
render : function ( element , containerTag , callback ) {
var root = roots . get ( containerTag ) ;
2018-09-10 14:42:08 -07:00
if ( ! root ) {
root = new FiberNode ( 5 , null , null , 0 ) ;
var root$jscomp$0 = {
current : root ,
containerInfo : containerTag ,
pendingChildren : null ,
earliestPendingTime : 0 ,
latestPendingTime : 0 ,
earliestSuspendedTime : 0 ,
latestSuspendedTime : 0 ,
latestPingedTime : 0 ,
didError : ! 1 ,
pendingCommitExpirationTime : 0 ,
finishedWork : null ,
timeoutHandle : - 1 ,
context : null ,
pendingContext : null ,
hydrate : ! 1 ,
nextExpirationTimeToWorkOn : 0 ,
expirationTime : 0 ,
firstBatch : null ,
nextScheduledRoot : null
} ;
root = root . stateNode = root$jscomp$0 ;
roots . set ( containerTag , root ) ;
}
2018-06-16 00:38:41 -07:00
updateContainer ( element , root , null , callback ) ;
2018-09-10 14:42:08 -07:00
a : if ( ( ( element = root . current ) , element . child ) )
switch ( element . child . tag ) {
case 7 :
element = element . child . stateNode ;
break a ;
default :
element = element . child . stateNode ;
}
else element = null ;
return element ;
2018-01-29 14:17:07 -08:00
} ,
unmountComponentAtNode : function ( containerTag ) {
var root = roots . get ( containerTag ) ;
root &&
2018-06-16 00:38:41 -07:00
updateContainer ( null , root , null , function ( ) {
2018-05-15 13:08:47 -07:00
roots . delete ( containerTag ) ;
2018-01-29 14:17:07 -08:00
} ) ;
} ,
unmountComponentAtNodeAndRemoveContainer : function ( containerTag ) {
ReactNativeRenderer . unmountComponentAtNode ( containerTag ) ;
UIManager . removeRootView ( containerTag ) ;
} ,
createPortal : function ( children , containerTag ) {
return createPortal (
children ,
containerTag ,
null ,
2 < arguments . length && void 0 !== arguments [ 2 ] ? arguments [ 2 ] : null
) ;
} ,
unstable _batchedUpdates : batchedUpdates ,
_ _SECRET _INTERNALS _DO _NOT _USE _OR _YOU _WILL _BE _FIRED : {
2018-04-10 15:19:57 -07:00
NativeMethodsMixin : ( function ( findNodeHandle , findHostInstance ) {
return {
measure : function ( callback ) {
UIManager . measure (
findNodeHandle ( this ) ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
2017-11-15 09:05:34 -08:00
) ;
2018-04-10 15:19:57 -07:00
} ,
measureInWindow : function ( callback ) {
UIManager . measureInWindow (
findNodeHandle ( this ) ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , callback )
2018-04-10 15:19:57 -07:00
) ;
} ,
measureLayout : function ( relativeToNativeNode , onSuccess , onFail ) {
UIManager . measureLayout (
findNodeHandle ( this ) ,
relativeToNativeNode ,
2018-09-10 14:42:08 -07:00
mountSafeCallback _NOT _REALLY _SAFE ( this , onFail ) ,
mountSafeCallback _NOT _REALLY _SAFE ( this , onSuccess )
2018-04-10 15:19:57 -07:00
) ;
} ,
setNativeProps : function ( nativeProps ) {
var maybeInstance = void 0 ;
try {
maybeInstance = findHostInstance ( this ) ;
} catch ( error ) { }
if ( null != maybeInstance ) {
var viewConfig = maybeInstance . viewConfig ;
nativeProps = diffProperties (
null ,
2018-07-24 14:45:35 -07:00
emptyObject ,
2018-04-10 15:19:57 -07:00
nativeProps ,
viewConfig . validAttributes
2018-01-29 14:17:07 -08:00
) ;
2018-04-10 15:19:57 -07:00
null != nativeProps &&
UIManager . updateView (
maybeInstance . _nativeTag ,
viewConfig . uiViewClassName ,
nativeProps
) ;
}
} ,
focus : function ( ) {
TextInputState . focusTextInput ( findNodeHandle ( this ) ) ;
} ,
blur : function ( ) {
TextInputState . blurTextInput ( findNodeHandle ( this ) ) ;
2018-01-29 14:17:07 -08:00
}
2018-04-10 15:19:57 -07:00
} ;
2018-06-16 00:38:41 -07:00
} ) ( findNodeHandle , findHostInstance$1 ) ,
2018-04-05 17:33:08 -07:00
computeComponentStackForErrorReporting : function ( reactTag ) {
return ( reactTag = getInstanceFromTag ( reactTag ) )
2018-07-24 14:45:35 -07:00
? getStackByFiberInDevAndProd ( reactTag )
2018-04-05 17:33:08 -07:00
: "" ;
2017-11-15 09:05:34 -08:00
}
}
2018-01-29 14:17:07 -08:00
} ;
2018-09-10 14:42:08 -07:00
( function ( devToolsConfig ) {
var findFiberByHostInstance = devToolsConfig . findFiberByHostInstance ;
return injectInternals (
Object . assign ( { } , devToolsConfig , {
findHostInstanceByFiber : function ( fiber ) {
fiber = findCurrentHostFiber ( fiber ) ;
return null === fiber ? null : fiber . stateNode ;
} ,
findFiberByHostInstance : function ( instance ) {
return findFiberByHostInstance
? findFiberByHostInstance ( instance )
: null ;
}
} )
) ;
} ) ( {
2017-11-15 09:05:34 -08:00
findFiberByHostInstance : getInstanceFromTag ,
getInspectorDataForViewTag : getInspectorDataForViewTag ,
bundleType : 0 ,
2018-09-10 14:42:08 -07:00
version : "16.5.0" ,
2017-11-15 09:05:34 -08:00
rendererPackageName : "react-native-renderer"
} ) ;
2018-06-16 00:38:41 -07:00
var ReactNativeRenderer$2 = { default : ReactNativeRenderer } ,
2017-11-15 09:05:34 -08:00
ReactNativeRenderer$3 =
( ReactNativeRenderer$2 && ReactNativeRenderer ) || ReactNativeRenderer$2 ;
2018-09-10 14:42:08 -07:00
module . exports = ReactNativeRenderer$3 . default || ReactNativeRenderer$3 ;