mirror of
https://github.com/zhigang1992/react-navigation.git
synced 2026-05-13 18:21:00 +08:00
fix: use addListener only when available
This commit is contained in:
@@ -1,12 +1,5 @@
|
||||
import * as React from 'react';
|
||||
import {
|
||||
Animated,
|
||||
View,
|
||||
StyleSheet,
|
||||
StyleProp,
|
||||
ViewStyle,
|
||||
Platform,
|
||||
} from 'react-native';
|
||||
import { Animated, View, StyleSheet, StyleProp, ViewStyle } from 'react-native';
|
||||
import { Route, useTheme } from '@react-navigation/native';
|
||||
import { Props as HeaderContainerProps } from '../Header/HeaderContainer';
|
||||
import Card from './Card';
|
||||
@@ -141,18 +134,18 @@ function CardContainer({
|
||||
);
|
||||
|
||||
React.useEffect(() => {
|
||||
if (Platform.OS === 'web') {
|
||||
return;
|
||||
}
|
||||
const valueListenerCallback = ({ value }: { value: number }) => {
|
||||
setPointerEvents(value <= EPSILON ? 'box-none' : 'none');
|
||||
};
|
||||
// `addListener` may not exist on web and older versions of React Native
|
||||
// @ts-ignore
|
||||
const listener = scene.progress.next?.addListener(valueListenerCallback);
|
||||
const listener = scene.progress.next?.addListener?.(
|
||||
({ value }: { value: number }) => {
|
||||
setPointerEvents(value <= EPSILON ? 'box-none' : 'none');
|
||||
}
|
||||
);
|
||||
|
||||
return () => {
|
||||
if (listener) {
|
||||
// @ts-ignore
|
||||
scene.progress.next?.removeListener(listener);
|
||||
scene.progress.next?.removeListener?.(listener);
|
||||
}
|
||||
};
|
||||
}, [pointerEvents, scene.progress.next]);
|
||||
|
||||
Reference in New Issue
Block a user