New onboarding (#241)
* delete old onboarding files and code * add custom FollowButton component to Post, FeedItem, & ProfileCard * move building suggested feed into helper lib * show suggested posts/feed if follower list is empty * Update tsconfig.json * add pagination to getting new onboarding * remove unnecessary console log * fix naming, add better null check for combinedCursor * In locally-combined feeds, correctly produce an undefined cursor when out of data * Minor refactors of the suggested posts lib functions * Show 'follow button' style of post meta in certain conditions only * Only show follow btn in posts on the main feed and the discovery feed * Add a welcome notice to the home feed * Tune the timing of when the welcome banner shows or hides * Make the follow button an observer (closes #244) * Update postmeta to keep the follow btn after press until next render * A couple of fixes that ensure consistent welcome screen * Fix lint * Rework the welcome banner * Fix cache invalidation of follows model on user switch * Show welcome banner while loading * Update the home onboarding feed to get top posts from hardcode recommends * Drop unused helper function * Update happy path tests --------- Co-authored-by: Paul Frazee <pfrazee@gmail.com>
This commit is contained in:
		
							parent
							
								
									9b46b2e6a9
								
							
						
					
					
						commit
						bd9386d81c
					
				
					 31 changed files with 426 additions and 866 deletions
				
			
		|  | @ -71,8 +71,6 @@ export const Home = observer(function Home({navIdx, visible}: ScreenParams) { | |||
|     store.log.debug('HomeScreen: Updating feed') | ||||
|     if (store.me.mainFeed.hasContent) { | ||||
|       store.me.mainFeed.update() | ||||
|     } else { | ||||
|       store.me.mainFeed.setup() | ||||
|     } | ||||
|     return cleanup | ||||
|   }, [visible, store, store.me.mainFeed, navIdx, doPoll, wasVisible, scrollToTop, screen]) | ||||
|  | @ -97,6 +95,8 @@ export const Home = observer(function Home({navIdx, visible}: ScreenParams) { | |||
|         feed={store.me.mainFeed} | ||||
|         scrollElRef={scrollElRef} | ||||
|         style={s.hContentRegion} | ||||
|         showWelcomeBanner | ||||
|         showPostFollowBtn | ||||
|         onPressTryAgain={onPressTryAgain} | ||||
|         onScroll={onMainScroll} | ||||
|         headerOffset={HEADER_HEIGHT} | ||||
|  |  | |||
|  | @ -1,40 +0,0 @@ | |||
| import React, {useEffect} from 'react' | ||||
| import {StyleSheet, View} from 'react-native' | ||||
| import {observer} from 'mobx-react-lite' | ||||
| import {FeatureExplainer} from '../com/onboard/FeatureExplainer' | ||||
| import {Follows} from '../com/onboard/Follows' | ||||
| import {OnboardStage, OnboardStageOrder} from 'state/models/onboard' | ||||
| import {useStores} from 'state/index' | ||||
| 
 | ||||
| export const Onboard = observer(() => { | ||||
|   const store = useStores() | ||||
| 
 | ||||
|   useEffect(() => { | ||||
|     // sanity check - bounce out of onboarding if the stage is wrong somehow
 | ||||
|     if (!OnboardStageOrder.includes(store.onboard.stage)) { | ||||
|       store.onboard.stop() | ||||
|     } | ||||
|   }, [store.onboard]) | ||||
| 
 | ||||
|   let Com | ||||
|   if (store.onboard.stage === OnboardStage.Explainers) { | ||||
|     Com = FeatureExplainer | ||||
|   } else if (store.onboard.stage === OnboardStage.Follows) { | ||||
|     Com = Follows | ||||
|   } else { | ||||
|     Com = View | ||||
|   } | ||||
| 
 | ||||
|   return ( | ||||
|     <View style={styles.container}> | ||||
|       <Com /> | ||||
|     </View> | ||||
|   ) | ||||
| }) | ||||
| 
 | ||||
| const styles = StyleSheet.create({ | ||||
|   container: { | ||||
|     height: '100%', | ||||
|     backgroundColor: '#fff', | ||||
|   }, | ||||
| }) | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue