react-native-screens
Version:
Native navigation primitives for your React Native app.
63 lines (61 loc) • 3.02 kB
JavaScript
'use client';
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
import React from 'react';
import { GHContext, RNSScreensRefContext } from '../contexts';
import warnOnce from 'warn-once';
// Native components
import ScreenStackNativeComponent from '../fabric/ScreenStackNativeComponent';
const assertGHProvider = (ScreenGestureDetector, goBackGesture) => {
const isGestureDetectorProviderNotDetected = ScreenGestureDetector.name !== 'GHWrapper' && goBackGesture !== undefined;
warnOnce(isGestureDetectorProviderNotDetected, 'Cannot detect GestureDetectorProvider in a screen that uses `goBackGesture`. Make sure your navigator is wrapped in GestureDetectorProvider.');
};
const assertCustomScreenTransitionsProps = (screensRefs, currentScreenId, goBackGesture) => {
const isGestureDetectorNotConfiguredProperly = goBackGesture !== undefined && screensRefs === null && currentScreenId === undefined;
warnOnce(isGestureDetectorNotConfiguredProperly, 'Custom Screen Transition require screensRefs and currentScreenId to be provided.');
};
function ScreenStack(props) {
const {
goBackGesture,
screensRefs: passedScreenRefs,
// TODO: For compatibility with v5, remove once v5 is removed
currentScreenId,
transitionAnimation,
screenEdgeGesture,
onFinishTransitioning,
children,
...rest
} = props;
const screensRefs = React.useRef(passedScreenRefs?.current ?? {});
const ref = React.useRef(null);
const ScreenGestureDetector = React.useContext(GHContext);
const gestureDetectorBridge = React.useRef({
stackUseEffectCallback: _stackRef => {
// this method will be overriden in GestureDetector
}
});
React.useEffect(() => {
gestureDetectorBridge.current.stackUseEffectCallback(ref);
});
assertGHProvider(ScreenGestureDetector, goBackGesture);
assertCustomScreenTransitionsProps(screensRefs, currentScreenId, goBackGesture);
return /*#__PURE__*/React.createElement(RNSScreensRefContext.Provider, {
value: screensRefs
}, /*#__PURE__*/React.createElement(ScreenGestureDetector, {
gestureDetectorBridge: gestureDetectorBridge,
goBackGesture: goBackGesture,
transitionAnimation: transitionAnimation,
screenEdgeGesture: screenEdgeGesture ?? false,
screensRefs: screensRefs,
currentScreenId: currentScreenId
}, /*#__PURE__*/React.createElement(ScreenStackNativeComponent, _extends({}, rest, {
/**
* This messy override is to conform NativeProps used by codegen and
* our Public API. To see reasoning go to this PR:
* https://github.com/software-mansion/react-native-screens/pull/2423#discussion_r1810616995
*/
onFinishTransitioning: onFinishTransitioning,
ref: ref
}), children)));
}
export default ScreenStack;
//# sourceMappingURL=ScreenStack.js.map