Tune feed loading behavior (#528)
* Never autoload home feed on focus * On web, just check for new notifications on focus * Switching tab in the home feed now checks for latest
This commit is contained in:
		
							parent
							
								
									7a10762716
								
							
						
					
					
						commit
						f4da2f4442
					
				
					 2 changed files with 21 additions and 17 deletions
				
			
		|  | @ -149,6 +149,8 @@ const FeedPage = observer( | |||
|       } | ||||
|     }, [isPageFocused, scrollToTop, feed]) | ||||
| 
 | ||||
|     // fires when screen is activated/deactivated
 | ||||
|     // - set up polls/listeners, update content
 | ||||
|     useFocusEffect( | ||||
|       React.useCallback(() => { | ||||
|         const softResetSub = store.onScreenSoftReset(onSoftReset) | ||||
|  | @ -168,30 +170,27 @@ const FeedPage = observer( | |||
|         } | ||||
|       }, [store, doPoll, onSoftReset, screen, feed]), | ||||
|     ) | ||||
|     // fires when tab is actived/deactivated
 | ||||
|     // - check for latest
 | ||||
|     useTabFocusEffect( | ||||
|       'Home', | ||||
|       React.useCallback( | ||||
|         isInside => { | ||||
|           if (!isPageFocused) { | ||||
|           if (!isPageFocused || !isInside) { | ||||
|             return | ||||
|           } | ||||
|           // on mobile:
 | ||||
|           // fires with `isInside=true` when the user navigates to the root tab
 | ||||
|           // but not when the user goes back to the screen by pressing back
 | ||||
|           // on web:
 | ||||
|           // essentially equivalent to useFocusEffect because we dont used tabbed
 | ||||
|           // navigation
 | ||||
|           if (isInside) { | ||||
|             if (feed.hasNewLatest) { | ||||
|               feed.refresh() | ||||
|             } else { | ||||
|               feed.checkForLatest() | ||||
|             } | ||||
|           } | ||||
|           feed.checkForLatest() | ||||
|         }, | ||||
|         [isPageFocused, feed], | ||||
|       ), | ||||
|     ) | ||||
|     // fires when page within screen is activated/deactivated
 | ||||
|     // - check for latest
 | ||||
|     React.useEffect(() => { | ||||
|       if (isPageFocused && isScreenFocused) { | ||||
|         feed.checkForLatest() | ||||
|       } | ||||
|     }, [isPageFocused, isScreenFocused, feed]) | ||||
| 
 | ||||
|     const onPressCompose = React.useCallback(() => { | ||||
|       track('HomeScreen:PressCompose') | ||||
|  |  | |||
|  | @ -16,6 +16,7 @@ import {useOnMainScroll} from 'lib/hooks/useOnMainScroll' | |||
| import {useTabFocusEffect} from 'lib/hooks/useTabFocusEffect' | ||||
| import {s} from 'lib/styles' | ||||
| import {useAnalytics} from 'lib/analytics' | ||||
| import {isWeb} from 'platform/detection' | ||||
| 
 | ||||
| type Props = NativeStackScreenProps< | ||||
|   NotificationsTabNavigatorParams, | ||||
|  | @ -70,10 +71,14 @@ export const NotificationsScreen = withAuthRequired( | |||
|           // essentially equivalent to useFocusEffect because we dont used tabbed
 | ||||
|           // navigation
 | ||||
|           if (isInside) { | ||||
|             if (store.me.notifications.unreadCount > 0) { | ||||
|               store.me.notifications.refresh() | ||||
|             } else { | ||||
|             if (isWeb) { | ||||
|               store.me.notifications.syncQueue() | ||||
|             } else { | ||||
|               if (store.me.notifications.unreadCount > 0) { | ||||
|                 store.me.notifications.refresh() | ||||
|               } else { | ||||
|                 store.me.notifications.syncQueue() | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue