Fix state lifecycle management with post-feed query, solving the duplicate key issue (#2034)
* Assign keys to feed slices via a counter, to enable duplicate items in the feed if needed * Move post-feed query state into the query's page params to consistently bind their lifecycles
This commit is contained in:
		
							parent
							
								
									a59d235e8b
								
							
						
					
					
						commit
						630637874d
					
				
					 4 changed files with 99 additions and 91 deletions
				
			
		|  | @ -23,6 +23,7 @@ import { | |||
|   FeedDescriptor, | ||||
|   FeedParams, | ||||
|   usePostFeedQuery, | ||||
|   pollLatest, | ||||
| } from '#/state/queries/post-feed' | ||||
| import {useModerationOpts} from '#/state/queries/preferences' | ||||
| 
 | ||||
|  | @ -84,22 +85,21 @@ let Feed = ({ | |||
|     hasNextPage, | ||||
|     isFetchingNextPage, | ||||
|     fetchNextPage, | ||||
|     pollLatest, | ||||
|   } = usePostFeedQuery(feed, feedParams, opts) | ||||
|   const isEmpty = !isFetching && !data?.pages[0]?.slices.length | ||||
| 
 | ||||
|   const checkForNew = React.useCallback(async () => { | ||||
|     if (!isFetched || isFetching || !onHasNew) { | ||||
|     if (!data?.pages[0] || isFetching || !onHasNew) { | ||||
|       return | ||||
|     } | ||||
|     try { | ||||
|       if (await pollLatest()) { | ||||
|       if (await pollLatest(data.pages[0])) { | ||||
|         onHasNew(true) | ||||
|       } | ||||
|     } catch (e) { | ||||
|       logger.error('Poll latest failed', {feed, error: String(e)}) | ||||
|     } | ||||
|   }, [feed, isFetched, isFetching, pollLatest, onHasNew]) | ||||
|   }, [feed, data, isFetching, onHasNew]) | ||||
| 
 | ||||
|   React.useEffect(() => { | ||||
|     // we store the interval handler in a ref to avoid needless
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue