2018-01-30 08:47:02 -08:00
/ * *
* Copyright ( c ) 2013 - present , Facebook , Inc .
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree .
*
* @ noflow
* @ providesModule ReactFabric - prod
* @ preventMunge
* /
"use strict" ;
require ( "InitializeCore" ) ;
var invariant = require ( "fbjs/lib/invariant" ) ,
emptyFunction = require ( "fbjs/lib/emptyFunction" ) ,
UIManager = require ( "UIManager" ) ,
TextInputState = require ( "TextInputState" ) ,
deepDiffer = require ( "deepDiffer" ) ,
flattenStyle = require ( "flattenStyle" ) ,
2018-02-28 19:16:47 -08:00
React = require ( "react" ) ,
2018-01-30 08:47:02 -08:00
emptyObject = require ( "fbjs/lib/emptyObject" ) ,
shallowEqual = require ( "fbjs/lib/shallowEqual" ) ,
2018-02-28 19:16:47 -08:00
FabricUIManager = require ( "FabricUIManager" ) ,
eventPluginOrder = null ,
2018-01-30 08:47:02 -08:00
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 isEndish ( topLevelType ) {
return (
"topMouseUp" === topLevelType ||
"topTouchEnd" === topLevelType ||
"topTouchCancel" === topLevelType
) ;
}
function isMoveish ( topLevelType ) {
return "topMouseMove" === topLevelType || "topTouchMove" === topLevelType ;
}
function isStartish ( topLevelType ) {
return "topMouseDown" === topLevelType || "topTouchStart" === topLevelType ;
}
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 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 ) {
do inst = inst [ "return" ] ;
while ( inst && 5 !== inst . tag ) ;
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
) ) ) ;
}
}
}
var shouldBeReleasedProperties = "dispatchConfig _targetInst nativeEvent isDefaultPrevented isPropagationStopped _dispatchListeners _dispatchInstances" . split (
" "
) ,
EventInterface = {
type : null ,
target : null ,
currentTarget : emptyFunction . thatReturnsNull ,
eventPhase : null ,
bubbles : null ,
cancelable : null ,
timeStamp : function ( event ) {
return event . timeStamp || Date . now ( ) ;
} ,
defaultPrevented : null ,
isTrusted : null
} ;
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 )
? emptyFunction . thatReturnsTrue
: emptyFunction . thatReturnsFalse ;
this . isPropagationStopped = emptyFunction . thatReturnsFalse ;
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 ) ,
( this . isDefaultPrevented = emptyFunction . thatReturnsTrue ) ) ;
} ,
stopPropagation : function ( ) {
var event = this . nativeEvent ;
event &&
( event . stopPropagation
? event . stopPropagation ( )
: "unknown" !== typeof event . cancelBubble && ( event . cancelBubble = ! 0 ) ,
( this . isPropagationStopped = emptyFunction . thatReturnsTrue ) ) ;
} ,
persist : function ( ) {
this . isPersistent = emptyFunction . thatReturnsTrue ;
} ,
isPersistent : emptyFunction . thatReturnsFalse ,
destructor : function ( ) {
var Interface = this . constructor . Interface ,
propName ;
for ( propName in Interface ) this [ propName ] = null ;
for (
Interface = 0 ;
Interface < shouldBeReleasedProperties . length ;
Interface ++
)
this [ shouldBeReleasedProperties [ Interface ] ] = null ;
}
} ) ;
SyntheticEvent . Interface = EventInterface ;
SyntheticEvent . extend = function ( Interface ) {
function E ( ) { }
function Class ( ) {
return Super . apply ( this , arguments ) ;
}
var Super = this ;
E . prototype = Super . prototype ;
var prototype = new E ( ) ;
Object . assign ( prototype , Class . prototype ) ;
Class . prototype = prototype ;
Class . prototype . constructor = Class ;
Class . Interface = Object . assign ( { } , Super . Interface , Interface ) ;
Class . extend = Super . extend ;
addEventPoolingTo ( Class ) ;
return Class ;
} ;
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 ,
"Trying to release an event instance into a pool of a different type."
) ;
event . destructor ( ) ;
10 > this . eventPool . length && this . eventPool . push ( event ) ;
}
function addEventPoolingTo ( EventConstructor ) {
EventConstructor . eventPool = [ ] ;
EventConstructor . getPooled = getPooledEvent ;
EventConstructor . release = releasePooledEvent ;
}
var ResponderSyntheticEvent = SyntheticEvent . extend ( {
touchHistory : function ( ) {
return null ;
}
} ) ,
touchBank = [ ] ,
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 (
isEndish ( topLevelType ) &&
( 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 ;
}
} ,
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 )
: Array . isArray ( next ) ? [ current ] . concat ( next ) : [ current , next ] ;
}
var responderInst = null ,
trackedTouchCount = 0 ,
previousActiveTouches = 0 ;
function changeResponder ( nextResponderInst , blockHostResponder ) {
var oldResponderInst = responderInst ;
responderInst = nextResponderInst ;
if ( null !== ResponderEventPlugin . GlobalResponderHandler )
ResponderEventPlugin . GlobalResponderHandler . onChange (
oldResponderInst ,
nextResponderInst ,
blockHostResponder
) ;
}
var eventTypes = {
startShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onStartShouldSetResponder" ,
captured : "onStartShouldSetResponderCapture"
}
} ,
scrollShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onScrollShouldSetResponder" ,
captured : "onScrollShouldSetResponderCapture"
}
} ,
selectionChangeShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onSelectionChangeShouldSetResponder" ,
captured : "onSelectionChangeShouldSetResponderCapture"
}
} ,
moveShouldSetResponder : {
phasedRegistrationNames : {
bubbled : "onMoveShouldSetResponder" ,
captured : "onMoveShouldSetResponderCapture"
}
} ,
responderStart : { registrationName : "onResponderStart" } ,
responderMove : { registrationName : "onResponderMove" } ,
responderEnd : { registrationName : "onResponderEnd" } ,
responderRelease : { registrationName : "onResponderRelease" } ,
responderTerminationRequest : {
registrationName : "onResponderTerminationRequest"
} ,
responderGrant : { registrationName : "onResponderGrant" } ,
responderReject : { registrationName : "onResponderReject" } ,
responderTerminate : { registrationName : "onResponderTerminate" }
} ,
ResponderEventPlugin = {
_getResponder : function ( ) {
return responderInst ;
} ,
eventTypes : eventTypes ,
extractEvents : function (
topLevelType ,
targetInst ,
nativeEvent ,
nativeEventTarget
) {
if ( isStartish ( topLevelType ) ) trackedTouchCount += 1 ;
else if ( isEndish ( topLevelType ) )
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 ) )
) {
var JSCompiler _temp = isStartish ( topLevelType )
? eventTypes . startShouldSetResponder
: isMoveish ( topLevelType )
? eventTypes . moveShouldSetResponder
: "topSelectionChange" === topLevelType
? eventTypes . selectionChangeShouldSetResponder
: eventTypes . scrollShouldSetResponder ;
if ( responderInst )
b : {
var JSCompiler _temp$jscomp$0 = responderInst ;
for (
var depthA = 0 , tempA = JSCompiler _temp$jscomp$0 ;
tempA ;
tempA = getParent ( tempA )
)
depthA ++ ;
tempA = 0 ;
for ( var tempB = targetInst ; tempB ; tempB = getParent ( tempB ) )
tempA ++ ;
for ( ; 0 < depthA - tempA ; )
( JSCompiler _temp$jscomp$0 = getParent ( JSCompiler _temp$jscomp$0 ) ) ,
depthA -- ;
for ( ; 0 < tempA - depthA ; )
( targetInst = getParent ( targetInst ) ) , tempA -- ;
for ( ; depthA -- ; ) {
if (
JSCompiler _temp$jscomp$0 === targetInst ||
JSCompiler _temp$jscomp$0 === targetInst . alternate
)
break b ;
JSCompiler _temp$jscomp$0 = getParent ( JSCompiler _temp$jscomp$0 ) ;
targetInst = getParent ( targetInst ) ;
}
JSCompiler _temp$jscomp$0 = null ;
}
else JSCompiler _temp$jscomp$0 = targetInst ;
targetInst = JSCompiler _temp$jscomp$0 === responderInst ;
JSCompiler _temp$jscomp$0 = ResponderSyntheticEvent . getPooled (
JSCompiler _temp ,
JSCompiler _temp$jscomp$0 ,
nativeEvent ,
nativeEventTarget
) ;
JSCompiler _temp$jscomp$0 . touchHistory =
ResponderTouchHistoryStore . touchHistory ;
targetInst
? forEachAccumulated (
JSCompiler _temp$jscomp$0 ,
accumulateTwoPhaseDispatchesSingleSkipTarget
)
: forEachAccumulated (
JSCompiler _temp$jscomp$0 ,
accumulateTwoPhaseDispatchesSingle
) ;
b : {
JSCompiler _temp = JSCompiler _temp$jscomp$0 . _dispatchListeners ;
targetInst = JSCompiler _temp$jscomp$0 . _dispatchInstances ;
if ( Array . isArray ( JSCompiler _temp ) )
for (
depthA = 0 ;
depthA < JSCompiler _temp . length &&
! JSCompiler _temp$jscomp$0 . isPropagationStopped ( ) ;
depthA ++
) {
if (
JSCompiler _temp [ depthA ] (
JSCompiler _temp$jscomp$0 ,
targetInst [ depthA ]
)
) {
JSCompiler _temp = targetInst [ depthA ] ;
break b ;
}
}
else if (
JSCompiler _temp &&
JSCompiler _temp ( JSCompiler _temp$jscomp$0 , targetInst )
) {
JSCompiler _temp = targetInst ;
break b ;
}
JSCompiler _temp = null ;
}
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 (
eventTypes . responderGrant ,
JSCompiler _temp ,
nativeEvent ,
nativeEventTarget
) ) ,
( targetInst . touchHistory = ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( targetInst , accumulateDirectDispatchesSingle ) ,
( depthA = ! 0 === executeDirectDispatch ( targetInst ) ) ,
responderInst
? ( ( tempA = ResponderSyntheticEvent . getPooled (
eventTypes . responderTerminationRequest ,
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 (
eventTypes . responderTerminate ,
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 (
eventTypes . responderReject ,
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 (
JSCompiler _temp$jscomp$0 ,
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 ) ;
depthA = responderInst && isEndish ( topLevelType ) ;
if (
( JSCompiler _temp$jscomp$0 = JSCompiler _temp$jscomp$0
? eventTypes . responderStart
: targetInst
? eventTypes . responderMove
: depthA ? eventTypes . responderEnd : null )
)
( JSCompiler _temp$jscomp$0 = ResponderSyntheticEvent . getPooled (
JSCompiler _temp$jscomp$0 ,
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
( JSCompiler _temp$jscomp$0 . touchHistory =
ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated (
JSCompiler _temp$jscomp$0 ,
accumulateDirectDispatchesSingle
) ,
( JSCompiler _temp = accumulate (
JSCompiler _temp ,
JSCompiler _temp$jscomp$0
) ) ;
JSCompiler _temp$jscomp$0 =
responderInst && "topTouchCancel" === topLevelType ;
if (
( topLevelType =
responderInst && ! JSCompiler _temp$jscomp$0 && isEndish ( topLevelType ) )
)
a : {
if ( ( topLevelType = nativeEvent . touches ) && 0 !== topLevelType . length )
for ( targetInst = 0 ; targetInst < topLevelType . length ; targetInst ++ )
if (
( ( depthA = topLevelType [ targetInst ] . target ) ,
null !== depthA && void 0 !== depthA && 0 !== depthA )
) {
tempA = getInstanceFromNode ( depthA ) ;
b : {
for ( depthA = responderInst ; tempA ; ) {
if ( depthA === tempA || depthA === tempA . alternate ) {
depthA = ! 0 ;
break b ;
}
tempA = getParent ( tempA ) ;
}
depthA = ! 1 ;
}
if ( depthA ) {
topLevelType = ! 1 ;
break a ;
}
}
topLevelType = ! 0 ;
}
if (
( topLevelType = JSCompiler _temp$jscomp$0
? eventTypes . responderTerminate
: topLevelType ? eventTypes . responderRelease : null )
)
( nativeEvent = ResponderSyntheticEvent . getPooled (
topLevelType ,
responderInst ,
nativeEvent ,
nativeEventTarget
) ) ,
( nativeEvent . touchHistory = ResponderTouchHistoryStore . touchHistory ) ,
forEachAccumulated ( nativeEvent , accumulateDirectDispatchesSingle ) ,
( JSCompiler _temp = accumulate ( JSCompiler _temp , nativeEvent ) ) ,
changeResponder ( null ) ;
nativeEvent = ResponderTouchHistoryStore . touchHistory . numberActiveTouches ;
if (
ResponderEventPlugin . GlobalInteractionHandler &&
nativeEvent !== previousActiveTouches
)
ResponderEventPlugin . GlobalInteractionHandler . onChange ( nativeEvent ) ;
previousActiveTouches = nativeEvent ;
return JSCompiler _temp ;
} ,
GlobalResponderHandler : null ,
GlobalInteractionHandler : null ,
injection : {
injectGlobalResponderHandler : function ( GlobalResponderHandler ) {
ResponderEventPlugin . GlobalResponderHandler = GlobalResponderHandler ;
} ,
injectGlobalInteractionHandler : function ( GlobalInteractionHandler ) {
ResponderEventPlugin . GlobalInteractionHandler = GlobalInteractionHandler ;
}
}
} ,
customBubblingEventTypes = { } ,
customDirectEventTypes = { } ,
ReactNativeBridgeEventPlugin = {
eventTypes : { } ,
extractEvents : function (
topLevelType ,
targetInst ,
nativeEvent ,
nativeEventTarget
) {
2018-02-28 19:16:47 -08:00
if ( null == targetInst ) return null ;
2018-01-30 08:47:02 -08:00
var bubbleDispatchConfig = customBubblingEventTypes [ topLevelType ] ,
directDispatchConfig = customDirectEventTypes [ topLevelType ] ;
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 ;
} ,
processEventTypes : function ( viewConfig ) {
var bubblingEventTypes = viewConfig . bubblingEventTypes ;
viewConfig = viewConfig . directEventTypes ;
if ( null != bubblingEventTypes )
for ( var _topLevelType in bubblingEventTypes )
null == customBubblingEventTypes [ _topLevelType ] &&
( ReactNativeBridgeEventPlugin . eventTypes [
_topLevelType
] = customBubblingEventTypes [ _topLevelType ] =
bubblingEventTypes [ _topLevelType ] ) ;
if ( null != viewConfig )
for ( var _topLevelType2 in viewConfig )
null == customDirectEventTypes [ _topLevelType2 ] &&
( ReactNativeBridgeEventPlugin . eventTypes [
_topLevelType2
] = customDirectEventTypes [ _topLevelType2 ] =
viewConfig [ _topLevelType2 ] ) ;
}
} ,
instanceCache = { } ,
instanceProps = { } ;
function getInstanceFromTag ( tag ) {
return "number" === typeof tag ? instanceCache [ tag ] || null : tag ;
}
var ReactNativeComponentTree = Object . freeze ( {
2018-02-28 19:16:47 -08:00
precacheFiberNode : function ( hostInst , tag ) {
instanceCache [ tag ] = hostInst ;
2018-01-30 08:47:02 -08:00
} ,
2018-02-28 19:16:47 -08:00
uncacheFiberNode : function ( tag ) {
delete instanceCache [ tag ] ;
delete instanceProps [ tag ] ;
2018-01-30 08:47:02 -08:00
} ,
2018-02-28 19:16:47 -08:00
getClosestInstanceFromNode : getInstanceFromTag ,
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 ;
} ,
getFiberCurrentPropsFromNode : function ( stateNode ) {
return instanceProps [ stateNode . _nativeTag ] || null ;
} ,
updateFiberProps : function ( tag , props ) {
instanceProps [ tag ] = props ;
2018-01-30 08:47:02 -08:00
}
} ) ;
injection . injectEventPluginOrder ( [
"ResponderEventPlugin" ,
"ReactNativeBridgeEventPlugin"
] ) ;
getFiberCurrentPropsFromNode =
ReactNativeComponentTree . getFiberCurrentPropsFromNode ;
getInstanceFromNode = ReactNativeComponentTree . getInstanceFromNode ;
getNodeFromInstance = ReactNativeComponentTree . getNodeFromInstance ;
ResponderEventPlugin . injection . injectGlobalResponderHandler ( {
onChange : function ( from , to , blockNativeResponder ) {
null !== to
? UIManager . setJSResponder ( to . stateNode . _nativeTag , blockNativeResponder )
: UIManager . clearJSResponder ( ) ;
}
} ) ;
injection . injectEventPluginsByName ( {
ResponderEventPlugin : ResponderEventPlugin ,
ReactNativeBridgeEventPlugin : ReactNativeBridgeEventPlugin
} ) ;
var hasSymbol = "function" === typeof Symbol && Symbol [ "for" ] ,
REACT _ELEMENT _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.element" ) : 60103 ,
REACT _CALL _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.call" ) : 60104 ,
REACT _RETURN _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.return" ) : 60105 ,
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 ,
REACT _PROVIDER _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.provider" ) : 60109 ,
REACT _CONTEXT _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.context" ) : 60110 ,
2018-02-01 13:33:12 -08:00
REACT _ASYNC _MODE _TYPE = hasSymbol ? Symbol [ "for" ] ( "react.async_mode" ) : 60111 ,
2018-03-14 23:23:11 -07:00
REACT _FORWARD _REF _TYPE = hasSymbol
? Symbol [ "for" ] ( "react.forward_ref" )
: 60112 ,
2018-01-30 08:47:02 -08:00
MAYBE _ITERATOR _SYMBOL = "function" === typeof Symbol && Symbol . iterator ;
function getIteratorFn ( maybeIterable ) {
if ( null === maybeIterable || "undefined" === typeof maybeIterable )
return null ;
maybeIterable =
( MAYBE _ITERATOR _SYMBOL && maybeIterable [ MAYBE _ITERATOR _SYMBOL ] ) ||
maybeIterable [ "@@iterator" ] ;
return "function" === typeof maybeIterable ? maybeIterable : null ;
}
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-02-28 19:16:47 -08:00
var restoreTarget = null ,
restoreQueue = null ;
function restoreStateOfTarget ( target ) {
if ( ( target = getInstanceFromNode ( target ) ) ) {
invariant (
null ,
"Fiber needs to be injected to handle a fiber target for controlled events. This error is likely caused by a bug in React. Please file an issue."
) ;
var props = getFiberCurrentPropsFromNode ( target . stateNode ) ;
null . restoreControlledState ( target . stateNode , target . type , props ) ;
}
}
function _batchedUpdates ( fn , bookkeeping ) {
return fn ( bookkeeping ) ;
}
function _flushInteractiveUpdates ( ) { }
var isBatching = ! 1 ,
TouchHistoryMath = {
2018-01-30 08:47:02 -08:00
centroidDimension : function (
touchHistory ,
touchesChangedAfter ,
isXAxis ,
ofCurrent
) {
var touchBank = touchHistory . touchBank ,
total = 0 ,
count = 0 ;
touchHistory =
1 === touchHistory . numberActiveTouches
? touchHistory . touchBank [ touchHistory . indexOfSingleActiveTouch ]
: null ;
if ( null !== touchHistory )
touchHistory . touchActive &&
touchHistory . currentTimeStamp > touchesChangedAfter &&
( ( total +=
ofCurrent && isXAxis
? touchHistory . currentPageX
: ofCurrent && ! isXAxis
? touchHistory . currentPageY
: ! ofCurrent && isXAxis
? touchHistory . previousPageX
: touchHistory . previousPageY ) ,
( count = 1 ) ) ;
else
for (
touchHistory = 0 ;
touchHistory < touchBank . length ;
touchHistory ++
) {
var touchTrack = touchBank [ touchHistory ] ;
null !== touchTrack &&
void 0 !== touchTrack &&
touchTrack . touchActive &&
touchTrack . currentTimeStamp >= touchesChangedAfter &&
( ( total +=
ofCurrent && isXAxis
? touchTrack . currentPageX
: ofCurrent && ! isXAxis
? touchTrack . currentPageY
: ! ofCurrent && isXAxis
? touchTrack . previousPageX
: touchTrack . previousPageY ) ,
count ++ ) ;
}
return 0 < count ? total / count : TouchHistoryMath . noCentroid ;
} ,
currentCentroidXOfTouchesChangedAfter : function (
touchHistory ,
touchesChangedAfter
) {
return TouchHistoryMath . centroidDimension (
touchHistory ,
touchesChangedAfter ,
! 0 ,
! 0
) ;
} ,
currentCentroidYOfTouchesChangedAfter : function (
touchHistory ,
touchesChangedAfter
) {
return TouchHistoryMath . centroidDimension (
touchHistory ,
touchesChangedAfter ,
! 1 ,
! 0
) ;
} ,
previousCentroidXOfTouchesChangedAfter : function (
touchHistory ,
touchesChangedAfter
) {
return TouchHistoryMath . centroidDimension (
touchHistory ,
touchesChangedAfter ,
! 0 ,
! 1
) ;
} ,
previousCentroidYOfTouchesChangedAfter : function (
touchHistory ,
touchesChangedAfter
) {
return TouchHistoryMath . centroidDimension (
touchHistory ,
touchesChangedAfter ,
! 1 ,
! 1
) ;
} ,
currentCentroidX : function ( touchHistory ) {
return TouchHistoryMath . centroidDimension ( touchHistory , 0 , ! 0 , ! 0 ) ;
} ,
currentCentroidY : function ( touchHistory ) {
return TouchHistoryMath . centroidDimension ( touchHistory , 0 , ! 1 , ! 0 ) ;
} ,
noCentroid : - 1
} ,
objects = { } ,
uniqueID = 1 ,
emptyObject$2 = { } ,
ReactNativePropRegistry = ( function ( ) {
function ReactNativePropRegistry ( ) {
if ( ! ( this instanceof ReactNativePropRegistry ) )
throw new TypeError ( "Cannot call a class as a function" ) ;
}
ReactNativePropRegistry . register = function ( object ) {
var id = ++ uniqueID ;
objects [ id ] = object ;
return id ;
} ;
ReactNativePropRegistry . getByID = function ( id ) {
if ( ! id ) return emptyObject$2 ;
var object = objects [ id ] ;
return object
? object
: ( console . warn ( "Invalid style with id `" + id + "`. Skipping ..." ) ,
emptyObject$2 ) ;
} ;
return ReactNativePropRegistry ;
} ) ( ) ,
emptyObject$1 = { } ,
removedKeys = null ,
removedKeyCount = 0 ;
function resolveObject ( idOrObject ) {
return "number" === typeof idOrObject
? ReactNativePropRegistry . getByID ( idOrObject )
: idOrObject ;
}
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 ( ( node = resolveObject ( node ) ) , removedKeys ) )
if ( removedKeys [ i ] ) {
var _nextProp = node [ i ] ;
if ( void 0 !== _nextProp ) {
var attributeConfig = validAttributes [ i ] ;
if ( attributeConfig ) {
"function" === typeof _nextProp && ( _nextProp = ! 0 ) ;
"undefined" === typeof _nextProp && ( _nextProp = null ) ;
if ( "object" !== typeof attributeConfig )
updatePayload [ i ] = _nextProp ;
else if (
"function" === typeof attributeConfig . diff ||
"function" === typeof attributeConfig . process
)
( _nextProp =
"function" === typeof attributeConfig . process
? attributeConfig . process ( _nextProp )
: _nextProp ) ,
( updatePayload [ i ] = _nextProp ) ;
removedKeys [ i ] = ! 1 ;
removedKeyCount -- ;
}
}
}
}
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 ,
resolveObject ( prevProp ) ,
resolveObject ( 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 ) ,
resolveObject ( nextProp ) ,
validAttributes
)
: diffProperties (
updatePayload ,
resolveObject ( prevProp ) ,
flattenStyle ( nextProp ) ,
validAttributes
) ;
}
function addNestedProperty ( updatePayload , nextProp , validAttributes ) {
if ( ! nextProp ) return updatePayload ;
if ( ! Array . isArray ( nextProp ) )
return (
( nextProp = resolveObject ( nextProp ) ) ,
diffProperties ( updatePayload , emptyObject$1 , 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 (
( prevProp = resolveObject ( prevProp ) ) ,
diffProperties ( updatePayload , prevProp , emptyObject$1 , 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 ;
}
function mountSafeCallback ( context , callback ) {
return function ( ) {
if ( callback ) {
if ( "boolean" === typeof context . _ _isMounted ) {
if ( ! context . _ _isMounted ) return ;
} else if (
"function" === typeof context . isMounted &&
! context . isMounted ( )
)
return ;
return callback . apply ( context , arguments ) ;
}
} ;
}
2018-02-28 19:16:47 -08:00
var ReactCurrentOwner =
React . _ _SECRET _INTERNALS _DO _NOT _USE _OR _YOU _WILL _BE _FIRED . ReactCurrentOwner ;
2018-01-30 08:47:02 -08:00
function getComponentName ( fiber ) {
fiber = fiber . type ;
if ( "function" === typeof fiber ) return fiber . displayName || fiber . name ;
if ( "string" === typeof fiber ) return fiber ;
switch ( fiber ) {
case REACT _FRAGMENT _TYPE :
return "ReactFragment" ;
case REACT _PORTAL _TYPE :
return "ReactPortal" ;
case REACT _CALL _TYPE :
return "ReactCall" ;
case REACT _RETURN _TYPE :
return "ReactReturn" ;
}
return null ;
}
function findHostInstanceFabric ( ) {
return null ;
}
function findNodeHandle ( componentOrHandle ) {
if ( null == componentOrHandle ) return null ;
if ( "number" === typeof componentOrHandle ) return componentOrHandle ;
var internalInstance = componentOrHandle . _reactInternalFiber ;
if ( internalInstance ) return findHostInstanceFabric ( internalInstance ) ;
if ( componentOrHandle ) return componentOrHandle ;
invariant (
( "object" === typeof componentOrHandle &&
"_nativeTag" in componentOrHandle ) ||
( null != componentOrHandle . render &&
"function" === typeof componentOrHandle . render ) ,
"findNodeHandle(...): Argument is not a component (type: %s, keys: %s)" ,
typeof componentOrHandle ,
Object . keys ( componentOrHandle )
) ;
invariant (
! 1 ,
"findNodeHandle(...): Unable to find node handle for unmounted component."
) ;
}
function findNumericNodeHandleFiber ( componentOrHandle ) {
componentOrHandle = findNodeHandle ( componentOrHandle ) ;
return null == componentOrHandle || "number" === typeof componentOrHandle
? componentOrHandle
: componentOrHandle . _nativeTag ;
}
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
}
} ) ;
superClass &&
( Object . setPrototypeOf
? Object . setPrototypeOf ( subClass , superClass )
: ( subClass . _ _proto _ _ = superClass ) ) ;
}
var ReactNativeComponent = ( 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 ( findNumericNodeHandleFiber ( this ) ) ;
} ;
ReactNativeComponent . prototype . focus = function ( ) {
TextInputState . focusTextInput ( findNumericNodeHandleFiber ( this ) ) ;
} ;
ReactNativeComponent . prototype . measure = function ( callback ) {
UIManager . measure (
findNumericNodeHandleFiber ( this ) ,
mountSafeCallback ( this , callback )
) ;
} ;
ReactNativeComponent . prototype . measureInWindow = function ( callback ) {
UIManager . measureInWindow (
findNumericNodeHandleFiber ( this ) ,
mountSafeCallback ( this , callback )
) ;
} ;
ReactNativeComponent . prototype . measureLayout = function (
relativeToNativeNode ,
onSuccess ,
onFail
) {
UIManager . measureLayout (
findNumericNodeHandleFiber ( this ) ,
relativeToNativeNode ,
mountSafeCallback ( this , onFail ) ,
mountSafeCallback ( this , onSuccess )
) ;
} ;
ReactNativeComponent . prototype . setNativeProps = function ( nativeProps ) {
var maybeInstance = void 0 ;
try {
maybeInstance = findNodeHandle ( this ) ;
} catch ( error ) { }
if ( null != maybeInstance ) {
var viewConfig =
maybeInstance . viewConfig || maybeInstance . canonical . viewConfig ;
nativeProps = diffProperties (
null ,
emptyObject$1 ,
nativeProps ,
viewConfig . validAttributes
) ;
null != nativeProps &&
UIManager . updateView (
maybeInstance . _nativeTag ,
viewConfig . uiViewClassName ,
nativeProps
) ;
}
} ;
return ReactNativeComponent ;
} ) ( React . Component ) ,
now =
"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 ( ) ;
2018-04-04 15:11:21 -07:00
} ,
didTimeout : ! 1
2018-01-30 08:47:02 -08:00
} ;
function setTimeoutCallback ( ) {
frameDeadline = now ( ) + 5 ;
var callback = scheduledCallback ;
scheduledCallback = null ;
null !== callback && callback ( frameDeadlineObject ) ;
}
var viewConfigCallbacks = new Map ( ) ,
viewConfigs = new Map ( ) ;
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 ;
}
return 3 === node . tag ? 2 : 3 ;
}
function isMounted ( component ) {
return ( component = component . _reactInternalFiber )
? 2 === isFiberMountedImpl ( component )
: ! 1 ;
}
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 ;
}
_child = _child . sibling ;
}
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."
) ;
}
}
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."
) ;
}
invariant ( 3 === a . tag , "Unable to find node on an unmounted component." ) ;
return a . stateNode . current === a ? fiber : alternate ;
}
function findCurrentHostFiber ( parent ) {
parent = findCurrentFiberUsingSlowPath ( parent ) ;
if ( ! parent ) return null ;
for ( var node = parent ; ; ) {
if ( 5 === node . tag || 6 === node . tag ) return node ;
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 ;
}
function findCurrentHostFiberWithNoPortals ( parent ) {
parent = findCurrentFiberUsingSlowPath ( parent ) ;
if ( ! parent ) return null ;
for ( var node = parent ; ; ) {
if ( 5 === node . tag || 6 === node . tag ) return node ;
if ( node . child && 4 !== node . tag )
( 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 ;
}
2018-02-01 13:33:12 -08:00
function FiberNode ( tag , pendingProps , key , mode ) {
2018-01-30 08:47:02 -08:00
this . tag = tag ;
this . key = key ;
this . stateNode = this . type = null ;
this . sibling = this . child = this [ "return" ] = null ;
this . index = 0 ;
this . ref = null ;
this . pendingProps = pendingProps ;
this . memoizedState = this . updateQueue = this . memoizedProps = null ;
2018-02-01 13:33:12 -08:00
this . mode = mode ;
2018-01-30 08:47:02 -08:00
this . effectTag = 0 ;
this . lastEffect = this . firstEffect = this . nextEffect = null ;
this . expirationTime = 0 ;
this . alternate = null ;
}
function createWorkInProgress ( current , pendingProps , expirationTime ) {
var workInProgress = current . alternate ;
null === workInProgress
? ( ( workInProgress = new FiberNode (
current . tag ,
pendingProps ,
current . key ,
2018-02-01 13:33:12 -08:00
current . mode
2018-01-30 08:47:02 -08:00
) ) ,
( 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 ) ) ;
workInProgress . expirationTime = expirationTime ;
workInProgress . child = current . child ;
workInProgress . memoizedProps = current . memoizedProps ;
workInProgress . memoizedState = current . memoizedState ;
workInProgress . updateQueue = current . updateQueue ;
workInProgress . sibling = current . sibling ;
workInProgress . index = current . index ;
workInProgress . ref = current . ref ;
return workInProgress ;
}
2018-02-01 13:33:12 -08:00
function createFiberFromElement ( element , mode , expirationTime ) {
2018-01-30 08:47:02 -08:00
var type = element . type ,
key = element . key ;
element = element . props ;
var fiberTag = void 0 ;
if ( "function" === typeof type )
fiberTag = type . prototype && type . prototype . isReactComponent ? 2 : 0 ;
else if ( "string" === typeof type ) fiberTag = 5 ;
else
switch ( type ) {
case REACT _FRAGMENT _TYPE :
return createFiberFromFragment (
element . children ,
2018-02-01 13:33:12 -08:00
mode ,
2018-01-30 08:47:02 -08:00
expirationTime ,
key
) ;
2018-02-01 13:33:12 -08:00
case REACT _ASYNC _MODE _TYPE :
fiberTag = 11 ;
mode |= 3 ;
break ;
2018-01-30 08:47:02 -08:00
case REACT _STRICT _MODE _TYPE :
fiberTag = 11 ;
2018-02-01 13:33:12 -08:00
mode |= 2 ;
2018-01-30 08:47:02 -08:00
break ;
case REACT _CALL _TYPE :
fiberTag = 7 ;
break ;
case REACT _RETURN _TYPE :
fiberTag = 9 ;
break ;
default :
if ( "object" === typeof type && null !== type )
switch ( type . $$typeof ) {
case REACT _PROVIDER _TYPE :
fiberTag = 13 ;
break ;
case REACT _CONTEXT _TYPE :
fiberTag = 12 ;
break ;
2018-03-14 23:23:11 -07:00
case REACT _FORWARD _REF _TYPE :
fiberTag = 14 ;
break ;
2018-01-30 08:47:02 -08:00
default :
if ( "number" === typeof type . tag )
return (
2018-02-01 13:33:12 -08:00
( mode = type ) ,
( mode . pendingProps = element ) ,
( mode . expirationTime = expirationTime ) ,
mode
2018-01-30 08:47:02 -08:00
) ;
throwOnInvalidElementType ( type , null ) ;
}
else throwOnInvalidElementType ( type , null ) ;
}
2018-02-01 13:33:12 -08:00
mode = new FiberNode ( fiberTag , element , key , mode ) ;
mode . type = type ;
mode . expirationTime = expirationTime ;
return mode ;
2018-01-30 08:47:02 -08:00
}
function throwOnInvalidElementType ( type ) {
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-02-01 13:33:12 -08:00
function createFiberFromFragment ( elements , mode , expirationTime , key ) {
elements = new FiberNode ( 10 , elements , key , mode ) ;
2018-01-30 08:47:02 -08:00
elements . expirationTime = expirationTime ;
return elements ;
}
2018-02-01 13:33:12 -08:00
function createFiberFromText ( content , mode , expirationTime ) {
content = new FiberNode ( 6 , content , null , mode ) ;
2018-01-30 08:47:02 -08:00
content . expirationTime = expirationTime ;
return content ;
}
2018-02-01 13:33:12 -08:00
function createFiberFromPortal ( portal , mode , expirationTime ) {
mode = new FiberNode (
2018-01-30 08:47:02 -08:00
4 ,
null !== portal . children ? portal . children : [ ] ,
portal . key ,
2018-02-01 13:33:12 -08:00
mode
2018-01-30 08:47:02 -08:00
) ;
2018-02-01 13:33:12 -08:00
mode . expirationTime = expirationTime ;
mode . stateNode = {
2018-01-30 08:47:02 -08:00
containerInfo : portal . containerInfo ,
pendingChildren : null ,
implementation : portal . implementation
} ;
2018-02-01 13:33:12 -08:00
return mode ;
2018-01-30 08:47:02 -08: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 ;
}
function onCommitRoot ( root ) {
"function" === typeof onCommitFiberRoot && onCommitFiberRoot ( root ) ;
}
function onCommitUnmount ( fiber ) {
"function" === typeof onCommitFiberUnmount && onCommitFiberUnmount ( fiber ) ;
}
2018-03-20 17:03:06 -07:00
function getStackAddendumByWorkInProgressFiber ( workInProgress ) {
var info = "" ;
do {
a : switch ( workInProgress . tag ) {
case 0 :
case 1 :
case 2 :
case 5 :
var owner = workInProgress . _debugOwner ,
source = workInProgress . _debugSource ;
var JSCompiler _inline _result = getComponentName ( workInProgress ) ;
var ownerName = null ;
owner && ( ownerName = getComponentName ( owner ) ) ;
owner = source ;
JSCompiler _inline _result =
"\n in " +
( JSCompiler _inline _result || "Unknown" ) +
( owner
? " (at " +
owner . fileName . replace ( /^.*[\\\/]/ , "" ) +
":" +
owner . lineNumber +
")"
: ownerName ? " (created by " + ownerName + ")" : "" ) ;
break a ;
default :
JSCompiler _inline _result = "" ;
}
info += JSCompiler _inline _result ;
workInProgress = workInProgress [ "return" ] ;
} while ( workInProgress ) ;
return info ;
}
new Set ( ) ;
2018-01-30 08:47:02 -08:00
function createUpdateQueue ( baseState ) {
return {
baseState : baseState ,
expirationTime : 0 ,
first : null ,
last : null ,
callbackList : null ,
hasForceUpdate : ! 1 ,
2018-02-28 19:16:47 -08:00
isInitialized : ! 1 ,
capturedValues : null
2018-01-30 08:47:02 -08:00
} ;
}
function insertUpdateIntoQueue ( queue , update ) {
null === queue . last
? ( queue . first = queue . last = update )
: ( ( queue . last . next = update ) , ( queue . last = update ) ) ;
if (
0 === queue . expirationTime ||
queue . expirationTime > update . expirationTime
)
queue . expirationTime = update . expirationTime ;
}
2018-02-28 19:16:47 -08:00
var q1 = void 0 ,
q2 = void 0 ;
function ensureUpdateQueues ( fiber ) {
q1 = q2 = null ;
2018-01-30 08:47:02 -08:00
var alternateFiber = fiber . alternate ,
queue1 = fiber . updateQueue ;
null === queue1 && ( queue1 = fiber . updateQueue = createUpdateQueue ( null ) ) ;
null !== alternateFiber
? ( ( fiber = alternateFiber . updateQueue ) ,
null === fiber &&
( fiber = alternateFiber . updateQueue = createUpdateQueue ( null ) ) )
: ( fiber = null ) ;
2018-02-28 19:16:47 -08:00
q1 = queue1 ;
q2 = fiber !== queue1 ? fiber : null ;
}
function insertUpdateIntoFiber ( fiber , update ) {
ensureUpdateQueues ( fiber ) ;
fiber = q1 ;
var queue2 = q2 ;
null === queue2
? insertUpdateIntoQueue ( fiber , update )
: null === fiber . last || null === queue2 . last
? ( insertUpdateIntoQueue ( fiber , update ) ,
insertUpdateIntoQueue ( queue2 , update ) )
: ( insertUpdateIntoQueue ( fiber , update ) , ( queue2 . last = update ) ) ;
2018-01-30 08:47:02 -08:00
}
function getStateFromUpdate ( update , instance , prevState , props ) {
update = update . partialState ;
return "function" === typeof update
? update . call ( instance , prevState , props )
: update ;
}
function processUpdateQueue (
current ,
workInProgress ,
queue ,
instance ,
props ,
renderExpirationTime
) {
null !== current &&
current . updateQueue === queue &&
( queue = workInProgress . updateQueue = {
baseState : queue . baseState ,
expirationTime : queue . expirationTime ,
first : queue . first ,
last : queue . last ,
isInitialized : queue . isInitialized ,
2018-02-28 19:16:47 -08:00
capturedValues : queue . capturedValues ,
2018-01-30 08:47:02 -08:00
callbackList : null ,
hasForceUpdate : ! 1
} ) ;
queue . expirationTime = 0 ;
queue . isInitialized
? ( current = queue . baseState )
: ( ( current = queue . baseState = workInProgress . memoizedState ) ,
( queue . isInitialized = ! 0 ) ) ;
for (
var dontMutatePrevState = ! 0 , update = queue . first , didSkip = ! 1 ;
null !== update ;
) {
var updateExpirationTime = update . expirationTime ;
if ( updateExpirationTime > renderExpirationTime ) {
var remainingExpirationTime = queue . expirationTime ;
if (
0 === remainingExpirationTime ||
remainingExpirationTime > updateExpirationTime
)
queue . expirationTime = updateExpirationTime ;
didSkip || ( ( didSkip = ! 0 ) , ( queue . baseState = current ) ) ;
} else {
didSkip ||
( ( queue . first = update . next ) ,
null === queue . first && ( queue . last = null ) ) ;
if ( update . isReplace )
( current = getStateFromUpdate ( update , instance , current , props ) ) ,
( dontMutatePrevState = ! 0 ) ;
else if (
( updateExpirationTime = getStateFromUpdate (
update ,
instance ,
current ,
props
) )
)
( current = dontMutatePrevState
? Object . assign ( { } , current , updateExpirationTime )
: Object . assign ( current , updateExpirationTime ) ) ,
( dontMutatePrevState = ! 1 ) ;
update . isForced && ( queue . hasForceUpdate = ! 0 ) ;
null !== update . callback &&
( ( updateExpirationTime = queue . callbackList ) ,
null === updateExpirationTime &&
( updateExpirationTime = queue . callbackList = [ ] ) ,
updateExpirationTime . push ( update ) ) ;
2018-02-28 19:16:47 -08:00
null !== update . capturedValue &&
( ( updateExpirationTime = queue . capturedValues ) ,
null === updateExpirationTime
? ( queue . capturedValues = [ update . capturedValue ] )
: updateExpirationTime . push ( update . capturedValue ) ) ;
2018-01-30 08:47:02 -08:00
}
update = update . next ;
}
null !== queue . callbackList
? ( workInProgress . effectTag |= 32 )
: null !== queue . first ||
queue . hasForceUpdate ||
2018-02-28 19:16:47 -08:00
null !== queue . capturedValues ||
2018-01-30 08:47:02 -08:00
( workInProgress . updateQueue = null ) ;
didSkip || ( queue . baseState = current ) ;
return current ;
}
function commitCallbacks ( queue , context ) {
var callbackList = queue . callbackList ;
if ( null !== callbackList )
for (
queue . callbackList = null , queue = 0 ;
queue < callbackList . length ;
queue ++
) {
var update = callbackList [ queue ] ,
_callback = update . callback ;
update . callback = null ;
invariant (
"function" === typeof _callback ,
"Invalid argument passed as callback. Expected a function. Instead received: %s" ,
_callback
) ;
_callback . call ( context ) ;
}
}
function ReactFiberClassComponent (
2018-03-20 17:03:06 -07:00
legacyContext ,
2018-01-30 08:47:02 -08:00
scheduleWork ,
computeExpirationForFiber ,
memoizeProps ,
memoizeState
) {
2018-02-28 19:16:47 -08:00
function checkShouldComponentUpdate (
workInProgress ,
oldProps ,
newProps ,
oldState ,
newState ,
newContext
) {
if (
null === oldProps ||
( null !== workInProgress . updateQueue &&
workInProgress . updateQueue . hasForceUpdate )
)
return ! 0 ;
var instance = workInProgress . stateNode ;
workInProgress = workInProgress . type ;
return "function" === typeof instance . shouldComponentUpdate
? instance . shouldComponentUpdate ( newProps , newState , newContext )
: workInProgress . prototype &&
workInProgress . prototype . isPureReactComponent
? ! shallowEqual ( oldProps , newProps ) || ! shallowEqual ( oldState , newState )
: ! 0 ;
}
2018-01-30 08:47:02 -08:00
function adoptClassInstance ( workInProgress , instance ) {
instance . updater = updater ;
workInProgress . stateNode = instance ;
instance . _reactInternalFiber = workInProgress ;
}
2018-02-28 19:16:47 -08:00
function callComponentWillReceiveProps (
workInProgress ,
instance ,
newProps ,
newContext
) {
workInProgress = instance . state ;
"function" === typeof instance . componentWillReceiveProps &&
instance . componentWillReceiveProps ( newProps , newContext ) ;
"function" === typeof instance . UNSAFE _componentWillReceiveProps &&
instance . UNSAFE _componentWillReceiveProps ( newProps , newContext ) ;
instance . state !== workInProgress &&
updater . enqueueReplaceState ( instance , instance . state , null ) ;
}
2018-04-04 15:11:21 -07:00
function callGetDerivedStateFromProps (
workInProgress ,
instance ,
nextProps ,
prevState
) {
workInProgress = workInProgress . type ;
if ( "function" === typeof workInProgress . getDerivedStateFromProps )
return workInProgress . getDerivedStateFromProps . call (
2018-01-30 08:47:02 -08:00
null ,
2018-04-04 15:11:21 -07:00
nextProps ,
prevState
2018-01-30 08:47:02 -08:00
) ;
}
2018-03-20 17:03:06 -07:00
var cacheContext = legacyContext . cacheContext ,
getMaskedContext = legacyContext . getMaskedContext ,
getUnmaskedContext = legacyContext . getUnmaskedContext ,
isContextConsumer = legacyContext . isContextConsumer ,
hasContextChanged = legacyContext . hasContextChanged ,
updater = {
isMounted : isMounted ,
enqueueSetState : function ( instance , partialState , callback ) {
instance = instance . _reactInternalFiber ;
callback = void 0 === callback ? null : callback ;
var expirationTime = computeExpirationForFiber ( instance ) ;
insertUpdateIntoFiber ( instance , {
expirationTime : expirationTime ,
partialState : partialState ,
callback : callback ,
isReplace : ! 1 ,
isForced : ! 1 ,
capturedValue : null ,
next : null
} ) ;
scheduleWork ( instance , expirationTime ) ;
} ,
enqueueReplaceState : function ( instance , state , callback ) {
instance = instance . _reactInternalFiber ;
callback = void 0 === callback ? null : callback ;
var expirationTime = computeExpirationForFiber ( instance ) ;
insertUpdateIntoFiber ( instance , {
expirationTime : expirationTime ,
partialState : state ,
callback : callback ,
isReplace : ! 0 ,
isForced : ! 1 ,
capturedValue : null ,
next : null
} ) ;
scheduleWork ( instance , expirationTime ) ;
} ,
enqueueForceUpdate : function ( instance , callback ) {
instance = instance . _reactInternalFiber ;
callback = void 0 === callback ? null : callback ;
var expirationTime = computeExpirationForFiber ( instance ) ;
insertUpdateIntoFiber ( instance , {
expirationTime : expirationTime ,
partialState : null ,
callback : callback ,
isReplace : ! 1 ,
isForced : ! 0 ,
capturedValue : null ,
next : null
} ) ;
scheduleWork ( instance , expirationTime ) ;
}
} ;
2018-01-30 08:47:02 -08:00
return {
adoptClassInstance : adoptClassInstance ,
callGetDerivedStateFromProps : callGetDerivedStateFromProps ,
constructClassInstance : function ( workInProgress , props ) {
var ctor = workInProgress . type ,
unmaskedContext = getUnmaskedContext ( workInProgress ) ,
2018-03-20 17:03:06 -07:00
needsContext = isContextConsumer ( workInProgress ) ,
2018-01-30 08:47:02 -08:00
context = needsContext
? getMaskedContext ( workInProgress , unmaskedContext )
: emptyObject ;
ctor = new ctor ( props , context ) ;
var state =
null !== ctor . state && void 0 !== ctor . state ? ctor . state : null ;
adoptClassInstance ( workInProgress , ctor ) ;
workInProgress . memoizedState = state ;
2018-04-04 15:11:21 -07:00
props = callGetDerivedStateFromProps ( workInProgress , ctor , props , state ) ;
2018-01-30 08:47:02 -08:00
null !== props &&
void 0 !== props &&
( workInProgress . memoizedState = Object . assign (
{ } ,
workInProgress . memoizedState ,
props
) ) ;
2018-03-20 17:03:06 -07:00
needsContext && cacheContext ( workInProgress , unmaskedContext , context ) ;
2018-01-30 08:47:02 -08:00
return ctor ;
} ,
mountClassInstance : function ( workInProgress , renderExpirationTime ) {
2018-02-28 19:16:47 -08:00
var ctor = workInProgress . type ,
current = workInProgress . alternate ,
2018-01-30 08:47:02 -08:00
instance = workInProgress . stateNode ,
props = workInProgress . pendingProps ,
unmaskedContext = getUnmaskedContext ( workInProgress ) ;
instance . props = props ;
instance . state = workInProgress . memoizedState ;
instance . refs = emptyObject ;
instance . context = getMaskedContext ( workInProgress , unmaskedContext ) ;
2018-04-04 15:11:21 -07:00
"function" === typeof ctor . getDerivedStateFromProps ||
"function" === typeof instance . getSnapshotBeforeUpdate ||
( "function" !== typeof instance . UNSAFE _componentWillMount &&
"function" !== typeof instance . componentWillMount ) ||
2018-02-28 19:16:47 -08:00
( ( ctor = instance . state ) ,
2018-02-01 13:33:12 -08:00
"function" === typeof instance . componentWillMount &&
instance . componentWillMount ( ) ,
"function" === typeof instance . UNSAFE _componentWillMount &&
instance . UNSAFE _componentWillMount ( ) ,
2018-02-28 19:16:47 -08:00
ctor !== instance . state &&
2018-01-30 08:47:02 -08:00
updater . enqueueReplaceState ( instance , instance . state , null ) ,
2018-02-28 19:16:47 -08:00
( ctor = workInProgress . updateQueue ) ,
null !== ctor &&
2018-01-30 08:47:02 -08:00
( instance . state = processUpdateQueue (
current ,
workInProgress ,
2018-02-28 19:16:47 -08:00
ctor ,
2018-01-30 08:47:02 -08:00
instance ,
props ,
renderExpirationTime
) ) ) ;
"function" === typeof instance . componentDidMount &&
( workInProgress . effectTag |= 4 ) ;
} ,
2018-02-28 19:16:47 -08:00
resumeMountClassInstance : function ( workInProgress , renderExpirationTime ) {
var ctor = workInProgress . type ,
instance = workInProgress . stateNode ;
instance . props = workInProgress . memoizedProps ;
instance . state = workInProgress . memoizedState ;
var oldProps = workInProgress . memoizedProps ,
newProps = workInProgress . pendingProps ,
oldContext = instance . context ,
newUnmaskedContext = getUnmaskedContext ( workInProgress ) ;
newUnmaskedContext = getMaskedContext ( workInProgress , newUnmaskedContext ) ;
2018-04-04 15:11:21 -07:00
( ctor =
2018-02-28 19:16:47 -08:00
"function" === typeof ctor . getDerivedStateFromProps ||
2018-04-04 15:11:21 -07:00
"function" === typeof instance . getSnapshotBeforeUpdate ) ||
( "function" !== typeof instance . UNSAFE _componentWillReceiveProps &&
"function" !== typeof instance . componentWillReceiveProps ) ||
2018-02-28 19:16:47 -08:00
( ( oldProps !== newProps || oldContext !== newUnmaskedContext ) &&
callComponentWillReceiveProps (
workInProgress ,
instance ,
newProps ,
newUnmaskedContext
) ) ;
2018-04-04 15:11:21 -07:00
oldContext = workInProgress . memoizedState ;
2018-02-28 19:16:47 -08:00
renderExpirationTime =
null !== workInProgress . updateQueue
? processUpdateQueue (
null ,
workInProgress ,
workInProgress . updateQueue ,
instance ,
newProps ,
renderExpirationTime
)
2018-04-04 15:11:21 -07:00
: oldContext ;
var derivedStateFromProps = void 0 ;
oldProps !== newProps &&
( derivedStateFromProps = callGetDerivedStateFromProps (
workInProgress ,
instance ,
newProps ,
renderExpirationTime
) ) ;
if ( null !== derivedStateFromProps && void 0 !== derivedStateFromProps ) {
renderExpirationTime =
2018-02-28 19:16:47 -08:00
null === renderExpirationTime || void 0 === renderExpirationTime
2018-04-04 15:11:21 -07:00
? derivedStateFromProps
: Object . assign ( { } , renderExpirationTime , derivedStateFromProps ) ;
var _updateQueue = workInProgress . updateQueue ;
null !== _updateQueue &&
( _updateQueue . baseState = Object . assign (
{ } ,
_updateQueue . baseState ,
derivedStateFromProps
) ) ;
}
2018-02-28 19:16:47 -08:00
if (
! (
oldProps !== newProps ||
2018-04-04 15:11:21 -07:00
oldContext !== renderExpirationTime ||
2018-03-20 17:03:06 -07:00
hasContextChanged ( ) ||
2018-02-28 19:16:47 -08:00
( null !== workInProgress . updateQueue &&
workInProgress . updateQueue . hasForceUpdate )
)
)
return (
"function" === typeof instance . componentDidMount &&
( workInProgress . effectTag |= 4 ) ,
! 1
) ;
( oldProps = checkShouldComponentUpdate (
workInProgress ,
oldProps ,
newProps ,
2018-04-04 15:11:21 -07:00
oldContext ,
2018-02-28 19:16:47 -08:00
renderExpirationTime ,
newUnmaskedContext
) )
2018-04-04 15:11:21 -07:00
? ( ctor ||
( "function" !== typeof instance . UNSAFE _componentWillMount &&
"function" !== typeof instance . componentWillMount ) ||
2018-03-14 23:23:11 -07:00
( "function" === typeof instance . componentWillMount &&
instance . componentWillMount ( ) ,
"function" === typeof instance . UNSAFE _componentWillMount &&
instance . UNSAFE _componentWillMount ( ) ) ,
"function" === typeof instance . componentDidMount &&
2018-02-28 19:16:47 -08:00
( workInProgress . effectTag |= 4 ) )
: ( "function" === typeof instance . componentDidMount &&
( workInProgress . effectTag |= 4 ) ,
memoizeProps ( workInProgress , newProps ) ,
memoizeState ( workInProgress , renderExpirationTime ) ) ;
instance . props = newProps ;
instance . state = renderExpirationTime ;
instance . context = newUnmaskedContext ;
return oldProps ;
} ,
2018-01-30 08:47:02 -08:00
updateClassInstance : function (
current ,
workInProgress ,
renderExpirationTime
) {
2018-02-28 19:16:47 -08:00
var ctor = workInProgress . type ,
instance = workInProgress . stateNode ;
2018-01-30 08:47:02 -08:00
instance . props = workInProgress . memoizedProps ;
instance . state = workInProgress . memoizedState ;
var oldProps = workInProgress . memoizedProps ,
newProps = workInProgress . pendingProps ,
oldContext = instance . context ,
newUnmaskedContext = getUnmaskedContext ( workInProgress ) ;
newUnmaskedContext = getMaskedContext ( workInProgress , newUnmaskedContext ) ;
2018-04-04 15:11:21 -07:00
( ctor =
2018-02-28 19:16:47 -08:00
"function" === typeof ctor . getDerivedStateFromProps ||
2018-04-04 15:11:21 -07:00
"function" === typeof instance . getSnapshotBeforeUpdate ) ||
( "function" !== typeof instance . UNSAFE _componentWillReceiveProps &&
"function" !== typeof instance . componentWillReceiveProps ) ||
2018-02-28 19:16:47 -08:00
( ( oldProps !== newProps || oldContext !== newUnmaskedContext ) &&
callComponentWillReceiveProps (
workInProgress ,
instance ,
2018-02-01 13:33:12 -08:00
newProps ,
newUnmaskedContext
2018-02-28 19:16:47 -08:00
) ) ;
2018-01-30 08:47:02 -08:00
oldContext = workInProgress . memoizedState ;
renderExpirationTime =
null !== workInProgress . updateQueue
? processUpdateQueue (
current ,
workInProgress ,
workInProgress . updateQueue ,
instance ,
newProps ,
renderExpirationTime
)
: oldContext ;
2018-04-04 15:11:21 -07:00
var derivedStateFromProps = void 0 ;
oldProps !== newProps &&
( derivedStateFromProps = callGetDerivedStateFromProps (
workInProgress ,
instance ,
newProps ,
renderExpirationTime
) ) ;
if ( null !== derivedStateFromProps && void 0 !== derivedStateFromProps ) {
renderExpirationTime =
2018-01-30 08:47:02 -08:00
null === renderExpirationTime || void 0 === renderExpirationTime
2018-02-28 19:16:47 -08:00
? derivedStateFromProps
2018-04-04 15:11:21 -07:00
: Object . assign ( { } , renderExpirationTime , derivedStateFromProps ) ;
var _updateQueue3 = workInProgress . updateQueue ;
null !== _updateQueue3 &&
( _updateQueue3 . baseState = Object . assign (
{ } ,
_updateQueue3 . baseState ,
derivedStateFromProps
) ) ;
}
2018-01-30 08:47:02 -08:00
if (
! (
oldProps !== newProps ||
oldContext !== renderExpirationTime ||
2018-03-20 17:03:06 -07:00
hasContextChanged ( ) ||
2018-01-30 08:47:02 -08:00
( null !== workInProgress . updateQueue &&
workInProgress . updateQueue . hasForceUpdate )
)
)
return (
"function" !== typeof instance . componentDidUpdate ||
( oldProps === current . memoizedProps &&
oldContext === current . memoizedState ) ||
( workInProgress . effectTag |= 4 ) ,
2018-04-04 15:11:21 -07:00
"function" !== typeof instance . getSnapshotBeforeUpdate ||
( oldProps === current . memoizedProps &&
oldContext === current . memoizedState ) ||
( workInProgress . effectTag |= 2048 ) ,
2018-01-30 08:47:02 -08:00
! 1
) ;
2018-02-28 19:16:47 -08:00
( derivedStateFromProps = checkShouldComponentUpdate (
workInProgress ,
oldProps ,
newProps ,
oldContext ,
renderExpirationTime ,
newUnmaskedContext
) )
2018-04-04 15:11:21 -07:00
? ( ctor ||
( "function" !== typeof instance . UNSAFE _componentWillUpdate &&
"function" !== typeof instance . componentWillUpdate ) ||
2018-02-01 13:33:12 -08:00
( "function" === typeof instance . componentWillUpdate &&
instance . componentWillUpdate (
newProps ,
renderExpirationTime ,
newUnmaskedContext
) ,
"function" === typeof instance . UNSAFE _componentWillUpdate &&
instance . UNSAFE _componentWillUpdate (
newProps ,
renderExpirationTime ,
newUnmaskedContext
) ) ,
2018-01-30 08:47:02 -08:00
"function" === typeof instance . componentDidUpdate &&
2018-04-04 15:11:21 -07:00
( workInProgress . effectTag |= 4 ) ,
"function" === typeof instance . getSnapshotBeforeUpdate &&
( workInProgress . effectTag |= 2048 ) )
2018-01-30 08:47:02 -08:00
: ( "function" !== typeof instance . componentDidUpdate ||
( oldProps === current . memoizedProps &&
oldContext === current . memoizedState ) ||
( workInProgress . effectTag |= 4 ) ,
2018-04-04 15:11:21 -07:00
"function" !== typeof instance . getSnapshotBeforeUpdate ||
( oldProps === current . memoizedProps &&
oldContext === current . memoizedState ) ||
( workInProgress . effectTag |= 2048 ) ,
2018-01-30 08:47:02 -08:00
memoizeProps ( workInProgress , newProps ) ,
memoizeState ( workInProgress , renderExpirationTime ) ) ;
instance . props = newProps ;
instance . state = renderExpirationTime ;
instance . context = newUnmaskedContext ;
2018-02-28 19:16:47 -08:00
return derivedStateFromProps ;
2018-01-30 08:47:02 -08:00
}
} ;
}
var isArray$1 = Array . isArray ;
2018-02-09 16:01:29 -08:00
function coerceRef ( returnFiber , current , element ) {
returnFiber = element . ref ;
if (
null !== returnFiber &&
"function" !== typeof returnFiber &&
"object" !== typeof returnFiber
) {
2018-01-30 08:47:02 -08:00
if ( element . _owner ) {
element = element . _owner ;
var inst = void 0 ;
element &&
( invariant (
2 === element . tag ,
"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
2018-01-30 08:47:02 -08:00
) ;
2018-02-09 16:01:29 -08:00
var stringRef = "" + returnFiber ;
2018-01-30 08:47:02 -08:00
if (
null !== current &&
null !== current . ref &&
current . ref . _stringRef === stringRef
)
return current . ref ;
current = function ( value ) {
var refs = inst . refs === emptyObject ? ( inst . refs = { } ) : inst . refs ;
null === value ? delete refs [ stringRef ] : ( refs [ stringRef ] = value ) ;
} ;
current . _stringRef = stringRef ;
return current ;
}
invariant (
2018-02-09 16:01:29 -08:00
"string" === typeof returnFiber ,
2018-01-30 08:47:02 -08:00
"Expected ref to be a function or a string."
) ;
invariant (
element . _owner ,
"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
2018-01-30 08:47:02 -08:00
) ;
}
2018-02-09 16:01:29 -08:00
return returnFiber ;
2018-01-30 08:47:02 -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 ,
""
) ;
}
function ChildReconciler ( shouldTrackSideEffects ) {
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 ) {
fiber = createWorkInProgress ( fiber , pendingProps , expirationTime ) ;
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 ;
}
function updateTextNode ( returnFiber , current , textContent , expirationTime ) {
if ( null === current || 6 !== current . tag )
return (
( current = createFiberFromText (
textContent ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
( current [ "return" ] = returnFiber ) ,
current
) ;
current = useFiber ( current , textContent , expirationTime ) ;
current [ "return" ] = returnFiber ;
return current ;
}
function updateElement ( returnFiber , current , element , expirationTime ) {
if ( null !== current && current . type === element . type )
return (
( expirationTime = useFiber ( current , element . props , expirationTime ) ) ,
2018-02-09 16:01:29 -08:00
( expirationTime . ref = coerceRef ( returnFiber , current , element ) ) ,
2018-01-30 08:47:02 -08:00
( expirationTime [ "return" ] = returnFiber ) ,
expirationTime
) ;
expirationTime = createFiberFromElement (
element ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ;
2018-02-09 16:01:29 -08:00
expirationTime . ref = coerceRef ( returnFiber , current , element ) ;
2018-01-30 08:47:02 -08:00
expirationTime [ "return" ] = returnFiber ;
return expirationTime ;
}
function updatePortal ( returnFiber , current , portal , expirationTime ) {
if (
null === current ||
4 !== current . tag ||
current . stateNode . containerInfo !== portal . containerInfo ||
current . stateNode . implementation !== portal . implementation
)
return (
( current = createFiberFromPortal (
portal ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
( current [ "return" ] = returnFiber ) ,
current
) ;
current = useFiber ( current , portal . children || [ ] , expirationTime ) ;
current [ "return" ] = returnFiber ;
return current ;
}
function updateFragment ( returnFiber , current , fragment , expirationTime , key ) {
if ( null === current || 10 !== current . tag )
return (
( current = createFiberFromFragment (
fragment ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime ,
key
) ) ,
( current [ "return" ] = returnFiber ) ,
current
) ;
current = useFiber ( current , fragment , expirationTime ) ;
current [ "return" ] = returnFiber ;
return current ;
}
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 ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
( newChild [ "return" ] = returnFiber ) ,
newChild
) ;
if ( "object" === typeof newChild && null !== newChild ) {
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
return (
( expirationTime = createFiberFromElement (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
2018-02-09 16:01:29 -08:00
( expirationTime . ref = coerceRef ( returnFiber , null , newChild ) ) ,
2018-01-30 08:47:02 -08:00
( expirationTime [ "return" ] = returnFiber ) ,
expirationTime
) ;
case REACT _PORTAL _TYPE :
return (
( newChild = createFiberFromPortal (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
( newChild [ "return" ] = returnFiber ) ,
newChild
) ;
}
if ( isArray$1 ( newChild ) || getIteratorFn ( newChild ) )
return (
( newChild = createFiberFromFragment (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime ,
null
) ) ,
( newChild [ "return" ] = returnFiber ) ,
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
) )
) {
if ( shouldTrackSideEffects && null !== nextOldFiber . alternate )
oldFiber [ "delete" ] (
null === nextOldFiber . key ? newIdx : nextOldFiber . key
) ;
currentFirstChild = placeChild ( nextOldFiber , currentFirstChild , newIdx ) ;
null === previousNewFiber
? ( resultingFirstChild = nextOldFiber )
: ( previousNewFiber . sibling = nextOldFiber ) ;
previousNewFiber = nextOldFiber ;
}
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 ( )
)
if (
( ( step = updateFromMap (
oldFiber ,
returnFiber ,
newIdx ,
step . value ,
expirationTime
) ) ,
null !== step )
) {
if ( 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 ;
}
shouldTrackSideEffects &&
oldFiber . forEach ( function ( child ) {
return deleteChild ( returnFiber , child ) ;
} ) ;
return iteratorFn ;
}
return function ( returnFiber , currentFirstChild , newChild , expirationTime ) {
"object" === typeof newChild &&
null !== newChild &&
newChild . type === REACT _FRAGMENT _TYPE &&
null === newChild . key &&
( newChild = newChild . props . children ) ;
var isObject = "object" === typeof newChild && null !== newChild ;
if ( isObject )
switch ( newChild . $$typeof ) {
case REACT _ELEMENT _TYPE :
a : {
var key = newChild . key ;
for ( isObject = currentFirstChild ; null !== isObject ; ) {
if ( isObject . key === key )
if (
10 === isObject . tag
? newChild . type === REACT _FRAGMENT _TYPE
: isObject . type === newChild . type
) {
deleteRemainingChildren ( returnFiber , isObject . sibling ) ;
currentFirstChild = useFiber (
isObject ,
newChild . type === REACT _FRAGMENT _TYPE
? newChild . props . children
: newChild . props ,
expirationTime
) ;
2018-02-09 16:01:29 -08:00
currentFirstChild . ref = coerceRef (
returnFiber ,
isObject ,
newChild
) ;
2018-01-30 08:47:02 -08:00
currentFirstChild [ "return" ] = returnFiber ;
returnFiber = currentFirstChild ;
break a ;
} else {
deleteRemainingChildren ( returnFiber , isObject ) ;
break ;
}
else deleteChild ( returnFiber , isObject ) ;
isObject = isObject . sibling ;
}
newChild . type === REACT _FRAGMENT _TYPE
? ( ( currentFirstChild = createFiberFromFragment (
newChild . props . children ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime ,
newChild . key
) ) ,
( currentFirstChild [ "return" ] = returnFiber ) ,
( returnFiber = currentFirstChild ) )
: ( ( expirationTime = createFiberFromElement (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ,
2018-02-09 16:01:29 -08:00
( expirationTime . ref = coerceRef (
returnFiber ,
currentFirstChild ,
newChild
) ) ,
2018-01-30 08:47:02 -08:00
( expirationTime [ "return" ] = returnFiber ) ,
( returnFiber = expirationTime ) ) ;
}
return placeSingleChild ( returnFiber ) ;
case REACT _PORTAL _TYPE :
a : {
for ( isObject = newChild . key ; null !== currentFirstChild ; ) {
if ( currentFirstChild . key === isObject )
if (
4 === currentFirstChild . tag &&
currentFirstChild . stateNode . containerInfo ===
newChild . containerInfo &&
currentFirstChild . stateNode . implementation ===
newChild . implementation
) {
deleteRemainingChildren (
returnFiber ,
currentFirstChild . sibling
) ;
currentFirstChild = useFiber (
currentFirstChild ,
newChild . children || [ ] ,
expirationTime
) ;
currentFirstChild [ "return" ] = returnFiber ;
returnFiber = currentFirstChild ;
break a ;
} else {
deleteRemainingChildren ( returnFiber , currentFirstChild ) ;
break ;
}
else deleteChild ( returnFiber , currentFirstChild ) ;
currentFirstChild = currentFirstChild . sibling ;
}
currentFirstChild = createFiberFromPortal (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ;
currentFirstChild [ "return" ] = returnFiber ;
returnFiber = currentFirstChild ;
}
return placeSingleChild ( returnFiber ) ;
}
if ( "string" === typeof newChild || "number" === typeof newChild )
return (
( newChild = "" + newChild ) ,
null !== currentFirstChild && 6 === currentFirstChild . tag
? ( deleteRemainingChildren ( returnFiber , currentFirstChild . sibling ) ,
( currentFirstChild = useFiber (
currentFirstChild ,
newChild ,
expirationTime
) ) )
: ( deleteRemainingChildren ( returnFiber , currentFirstChild ) ,
( currentFirstChild = createFiberFromText (
newChild ,
2018-02-01 13:33:12 -08:00
returnFiber . mode ,
2018-01-30 08:47:02 -08:00
expirationTime
) ) ) ,
( currentFirstChild [ "return" ] = returnFiber ) ,
( returnFiber = currentFirstChild ) ,
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 ) ;
if ( "undefined" === typeof newChild )
switch ( returnFiber . tag ) {
case 2 :
case 1 :
( expirationTime = returnFiber . type ) ,
invariant (
! 1 ,
"%s(...): Nothing was returned from render. This usually means a return statement is missing. Or, to render nothing, return null." ,
expirationTime . displayName || expirationTime . name || "Component"
) ;
}
return deleteRemainingChildren ( returnFiber , currentFirstChild ) ;
} ;
}
var reconcileChildFibers = ChildReconciler ( ! 0 ) ,
2018-03-20 17:03:06 -07:00
mountChildFibers = ChildReconciler ( ! 1 ) ;
2018-01-30 08:47:02 -08:00
function ReactFiberBeginWork (
config ,
hostContext ,
2018-03-20 17:03:06 -07:00
legacyContext ,
newContext ,
2018-01-30 08:47:02 -08:00
hydrationContext ,
scheduleWork ,
computeExpirationForFiber
) {
function reconcileChildren ( current , workInProgress , nextChildren ) {
2018-02-28 19:16:47 -08:00
reconcileChildrenAtExpirationTime (
current ,
workInProgress ,
nextChildren ,
workInProgress . expirationTime
) ;
}
function reconcileChildrenAtExpirationTime (
current ,
workInProgress ,
nextChildren ,
renderExpirationTime
) {
2018-01-30 08:47:02 -08:00
workInProgress . child =
null === current
? mountChildFibers (
workInProgress ,
null ,
nextChildren ,
renderExpirationTime
)
: reconcileChildFibers (
workInProgress ,
current . child ,
nextChildren ,
renderExpirationTime
) ;
}
function markRef ( current , workInProgress ) {
var ref = workInProgress . ref ;
2018-02-09 16:01:29 -08:00
if (
( null === current && null !== ref ) ||
( null !== current && current . ref !== ref )
)
workInProgress . effectTag |= 128 ;
2018-01-30 08:47:02 -08:00
}
function finishClassComponent (
current ,
workInProgress ,
shouldUpdate ,
2018-02-28 19:16:47 -08:00
hasContext ,
didCaptureError ,
renderExpirationTime
2018-01-30 08:47:02 -08:00
) {
markRef ( current , workInProgress ) ;
2018-02-28 19:16:47 -08:00
if ( ! shouldUpdate && ! didCaptureError )
2018-01-30 08:47:02 -08:00
return (
hasContext && invalidateContextProvider ( workInProgress , ! 1 ) ,
bailoutOnAlreadyFinishedWork ( current , workInProgress )
) ;
shouldUpdate = workInProgress . stateNode ;
ReactCurrentOwner . current = workInProgress ;
2018-02-28 19:16:47 -08:00
var nextChildren = didCaptureError ? null : shouldUpdate . render ( ) ;
2018-01-30 08:47:02 -08:00
workInProgress . effectTag |= 1 ;
2018-02-28 19:16:47 -08:00
didCaptureError &&
( reconcileChildrenAtExpirationTime (
current ,
workInProgress ,
null ,
renderExpirationTime
) ,
( workInProgress . child = null ) ) ;
reconcileChildrenAtExpirationTime (
current ,
workInProgress ,
nextChildren ,
renderExpirationTime
) ;
2018-01-30 08:47:02 -08:00
workInProgress . memoizedState = shouldUpdate . state ;
workInProgress . memoizedProps = shouldUpdate . props ;
hasContext && invalidateContextProvider ( workInProgress , ! 0 ) ;
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-02-01 13:33:12 -08:00
function propagateContextChange (
workInProgress ,
context ,
changedBits ,
renderExpirationTime
) {
2018-03-20 17:03:06 -07:00
var fiber = workInProgress . child ;
for (
null !== fiber && ( fiber [ "return" ] = workInProgress ) ;
null !== fiber ;
) {
2018-02-01 13:33:12 -08:00
switch ( fiber . tag ) {
case 12 :
var nextFiber = fiber . stateNode | 0 ;
if ( fiber . type === context && 0 !== ( nextFiber & changedBits ) ) {
for ( nextFiber = fiber ; null !== nextFiber ; ) {
var alternate = nextFiber . alternate ;
if (
0 === nextFiber . expirationTime ||
nextFiber . expirationTime > renderExpirationTime
)
( nextFiber . expirationTime = renderExpirationTime ) ,
null !== alternate &&
( 0 === alternate . expirationTime ||
alternate . expirationTime > renderExpirationTime ) &&
( alternate . expirationTime = renderExpirationTime ) ;
else if (
null !== alternate &&
( 0 === alternate . expirationTime ||
alternate . expirationTime > renderExpirationTime )
)
alternate . expirationTime = renderExpirationTime ;
else break ;
nextFiber = nextFiber [ "return" ] ;
}
nextFiber = null ;
} else nextFiber = fiber . child ;
break ;
case 13 :
nextFiber = fiber . type === workInProgress . type ? null : fiber . child ;
break ;
default :
nextFiber = fiber . child ;
}
if ( null !== nextFiber ) nextFiber [ "return" ] = fiber ;
else
for ( nextFiber = fiber ; null !== nextFiber ; ) {
if ( nextFiber === workInProgress ) {
nextFiber = null ;
break ;
}
fiber = nextFiber . sibling ;
if ( null !== fiber ) {
nextFiber = fiber ;
break ;
}
nextFiber = nextFiber [ "return" ] ;
}
fiber = nextFiber ;
}
}
2018-03-14 08:47:36 -07:00
function updateContextProvider (
current ,
workInProgress ,
renderExpirationTime
) {
2018-04-04 15:11:21 -07:00
var context = workInProgress . type . _context ,
2018-03-14 08:47:36 -07:00
newProps = workInProgress . pendingProps ,
oldProps = workInProgress . memoizedProps ;
2018-03-20 17:03:06 -07:00
if ( ! hasLegacyContextChanged ( ) && oldProps === newProps )
2018-03-14 08:47:36 -07:00
return (
( workInProgress . stateNode = 0 ) ,
pushProvider ( workInProgress ) ,
bailoutOnAlreadyFinishedWork ( current , workInProgress )
) ;
var newValue = newProps . value ;
workInProgress . memoizedProps = newProps ;
if ( null === oldProps ) newValue = 1073741823 ;
else if ( oldProps . value === newProps . value ) {
if ( oldProps . children === newProps . children )
return (
( workInProgress . stateNode = 0 ) ,
pushProvider ( workInProgress ) ,
bailoutOnAlreadyFinishedWork ( current , workInProgress )
) ;
newValue = 0 ;
} else {
var oldValue = oldProps . value ;
if (
( oldValue === newValue &&
( 0 !== oldValue || 1 / oldValue === 1 / newValue ) ) ||
( oldValue !== oldValue && newValue !== newValue )
) {
if ( oldProps . children === newProps . children )
return (
( workInProgress . stateNode = 0 ) ,
pushProvider ( workInProgress ) ,
bailoutOnAlreadyFinishedWork ( current , workInProgress )
) ;
newValue = 0 ;
} else if (
( ( newValue =
"function" === typeof context . _calculateChangedBits
? context . _calculateChangedBits ( oldValue , newValue )
: 1073741823 ) ,
( newValue |= 0 ) ,
0 === newValue )
) {
if ( oldProps . children === newProps . children )
return (
( workInProgress . stateNode = 0 ) ,
pushProvider ( workInProgress ) ,
bailoutOnAlreadyFinishedWork ( current , workInProgress )
) ;
} else
propagateContextChange (
workInProgress ,
context ,
newValue ,
renderExpirationTime
) ;
}
workInProgress . stateNode = newValue ;
pushProvider ( workInProgress ) ;
reconcileChildren ( current , workInProgress , newProps . children ) ;
return workInProgress . child ;
}
2018-01-30 08:47:02 -08:00
function bailoutOnAlreadyFinishedWork ( current , workInProgress ) {
invariant (
null === current || workInProgress . child === current . child ,
"Resuming work not yet implemented."
) ;
if ( null !== workInProgress . child ) {
current = workInProgress . child ;
var newChild = createWorkInProgress (
current ,
current . pendingProps ,
current . expirationTime
) ;
workInProgress . child = newChild ;
for ( newChild [ "return" ] = workInProgress ; null !== current . sibling ; )
( current = current . sibling ) ,
( newChild = newChild . sibling = createWorkInProgress (
current ,
current . pendingProps ,
current . expirationTime
) ) ,
( newChild [ "return" ] = workInProgress ) ;
newChild . sibling = null ;
}
return workInProgress . child ;
}
var shouldSetTextContent = config . shouldSetTextContent ,
shouldDeprioritizeSubtree = config . shouldDeprioritizeSubtree ,
pushHostContext = hostContext . pushHostContext ,
pushHostContainer = hostContext . pushHostContainer ,
2018-03-20 17:03:06 -07:00
pushProvider = newContext . pushProvider ,
getMaskedContext = legacyContext . getMaskedContext ,
getUnmaskedContext = legacyContext . getUnmaskedContext ,
hasLegacyContextChanged = legacyContext . hasContextChanged ,
pushLegacyContextProvider = legacyContext . pushContextProvider ,
pushTopLevelContextObject = legacyContext . pushTopLevelContextObject ,
invalidateContextProvider = legacyContext . invalidateContextProvider ,
2018-01-30 08:47:02 -08:00
enterHydrationState = hydrationContext . enterHydrationState ,
resetHydrationState = hydrationContext . resetHydrationState ,
tryToClaimNextHydratableInstance =
hydrationContext . tryToClaimNextHydratableInstance ;
config = ReactFiberClassComponent (
2018-03-20 17:03:06 -07:00
legacyContext ,
2018-01-30 08:47:02 -08:00
scheduleWork ,
computeExpirationForFiber ,
function ( workInProgress , nextProps ) {
workInProgress . memoizedProps = nextProps ;
} ,
function ( workInProgress , nextState ) {
workInProgress . memoizedState = nextState ;
}
) ;
var adoptClassInstance = config . adoptClassInstance ,
callGetDerivedStateFromProps = config . callGetDerivedStateFromProps ,
constructClassInstance = config . constructClassInstance ,
mountClassInstance = config . mountClassInstance ,
2018-02-28 19:16:47 -08:00
resumeMountClassInstance = config . resumeMountClassInstance ,
2018-01-30 08:47:02 -08:00
updateClassInstance = config . updateClassInstance ;
return {
beginWork : function ( current , workInProgress , renderExpirationTime ) {
if (
0 === workInProgress . expirationTime ||
workInProgress . expirationTime > renderExpirationTime
2018-02-28 19:16:47 -08:00
) {
switch ( workInProgress . tag ) {
case 3 :
pushHostRootContext ( workInProgress ) ;
break ;
case 2 :
2018-03-20 17:03:06 -07:00
pushLegacyContextProvider ( workInProgress ) ;
2018-02-28 19:16:47 -08:00
break ;
case 4 :
pushHostContainer (
workInProgress ,
workInProgress . stateNode . containerInfo
) ;
break ;
case 13 :
pushProvider ( workInProgress ) ;
}
return null ;
}
2018-01-30 08:47:02 -08:00
switch ( workInProgress . tag ) {
case 0 :
invariant (
null === current ,
"An indeterminate component should never have mounted. This error is likely caused by a bug in React. Please file an issue."
) ;
var fn = workInProgress . type ,
props = workInProgress . pendingProps ,
unmaskedContext = getUnmaskedContext ( workInProgress ) ;
unmaskedContext = getMaskedContext ( workInProgress , unmaskedContext ) ;
fn = fn ( props , unmaskedContext ) ;
workInProgress . effectTag |= 1 ;
"object" === typeof fn &&
null !== fn &&
"function" === typeof fn . render &&
void 0 === fn . $$typeof
? ( ( unmaskedContext = workInProgress . type ) ,
( workInProgress . tag = 2 ) ,
( workInProgress . memoizedState =
null !== fn . state && void 0 !== fn . state ? fn . state : null ) ,
"function" === typeof unmaskedContext . getDerivedStateFromProps &&
( ( props = callGetDerivedStateFromProps (
workInProgress ,
fn ,
2018-04-04 15:11:21 -07:00
props ,
workInProgress . memoizedState
2018-01-30 08:47:02 -08:00
) ) ,
null !== props &&
void 0 !== props &&
( workInProgress . memoizedState = Object . assign (
{ } ,
workInProgress . memoizedState ,
props
) ) ) ,
2018-03-20 17:03:06 -07:00
( props = pushLegacyContextProvider ( workInProgress ) ) ,
2018-01-30 08:47:02 -08:00
adoptClassInstance ( workInProgress , fn ) ,
mountClassInstance ( workInProgress , renderExpirationTime ) ,
( current = finishClassComponent (
current ,
workInProgress ,
! 0 ,
2018-02-28 19:16:47 -08:00
props ,
! 1 ,
renderExpirationTime
2018-01-30 08:47:02 -08:00
) ) )
: ( ( workInProgress . tag = 1 ) ,
reconcileChildren ( current , workInProgress , fn ) ,
( workInProgress . memoizedProps = props ) ,
( current = workInProgress . child ) ) ;
return current ;
case 1 :
return (
( props = workInProgress . type ) ,
( renderExpirationTime = workInProgress . pendingProps ) ,
2018-03-20 17:03:06 -07:00
hasLegacyContextChanged ( ) ||
2018-01-30 08:47:02 -08:00
workInProgress . memoizedProps !== renderExpirationTime
? ( ( fn = getUnmaskedContext ( workInProgress ) ) ,
( fn = getMaskedContext ( workInProgress , fn ) ) ,
( props = props ( renderExpirationTime , fn ) ) ,
( workInProgress . effectTag |= 1 ) ,
reconcileChildren ( current , workInProgress , props ) ,
( workInProgress . memoizedProps = renderExpirationTime ) ,
( current = workInProgress . child ) )
: ( current = bailoutOnAlreadyFinishedWork (
current ,
workInProgress
) ) ,
current
) ;
case 2 :
2018-03-20 17:03:06 -07:00
props = pushLegacyContextProvider ( workInProgress ) ;
2018-02-28 19:16:47 -08:00
null === current
? null === workInProgress . stateNode
? ( constructClassInstance (
workInProgress ,
workInProgress . pendingProps
) ,
mountClassInstance ( workInProgress , renderExpirationTime ) ,
( fn = ! 0 ) )
: ( fn = resumeMountClassInstance (
2018-01-30 08:47:02 -08:00
workInProgress ,
renderExpirationTime
2018-02-28 19:16:47 -08:00
) )
: ( fn = updateClassInstance (
current ,
workInProgress ,
renderExpirationTime
) ) ;
unmaskedContext = ! 1 ;
var updateQueue = workInProgress . updateQueue ;
null !== updateQueue &&
null !== updateQueue . capturedValues &&
( unmaskedContext = fn = ! 0 ) ;
return finishClassComponent (
current ,
workInProgress ,
fn ,
props ,
unmaskedContext ,
renderExpirationTime
) ;
2018-01-30 08:47:02 -08:00
case 3 :
2018-02-28 19:16:47 -08:00
a : if (
( pushHostRootContext ( workInProgress ) ,
( fn = workInProgress . updateQueue ) ,
null !== fn )
) {
unmaskedContext = workInProgress . memoizedState ;
props = processUpdateQueue (
current ,
workInProgress ,
fn ,
null ,
null ,
renderExpirationTime
) ;
workInProgress . memoizedState = props ;
fn = workInProgress . updateQueue ;
if ( null !== fn && null !== fn . capturedValues ) fn = null ;
else if ( unmaskedContext === props ) {
resetHydrationState ( ) ;
current = bailoutOnAlreadyFinishedWork ( current , workInProgress ) ;
break a ;
} else fn = props . element ;
unmaskedContext = workInProgress . stateNode ;
( null === current || null === current . child ) &&
unmaskedContext . hydrate &&
enterHydrationState ( workInProgress )
? ( ( workInProgress . effectTag |= 2 ) ,
( workInProgress . child = mountChildFibers (
2018-01-30 08:47:02 -08:00
workInProgress ,
null ,
2018-02-28 19:16:47 -08:00
fn ,
2018-01-30 08:47:02 -08:00
renderExpirationTime
2018-02-28 19:16:47 -08:00
) ) )
2018-01-30 08:47:02 -08:00
: ( resetHydrationState ( ) ,
2018-02-28 19:16:47 -08:00
reconcileChildren ( current , workInProgress , fn ) ) ;
workInProgress . memoizedState = props ;
current = workInProgress . child ;
} else
resetHydrationState ( ) ,
( current = bailoutOnAlreadyFinishedWork ( current , workInProgress ) ) ;
return current ;
2018-01-30 08:47:02 -08:00
case 5 :
2018-02-28 19:16:47 -08:00
a : {
pushHostContext ( workInProgress ) ;
null === current &&
tryToClaimNextHydratableInstance ( workInProgress ) ;
props = workInProgress . type ;
updateQueue = workInProgress . memoizedProps ;
fn = workInProgress . pendingProps ;
unmaskedContext = null !== current ? current . memoizedProps : null ;
2018-03-20 17:03:06 -07:00
if ( ! hasLegacyContextChanged ( ) && updateQueue === fn ) {
2018-02-28 19:16:47 -08:00
if (
( updateQueue =
workInProgress . mode & 1 &&
shouldDeprioritizeSubtree ( props , fn ) )
)
workInProgress . expirationTime = 1073741823 ;
if ( ! updateQueue || 1073741823 !== renderExpirationTime ) {
current = bailoutOnAlreadyFinishedWork ( current , workInProgress ) ;
break a ;
}
}
updateQueue = fn . children ;
shouldSetTextContent ( props , fn )
? ( updateQueue = null )
: unmaskedContext &&
shouldSetTextContent ( props , unmaskedContext ) &&
( workInProgress . effectTag |= 16 ) ;
markRef ( current , workInProgress ) ;
1073741823 !== renderExpirationTime &&
workInProgress . mode & 1 &&
shouldDeprioritizeSubtree ( props , fn )
? ( ( workInProgress . expirationTime = 1073741823 ) ,
( workInProgress . memoizedProps = fn ) ,
( current = null ) )
: ( reconcileChildren ( current , workInProgress , updateQueue ) ,
( workInProgress . memoizedProps = fn ) ,
( current = workInProgress . child ) ) ;
}
2018-01-30 08:47:02 -08:00
return current ;
case 6 :
return (
null === current &&
tryToClaimNextHydratableInstance ( workInProgress ) ,
( workInProgress . memoizedProps = workInProgress . pendingProps ) ,
null
) ;
case 8 :
workInProgress . tag = 7 ;
case 7 :
return (
( props = workInProgress . pendingProps ) ,
2018-03-20 17:03:06 -07:00
hasLegacyContextChanged ( ) ||
2018-01-30 08:47:02 -08:00
workInProgress . memoizedProps !== props ||
( props = workInProgress . memoizedProps ) ,
( fn = props . children ) ,
( workInProgress . stateNode =
null === current
? mountChildFibers (
workInProgress ,
workInProgress . stateNode ,
fn ,
renderExpirationTime
)
: reconcileChildFibers (
workInProgress ,
current . stateNode ,
fn ,
renderExpirationTime
) ) ,
( workInProgress . memoizedProps = props ) ,
workInProgress . stateNode
) ;
case 9 :
return null ;
case 4 :
return (
pushHostContainer (
workInProgress ,
workInProgress . stateNode . containerInfo
) ,
( props = workInProgress . pendingProps ) ,
2018-03-20 17:03:06 -07:00
hasLegacyContextChanged ( ) || workInProgress . memoizedProps !== props
2018-01-30 08:47:02 -08:00
? ( null === current
? ( workInProgress . child = reconcileChildFibers (
workInProgress ,
null ,
props ,
renderExpirationTime
) )
: reconcileChildren ( current , workInProgress , props ) ,
( workInProgress . memoizedProps = props ) ,
( current = workInProgress . child ) )
: ( current = bailoutOnAlreadyFinishedWork (
current ,
workInProgress
) ) ,
current
) ;
2018-03-14 23:23:11 -07:00
case 14 :
return (
( renderExpirationTime = workInProgress . type . render ) ,
( renderExpirationTime = renderExpirationTime (
workInProgress . pendingProps ,
workInProgress . ref
) ) ,
reconcileChildren ( current , workInProgress , renderExpirationTime ) ,
( workInProgress . memoizedProps = renderExpirationTime ) ,
workInProgress . child
) ;
2018-01-30 08:47:02 -08:00
case 10 :
return (
( renderExpirationTime = workInProgress . pendingProps ) ,
2018-03-20 17:03:06 -07:00
hasLegacyContextChanged ( ) ||
2018-01-30 08:47:02 -08:00
workInProgress . memoizedProps !== renderExpirationTime
? ( reconcileChildren (
current ,
workInProgress ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = renderExpirationTime ) ,
( current = workInProgress . child ) )
: ( current = bailoutOnAlreadyFinishedWork (
current ,
workInProgress
) ) ,
current
) ;
case 11 :
return (
( renderExpirationTime = workInProgress . pendingProps . children ) ,
2018-03-20 17:03:06 -07:00
hasLegacyContextChanged ( ) ||
2018-01-30 08:47:02 -08:00
( null !== renderExpirationTime &&
workInProgress . memoizedProps !== renderExpirationTime )
? ( reconcileChildren (
current ,
workInProgress ,
renderExpirationTime
) ,
( workInProgress . memoizedProps = renderExpirationTime ) ,
( current = workInProgress . child ) )
: ( current = bailoutOnAlreadyFinishedWork (
current ,
workInProgress
) ) ,
current
) ;
case 13 :
2018-03-14 08:47:36 -07:00
return updateContextProvider (
current ,
workInProgress ,
renderExpirationTime
) ;
2018-01-30 08:47:02 -08:00
case 12 :
2018-04-05 17:33:08 -07:00
a : {
fn = workInProgress . type ;
unmaskedContext = workInProgress . pendingProps ;
updateQueue = workInProgress . memoizedProps ;
props = fn . _currentValue ;
var changedBits = fn . _changedBits ;
if (
hasLegacyContextChanged ( ) ||
0 !== changedBits ||
updateQueue !== unmaskedContext
) {
workInProgress . memoizedProps = unmaskedContext ;
var observedBits = unmaskedContext . unstable _observedBits ;
if ( void 0 === observedBits || null === observedBits )
observedBits = 1073741823 ;
workInProgress . stateNode = observedBits ;
if ( 0 !== ( changedBits & observedBits ) )
propagateContextChange (
workInProgress ,
fn ,
changedBits ,
renderExpirationTime
) ;
else if ( updateQueue === unmaskedContext ) {
current = bailoutOnAlreadyFinishedWork ( current , workInProgress ) ;
break a ;
}
renderExpirationTime = unmaskedContext . children ;
renderExpirationTime = renderExpirationTime ( props ) ;
reconcileChildren ( current , workInProgress , renderExpirationTime ) ;
current = workInProgress . child ;
} else
current = bailoutOnAlreadyFinishedWork ( current , workInProgress ) ;
}
2018-03-14 08:47:36 -07:00
return current ;
2018-01-30 08:47:02 -08:00
default :
invariant (
! 1 ,
"Unknown unit of work tag. This error is likely caused by a bug in React. Please file an issue."
) ;
}
}
} ;
}
2018-03-20 17:03:06 -07:00
function ReactFiberCompleteWork (
config ,
hostContext ,
legacyContext ,
newContext ,
hydrationContext
) {
2018-01-30 08:47:02 -08:00
function markUpdate ( workInProgress ) {
workInProgress . effectTag |= 4 ;
}
2018-02-09 16:01:29 -08:00
function appendAllChildren ( parent , workInProgress ) {
for ( var node = workInProgress . child ; null !== node ; ) {
if ( 5 === node . tag || 6 === node . tag )
appendInitialChild ( parent , node . stateNode ) ;
else if ( 4 !== node . tag && null !== node . child ) {
node . child [ "return" ] = node ;
node = node . child ;
continue ;
}
if ( node === workInProgress ) break ;
for ( ; null === node . sibling ; ) {
if ( null === node [ "return" ] || node [ "return" ] === workInProgress )
return ;
node = node [ "return" ] ;
}
node . sibling [ "return" ] = node [ "return" ] ;
node = node . sibling ;
}
}
2018-01-30 08:47:02 -08:00
var createInstance = config . createInstance ,
createTextInstance = config . createTextInstance ,
appendInitialChild = config . appendInitialChild ,
finalizeInitialChildren = config . finalizeInitialChildren ,
prepareUpdate = config . prepareUpdate ,
persistence = config . persistence ,
getRootHostContainer = hostContext . getRootHostContainer ,
popHostContext = hostContext . popHostContext ,
getHostContext = hostContext . getHostContext ,
popHostContainer = hostContext . popHostContainer ,
2018-03-20 17:03:06 -07:00
popLegacyContextProvider = legacyContext . popContextProvider ,
popTopLevelLegacyContextObject = legacyContext . popTopLevelContextObject ,
popProvider = newContext . popProvider ,
2018-01-30 08:47:02 -08:00
prepareToHydrateHostInstance =
hydrationContext . prepareToHydrateHostInstance ,
prepareToHydrateHostTextInstance =
hydrationContext . prepareToHydrateHostTextInstance ,
popHydrationState = hydrationContext . popHydrationState ,
updateHostContainer = void 0 ,
updateHostComponent = void 0 ,
updateHostText = void 0 ;
2018-02-09 16:01:29 -08:00
if ( config . mutation ) invariant ( ! 1 , "Mutating reconciler is disabled." ) ;
else if ( persistence ) {
var cloneInstance = persistence . cloneInstance ,
createContainerChildSet = persistence . createContainerChildSet ,
appendChildToContainerChildSet =
persistence . appendChildToContainerChildSet ,
finalizeContainerChildren = persistence . finalizeContainerChildren ;
updateHostContainer = function ( workInProgress ) {
var portalOrRoot = workInProgress . stateNode ;
if ( null !== workInProgress . firstEffect ) {
var container = portalOrRoot . containerInfo ,
newChildSet = createContainerChildSet ( container ) ;
2018-02-28 19:16:47 -08:00
a : for ( var node = workInProgress . child ; null !== node ; ) {
if ( 5 === node . tag || 6 === node . tag )
appendChildToContainerChildSet ( newChildSet , node . stateNode ) ;
else if ( 4 !== node . tag && null !== node . child ) {
node . child [ "return" ] = node ;
node = node . child ;
2018-02-09 16:01:29 -08:00
continue ;
}
2018-02-28 19:16:47 -08:00
if ( node === workInProgress ) break a ;
for ( ; null === node . sibling ; ) {
if ( null === node [ "return" ] || node [ "return" ] === workInProgress )
2018-02-09 16:01:29 -08:00
break a ;
2018-02-28 19:16:47 -08:00
node = node [ "return" ] ;
2018-02-09 16:01:29 -08:00
}
2018-02-28 19:16:47 -08:00
node . sibling [ "return" ] = node [ "return" ] ;
node = node . sibling ;
2018-02-09 16:01:29 -08:00
}
2018-02-28 19:16:47 -08:00
portalOrRoot . pendingChildren = newChildSet ;
2018-02-09 16:01:29 -08:00
markUpdate ( workInProgress ) ;
2018-02-28 19:16:47 -08:00
finalizeContainerChildren ( container , newChildSet ) ;
2018-02-09 16:01:29 -08:00
}
} ;
updateHostComponent = function (
current ,
workInProgress ,
updatePayload ,
type ,
oldProps ,
newProps ,
rootContainerInstance ,
currentHostContext
) {
var childrenUnchanged = null === workInProgress . firstEffect ;
current = current . stateNode ;
childrenUnchanged && null === updatePayload
? ( workInProgress . stateNode = current )
: ( ( updatePayload = cloneInstance (
current ,
updatePayload ,
type ,
oldProps ,
newProps ,
workInProgress ,
childrenUnchanged ,
workInProgress . stateNode
) ) ,
finalizeInitialChildren (
updatePayload ,
type ,
newProps ,
rootContainerInstance ,
currentHostContext
) && markUpdate ( workInProgress ) ,
( workInProgress . stateNode = updatePayload ) ,
childrenUnchanged
? markUpdate ( workInProgress )
: appendAllChildren ( updatePayload , workInProgress ) ) ;
} ;
updateHostText = function ( current , workInProgress , oldText , newText ) {
oldText !== newText &&
( ( current = getRootHostContainer ( ) ) ,
( oldText = getHostContext ( ) ) ,
( workInProgress . stateNode = createTextInstance (
newText ,
current ,
oldText ,
workInProgress
) ) ,
markUpdate ( workInProgress ) ) ;
} ;
} else invariant ( ! 1 , "Noop reconciler is disabled." ) ;
2018-01-30 08:47:02 -08:00
return {
completeWork : function ( current , workInProgress , renderExpirationTime ) {
var newProps = workInProgress . pendingProps ;
switch ( workInProgress . tag ) {
case 1 :
return null ;
case 2 :
2018-02-28 19:16:47 -08:00
return (
2018-03-20 17:03:06 -07:00
popLegacyContextProvider ( workInProgress ) ,
2018-02-28 19:16:47 -08:00
( current = workInProgress . stateNode ) ,
( newProps = workInProgress . updateQueue ) ,
null !== newProps &&
null !== newProps . capturedValues &&
( ( workInProgress . effectTag &= - 65 ) ,
"function" === typeof current . componentDidCatch
? ( workInProgress . effectTag |= 256 )
: ( newProps . capturedValues = null ) ) ,
null
) ;
2018-01-30 08:47:02 -08:00
case 3 :
popHostContainer ( workInProgress ) ;
2018-03-20 17:03:06 -07:00
popTopLevelLegacyContextObject ( workInProgress ) ;
2018-01-30 08:47:02 -08:00
newProps = workInProgress . stateNode ;
newProps . pendingContext &&
( ( newProps . context = newProps . pendingContext ) ,
( newProps . pendingContext = null ) ) ;
if ( null === current || null === current . child )
popHydrationState ( workInProgress ) , ( workInProgress . effectTag &= - 3 ) ;
updateHostContainer ( workInProgress ) ;
2018-02-28 19:16:47 -08:00
current = workInProgress . updateQueue ;
null !== current &&
null !== current . capturedValues &&
( workInProgress . effectTag |= 256 ) ;
2018-01-30 08:47:02 -08:00
return null ;
case 5 :
popHostContext ( workInProgress ) ;
renderExpirationTime = getRootHostContainer ( ) ;
var type = workInProgress . type ;
if ( null !== current && null != workInProgress . stateNode ) {
var oldProps = current . memoizedProps ,
2018-02-28 19:16:47 -08:00
_instance = workInProgress . stateNode ,
2018-01-30 08:47:02 -08:00
currentHostContext = getHostContext ( ) ;
2018-02-28 19:16:47 -08:00
_instance = prepareUpdate (
_instance ,
2018-01-30 08:47:02 -08:00
type ,
oldProps ,
newProps ,
renderExpirationTime ,
currentHostContext
) ;
updateHostComponent (
current ,
workInProgress ,
2018-02-28 19:16:47 -08:00
_instance ,
2018-01-30 08:47:02 -08:00
type ,
oldProps ,
newProps ,
renderExpirationTime ,
currentHostContext
) ;
current . ref !== workInProgress . ref &&
( workInProgress . effectTag |= 128 ) ;
} else {
if ( ! newProps )
return (
invariant (
null !== workInProgress . stateNode ,
"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue."
) ,
null
) ;
current = getHostContext ( ) ;
2018-02-09 16:01:29 -08:00
popHydrationState ( workInProgress )
? prepareToHydrateHostInstance (
workInProgress ,
renderExpirationTime ,
current
) && markUpdate ( workInProgress )
: ( ( oldProps = createInstance (
type ,
newProps ,
renderExpirationTime ,
current ,
workInProgress
) ) ,
appendAllChildren ( oldProps , workInProgress ) ,
finalizeInitialChildren (
oldProps ,
type ,
newProps ,
renderExpirationTime ,
current
) && markUpdate ( workInProgress ) ,
( workInProgress . stateNode = oldProps ) ) ;
2018-01-30 08:47:02 -08:00
null !== workInProgress . ref && ( workInProgress . effectTag |= 128 ) ;
}
return null ;
case 6 :
if ( current && null != workInProgress . stateNode )
updateHostText (
current ,
workInProgress ,
current . memoizedProps ,
newProps
) ;
else {
if ( "string" !== typeof newProps )
return (
invariant (
null !== workInProgress . stateNode ,
"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue."
) ,
null
) ;
current = getRootHostContainer ( ) ;
renderExpirationTime = getHostContext ( ) ;
popHydrationState ( workInProgress )
? prepareToHydrateHostTextInstance ( workInProgress ) &&
markUpdate ( workInProgress )
: ( workInProgress . stateNode = createTextInstance (
newProps ,
current ,
renderExpirationTime ,
workInProgress
) ) ;
}
return null ;
case 7 :
newProps = workInProgress . memoizedProps ;
invariant (
newProps ,
"Should be resolved by now. This error is likely caused by a bug in React. Please file an issue."
) ;
workInProgress . tag = 8 ;
type = [ ] ;
a : for (
( oldProps = workInProgress . stateNode ) &&
( oldProps [ "return" ] = workInProgress ) ;
null !== oldProps ;
) {
if ( 5 === oldProps . tag || 6 === oldProps . tag || 4 === oldProps . tag )
invariant ( ! 1 , "A call cannot have host component children." ) ;
else if ( 9 === oldProps . tag ) type . push ( oldProps . pendingProps . value ) ;
else if ( null !== oldProps . child ) {
oldProps . child [ "return" ] = oldProps ;
oldProps = oldProps . child ;
continue ;
}
for ( ; null === oldProps . sibling ; ) {
if (
null === oldProps [ "return" ] ||
oldProps [ "return" ] === workInProgress
)
break a ;
oldProps = oldProps [ "return" ] ;
}
oldProps . sibling [ "return" ] = oldProps [ "return" ] ;
oldProps = oldProps . sibling ;
}
oldProps = newProps . handler ;
newProps = oldProps ( newProps . props , type ) ;
workInProgress . child = reconcileChildFibers (
workInProgress ,
null !== current ? current . child : null ,
newProps ,
renderExpirationTime
) ;
return workInProgress . child ;
case 8 :
return ( workInProgress . tag = 7 ) , null ;
case 9 :
return null ;
2018-03-14 23:23:11 -07:00
case 14 :
return null ;
2018-01-30 08:47:02 -08:00
case 10 :
return null ;
case 11 :
return null ;
case 4 :
return (
popHostContainer ( workInProgress ) ,
updateHostContainer ( workInProgress ) ,
null
) ;
case 13 :
return popProvider ( workInProgress ) , null ;
case 12 :
return null ;
case 0 :
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."
) ;
}
}
} ;
}
2018-02-28 19:16:47 -08:00
function ReactFiberUnwindWork (
hostContext ,
2018-03-20 17:03:06 -07:00
legacyContext ,
newContext ,
2018-02-28 19:16:47 -08:00
scheduleWork ,
isAlreadyFailedLegacyErrorBoundary
) {
var popHostContainer = hostContext . popHostContainer ,
2018-03-20 17:03:06 -07:00
popHostContext = hostContext . popHostContext ,
popLegacyContextProvider = legacyContext . popContextProvider ,
popTopLevelLegacyContextObject = legacyContext . popTopLevelContextObject ,
popProvider = newContext . popProvider ;
2018-02-28 19:16:47 -08:00
return {
throwException : function ( returnFiber , sourceFiber , rawValue ) {
sourceFiber . effectTag |= 512 ;
sourceFiber . firstEffect = sourceFiber . lastEffect = null ;
sourceFiber = {
value : rawValue ,
source : sourceFiber ,
stack : getStackAddendumByWorkInProgressFiber ( sourceFiber )
} ;
do {
switch ( returnFiber . tag ) {
case 3 :
ensureUpdateQueues ( returnFiber ) ;
returnFiber . updateQueue . capturedValues = [ sourceFiber ] ;
returnFiber . effectTag |= 1024 ;
return ;
case 2 :
if (
( ( rawValue = returnFiber . stateNode ) ,
0 === ( returnFiber . effectTag & 64 ) &&
null !== rawValue &&
"function" === typeof rawValue . componentDidCatch &&
! isAlreadyFailedLegacyErrorBoundary ( rawValue ) )
) {
ensureUpdateQueues ( returnFiber ) ;
rawValue = returnFiber . updateQueue ;
var capturedValues = rawValue . capturedValues ;
null === capturedValues
? ( rawValue . capturedValues = [ sourceFiber ] )
: capturedValues . push ( sourceFiber ) ;
returnFiber . effectTag |= 1024 ;
return ;
}
}
returnFiber = returnFiber [ "return" ] ;
} while ( null !== returnFiber ) ;
} ,
unwindWork : function ( workInProgress ) {
switch ( workInProgress . tag ) {
case 2 :
2018-03-20 17:03:06 -07:00
popLegacyContextProvider ( workInProgress ) ;
2018-02-28 19:16:47 -08:00
var effectTag = workInProgress . effectTag ;
return effectTag & 1024
? ( ( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress )
: null ;
case 3 :
return (
popHostContainer ( workInProgress ) ,
2018-03-20 17:03:06 -07:00
popTopLevelLegacyContextObject ( workInProgress ) ,
2018-02-28 19:16:47 -08:00
( effectTag = workInProgress . effectTag ) ,
effectTag & 1024
? ( ( workInProgress . effectTag = ( effectTag & - 1025 ) | 64 ) ,
workInProgress )
: null
) ;
case 5 :
return popHostContext ( workInProgress ) , null ;
case 4 :
return popHostContainer ( workInProgress ) , null ;
case 13 :
return popProvider ( workInProgress ) , null ;
default :
return null ;
}
2018-03-20 17:03:06 -07:00
} ,
unwindInterruptedWork : function ( interruptedWork ) {
switch ( interruptedWork . tag ) {
case 2 :
popLegacyContextProvider ( interruptedWork ) ;
break ;
case 3 :
popHostContainer ( interruptedWork ) ;
popTopLevelLegacyContextObject ( interruptedWork ) ;
break ;
case 5 :
popHostContext ( interruptedWork ) ;
break ;
case 4 :
popHostContainer ( interruptedWork ) ;
break ;
case 13 :
popProvider ( interruptedWork ) ;
}
2018-02-28 19:16:47 -08:00
}
} ;
}
function logError ( boundary , errorInfo ) {
var source = errorInfo . source ;
null === errorInfo . stack && getStackAddendumByWorkInProgressFiber ( source ) ;
null !== source && getComponentName ( source ) ;
errorInfo = errorInfo . value ;
2018-04-04 15:11:21 -07:00
null !== boundary && 2 === boundary . tag && getComponentName ( boundary ) ;
2018-02-28 19:16:47 -08:00
try {
( errorInfo && errorInfo . suppressReactErrorLogging ) ||
console . error ( errorInfo ) ;
} catch ( e ) {
( e && e . suppressReactErrorLogging ) || console . error ( e ) ;
}
}
function ReactFiberCommitWork (
config ,
captureError ,
scheduleWork ,
computeExpirationForFiber ,
markLegacyErrorBoundaryAsFailed
) {
2018-01-30 08:47:02 -08:00
function safelyDetachRef ( current ) {
var ref = current . ref ;
if ( null !== ref )
2018-02-09 16:01:29 -08:00
if ( "function" === typeof ref )
try {
ref ( null ) ;
} catch ( refError ) {
captureError ( current , refError ) ;
}
2018-03-14 23:23:11 -07:00
else ref . current = null ;
2018-01-30 08:47:02 -08:00
}
2018-04-04 15:11:21 -07:00
function commitBeforeMutationLifeCycles ( current , finishedWork ) {
switch ( finishedWork . tag ) {
case 2 :
if ( finishedWork . effectTag & 2048 && null !== current ) {
var prevProps = current . memoizedProps ,
prevState = current . memoizedState ;
current = finishedWork . stateNode ;
current . props = finishedWork . memoizedProps ;
current . state = finishedWork . memoizedState ;
finishedWork = current . getSnapshotBeforeUpdate ( prevProps , prevState ) ;
current . _ _reactInternalSnapshotBeforeUpdate = finishedWork ;
}
break ;
case 3 :
case 5 :
case 6 :
case 4 :
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."
) ;
}
}
2018-02-28 19:16:47 -08:00
function commitLifeCycles ( finishedRoot , current , finishedWork ) {
2018-02-09 16:01:29 -08:00
switch ( finishedWork . tag ) {
2018-01-30 08:47:02 -08:00
case 2 :
2018-02-28 19:16:47 -08:00
finishedRoot = finishedWork . stateNode ;
2018-02-09 16:01:29 -08:00
if ( finishedWork . effectTag & 4 )
if ( null === current )
2018-02-28 19:16:47 -08:00
( finishedRoot . props = finishedWork . memoizedProps ) ,
( finishedRoot . state = finishedWork . memoizedState ) ,
finishedRoot . componentDidMount ( ) ;
2018-02-09 16:01:29 -08:00
else {
var prevProps = current . memoizedProps ;
current = current . memoizedState ;
2018-02-28 19:16:47 -08:00
finishedRoot . props = finishedWork . memoizedProps ;
finishedRoot . state = finishedWork . memoizedState ;
2018-04-04 15:11:21 -07:00
finishedRoot . componentDidUpdate (
prevProps ,
current ,
finishedRoot . _ _reactInternalSnapshotBeforeUpdate
) ;
2018-01-30 08:47:02 -08:00
}
2018-02-09 16:01:29 -08:00
finishedWork = finishedWork . updateQueue ;
2018-02-28 19:16:47 -08:00
null !== finishedWork && commitCallbacks ( finishedWork , finishedRoot ) ;
2018-02-09 16:01:29 -08:00
break ;
case 3 :
2018-02-28 19:16:47 -08:00
current = finishedWork . updateQueue ;
if ( null !== current ) {
finishedRoot = null ;
2018-02-09 16:01:29 -08:00
if ( null !== finishedWork . child )
switch ( finishedWork . child . tag ) {
case 5 :
2018-02-28 19:16:47 -08:00
finishedRoot = getPublicInstance ( finishedWork . child . stateNode ) ;
2018-02-09 16:01:29 -08:00
break ;
case 2 :
2018-02-28 19:16:47 -08:00
finishedRoot = finishedWork . child . stateNode ;
2018-02-09 16:01:29 -08:00
}
2018-02-28 19:16:47 -08:00
commitCallbacks ( current , finishedRoot ) ;
2018-02-09 16:01:29 -08:00
}
2018-01-30 08:47:02 -08:00
break ;
case 5 :
2018-02-28 19:16:47 -08:00
finishedRoot = finishedWork . stateNode ;
2018-02-09 16:01:29 -08:00
null === current &&
finishedWork . effectTag & 4 &&
commitMount (
2018-02-28 19:16:47 -08:00
finishedRoot ,
2018-02-09 16:01:29 -08:00
finishedWork . type ,
finishedWork . memoizedProps ,
finishedWork
) ;
2018-01-30 08:47:02 -08:00
break ;
2018-02-09 16:01:29 -08:00
case 6 :
2018-01-30 08:47:02 -08:00
break ;
case 4 :
2018-02-09 16:01:29 -08:00
break ;
default :
2018-01-30 08:47:02 -08:00
invariant (
! 1 ,
2018-02-09 16:01:29 -08:00
"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-01-30 08:47:02 -08:00
) ;
2018-02-09 16:01:29 -08:00
}
}
2018-02-28 19:16:47 -08:00
function commitErrorLogging ( finishedWork , onUncaughtError ) {
switch ( finishedWork . tag ) {
case 2 :
var ctor = finishedWork . type ;
onUncaughtError = finishedWork . stateNode ;
var updateQueue = finishedWork . updateQueue ;
invariant (
null !== updateQueue && null !== updateQueue . capturedValues ,
"An error logging effect should not have been scheduled if no errors were captured. This error is likely caused by a bug in React. Please file an issue."
) ;
var capturedErrors = updateQueue . capturedValues ;
updateQueue . capturedValues = null ;
"function" !== typeof ctor . getDerivedStateFromCatch &&
markLegacyErrorBoundaryAsFailed ( onUncaughtError ) ;
onUncaughtError . props = finishedWork . memoizedProps ;
onUncaughtError . state = finishedWork . memoizedState ;
for ( ctor = 0 ; ctor < capturedErrors . length ; ctor ++ ) {
updateQueue = capturedErrors [ ctor ] ;
2018-04-04 15:11:21 -07:00
var _error = updateQueue . value ,
stack = updateQueue . stack ;
2018-02-28 19:16:47 -08:00
logError ( finishedWork , updateQueue ) ;
2018-04-04 15:11:21 -07:00
onUncaughtError . componentDidCatch ( _error , {
componentStack : null !== stack ? stack : ""
} ) ;
2018-02-28 19:16:47 -08:00
}
break ;
case 3 :
ctor = finishedWork . updateQueue ;
invariant (
null !== ctor && null !== ctor . capturedValues ,
"An error logging effect should not have been scheduled if no errors were captured. This error is likely caused by a bug in React. Please file an issue."
) ;
capturedErrors = ctor . capturedValues ;
ctor . capturedValues = null ;
for ( ctor = 0 ; ctor < capturedErrors . length ; ctor ++ )
( updateQueue = capturedErrors [ ctor ] ) ,
logError ( finishedWork , updateQueue ) ,
onUncaughtError ( updateQueue . value ) ;
break ;
default :
invariant (
! 1 ,
"This unit of work tag cannot capture errors. This error is likely caused by a bug in React. Please file an issue."
) ;
}
}
2018-02-09 16:01:29 -08:00
function commitAttachRef ( finishedWork ) {
var ref = finishedWork . ref ;
if ( null !== ref ) {
2018-04-04 15:11:21 -07:00
var _instance6 = finishedWork . stateNode ;
2018-01-30 08:47:02 -08:00
switch ( finishedWork . tag ) {
case 5 :
2018-04-04 15:11:21 -07:00
finishedWork = getPublicInstance ( _instance6 ) ;
2018-01-30 08:47:02 -08:00
break ;
default :
2018-04-04 15:11:21 -07:00
finishedWork = _instance6 ;
2018-01-30 08:47:02 -08:00
}
2018-02-09 16:01:29 -08:00
"function" === typeof ref
? ref ( finishedWork )
2018-03-14 23:23:11 -07:00
: ( ref . current = finishedWork ) ;
2018-02-09 16:01:29 -08:00
}
}
function commitDetachRef ( current ) {
current = current . ref ;
null !== current &&
2018-03-14 23:23:11 -07:00
( "function" === typeof current
? current ( null )
: ( current . current = null ) ) ;
2018-02-09 16:01:29 -08:00
}
function commitNestedUnmounts ( root ) {
for ( var node = root ; ; ) {
var current = node ;
"function" === typeof onCommitUnmount && onCommitUnmount ( current ) ;
switch ( current . tag ) {
2018-01-30 08:47:02 -08:00
case 2 :
2018-02-09 16:01:29 -08:00
safelyDetachRef ( current ) ;
2018-04-04 15:11:21 -07:00
var _instance7 = current . stateNode ;
if ( "function" === typeof _instance7 . componentWillUnmount )
2018-02-09 16:01:29 -08:00
try {
2018-04-04 15:11:21 -07:00
( _instance7 . props = current . memoizedProps ) ,
( _instance7 . state = current . memoizedState ) ,
_instance7 . componentWillUnmount ( ) ;
2018-02-09 16:01:29 -08:00
} catch ( unmountError ) {
captureError ( current , unmountError ) ;
2018-01-30 08:47:02 -08:00
}
break ;
case 5 :
2018-02-09 16:01:29 -08:00
safelyDetachRef ( current ) ;
2018-01-30 08:47:02 -08:00
break ;
2018-02-09 16:01:29 -08:00
case 7 :
commitNestedUnmounts ( current . stateNode ) ;
2018-01-30 08:47:02 -08:00
break ;
case 4 :
2018-02-09 16:01:29 -08:00
persistence && emptyPortalContainer ( current ) ;
2018-01-30 08:47:02 -08:00
}
2018-02-09 16:01:29 -08:00
if ( null === node . child || ( mutation && 4 === node . tag ) ) {
if ( node === root ) break ;
for ( ; null === node . sibling ; ) {
if ( null === node [ "return" ] || node [ "return" ] === root ) return ;
node = node [ "return" ] ;
}
node . sibling [ "return" ] = node [ "return" ] ;
node = node . sibling ;
} else ( node . child [ "return" ] = node ) , ( node = node . child ) ;
}
}
var getPublicInstance = config . getPublicInstance ,
mutation = config . mutation ,
persistence = config . persistence ,
emptyPortalContainer = void 0 ;
if ( ! mutation ) {
var commitContainer = void 0 ;
if ( persistence ) {
var replaceContainerChildren = persistence . replaceContainerChildren ,
createContainerChildSet = persistence . createContainerChildSet ;
emptyPortalContainer = function ( current ) {
current = current . stateNode . containerInfo ;
var emptyChildSet = createContainerChildSet ( current ) ;
replaceContainerChildren ( current , emptyChildSet ) ;
} ;
commitContainer = function ( finishedWork ) {
2018-01-30 08:47:02 -08:00
switch ( finishedWork . tag ) {
2018-02-09 16:01:29 -08:00
case 2 :
break ;
2018-01-30 08:47:02 -08:00
case 5 :
2018-02-09 16:01:29 -08:00
break ;
case 6 :
break ;
case 3 :
case 4 :
finishedWork = finishedWork . stateNode ;
replaceContainerChildren (
finishedWork . containerInfo ,
finishedWork . pendingChildren
) ;
2018-01-30 08:47:02 -08:00
break ;
default :
2018-02-09 16:01:29 -08:00
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-01-30 08:47:02 -08:00
}
2018-02-09 16:01:29 -08:00
} ;
} else commitContainer = function ( ) { } ;
return {
commitResetTextContent : function ( ) { } ,
commitPlacement : function ( ) { } ,
commitDeletion : function ( current ) {
commitNestedUnmounts ( current ) ;
current [ "return" ] = null ;
current . child = null ;
current . alternate &&
( ( current . alternate . child = null ) ,
( current . alternate [ "return" ] = null ) ) ;
} ,
commitWork : function ( current , finishedWork ) {
commitContainer ( finishedWork ) ;
} ,
commitLifeCycles : commitLifeCycles ,
2018-04-04 15:11:21 -07:00
commitBeforeMutationLifeCycles : commitBeforeMutationLifeCycles ,
2018-02-28 19:16:47 -08:00
commitErrorLogging : commitErrorLogging ,
2018-02-09 16:01:29 -08:00
commitAttachRef : commitAttachRef ,
commitDetachRef : commitDetachRef
} ;
}
var commitMount = mutation . commitMount ;
invariant ( ! 1 , "Mutating reconciler is disabled." ) ;
2018-01-30 08:47:02 -08:00
}
var NO _CONTEXT = { } ;
2018-03-20 17:03:06 -07:00
function ReactFiberHostContext ( config , stack ) {
2018-01-30 08:47:02 -08: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 ;
}
var getChildHostContext = config . getChildHostContext ,
2018-03-20 17:03:06 -07:00
getRootHostContext = config . getRootHostContext ;
config = stack . createCursor ;
var push = stack . push ,
pop = stack . pop ,
contextStackCursor = config ( NO _CONTEXT ) ,
contextFiberStackCursor = config ( NO _CONTEXT ) ,
rootInstanceStackCursor = config ( NO _CONTEXT ) ;
2018-01-30 08:47:02 -08:00
return {
getHostContext : function ( ) {
return requiredContext ( contextStackCursor . current ) ;
} ,
getRootHostContainer : function ( ) {
return requiredContext ( rootInstanceStackCursor . current ) ;
} ,
popHostContainer : function ( fiber ) {
pop ( contextStackCursor , fiber ) ;
pop ( contextFiberStackCursor , fiber ) ;
pop ( rootInstanceStackCursor , fiber ) ;
} ,
popHostContext : function ( fiber ) {
contextFiberStackCursor . current === fiber &&
( pop ( contextStackCursor , fiber ) , pop ( contextFiberStackCursor , fiber ) ) ;
} ,
pushHostContainer : function ( fiber , nextRootInstance ) {
push ( rootInstanceStackCursor , nextRootInstance , fiber ) ;
push ( contextFiberStackCursor , fiber , fiber ) ;
2018-04-04 15:11:21 -07:00
push ( contextStackCursor , NO _CONTEXT , fiber ) ;
nextRootInstance = getRootHostContext ( nextRootInstance ) ;
pop ( contextStackCursor , fiber ) ;
2018-01-30 08:47:02 -08:00
push ( contextStackCursor , nextRootInstance , fiber ) ;
} ,
pushHostContext : function ( fiber ) {
var rootInstance = requiredContext ( rootInstanceStackCursor . current ) ,
context = requiredContext ( contextStackCursor . current ) ;
rootInstance = getChildHostContext ( context , fiber . type , rootInstance ) ;
context !== rootInstance &&
( push ( contextFiberStackCursor , fiber , fiber ) ,
push ( contextStackCursor , rootInstance , fiber ) ) ;
}
} ;
}
function ReactFiberHydrationContext ( config ) {
function deleteHydratableInstance ( returnFiber , instance ) {
var fiber = new FiberNode ( 5 , null , null , 0 ) ;
fiber . type = "DELETED" ;
fiber . stateNode = instance ;
fiber [ "return" ] = returnFiber ;
fiber . effectTag = 8 ;
null !== returnFiber . lastEffect
? ( ( returnFiber . lastEffect . nextEffect = fiber ) ,
( returnFiber . lastEffect = fiber ) )
: ( returnFiber . firstEffect = returnFiber . lastEffect = fiber ) ;
}
function tryHydrate ( fiber , nextInstance ) {
switch ( fiber . tag ) {
case 5 :
return (
( nextInstance = canHydrateInstance (
nextInstance ,
fiber . type ,
fiber . pendingProps
) ) ,
null !== nextInstance ? ( ( fiber . stateNode = nextInstance ) , ! 0 ) : ! 1
) ;
case 6 :
return (
( nextInstance = canHydrateTextInstance (
nextInstance ,
fiber . pendingProps
) ) ,
null !== nextInstance ? ( ( fiber . stateNode = nextInstance ) , ! 0 ) : ! 1
) ;
default :
return ! 1 ;
}
}
function popToNextHostParent ( fiber ) {
for (
fiber = fiber [ "return" ] ;
null !== fiber && 5 !== fiber . tag && 3 !== fiber . tag ;
)
fiber = fiber [ "return" ] ;
hydrationParentFiber = fiber ;
}
var shouldSetTextContent = config . shouldSetTextContent ;
config = config . hydration ;
if ( ! config )
return {
enterHydrationState : function ( ) {
return ! 1 ;
} ,
resetHydrationState : function ( ) { } ,
tryToClaimNextHydratableInstance : function ( ) { } ,
prepareToHydrateHostInstance : function ( ) {
invariant (
! 1 ,
"Expected prepareToHydrateHostInstance() to never be called. This error is likely caused by a bug in React. Please file an issue."
) ;
} ,
prepareToHydrateHostTextInstance : function ( ) {
invariant (
! 1 ,
"Expected prepareToHydrateHostTextInstance() to never be called. This error is likely caused by a bug in React. Please file an issue."
) ;
} ,
popHydrationState : function ( ) {
return ! 1 ;
}
} ;
var canHydrateInstance = config . canHydrateInstance ,
canHydrateTextInstance = config . canHydrateTextInstance ,
getNextHydratableSibling = config . getNextHydratableSibling ,
getFirstHydratableChild = config . getFirstHydratableChild ,
hydrateInstance = config . hydrateInstance ,
hydrateTextInstance = config . hydrateTextInstance ,
hydrationParentFiber = null ,
nextHydratableInstance = null ,
isHydrating = ! 1 ;
return {
enterHydrationState : function ( fiber ) {
nextHydratableInstance = getFirstHydratableChild (
fiber . stateNode . containerInfo
) ;
hydrationParentFiber = fiber ;
return ( isHydrating = ! 0 ) ;
} ,
resetHydrationState : function ( ) {
nextHydratableInstance = hydrationParentFiber = null ;
isHydrating = ! 1 ;
} ,
tryToClaimNextHydratableInstance : function ( fiber ) {
if ( isHydrating ) {
var nextInstance = nextHydratableInstance ;
if ( nextInstance ) {
if ( ! tryHydrate ( fiber , nextInstance ) ) {
nextInstance = getNextHydratableSibling ( nextInstance ) ;
if ( ! nextInstance || ! tryHydrate ( fiber , nextInstance ) ) {
fiber . effectTag |= 2 ;
isHydrating = ! 1 ;
hydrationParentFiber = fiber ;
return ;
}
deleteHydratableInstance (
hydrationParentFiber ,
nextHydratableInstance
) ;
}
hydrationParentFiber = fiber ;
nextHydratableInstance = getFirstHydratableChild ( nextInstance ) ;
} else
( fiber . effectTag |= 2 ) ,
( isHydrating = ! 1 ) ,
( hydrationParentFiber = fiber ) ;
}
} ,
prepareToHydrateHostInstance : function (
fiber ,
rootContainerInstance ,
hostContext
) {
rootContainerInstance = hydrateInstance (
fiber . stateNode ,
fiber . type ,
fiber . memoizedProps ,
rootContainerInstance ,
hostContext ,
fiber
) ;
fiber . updateQueue = rootContainerInstance ;
return null !== rootContainerInstance ? ! 0 : ! 1 ;
} ,
prepareToHydrateHostTextInstance : function ( fiber ) {
return hydrateTextInstance ( fiber . stateNode , fiber . memoizedProps , fiber ) ;
} ,
popHydrationState : function ( fiber ) {
if ( fiber !== hydrationParentFiber ) return ! 1 ;
if ( ! isHydrating )
return popToNextHostParent ( fiber ) , ( isHydrating = ! 0 ) , ! 1 ;
var type = fiber . type ;
if (
5 !== fiber . tag ||
( "head" !== type &&
"body" !== type &&
! shouldSetTextContent ( type , fiber . memoizedProps ) )
)
for ( type = nextHydratableInstance ; type ; )
deleteHydratableInstance ( fiber , type ) ,
( type = getNextHydratableSibling ( type ) ) ;
popToNextHostParent ( fiber ) ;
nextHydratableInstance = hydrationParentFiber
? getNextHydratableSibling ( fiber . stateNode )
: null ;
return ! 0 ;
}
} ;
}
2018-03-20 17:03:06 -07:00
function ReactFiberLegacyContext ( stack ) {
function cacheContext ( workInProgress , unmaskedContext , maskedContext ) {
workInProgress = workInProgress . stateNode ;
workInProgress . _ _reactInternalMemoizedUnmaskedChildContext = unmaskedContext ;
workInProgress . _ _reactInternalMemoizedMaskedChildContext = maskedContext ;
}
function isContextProvider ( fiber ) {
return 2 === fiber . tag && null != fiber . type . childContextTypes ;
}
function processChildContext ( fiber , parentContext ) {
var instance = fiber . stateNode ,
childContextTypes = fiber . type . childContextTypes ;
if ( "function" !== typeof instance . getChildContext ) return parentContext ;
instance = instance . getChildContext ( ) ;
for ( var contextKey in instance )
invariant (
contextKey in childContextTypes ,
'%s.getChildContext(): key "%s" is not defined in childContextTypes.' ,
getComponentName ( fiber ) || "Unknown" ,
contextKey
) ;
return Object . assign ( { } , parentContext , instance ) ;
}
var createCursor = stack . createCursor ,
push = stack . push ,
pop = stack . pop ,
contextStackCursor = createCursor ( emptyObject ) ,
didPerformWorkStackCursor = createCursor ( ! 1 ) ,
2018-02-28 19:16:47 -08:00
previousContext = emptyObject ;
2018-03-20 17:03:06 -07:00
return {
getUnmaskedContext : function ( workInProgress ) {
return isContextProvider ( workInProgress )
? previousContext
: contextStackCursor . current ;
} ,
cacheContext : cacheContext ,
getMaskedContext : function ( workInProgress , unmaskedContext ) {
var contextTypes = workInProgress . type . contextTypes ;
if ( ! contextTypes ) return emptyObject ;
var instance = workInProgress . stateNode ;
if (
instance &&
instance . _ _reactInternalMemoizedUnmaskedChildContext === unmaskedContext
)
return instance . _ _reactInternalMemoizedMaskedChildContext ;
var context = { } ,
key ;
for ( key in contextTypes ) context [ key ] = unmaskedContext [ key ] ;
instance && cacheContext ( workInProgress , unmaskedContext , context ) ;
return context ;
} ,
hasContextChanged : function ( ) {
return didPerformWorkStackCursor . current ;
} ,
isContextConsumer : function ( fiber ) {
return 2 === fiber . tag && null != fiber . type . contextTypes ;
} ,
isContextProvider : isContextProvider ,
popContextProvider : function ( fiber ) {
isContextProvider ( fiber ) &&
( pop ( didPerformWorkStackCursor , fiber ) , pop ( contextStackCursor , fiber ) ) ;
} ,
popTopLevelContextObject : function ( fiber ) {
pop ( didPerformWorkStackCursor , fiber ) ;
pop ( contextStackCursor , fiber ) ;
} ,
pushTopLevelContextObject : function ( fiber , context , didChange ) {
invariant (
null == contextStackCursor . cursor ,
"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 ) ;
} ,
processChildContext : processChildContext ,
pushContextProvider : function ( workInProgress ) {
if ( ! isContextProvider ( workInProgress ) ) return ! 1 ;
var instance = workInProgress . stateNode ;
instance =
( instance && instance . _ _reactInternalMemoizedMergedChildContext ) ||
emptyObject ;
previousContext = contextStackCursor . current ;
push ( contextStackCursor , instance , workInProgress ) ;
push (
didPerformWorkStackCursor ,
didPerformWorkStackCursor . current ,
workInProgress
) ;
return ! 0 ;
} ,
invalidateContextProvider : function ( workInProgress , didChange ) {
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."
) ;
if ( didChange ) {
var mergedContext = processChildContext (
workInProgress ,
previousContext
) ;
instance . _ _reactInternalMemoizedMergedChildContext = mergedContext ;
pop ( didPerformWorkStackCursor , workInProgress ) ;
pop ( contextStackCursor , workInProgress ) ;
push ( contextStackCursor , mergedContext , workInProgress ) ;
} else pop ( didPerformWorkStackCursor , workInProgress ) ;
push ( didPerformWorkStackCursor , didChange , workInProgress ) ;
} ,
findCurrentUnmaskedContext : function ( fiber ) {
for (
invariant (
2 === isFiberMountedImpl ( fiber ) && 2 === fiber . tag ,
"Expected subtree parent to be a mounted class component. This error is likely caused by a bug in React. Please file an issue."
) ;
3 !== fiber . tag ;
) {
if ( isContextProvider ( fiber ) )
return fiber . stateNode . _ _reactInternalMemoizedMergedChildContext ;
fiber = fiber [ "return" ] ;
invariant (
fiber ,
"Found unexpected detached subtree parent. This error is likely caused by a bug in React. Please file an issue."
) ;
}
return fiber . stateNode . context ;
}
} ;
}
function ReactFiberNewContext ( stack ) {
var createCursor = stack . createCursor ,
push = stack . push ,
pop = stack . pop ,
providerCursor = createCursor ( null ) ,
valueCursor = createCursor ( null ) ,
changedBitsCursor = createCursor ( 0 ) ;
return {
pushProvider : function ( providerFiber ) {
2018-04-04 15:11:21 -07:00
var context = providerFiber . type . _context ;
2018-03-20 17:03:06 -07:00
push ( changedBitsCursor , context . _changedBits , providerFiber ) ;
push ( valueCursor , context . _currentValue , providerFiber ) ;
push ( providerCursor , providerFiber , providerFiber ) ;
context . _currentValue = providerFiber . pendingProps . value ;
context . _changedBits = providerFiber . stateNode ;
} ,
popProvider : function ( providerFiber ) {
var changedBits = changedBitsCursor . current ,
currentValue = valueCursor . current ;
pop ( providerCursor , providerFiber ) ;
pop ( valueCursor , providerFiber ) ;
pop ( changedBitsCursor , providerFiber ) ;
2018-04-04 15:11:21 -07:00
providerFiber = providerFiber . type . _context ;
2018-03-20 17:03:06 -07:00
providerFiber . _currentValue = currentValue ;
providerFiber . _changedBits = changedBits ;
2018-02-28 19:16:47 -08:00
}
2018-03-20 17:03:06 -07:00
} ;
}
function ReactFiberStack ( ) {
var valueStack = [ ] ,
index = - 1 ;
return {
createCursor : function ( defaultValue ) {
return { current : defaultValue } ;
} ,
isEmpty : function ( ) {
return - 1 === index ;
} ,
pop : function ( cursor ) {
0 > index ||
( ( cursor . current = valueStack [ index ] ) ,
( valueStack [ index ] = null ) ,
index -- ) ;
} ,
push : function ( cursor , value ) {
index ++ ;
valueStack [ index ] = cursor . current ;
cursor . current = value ;
} ,
checkThatStackIsEmpty : function ( ) { } ,
resetStackAfterFatalErrorInDev : function ( ) { }
} ;
}
function ReactFiberScheduler ( config ) {
function resetStack ( ) {
if ( null !== nextUnitOfWork )
for (
var interruptedWork = nextUnitOfWork [ "return" ] ;
null !== interruptedWork ;
)
unwindInterruptedWork ( interruptedWork ) ,
( interruptedWork = interruptedWork [ "return" ] ) ;
2018-02-28 19:16:47 -08:00
nextRoot = null ;
nextRenderExpirationTime = 0 ;
nextUnitOfWork = null ;
isRootReadyForCommit = ! 1 ;
}
function isAlreadyFailedLegacyErrorBoundary ( instance ) {
return (
null !== legacyErrorBoundariesThatAlreadyFailed &&
legacyErrorBoundariesThatAlreadyFailed . has ( instance )
) ;
}
2018-01-30 08:47:02 -08:00
function completeUnitOfWork ( workInProgress$jscomp$0 ) {
for ( ; ; ) {
2018-02-28 19:16:47 -08:00
var current = workInProgress$jscomp$0 . alternate ,
2018-01-30 08:47:02 -08:00
returnFiber = workInProgress$jscomp$0 [ "return" ] ,
siblingFiber = workInProgress$jscomp$0 . sibling ;
2018-02-28 19:16:47 -08:00
if ( 0 === ( workInProgress$jscomp$0 . effectTag & 512 ) ) {
current = completeWork (
current ,
workInProgress$jscomp$0 ,
nextRenderExpirationTime
) ;
var workInProgress = workInProgress$jscomp$0 ;
if (
1073741823 === nextRenderExpirationTime ||
1073741823 !== workInProgress . expirationTime
) {
b : switch ( workInProgress . tag ) {
case 3 :
case 2 :
var newExpirationTime = workInProgress . updateQueue ;
newExpirationTime =
null === newExpirationTime
? 0
: newExpirationTime . expirationTime ;
break b ;
default :
newExpirationTime = 0 ;
}
for ( var child = workInProgress . child ; null !== child ; )
0 !== child . expirationTime &&
( 0 === newExpirationTime ||
newExpirationTime > child . expirationTime ) &&
( newExpirationTime = child . expirationTime ) ,
( child = child . sibling ) ;
workInProgress . expirationTime = newExpirationTime ;
}
if ( null !== current ) return current ;
null !== returnFiber &&
0 === ( returnFiber . effectTag & 512 ) &&
( null === returnFiber . firstEffect &&
( returnFiber . firstEffect = workInProgress$jscomp$0 . firstEffect ) ,
null !== workInProgress$jscomp$0 . lastEffect &&
( null !== returnFiber . lastEffect &&
( returnFiber . lastEffect . nextEffect =
workInProgress$jscomp$0 . firstEffect ) ,
( returnFiber . lastEffect = workInProgress$jscomp$0 . lastEffect ) ) ,
1 < workInProgress$jscomp$0 . effectTag &&
( null !== returnFiber . lastEffect
? ( returnFiber . lastEffect . nextEffect = workInProgress$jscomp$0 )
: ( returnFiber . firstEffect = workInProgress$jscomp$0 ) ,
( returnFiber . lastEffect = workInProgress$jscomp$0 ) ) ) ;
if ( null !== siblingFiber ) return siblingFiber ;
if ( null !== returnFiber ) workInProgress$jscomp$0 = returnFiber ;
else {
isRootReadyForCommit = ! 0 ;
break ;
}
} else {
workInProgress$jscomp$0 = unwindWork ( workInProgress$jscomp$0 ) ;
if ( null !== workInProgress$jscomp$0 )
return (
2018-04-04 15:11:21 -07:00
( workInProgress$jscomp$0 . effectTag &= 2559 ) , workInProgress$jscomp$0
2018-02-28 19:16:47 -08:00
) ;
null !== returnFiber &&
( ( returnFiber . firstEffect = returnFiber . lastEffect = null ) ,
( returnFiber . effectTag |= 512 ) ) ;
if ( null !== siblingFiber ) return siblingFiber ;
if ( null !== returnFiber ) workInProgress$jscomp$0 = returnFiber ;
else break ;
2018-01-30 08:47:02 -08:00
}
}
return null ;
}
function performUnitOfWork ( workInProgress ) {
var next = beginWork (
workInProgress . alternate ,
workInProgress ,
nextRenderExpirationTime
) ;
null === next && ( next = completeUnitOfWork ( workInProgress ) ) ;
ReactCurrentOwner . current = null ;
return next ;
}
2018-02-01 13:33:12 -08:00
function renderRoot ( root , expirationTime , isAsync ) {
2018-01-30 08:47:02 -08:00
invariant (
! isWorking ,
"renderRoot was called recursively. This error is likely caused by a bug in React. Please file an issue."
) ;
isWorking = ! 0 ;
if (
expirationTime !== nextRenderExpirationTime ||
2018-02-28 19:16:47 -08:00
root !== nextRoot ||
2018-01-30 08:47:02 -08:00
null === nextUnitOfWork
2018-02-28 19:16:47 -08:00
)
2018-03-20 17:03:06 -07:00
resetStack ( ) ,
2018-02-28 19:16:47 -08:00
( nextRoot = root ) ,
( nextRenderExpirationTime = expirationTime ) ,
( nextUnitOfWork = createWorkInProgress (
nextRoot . current ,
null ,
nextRenderExpirationTime
) ) ,
( root . pendingCommitExpirationTime = 0 ) ;
var didFatal = ! 1 ;
do {
try {
if ( isAsync )
for ( ; null !== nextUnitOfWork && ! shouldYield ( ) ; )
nextUnitOfWork = performUnitOfWork ( nextUnitOfWork ) ;
else
for ( ; null !== nextUnitOfWork ; )
nextUnitOfWork = performUnitOfWork ( nextUnitOfWork ) ;
} catch ( thrownValue ) {
if ( null === nextUnitOfWork ) {
didFatal = ! 0 ;
onUncaughtError ( thrownValue ) ;
2018-01-30 08:47:02 -08:00
break ;
}
2018-02-28 19:16:47 -08:00
isAsync = nextUnitOfWork ;
var returnFiber = isAsync [ "return" ] ;
if ( null === returnFiber ) {
didFatal = ! 0 ;
onUncaughtError ( thrownValue ) ;
break ;
2018-01-30 08:47:02 -08:00
}
2018-02-28 19:16:47 -08:00
throwException ( returnFiber , isAsync , thrownValue ) ;
nextUnitOfWork = completeUnitOfWork ( isAsync ) ;
2018-01-30 08:47:02 -08:00
}
2018-02-28 19:16:47 -08:00
break ;
} while ( 1 ) ;
isWorking = ! 1 ;
if ( didFatal || null !== nextUnitOfWork ) return null ;
if ( isRootReadyForCommit )
return (
( root . pendingCommitExpirationTime = expirationTime ) ,
root . current . alternate
) ;
invariant (
! 1 ,
"Expired work should have completed. This error is likely caused by a bug in React. Please file an issue."
) ;
}
function scheduleCapture ( sourceFiber , boundaryFiber , value , expirationTime ) {
sourceFiber = {
value : value ,
source : sourceFiber ,
stack : getStackAddendumByWorkInProgressFiber ( sourceFiber )
} ;
insertUpdateIntoFiber ( boundaryFiber , {
expirationTime : expirationTime ,
partialState : null ,
callback : null ,
isReplace : ! 1 ,
isForced : ! 1 ,
capturedValue : sourceFiber ,
next : null
} ) ;
scheduleWork ( boundaryFiber , expirationTime ) ;
}
function onCommitPhaseError ( fiber$jscomp$0 , error ) {
a : {
invariant (
! isWorking || isCommitting ,
"dispatch: Cannot dispatch during the render phase."
) ;
for ( var fiber = fiber$jscomp$0 [ "return" ] ; null !== fiber ; ) {
switch ( fiber . tag ) {
2018-01-30 08:47:02 -08:00
case 2 :
2018-02-28 19:16:47 -08:00
var instance = fiber . stateNode ;
if (
"function" === typeof fiber . type . getDerivedStateFromCatch ||
( "function" === typeof instance . componentDidCatch &&
! isAlreadyFailedLegacyErrorBoundary ( instance ) )
) {
scheduleCapture ( fiber$jscomp$0 , fiber , error , 1 ) ;
fiber$jscomp$0 = void 0 ;
break a ;
}
break ;
case 3 :
scheduleCapture ( fiber$jscomp$0 , fiber , error , 1 ) ;
fiber$jscomp$0 = void 0 ;
2018-01-30 08:47:02 -08:00
break a ;
}
2018-02-28 19:16:47 -08:00
fiber = fiber [ "return" ] ;
2018-01-30 08:47:02 -08:00
}
2018-02-28 19:16:47 -08:00
3 === fiber$jscomp$0 . tag &&
scheduleCapture ( fiber$jscomp$0 , fiber$jscomp$0 , error , 1 ) ;
fiber$jscomp$0 = void 0 ;
2018-01-30 08:47:02 -08:00
}
2018-02-28 19:16:47 -08:00
return fiber$jscomp$0 ;
2018-01-30 08:47:02 -08:00
}
function computeExpirationForFiber ( fiber ) {
2018-02-01 13:33:12 -08:00
fiber =
0 !== expirationContext
? expirationContext
: isWorking
? isCommitting ? 1 : nextRenderExpirationTime
: fiber . mode & 1
? isBatchingInteractiveUpdates
? 10 * ( ( ( ( recalculateCurrentTime ( ) + 50 ) / 10 ) | 0 ) + 1 )
2018-02-28 19:16:47 -08:00
: 25 * ( ( ( ( recalculateCurrentTime ( ) + 500 ) / 25 ) | 0 ) + 1 )
2018-02-01 13:33:12 -08:00
: 1 ;
isBatchingInteractiveUpdates &&
( 0 === lowestPendingInteractiveExpirationTime ||
fiber > lowestPendingInteractiveExpirationTime ) &&
( lowestPendingInteractiveExpirationTime = fiber ) ;
return fiber ;
2018-01-30 08:47:02 -08:00
}
function scheduleWork ( fiber , expirationTime ) {
2018-02-28 19:16:47 -08:00
a : {
for ( ; null !== fiber ; ) {
if ( 0 === fiber . expirationTime || fiber . expirationTime > expirationTime )
fiber . expirationTime = expirationTime ;
null !== fiber . alternate &&
( 0 === fiber . alternate . expirationTime ||
fiber . alternate . expirationTime > expirationTime ) &&
( fiber . alternate . expirationTime = expirationTime ) ;
if ( null === fiber [ "return" ] )
if ( 3 === fiber . tag ) {
var root = fiber . stateNode ;
! isWorking &&
0 !== nextRenderExpirationTime &&
expirationTime < nextRenderExpirationTime &&
2018-03-20 17:03:06 -07:00
resetStack ( ) ;
2018-04-04 15:11:21 -07:00
( isWorking && ! isCommitting && nextRoot === root ) ||
2018-02-28 19:16:47 -08:00
requestWork ( root , expirationTime ) ;
nestedUpdateCount > NESTED _UPDATE _LIMIT &&
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."
) ;
} else {
expirationTime = void 0 ;
break a ;
}
fiber = fiber [ "return" ] ;
}
expirationTime = void 0 ;
2018-01-30 08:47:02 -08:00
}
2018-02-28 19:16:47 -08:00
return expirationTime ;
2018-01-30 08:47:02 -08:00
}
function recalculateCurrentTime ( ) {
2018-02-28 19:16:47 -08:00
mostRecentCurrentTimeMs = now ( ) - originalStartTimeMs ;
return ( mostRecentCurrentTime = ( ( mostRecentCurrentTimeMs / 10 ) | 0 ) + 2 ) ;
2018-01-30 08:47:02 -08:00
}
2018-02-01 13:33:12 -08:00
function syncUpdates ( fn , a , b , c , d ) {
var previousExpirationContext = expirationContext ;
expirationContext = 1 ;
try {
return fn ( a , b , c , d ) ;
} finally {
expirationContext = previousExpirationContext ;
}
}
2018-01-30 08:47:02 -08:00
function scheduleCallbackWithExpiration ( expirationTime ) {
if ( 0 !== callbackExpirationTime ) {
if ( expirationTime > callbackExpirationTime ) return ;
cancelDeferredCallback ( callbackID ) ;
}
2018-02-28 19:16:47 -08:00
var currentMs = now ( ) - originalStartTimeMs ;
2018-01-30 08:47:02 -08:00
callbackExpirationTime = expirationTime ;
callbackID = scheduleDeferredCallback ( performAsyncWork , {
timeout : 10 * ( expirationTime - 2 ) - currentMs
} ) ;
}
function requestWork ( root , expirationTime ) {
if ( null === root . nextScheduledRoot )
( root . remainingExpirationTime = expirationTime ) ,
null === lastScheduledRoot
? ( ( firstScheduledRoot = lastScheduledRoot = root ) ,
( root . nextScheduledRoot = root ) )
: ( ( lastScheduledRoot = lastScheduledRoot . nextScheduledRoot = root ) ,
( lastScheduledRoot . nextScheduledRoot = firstScheduledRoot ) ) ;
else {
var remainingExpirationTime = root . remainingExpirationTime ;
if (
0 === remainingExpirationTime ||
expirationTime < remainingExpirationTime
)
root . remainingExpirationTime = expirationTime ;
}
isRendering ||
( isBatchingUpdates
? isUnbatchingUpdates &&
( ( nextFlushedRoot = root ) ,
( nextFlushedExpirationTime = 1 ) ,
2018-02-01 13:33:12 -08:00
performWorkOnRoot ( root , 1 , ! 1 ) )
2018-01-30 08:47:02 -08:00
: 1 === expirationTime
2018-04-04 15:11:21 -07:00
? performSyncWork ( )
2018-01-30 08:47:02 -08:00
: scheduleCallbackWithExpiration ( expirationTime ) ) ;
}
function findHighestPriorityRoot ( ) {
var highestPriorityWork = 0 ,
highestPriorityRoot = null ;
if ( null !== lastScheduledRoot )
for (
var previousScheduledRoot = lastScheduledRoot ,
root = firstScheduledRoot ;
null !== root ;
) {
var remainingExpirationTime = root . remainingExpirationTime ;
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 ;
previousScheduledRoot = root ;
root = root . nextScheduledRoot ;
}
}
previousScheduledRoot = nextFlushedRoot ;
null !== previousScheduledRoot &&
2018-02-28 19:16:47 -08:00
previousScheduledRoot === highestPriorityRoot &&
1 === highestPriorityWork
2018-01-30 08:47:02 -08:00
? nestedUpdateCount ++
: ( nestedUpdateCount = 0 ) ;
nextFlushedRoot = highestPriorityRoot ;
nextFlushedExpirationTime = highestPriorityWork ;
}
function performAsyncWork ( dl ) {
2018-02-01 13:33:12 -08:00
performWork ( 0 , ! 0 , dl ) ;
2018-01-30 08:47:02 -08:00
}
2018-04-04 15:11:21 -07:00
function performSyncWork ( ) {
performWork ( 1 , ! 1 , null ) ;
}
2018-02-01 13:33:12 -08:00
function performWork ( minExpirationTime , isAsync , dl ) {
2018-01-30 08:47:02 -08:00
deadline = dl ;
2018-02-01 13:33:12 -08:00
findHighestPriorityRoot ( ) ;
if ( isAsync )
for (
;
null !== nextFlushedRoot &&
0 !== nextFlushedExpirationTime &&
( 0 === minExpirationTime ||
minExpirationTime >= nextFlushedExpirationTime ) &&
( ! deadlineDidExpire ||
recalculateCurrentTime ( ) >= nextFlushedExpirationTime ) ;
2018-01-30 08:47:02 -08:00
2018-02-01 13:33:12 -08:00
)
performWorkOnRoot (
nextFlushedRoot ,
nextFlushedExpirationTime ,
! deadlineDidExpire
) ,
findHighestPriorityRoot ( ) ;
else
for (
;
null !== nextFlushedRoot &&
0 !== nextFlushedExpirationTime &&
( 0 === minExpirationTime ||
minExpirationTime >= nextFlushedExpirationTime ) ;
)
performWorkOnRoot ( nextFlushedRoot , nextFlushedExpirationTime , ! 1 ) ,
findHighestPriorityRoot ( ) ;
2018-01-30 08:47:02 -08:00
null !== deadline && ( ( callbackExpirationTime = 0 ) , ( callbackID = - 1 ) ) ;
0 !== nextFlushedExpirationTime &&
scheduleCallbackWithExpiration ( nextFlushedExpirationTime ) ;
deadline = null ;
deadlineDidExpire = ! 1 ;
finishRendering ( ) ;
}
function finishRendering ( ) {
2018-02-28 19:16:47 -08:00
nestedUpdateCount = 0 ;
2018-01-30 08:47:02 -08:00
if ( null !== completedBatches ) {
var batches = completedBatches ;
completedBatches = null ;
for ( var i = 0 ; i < batches . length ; i ++ ) {
var batch = batches [ i ] ;
try {
batch . _onComplete ( ) ;
} catch ( error ) {
hasUnhandledError ||
( ( hasUnhandledError = ! 0 ) , ( unhandledError = error ) ) ;
}
}
}
if ( hasUnhandledError )
throw ( ( batches = unhandledError ) ,
( unhandledError = null ) ,
( hasUnhandledError = ! 1 ) ,
batches ) ;
}
2018-02-01 13:33:12 -08:00
function performWorkOnRoot ( root , expirationTime , isAsync ) {
2018-01-30 08:47:02 -08:00
invariant (
! isRendering ,
"performWorkOnRoot was called recursively. This error is likely caused by a bug in React. Please file an issue."
) ;
isRendering = ! 0 ;
2018-02-01 13:33:12 -08:00
isAsync
? ( ( isAsync = root . finishedWork ) ,
null !== isAsync
? completeRoot ( root , isAsync , expirationTime )
2018-01-30 08:47:02 -08:00
: ( ( root . finishedWork = null ) ,
2018-02-01 13:33:12 -08:00
( isAsync = renderRoot ( root , expirationTime , ! 0 ) ) ,
null !== isAsync &&
2018-01-30 08:47:02 -08:00
( shouldYield ( )
2018-02-01 13:33:12 -08:00
? ( root . finishedWork = isAsync )
: completeRoot ( root , isAsync , expirationTime ) ) ) )
: ( ( isAsync = root . finishedWork ) ,
null !== isAsync
? completeRoot ( root , isAsync , expirationTime )
: ( ( root . finishedWork = null ) ,
( isAsync = renderRoot ( root , expirationTime , ! 1 ) ) ,
null !== isAsync && completeRoot ( root , isAsync , expirationTime ) ) ) ;
2018-01-30 08:47:02 -08:00
isRendering = ! 1 ;
}
function completeRoot ( root , finishedWork , expirationTime ) {
var firstBatch = root . firstBatch ;
if (
null !== firstBatch &&
firstBatch . _expirationTime <= expirationTime &&
( null === completedBatches
? ( completedBatches = [ firstBatch ] )
: completedBatches . push ( firstBatch ) ,
firstBatch . _defer )
) {
root . finishedWork = finishedWork ;
root . remainingExpirationTime = 0 ;
return ;
}
root . finishedWork = null ;
isCommitting = isWorking = ! 0 ;
expirationTime = finishedWork . stateNode ;
invariant (
expirationTime . current !== finishedWork ,
"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."
) ;
2018-02-28 19:16:47 -08:00
firstBatch = expirationTime . pendingCommitExpirationTime ;
invariant (
0 !== firstBatch ,
"Cannot commit an incomplete root. This error is likely caused by a bug in React. Please file an issue."
) ;
expirationTime . pendingCommitExpirationTime = 0 ;
var currentTime = recalculateCurrentTime ( ) ;
2018-01-30 08:47:02 -08:00
ReactCurrentOwner . current = null ;
2018-02-28 19:16:47 -08:00
if ( 1 < finishedWork . effectTag )
if ( null !== finishedWork . lastEffect ) {
finishedWork . lastEffect . nextEffect = finishedWork ;
var firstEffect = finishedWork . firstEffect ;
} else firstEffect = finishedWork ;
else firstEffect = finishedWork . firstEffect ;
2018-02-01 13:33:12 -08:00
prepareForCommit ( expirationTime . containerInfo ) ;
2018-02-28 19:16:47 -08:00
for ( nextEffect = firstEffect ; null !== nextEffect ; ) {
2018-01-30 08:47:02 -08:00
var didError = ! 1 ,
2018-02-28 19:16:47 -08:00
error = void 0 ;
2018-04-04 15:11:21 -07:00
try {
for ( ; null !== nextEffect ; )
nextEffect . effectTag & 2048 &&
commitBeforeMutationLifeCycles ( nextEffect . alternate , nextEffect ) ,
( nextEffect = nextEffect . nextEffect ) ;
} catch ( e ) {
( didError = ! 0 ) , ( error = e ) ;
}
didError &&
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
onCommitPhaseError ( nextEffect , error ) ,
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
}
for ( nextEffect = firstEffect ; null !== nextEffect ; ) {
didError = ! 1 ;
error = void 0 ;
2018-01-30 08:47:02 -08:00
try {
for ( ; null !== nextEffect ; ) {
var effectTag = nextEffect . effectTag ;
effectTag & 16 && commitResetTextContent ( nextEffect ) ;
if ( effectTag & 128 ) {
var current = nextEffect . alternate ;
null !== current && commitDetachRef ( current ) ;
}
2018-02-28 19:16:47 -08:00
switch ( effectTag & 14 ) {
2018-01-30 08:47:02 -08:00
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 :
2018-02-28 19:16:47 -08:00
commitDeletion ( nextEffect ) ;
2018-01-30 08:47:02 -08:00
}
nextEffect = nextEffect . nextEffect ;
}
} catch ( e ) {
2018-02-28 19:16:47 -08:00
( didError = ! 0 ) , ( error = e ) ;
2018-01-30 08:47:02 -08:00
}
didError &&
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
2018-02-28 19:16:47 -08:00
onCommitPhaseError ( nextEffect , error ) ,
2018-01-30 08:47:02 -08:00
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
}
2018-02-01 13:33:12 -08:00
resetAfterCommit ( expirationTime . containerInfo ) ;
2018-01-30 08:47:02 -08:00
expirationTime . current = finishedWork ;
2018-02-28 19:16:47 -08:00
for ( nextEffect = firstEffect ; null !== nextEffect ; ) {
2018-01-30 08:47:02 -08:00
effectTag = ! 1 ;
current = void 0 ;
try {
2018-02-28 19:16:47 -08:00
for (
firstEffect = expirationTime ,
didError = currentTime ,
error = firstBatch ;
null !== nextEffect ;
) {
2018-01-30 08:47:02 -08:00
var effectTag$jscomp$0 = nextEffect . effectTag ;
effectTag$jscomp$0 & 36 &&
2018-02-28 19:16:47 -08:00
commitLifeCycles (
firstEffect ,
nextEffect . alternate ,
nextEffect ,
didError ,
error
) ;
effectTag$jscomp$0 & 256 &&
commitErrorLogging ( nextEffect , onUncaughtError ) ;
2018-01-30 08:47:02 -08:00
effectTag$jscomp$0 & 128 && commitAttachRef ( nextEffect ) ;
var next = nextEffect . nextEffect ;
nextEffect . nextEffect = null ;
nextEffect = next ;
}
} catch ( e ) {
( effectTag = ! 0 ) , ( current = e ) ;
}
effectTag &&
( invariant (
null !== nextEffect ,
"Should have next effect. This error is likely caused by a bug in React. Please file an issue."
) ,
2018-02-28 19:16:47 -08:00
onCommitPhaseError ( nextEffect , current ) ,
2018-01-30 08:47:02 -08:00
null !== nextEffect && ( nextEffect = nextEffect . nextEffect ) ) ;
}
isWorking = isCommitting = ! 1 ;
"function" === typeof onCommitRoot && onCommitRoot ( finishedWork . stateNode ) ;
finishedWork = expirationTime . current . expirationTime ;
2018-02-28 19:16:47 -08:00
0 === finishedWork && ( legacyErrorBoundariesThatAlreadyFailed = null ) ;
2018-01-30 08:47:02 -08:00
root . remainingExpirationTime = finishedWork ;
}
function shouldYield ( ) {
return null === deadline ||
deadline . timeRemaining ( ) > timeHeuristicForUnitOfWork
? ! 1
: ( deadlineDidExpire = ! 0 ) ;
}
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 . remainingExpirationTime = 0 ;
hasUnhandledError || ( ( hasUnhandledError = ! 0 ) , ( unhandledError = error ) ) ;
}
2018-03-20 17:03:06 -07:00
var stack = ReactFiberStack ( ) ,
hostContext = ReactFiberHostContext ( config , stack ) ,
legacyContext = ReactFiberLegacyContext ( stack ) ;
stack = ReactFiberNewContext ( stack ) ;
var hydrationContext = ReactFiberHydrationContext ( config ) ,
2018-02-28 19:16:47 -08:00
beginWork = ReactFiberBeginWork (
2018-01-30 08:47:02 -08:00
config ,
hostContext ,
2018-03-20 17:03:06 -07:00
legacyContext ,
stack ,
2018-01-30 08:47:02 -08:00
hydrationContext ,
scheduleWork ,
computeExpirationForFiber
2018-02-28 19:16:47 -08:00
) . beginWork ,
2018-03-20 17:03:06 -07:00
completeWork = ReactFiberCompleteWork (
config ,
hostContext ,
legacyContext ,
stack ,
hydrationContext
) . completeWork ;
2018-02-28 19:16:47 -08:00
hostContext = ReactFiberUnwindWork (
hostContext ,
2018-03-20 17:03:06 -07:00
legacyContext ,
stack ,
2018-02-28 19:16:47 -08:00
scheduleWork ,
isAlreadyFailedLegacyErrorBoundary
) ;
var throwException = hostContext . throwException ,
2018-03-20 17:03:06 -07:00
unwindWork = hostContext . unwindWork ,
unwindInterruptedWork = hostContext . unwindInterruptedWork ;
2018-02-28 19:16:47 -08:00
hostContext = ReactFiberCommitWork (
config ,
onCommitPhaseError ,
scheduleWork ,
computeExpirationForFiber ,
function ( instance ) {
null === legacyErrorBoundariesThatAlreadyFailed
? ( legacyErrorBoundariesThatAlreadyFailed = new Set ( [ instance ] ) )
: legacyErrorBoundariesThatAlreadyFailed . add ( instance ) ;
} ,
recalculateCurrentTime
) ;
2018-04-04 15:11:21 -07:00
var commitBeforeMutationLifeCycles =
hostContext . commitBeforeMutationLifeCycles ,
commitResetTextContent = hostContext . commitResetTextContent ,
2018-01-30 08:47:02 -08:00
commitPlacement = hostContext . commitPlacement ,
commitDeletion = hostContext . commitDeletion ,
commitWork = hostContext . commitWork ,
commitLifeCycles = hostContext . commitLifeCycles ,
2018-02-28 19:16:47 -08:00
commitErrorLogging = hostContext . commitErrorLogging ,
2018-01-30 08:47:02 -08:00
commitAttachRef = hostContext . commitAttachRef ,
commitDetachRef = hostContext . commitDetachRef ,
now = config . now ,
scheduleDeferredCallback = config . scheduleDeferredCallback ,
cancelDeferredCallback = config . cancelDeferredCallback ,
prepareForCommit = config . prepareForCommit ,
resetAfterCommit = config . resetAfterCommit ,
2018-02-28 19:16:47 -08:00
originalStartTimeMs = now ( ) ,
2018-01-30 08:47:02 -08:00
mostRecentCurrentTime = 2 ,
2018-02-28 19:16:47 -08:00
mostRecentCurrentTimeMs = originalStartTimeMs ,
2018-01-30 08:47:02 -08:00
lastUniqueAsyncExpiration = 0 ,
expirationContext = 0 ,
isWorking = ! 1 ,
nextUnitOfWork = null ,
nextRoot = null ,
nextRenderExpirationTime = 0 ,
nextEffect = null ,
isCommitting = ! 1 ,
2018-02-28 19:16:47 -08:00
isRootReadyForCommit = ! 1 ,
legacyErrorBoundariesThatAlreadyFailed = null ,
2018-01-30 08:47:02 -08:00
firstScheduledRoot = null ,
lastScheduledRoot = null ,
callbackExpirationTime = 0 ,
callbackID = - 1 ,
isRendering = ! 1 ,
nextFlushedRoot = null ,
nextFlushedExpirationTime = 0 ,
2018-02-01 13:33:12 -08:00
lowestPendingInteractiveExpirationTime = 0 ,
2018-01-30 08:47:02 -08:00
deadlineDidExpire = ! 1 ,
hasUnhandledError = ! 1 ,
unhandledError = null ,
deadline = null ,
isBatchingUpdates = ! 1 ,
isUnbatchingUpdates = ! 1 ,
2018-02-01 13:33:12 -08:00
isBatchingInteractiveUpdates = ! 1 ,
2018-01-30 08:47:02 -08:00
completedBatches = null ,
NESTED _UPDATE _LIMIT = 1e3 ,
nestedUpdateCount = 0 ,
timeHeuristicForUnitOfWork = 1 ;
return {
2018-02-28 19:16:47 -08:00
recalculateCurrentTime : recalculateCurrentTime ,
2018-01-30 08:47:02 -08:00
computeExpirationForFiber : computeExpirationForFiber ,
scheduleWork : scheduleWork ,
requestWork : requestWork ,
flushRoot : function ( root , expirationTime ) {
invariant (
! isRendering ,
"work.commit(): Cannot commit while already rendering. This likely means you attempted to commit from inside a lifecycle method."
) ;
2018-04-04 15:11:21 -07:00
nextFlushedRoot = root ;
nextFlushedExpirationTime = expirationTime ;
2018-02-01 13:33:12 -08:00
performWorkOnRoot ( root , expirationTime , ! 1 ) ;
2018-04-04 15:11:21 -07:00
performSyncWork ( ) ;
2018-01-30 08:47:02 -08:00
finishRendering ( ) ;
} ,
batchedUpdates : function ( fn , a ) {
var previousIsBatchingUpdates = isBatchingUpdates ;
isBatchingUpdates = ! 0 ;
try {
return fn ( a ) ;
} finally {
( isBatchingUpdates = previousIsBatchingUpdates ) ||
isRendering ||
2018-04-04 15:11:21 -07:00
performSyncWork ( ) ;
2018-01-30 08:47:02 -08:00
}
} ,
2018-02-01 13:33:12 -08:00
unbatchedUpdates : function ( fn , a ) {
2018-01-30 08:47:02 -08:00
if ( isBatchingUpdates && ! isUnbatchingUpdates ) {
isUnbatchingUpdates = ! 0 ;
try {
2018-02-01 13:33:12 -08:00
return fn ( a ) ;
2018-01-30 08:47:02 -08:00
} finally {
isUnbatchingUpdates = ! 1 ;
}
}
2018-02-01 13:33:12 -08:00
return fn ( a ) ;
2018-01-30 08:47:02 -08:00
} ,
2018-02-01 13:33:12 -08:00
flushSync : function ( fn , a ) {
invariant (
! isRendering ,
"flushSync was called from inside a lifecycle method. It cannot be called when React is already rendering."
) ;
2018-01-30 08:47:02 -08:00
var previousIsBatchingUpdates = isBatchingUpdates ;
isBatchingUpdates = ! 0 ;
try {
2018-02-01 13:33:12 -08:00
return syncUpdates ( fn , a ) ;
2018-01-30 08:47:02 -08:00
} finally {
2018-04-04 15:11:21 -07:00
( isBatchingUpdates = previousIsBatchingUpdates ) , performSyncWork ( ) ;
2018-02-01 13:33:12 -08:00
}
} ,
flushControlled : function ( fn ) {
var previousIsBatchingUpdates = isBatchingUpdates ;
isBatchingUpdates = ! 0 ;
try {
syncUpdates ( fn ) ;
} finally {
( isBatchingUpdates = previousIsBatchingUpdates ) ||
isRendering ||
performWork ( 1 , ! 1 , null ) ;
2018-01-30 08:47:02 -08:00
}
} ,
deferredUpdates : function ( fn ) {
var previousExpirationContext = expirationContext ;
2018-02-28 19:16:47 -08:00
expirationContext =
25 * ( ( ( ( recalculateCurrentTime ( ) + 500 ) / 25 ) | 0 ) + 1 ) ;
2018-01-30 08:47:02 -08:00
try {
return fn ( ) ;
} finally {
expirationContext = previousExpirationContext ;
}
} ,
2018-02-01 13:33:12 -08:00
syncUpdates : syncUpdates ,
interactiveUpdates : function ( fn , a , b ) {
if ( isBatchingInteractiveUpdates ) return fn ( a , b ) ;
isBatchingUpdates ||
isRendering ||
0 === lowestPendingInteractiveExpirationTime ||
( performWork ( lowestPendingInteractiveExpirationTime , ! 1 , null ) ,
( lowestPendingInteractiveExpirationTime = 0 ) ) ;
var previousIsBatchingInteractiveUpdates = isBatchingInteractiveUpdates ,
previousIsBatchingUpdates = isBatchingUpdates ;
isBatchingUpdates = isBatchingInteractiveUpdates = ! 0 ;
try {
return fn ( a , b ) ;
} finally {
( isBatchingInteractiveUpdates = previousIsBatchingInteractiveUpdates ) ,
( isBatchingUpdates = previousIsBatchingUpdates ) ||
isRendering ||
2018-04-04 15:11:21 -07:00
performSyncWork ( ) ;
2018-02-01 13:33:12 -08:00
}
} ,
flushInteractiveUpdates : function ( ) {
isRendering ||
0 === lowestPendingInteractiveExpirationTime ||
( performWork ( lowestPendingInteractiveExpirationTime , ! 1 , null ) ,
( lowestPendingInteractiveExpirationTime = 0 ) ) ;
} ,
2018-01-30 08:47:02 -08:00
computeUniqueAsyncExpiration : function ( ) {
2018-02-28 19:16:47 -08:00
var result = 25 * ( ( ( ( recalculateCurrentTime ( ) + 500 ) / 25 ) | 0 ) + 1 ) ;
2018-01-30 08:47:02 -08:00
result <= lastUniqueAsyncExpiration &&
( result = lastUniqueAsyncExpiration + 1 ) ;
return ( lastUniqueAsyncExpiration = result ) ;
2018-03-20 17:03:06 -07:00
} ,
legacyContext : legacyContext
2018-01-30 08:47:02 -08:00
} ;
}
function ReactFiberReconciler$1 ( config ) {
function updateContainerAtExpirationTime (
element ,
container ,
parentComponent ,
2018-02-28 19:16:47 -08:00
currentTime ,
2018-01-30 08:47:02 -08:00
expirationTime ,
callback
) {
2018-02-28 19:16:47 -08:00
currentTime = container . current ;
2018-01-30 08:47:02 -08:00
if ( parentComponent ) {
parentComponent = parentComponent . _reactInternalFiber ;
2018-03-20 17:03:06 -07:00
var parentContext = findCurrentUnmaskedContext ( parentComponent ) ;
2018-01-30 08:47:02 -08:00
parentComponent = isContextProvider ( parentComponent )
? processChildContext ( parentComponent , parentContext )
: parentContext ;
} else parentComponent = emptyObject ;
null === container . context
? ( container . context = parentComponent )
: ( container . pendingContext = parentComponent ) ;
container = callback ;
2018-02-28 19:16:47 -08:00
insertUpdateIntoFiber ( currentTime , {
2018-01-30 08:47:02 -08:00
expirationTime : expirationTime ,
partialState : { element : element } ,
callback : void 0 === container ? null : container ,
isReplace : ! 1 ,
isForced : ! 1 ,
2018-02-28 19:16:47 -08:00
capturedValue : null ,
2018-01-30 08:47:02 -08:00
next : null
} ) ;
2018-02-28 19:16:47 -08:00
scheduleWork ( currentTime , expirationTime ) ;
2018-01-30 08:47:02 -08:00
return expirationTime ;
}
function findHostInstance ( fiber ) {
fiber = findCurrentHostFiber ( fiber ) ;
return null === fiber ? null : fiber . stateNode ;
}
var getPublicInstance = config . getPublicInstance ;
config = ReactFiberScheduler ( config ) ;
2018-02-28 19:16:47 -08:00
var recalculateCurrentTime = config . recalculateCurrentTime ,
computeExpirationForFiber = config . computeExpirationForFiber ,
2018-03-20 17:03:06 -07:00
scheduleWork = config . scheduleWork ,
legacyContext = config . legacyContext ,
findCurrentUnmaskedContext = legacyContext . findCurrentUnmaskedContext ,
isContextProvider = legacyContext . isContextProvider ,
processChildContext = legacyContext . processChildContext ;
2018-01-30 08:47:02 -08:00
return {
createContainer : function ( containerInfo , isAsync , hydrate ) {
isAsync = new FiberNode ( 3 , null , null , isAsync ? 3 : 0 ) ;
containerInfo = {
current : isAsync ,
containerInfo : containerInfo ,
pendingChildren : null ,
2018-02-28 19:16:47 -08:00
pendingCommitExpirationTime : 0 ,
2018-01-30 08:47:02 -08:00
finishedWork : null ,
context : null ,
pendingContext : null ,
hydrate : hydrate ,
2018-02-28 19:16:47 -08:00
remainingExpirationTime : 0 ,
2018-01-30 08:47:02 -08:00
firstBatch : null ,
nextScheduledRoot : null
} ;
return ( isAsync . stateNode = containerInfo ) ;
} ,
updateContainer : function ( element , container , parentComponent , callback ) {
2018-02-28 19:16:47 -08:00
var current = container . current ,
currentTime = recalculateCurrentTime ( ) ;
current = computeExpirationForFiber ( current ) ;
return updateContainerAtExpirationTime (
element ,
container ,
parentComponent ,
currentTime ,
current ,
callback
) ;
} ,
updateContainerAtExpirationTime : function (
element ,
container ,
parentComponent ,
expirationTime ,
callback
) {
var currentTime = recalculateCurrentTime ( ) ;
2018-01-30 08:47:02 -08:00
return updateContainerAtExpirationTime (
element ,
container ,
parentComponent ,
2018-02-28 19:16:47 -08:00
currentTime ,
2018-01-30 08:47:02 -08:00
expirationTime ,
callback
) ;
} ,
flushRoot : config . flushRoot ,
requestWork : config . requestWork ,
computeUniqueAsyncExpiration : config . computeUniqueAsyncExpiration ,
batchedUpdates : config . batchedUpdates ,
unbatchedUpdates : config . unbatchedUpdates ,
deferredUpdates : config . deferredUpdates ,
2018-02-01 13:33:12 -08:00
syncUpdates : config . syncUpdates ,
interactiveUpdates : config . interactiveUpdates ,
flushInteractiveUpdates : config . flushInteractiveUpdates ,
flushControlled : config . flushControlled ,
2018-01-30 08:47:02 -08:00
flushSync : config . flushSync ,
getPublicRootInstance : function ( container ) {
container = container . current ;
if ( ! container . child ) return null ;
switch ( container . child . tag ) {
case 5 :
return getPublicInstance ( container . child . stateNode ) ;
default :
return container . child . stateNode ;
}
} ,
findHostInstance : findHostInstance ,
findHostInstanceWithNoPortals : function ( fiber ) {
fiber = findCurrentHostFiberWithNoPortals ( fiber ) ;
return null === fiber ? null : fiber . stateNode ;
} ,
injectIntoDevTools : function ( devToolsConfig ) {
var findFiberByHostInstance = devToolsConfig . findFiberByHostInstance ;
return injectInternals (
Object . assign ( { } , devToolsConfig , {
findHostInstanceByFiber : function ( fiber ) {
return findHostInstance ( fiber ) ;
} ,
findFiberByHostInstance : function ( instance ) {
return findFiberByHostInstance
? findFiberByHostInstance ( instance )
: null ;
}
} )
) ;
}
} ;
}
var ReactFiberReconciler$2 = Object . freeze ( { default : ReactFiberReconciler$1 } ) ,
ReactFiberReconciler$3 =
( ReactFiberReconciler$2 && ReactFiberReconciler$1 ) ||
ReactFiberReconciler$2 ,
reactReconciler = ReactFiberReconciler$3 [ "default" ]
? ReactFiberReconciler$3 [ "default" ]
: ReactFiberReconciler$3 ,
2018-02-28 19:16:47 -08:00
ReactNativeTagHandles = {
tagsStartAt : 1 ,
tagCount : 1 ,
allocateTag : function ( ) {
for ( ; this . reactTagIsNativeTopRootID ( ReactNativeTagHandles . tagCount ) ; )
ReactNativeTagHandles . tagCount ++ ;
var tag = ReactNativeTagHandles . tagCount ;
ReactNativeTagHandles . tagCount ++ ;
return tag ;
} ,
assertRootTag : function ( tag ) {
invariant (
this . reactTagIsNativeTopRootID ( tag ) ,
"Expect a native root tag, instead got %s" ,
tag
) ;
} ,
reactTagIsNativeTopRootID : function ( reactTag ) {
return 1 === reactTag % 10 ;
}
} ,
2018-01-30 08:47:02 -08:00
ReactFabricHostComponent = ( function ( ) {
function ReactFabricHostComponent ( tag , viewConfig , props ) {
if ( ! ( this instanceof ReactFabricHostComponent ) )
throw new TypeError ( "Cannot call a class as a function" ) ;
this . _nativeTag = tag ;
this . viewConfig = viewConfig ;
this . currentProps = props ;
}
ReactFabricHostComponent . prototype . blur = function ( ) {
TextInputState . blurTextInput ( this . _nativeTag ) ;
} ;
ReactFabricHostComponent . prototype . focus = function ( ) {
TextInputState . focusTextInput ( this . _nativeTag ) ;
} ;
ReactFabricHostComponent . prototype . measure = function ( callback ) {
UIManager . measure ( this . _nativeTag , mountSafeCallback ( this , callback ) ) ;
} ;
ReactFabricHostComponent . prototype . measureInWindow = function ( callback ) {
UIManager . measureInWindow (
this . _nativeTag ,
mountSafeCallback ( this , callback )
) ;
} ;
ReactFabricHostComponent . prototype . measureLayout = function (
relativeToNativeNode ,
onSuccess ,
onFail
) {
UIManager . measureLayout (
this . _nativeTag ,
relativeToNativeNode ,
mountSafeCallback ( this , onFail ) ,
mountSafeCallback ( this , onSuccess )
) ;
} ;
ReactFabricHostComponent . prototype . setNativeProps = function ( nativeProps ) {
nativeProps = diffProperties (
null ,
emptyObject$1 ,
nativeProps ,
this . viewConfig . validAttributes
) ;
null != nativeProps &&
UIManager . updateView (
this . _nativeTag ,
this . viewConfig . uiViewClassName ,
nativeProps
) ;
} ;
return ReactFabricHostComponent ;
} ) ( ) ,
ReactFabricRenderer = reactReconciler ( {
appendInitialChild : function ( parentInstance , child ) {
FabricUIManager . appendChild ( parentInstance . node , child . node ) ;
} ,
createInstance : function (
type ,
props ,
rootContainerInstance ,
hostContext ,
internalInstanceHandle
) {
hostContext = ReactNativeTagHandles . allocateTag ( ) ;
if ( viewConfigs . has ( type ) ) var viewConfig = viewConfigs . get ( type ) ;
else
( viewConfig = viewConfigCallbacks . get ( type ) ) ,
invariant (
"function" === typeof viewConfig ,
"View config not found for name %s" ,
type
) ,
viewConfigCallbacks . set ( type , null ) ,
( viewConfig = viewConfig ( ) ) ,
viewConfigs . set ( type , viewConfig ) ;
invariant ( viewConfig , "View config not found for name %s" , type ) ;
type = viewConfig ;
viewConfig = diffProperties (
null ,
emptyObject$1 ,
props ,
type . validAttributes
) ;
rootContainerInstance = FabricUIManager . createNode (
hostContext ,
type . uiViewClassName ,
rootContainerInstance ,
viewConfig ,
internalInstanceHandle
) ;
props = new ReactFabricHostComponent ( hostContext , type , props ) ;
return { node : rootContainerInstance , canonical : props } ;
} ,
createTextInstance : function (
text ,
rootContainerInstance ,
hostContext ,
internalInstanceHandle
) {
hostContext = ReactNativeTagHandles . allocateTag ( ) ;
return {
node : FabricUIManager . createNode (
hostContext ,
"RCTRawText" ,
rootContainerInstance ,
{ text : text } ,
internalInstanceHandle
)
} ;
} ,
finalizeInitialChildren : function ( ) {
return ! 1 ;
} ,
getRootHostContext : function ( ) {
return emptyObject ;
} ,
getChildHostContext : function ( ) {
return emptyObject ;
} ,
getPublicInstance : function ( instance ) {
return instance . canonical ;
} ,
now : now ,
prepareForCommit : function ( ) { } ,
prepareUpdate : function ( instance , type , oldProps , newProps ) {
return diffProperties (
null ,
oldProps ,
newProps ,
instance . canonical . viewConfig . validAttributes
) ;
} ,
resetAfterCommit : function ( ) { } ,
scheduleDeferredCallback : function ( callback ) {
scheduledCallback = callback ;
return setTimeout ( setTimeoutCallback , 1 ) ;
} ,
cancelDeferredCallback : function ( callbackID ) {
scheduledCallback = null ;
clearTimeout ( callbackID ) ;
} ,
shouldDeprioritizeSubtree : function ( ) {
return ! 1 ;
} ,
shouldSetTextContent : function ( ) {
return ! 1 ;
} ,
persistence : {
cloneInstance : function (
instance ,
updatePayload ,
type ,
oldProps ,
newProps ,
internalInstanceHandle ,
keepChildren
) {
type = instance . node ;
return {
node : keepChildren
? null !== updatePayload
? FabricUIManager . cloneNodeWithNewProps ( type , updatePayload )
: FabricUIManager . cloneNode ( type )
: null !== updatePayload
? FabricUIManager . cloneNodeWithNewChildrenAndProps (
type ,
updatePayload
)
: FabricUIManager . cloneNodeWithNewChildren ( type ) ,
canonical : instance . canonical
} ;
} ,
createContainerChildSet : function ( container ) {
return FabricUIManager . createChildSet ( container ) ;
} ,
appendChildToContainerChildSet : function ( childSet , child ) {
FabricUIManager . appendChildToSet ( childSet , child . node ) ;
} ,
finalizeContainerChildren : function ( container , newChildren ) {
FabricUIManager . completeRoot ( container , newChildren ) ;
} ,
replaceContainerChildren : function ( ) { }
}
2018-02-01 13:33:12 -08:00
} ) ,
getInspectorDataForViewTag = void 0 ;
2018-01-30 08:47:02 -08:00
getInspectorDataForViewTag = function ( ) {
invariant ( ! 1 , "getInspectorDataForViewTag() is not available in production" ) ;
} ;
findHostInstanceFabric = ReactFabricRenderer . findHostInstance ;
2018-02-01 13:33:12 -08:00
_batchedUpdates = ReactFabricRenderer . batchedUpdates ;
_flushInteractiveUpdates = ReactFabricRenderer . flushInteractiveUpdates ;
2018-01-30 08:47:02 -08:00
var roots = new Map ( ) ,
ReactFabric = {
NativeComponent : ReactNativeComponent ,
findNodeHandle : findNumericNodeHandleFiber ,
render : function ( element , containerTag , callback ) {
var root = roots . get ( containerTag ) ;
root ||
( ( root = ReactFabricRenderer . createContainer ( containerTag , ! 1 , ! 1 ) ) ,
roots . set ( containerTag , root ) ) ;
ReactFabricRenderer . updateContainer ( element , root , null , callback ) ;
return ReactFabricRenderer . getPublicRootInstance ( root ) ;
} ,
unmountComponentAtNode : function ( containerTag ) {
var root = roots . get ( containerTag ) ;
root &&
ReactFabricRenderer . updateContainer ( null , root , null , function ( ) {
roots [ "delete" ] ( containerTag ) ;
} ) ;
} ,
unmountComponentAtNodeAndRemoveContainer : function ( containerTag ) {
ReactFabric . unmountComponentAtNode ( containerTag ) ;
} ,
createPortal : function ( children , containerTag ) {
return createPortal (
children ,
containerTag ,
null ,
2 < arguments . length && void 0 !== arguments [ 2 ] ? arguments [ 2 ] : null
) ;
} ,
2018-02-28 19:16:47 -08:00
unstable _batchedUpdates : function ( fn , bookkeeping ) {
if ( isBatching ) return fn ( bookkeeping ) ;
isBatching = ! 0 ;
try {
return _batchedUpdates ( fn , bookkeeping ) ;
} finally {
if (
( ( isBatching = ! 1 ) , null !== restoreTarget || null !== restoreQueue )
)
if (
( _flushInteractiveUpdates ( ) ,
restoreTarget &&
( ( bookkeeping = restoreTarget ) ,
( fn = restoreQueue ) ,
( restoreQueue = restoreTarget = null ) ,
restoreStateOfTarget ( bookkeeping ) ,
fn ) )
)
for ( bookkeeping = 0 ; bookkeeping < fn . length ; bookkeeping ++ )
restoreStateOfTarget ( fn [ bookkeeping ] ) ;
}
} ,
2018-01-30 08:47:02 -08:00
flushSync : ReactFabricRenderer . flushSync ,
_ _SECRET _INTERNALS _DO _NOT _USE _OR _YOU _WILL _BE _FIRED : {
NativeMethodsMixin : {
measure : function ( callback ) {
UIManager . measure (
findNumericNodeHandleFiber ( this ) ,
mountSafeCallback ( this , callback )
) ;
} ,
measureInWindow : function ( callback ) {
UIManager . measureInWindow (
findNumericNodeHandleFiber ( this ) ,
mountSafeCallback ( this , callback )
) ;
} ,
measureLayout : function ( relativeToNativeNode , onSuccess , onFail ) {
UIManager . measureLayout (
findNumericNodeHandleFiber ( this ) ,
relativeToNativeNode ,
mountSafeCallback ( this , onFail ) ,
mountSafeCallback ( this , onSuccess )
) ;
} ,
setNativeProps : function ( nativeProps ) {
var maybeInstance = void 0 ;
try {
maybeInstance = findNodeHandle ( this ) ;
} catch ( error ) { }
if ( null != maybeInstance ) {
var viewConfig = maybeInstance . viewConfig ;
nativeProps = diffProperties (
null ,
emptyObject$1 ,
nativeProps ,
viewConfig . validAttributes
) ;
null != nativeProps &&
UIManager . updateView (
maybeInstance . _nativeTag ,
viewConfig . uiViewClassName ,
nativeProps
) ;
}
} ,
focus : function ( ) {
TextInputState . focusTextInput ( findNumericNodeHandleFiber ( this ) ) ;
} ,
blur : function ( ) {
TextInputState . blurTextInput ( findNumericNodeHandleFiber ( this ) ) ;
}
} ,
ReactNativeBridgeEventPlugin : ReactNativeBridgeEventPlugin ,
ReactNativeComponentTree : ReactNativeComponentTree ,
ReactNativePropRegistry : ReactNativePropRegistry ,
TouchHistoryMath : TouchHistoryMath ,
createReactNativeComponentClass : function ( name , callback ) {
invariant (
! viewConfigCallbacks . has ( name ) ,
"Tried to register two views with the same name %s" ,
name
) ;
viewConfigCallbacks . set ( name , callback ) ;
return name ;
} ,
takeSnapshot : function ( view , options ) {
"number" !== typeof view &&
"window" !== view &&
( view = findNumericNodeHandleFiber ( view ) || "window" ) ;
return UIManager . _ _takeSnapshot ( view , options ) ;
}
}
} ;
ReactFabricRenderer . injectIntoDevTools ( {
findFiberByHostInstance : getInstanceFromTag ,
getInspectorDataForViewTag : getInspectorDataForViewTag ,
bundleType : 0 ,
2018-04-04 15:11:21 -07:00
version : "16.3.1" ,
2018-01-30 08:47:02 -08:00
rendererPackageName : "react-native-renderer"
} ) ;
var ReactFabric$2 = Object . freeze ( { default : ReactFabric } ) ,
ReactFabric$3 = ( ReactFabric$2 && ReactFabric ) || ReactFabric$2 ;
module . exports = ReactFabric$3 [ "default" ]
? ReactFabric$3 [ "default" ]
: ReactFabric$3 ;