Skip to content

Commit

Permalink
Pull useAnimatedScrollHandler back up (#1858)
Browse files Browse the repository at this point in the history
* Revert "Pull animated scroll handler down from pager"

This reverts commit ecebb78.

* Only handle onScroll for current page
  • Loading branch information
gaearon authored Nov 9, 2023
1 parent fb4f570 commit 487d871
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 47 deletions.
40 changes: 15 additions & 25 deletions src/view/com/pager/PagerWithHeader.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,9 @@
import * as React from 'react'
import {
LayoutChangeEvent,
NativeScrollEvent,
StyleSheet,
View,
} from 'react-native'
import {LayoutChangeEvent, StyleSheet, View} from 'react-native'
import Animated, {
Easing,
useAnimatedReaction,
useAnimatedScrollHandler,
useAnimatedStyle,
useSharedValue,
withTiming,
Expand All @@ -16,12 +12,13 @@ import Animated, {
import {Pager, PagerRef, RenderTabBarFnProps} from 'view/com/pager/Pager'
import {TabBar} from './TabBar'
import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries'
import {OnScrollCb} from 'lib/hooks/useOnMainScroll'

const SCROLLED_DOWN_LIMIT = 200

interface PagerWithHeaderChildParams {
headerHeight: number
onScroll: (e: NativeScrollEvent) => void
onScroll: OnScrollCb
isScrolledDown: boolean
}

Expand Down Expand Up @@ -143,25 +140,12 @@ export const PagerWithHeader = React.forwardRef<PagerRef, PagerWithHeaderProps>(
],
)

// Ideally we'd call useAnimatedScrollHandler here but we can't safely do that
// due to https://github.com/software-mansion/react-native-reanimated/issues/5345.
// So instead we pass down a worklet, and individual pages will have to call it.
const onScroll = React.useCallback(
(e: NativeScrollEvent) => {
'worklet'
// props to pass into children render functions
const onScroll = useAnimatedScrollHandler({
onScroll(e) {
scrollY.value = e.contentOffset.y
},
[scrollY],
)

// props to pass into children render functions
const childProps = React.useMemo<PagerWithHeaderChildParams>(() => {
return {
headerHeight,
onScroll,
isScrolledDown,
}
}, [headerHeight, onScroll, isScrolledDown])
})

const onPageSelectedInner = React.useCallback(
(index: number) => {
Expand Down Expand Up @@ -205,7 +189,11 @@ export const PagerWithHeader = React.forwardRef<PagerRef, PagerWithHeaderProps>(
headerOnlyHeight > 0 &&
tabBarHeight > 0
) {
output = child(childProps)
output = child({
headerHeight,
isScrolledDown,
onScroll: i === currentPage ? onScroll : noop,
})
}
// Pager children must be noncollapsible plain <View>s.
return (
Expand Down Expand Up @@ -237,6 +225,8 @@ const styles = StyleSheet.create({
},
})

function noop() {}

function toArray<T>(v: T | T[]): T[] {
if (Array.isArray(v)) {
return v
Expand Down
20 changes: 6 additions & 14 deletions src/view/screens/ProfileFeed.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,7 @@
import React, {useMemo, useCallback} from 'react'
import {
FlatList,
NativeScrollEvent,
StyleSheet,
View,
ActivityIndicator,
} from 'react-native'
import {FlatList, StyleSheet, View, ActivityIndicator} from 'react-native'
import {NativeStackScreenProps} from '@react-navigation/native-stack'
import {useNavigation} from '@react-navigation/native'
import {useAnimatedScrollHandler} from 'react-native-reanimated'
import {usePalette} from 'lib/hooks/usePalette'
import {HeartIcon, HeartIconSolid} from 'lib/icons'
import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome'
Expand All @@ -33,6 +26,7 @@ import {EmptyState} from 'view/com/util/EmptyState'
import * as Toast from 'view/com/util/Toast'
import {useSetTitle} from 'lib/hooks/useSetTitle'
import {useCustomFeed} from 'lib/hooks/useCustomFeed'
import {OnScrollCb} from 'lib/hooks/useOnMainScroll'
import {shareUrl} from 'lib/sharing'
import {toShareUrl} from 'lib/strings/url-helpers'
import {Haptics} from 'lib/haptics'
Expand Down Expand Up @@ -389,7 +383,7 @@ export const ProfileFeedScreenInner = observer(

interface FeedSectionProps {
feed: PostsFeedModel
onScroll: (e: NativeScrollEvent) => void
onScroll: OnScrollCb
headerHeight: number
isScrolledDown: boolean
}
Expand All @@ -414,13 +408,12 @@ const FeedSection = React.forwardRef<SectionRef, FeedSectionProps>(
return <EmptyState icon="feed" message="This feed is empty!" />
}, [])

const scrollHandler = useAnimatedScrollHandler({onScroll})
return (
<View>
<Feed
feed={feed}
scrollElRef={scrollElRef}
onScroll={scrollHandler}
onScroll={onScroll}
scrollEventThrottle={5}
renderEmptyState={renderPostsEmpty}
headerOffset={headerHeight}
Expand Down Expand Up @@ -450,11 +443,10 @@ const AboutSection = observer(function AboutPageImpl({
feedInfo: FeedSourceModel | undefined
headerHeight: number
onToggleLiked: () => void
onScroll: (e: NativeScrollEvent) => void
onScroll: OnScrollCb
}) {
const pal = usePalette('default')
const {_} = useLingui()
const scrollHandler = useAnimatedScrollHandler({onScroll})

if (!feedInfo) {
return <View />
Expand All @@ -464,7 +456,7 @@ const AboutSection = observer(function AboutPageImpl({
<ScrollView
scrollEventThrottle={1}
contentContainerStyle={{paddingTop: headerHeight}}
onScroll={scrollHandler}>
onScroll={onScroll}>
<View
style={[
{
Expand Down
13 changes: 5 additions & 8 deletions src/view/screens/ProfileList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import React, {useCallback, useMemo} from 'react'
import {
ActivityIndicator,
FlatList,
NativeScrollEvent,
Pressable,
StyleSheet,
View,
Expand All @@ -11,7 +10,6 @@ import {useFocusEffect} from '@react-navigation/native'
import {NativeStackScreenProps, CommonNavigatorParams} from 'lib/routes/types'
import {useNavigation} from '@react-navigation/native'
import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome'
import {useAnimatedScrollHandler} from 'react-native-reanimated'
import {observer} from 'mobx-react-lite'
import {RichText as RichTextAPI} from '@atproto/api'
import {withAuthRequired} from 'view/com/auth/withAuthRequired'
Expand All @@ -35,6 +33,7 @@ import {useStores} from 'state/index'
import {usePalette} from 'lib/hooks/usePalette'
import {useSetTitle} from 'lib/hooks/useSetTitle'
import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries'
import {OnScrollCb} from 'lib/hooks/useOnMainScroll'
import {NavigationProp} from 'lib/routes/types'
import {toShareUrl} from 'lib/strings/url-helpers'
import {shareUrl} from 'lib/sharing'
Expand Down Expand Up @@ -555,7 +554,7 @@ const Header = observer(function HeaderImpl({

interface FeedSectionProps {
feed: PostsFeedModel
onScroll: (e: NativeScrollEvent) => void
onScroll: OnScrollCb
headerHeight: number
isScrolledDown: boolean
}
Expand All @@ -579,14 +578,13 @@ const FeedSection = React.forwardRef<SectionRef, FeedSectionProps>(
return <EmptyState icon="feed" message="This feed is empty!" />
}, [])

const scrollHandler = useAnimatedScrollHandler({onScroll})
return (
<View>
<Feed
testID="listFeed"
feed={feed}
scrollElRef={scrollElRef}
onScroll={scrollHandler}
onScroll={onScroll}
scrollEventThrottle={1}
renderEmptyState={renderPostsEmpty}
headerOffset={headerHeight}
Expand All @@ -610,7 +608,7 @@ interface AboutSectionProps {
isCurateList: boolean | undefined
isOwner: boolean | undefined
onPressAddUser: () => void
onScroll: (e: NativeScrollEvent) => void
onScroll: OnScrollCb
headerHeight: number
isScrolledDown: boolean
}
Expand Down Expand Up @@ -741,7 +739,6 @@ const AboutSection = React.forwardRef<SectionRef, AboutSectionProps>(
)
}, [])

const scrollHandler = useAnimatedScrollHandler({onScroll})
return (
<View>
<ListItems
Expand All @@ -751,7 +748,7 @@ const AboutSection = React.forwardRef<SectionRef, AboutSectionProps>(
renderEmptyState={renderEmptyState}
list={list}
headerOffset={headerHeight}
onScroll={scrollHandler}
onScroll={onScroll}
scrollEventThrottle={1}
/>
{isScrolledDown && (
Expand Down

0 comments on commit 487d871

Please sign in to comment.