From e4ca751fb0e2f3f10465ddfcf4c7f7982512302c Mon Sep 17 00:00:00 2001 From: Rajarshee Chatterjee Date: Sun, 7 Jan 2024 17:58:46 +0530 Subject: [PATCH] Animated FAB in Novel Screen (Closes #839) --- src/screens/novel/NovelScreen.js | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/screens/novel/NovelScreen.js b/src/screens/novel/NovelScreen.js index 3fd5514b6..266f92112 100644 --- a/src/screens/novel/NovelScreen.js +++ b/src/screens/novel/NovelScreen.js @@ -23,8 +23,8 @@ import { Appbar, IconButton, Menu, - FAB, Snackbar, + AnimatedFAB, } from 'react-native-paper'; import { useDispatch, useSelector } from 'react-redux'; import * as Haptics from 'expo-haptics'; @@ -86,6 +86,7 @@ const Novel = ({ route, navigation }) => { const [selected, setSelected] = useState([]); const [downloadMenu, showDownloadMenu] = useState(false); const [extraMenu, showExtraMenu] = useState(false); + const [isFabExtended, setIsFabExtended] = useState(true); let flatlistRef = useRef(null); let novelBottomSheetRef = useRef(null); @@ -126,6 +127,9 @@ const Novel = ({ route, navigation }) => { const onPageScroll = event => { const y = event.nativeEvent.contentOffset.y; headerOpacity.value = withTiming(y > 10 ? 1 : 0, { duration: 200 }); + + const currentScrollPosition = Math.floor(y) ?? 0; + setIsFabExtended(currentScrollPosition <= 0); }; useEffect(() => { @@ -679,12 +683,12 @@ const Novel = ({ route, navigation }) => { /> {useFabForContinueReading && chapters.length > 0 && lastReadChapter && ( -