diff options
author | dan <dan.abramov@gmail.com> | 2023-10-13 15:24:28 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-10-13 15:24:28 +0100 |
commit | 2a1edab6d4a8e8b4197b10868153a525f918509c (patch) | |
tree | b73ee178ec662b8209989400e9c9dfa2781fa864 /src/view/com | |
parent | 4431cfe2d2971577e9c0a4fa4ed83f0c52fb7540 (diff) | |
download | voidsky-2a1edab6d4a8e8b4197b10868153a525f918509c.tar.zst |
Don't re-render bars when showing/hiding them (#1691)
* Don't re-render bars when showing/hiding them * Fix more cases * Use autorun instead of reaction to fix first render
Diffstat (limited to 'src/view/com')
-rw-r--r-- | src/view/com/pager/FeedsTabBarMobile.tsx | 17 | ||||
-rw-r--r-- | src/view/com/util/ViewHeader.tsx | 35 | ||||
-rw-r--r-- | src/view/com/util/fab/FABInner.tsx | 17 |
3 files changed, 39 insertions, 30 deletions
diff --git a/src/view/com/pager/FeedsTabBarMobile.tsx b/src/view/com/pager/FeedsTabBarMobile.tsx index ad1a69cf6..6bdba11a1 100644 --- a/src/view/com/pager/FeedsTabBarMobile.tsx +++ b/src/view/com/pager/FeedsTabBarMobile.tsx @@ -1,6 +1,7 @@ import React, {useMemo} from 'react' import {Animated, StyleSheet, TouchableOpacity, View} from 'react-native' import {observer} from 'mobx-react-lite' +import {autorun} from 'mobx' import {TabBar} from 'view/com/pager/TabBar' import {RenderTabBarFnProps} from 'view/com/pager/Pager' import {useStores} from 'state/index' @@ -22,13 +23,15 @@ export const FeedsTabBar = observer(function FeedsTabBarImpl( const interp = useAnimatedValue(0) React.useEffect(() => { - Animated.timing(interp, { - toValue: store.shell.minimalShellMode ? 1 : 0, - duration: 150, - useNativeDriver: true, - isInteraction: false, - }).start() - }, [interp, store.shell.minimalShellMode]) + return autorun(() => { + Animated.timing(interp, { + toValue: store.shell.minimalShellMode ? 1 : 0, + duration: 150, + useNativeDriver: true, + isInteraction: false, + }).start() + }) + }, [interp, store]) const transform = { opacity: Animated.subtract(1, interp), transform: [{translateY: Animated.multiply(interp, -50)}], diff --git a/src/view/com/util/ViewHeader.tsx b/src/view/com/util/ViewHeader.tsx index 164028708..3a34777ab 100644 --- a/src/view/com/util/ViewHeader.tsx +++ b/src/view/com/util/ViewHeader.tsx @@ -1,5 +1,6 @@ import React from 'react' import {observer} from 'mobx-react-lite' +import {autorun} from 'mobx' import {Animated, StyleSheet, TouchableOpacity, View} from 'react-native' import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' import {useNavigation} from '@react-navigation/native' @@ -154,22 +155,24 @@ const Container = observer(function ContainerImpl({ const interp = useAnimatedValue(0) React.useEffect(() => { - if (store.shell.minimalShellMode) { - Animated.timing(interp, { - toValue: 1, - duration: 100, - useNativeDriver: true, - isInteraction: false, - }).start() - } else { - Animated.timing(interp, { - toValue: 0, - duration: 100, - useNativeDriver: true, - isInteraction: false, - }).start() - } - }, [interp, store.shell.minimalShellMode]) + return autorun(() => { + if (store.shell.minimalShellMode) { + Animated.timing(interp, { + toValue: 1, + duration: 100, + useNativeDriver: true, + isInteraction: false, + }).start() + } else { + Animated.timing(interp, { + toValue: 0, + duration: 100, + useNativeDriver: true, + isInteraction: false, + }).start() + } + }) + }, [interp, store]) const transform = { transform: [{translateY: Animated.multiply(interp, -100)}], } diff --git a/src/view/com/util/fab/FABInner.tsx b/src/view/com/util/fab/FABInner.tsx index 6c96eef2c..97eeba358 100644 --- a/src/view/com/util/fab/FABInner.tsx +++ b/src/view/com/util/fab/FABInner.tsx @@ -1,5 +1,6 @@ import React, {ComponentProps} from 'react' import {observer} from 'mobx-react-lite' +import {autorun} from 'mobx' import {Animated, StyleSheet, TouchableWithoutFeedback} from 'react-native' import LinearGradient from 'react-native-linear-gradient' import {gradients} from 'lib/styles' @@ -25,13 +26,15 @@ export const FABInner = observer(function FABInnerImpl({ const store = useStores() const interp = useAnimatedValue(0) React.useEffect(() => { - Animated.timing(interp, { - toValue: store.shell.minimalShellMode ? 0 : 1, - duration: 100, - useNativeDriver: true, - isInteraction: false, - }).start() - }, [interp, store.shell.minimalShellMode]) + return autorun(() => { + Animated.timing(interp, { + toValue: store.shell.minimalShellMode ? 0 : 1, + duration: 100, + useNativeDriver: true, + isInteraction: false, + }).start() + }) + }, [interp, store]) const transform = isTablet ? undefined : { |