Lex refactor (#362)
* Remove the hackcheck for upgrades * Rename the PostEmbeds folder to match the codebase style * Updates to latest lex refactor * Update to use new bsky agent * Update to use api package's richtext library * Switch to upsertProfile * Add TextEncoder/TextDecoder polyfill * Add Intl.Segmenter polyfill * Update composer to calculate lengths by grapheme * Fix detox * Fix login in e2e * Create account e2e passing * Implement an e2e mocking framework * Don't use private methods on mobx models as mobx can't track them * Add tooling for e2e-specific builds and add e2e media-picker mock * Add some tests and fix some bugs around profile editing * Add shell tests * Add home screen tests * Add thread screen tests * Add tests for other user profile screens * Add search screen tests * Implement profile imagery change tools and tests * Update to new embed behaviors * Add post tests * Fix to profile-screen test * Fix session resumption * Update web composer to new api * 1.11.0 * Fix pagination cursor parameters * Add quote posts to notifications * Fix embed layouts * Remove youtube inline player and improve tap handling on link cards * Reset minimal shell mode on all screen loads and feed swipes (close #299) * Update podfile.lock * Improve post notfound UI (close #366) * Bump atproto packages
This commit is contained in:
		
							parent
							
								
									19f3a2fa92
								
							
						
					
					
						commit
						a3334a01a2
					
				
					 133 changed files with 3103 additions and 2839 deletions
				
			
		|  | @ -33,6 +33,7 @@ export const HomeScreen = withAuthRequired((_opts: Props) => { | |||
| 
 | ||||
|   useFocusEffect( | ||||
|     React.useCallback(() => { | ||||
|       store.shell.setMinimalShellMode(false) | ||||
|       store.shell.setIsDrawerSwipeDisabled(selectedPage > 0) | ||||
|       return () => { | ||||
|         store.shell.setIsDrawerSwipeDisabled(false) | ||||
|  | @ -42,6 +43,7 @@ export const HomeScreen = withAuthRequired((_opts: Props) => { | |||
| 
 | ||||
|   const onPageSelected = React.useCallback( | ||||
|     (index: number) => { | ||||
|       store.shell.setMinimalShellMode(false) | ||||
|       setSelectedPage(index) | ||||
|       store.shell.setIsDrawerSwipeDisabled(index > 0) | ||||
|     }, | ||||
|  | @ -54,7 +56,13 @@ export const HomeScreen = withAuthRequired((_opts: Props) => { | |||
| 
 | ||||
|   const renderTabBar = React.useCallback( | ||||
|     (props: RenderTabBarFnProps) => { | ||||
|       return <FeedsTabBar {...props} onPressSelected={onPressSelected} /> | ||||
|       return ( | ||||
|         <FeedsTabBar | ||||
|           {...props} | ||||
|           testID="homeScreenFeedTabs" | ||||
|           onPressSelected={onPressSelected} | ||||
|         /> | ||||
|       ) | ||||
|     }, | ||||
|     [onPressSelected], | ||||
|   ) | ||||
|  | @ -66,27 +74,36 @@ export const HomeScreen = withAuthRequired((_opts: Props) => { | |||
|   const initialPage = store.me.follows.isEmpty ? 1 : 0 | ||||
|   return ( | ||||
|     <Pager | ||||
|       testID="homeScreen" | ||||
|       onPageSelected={onPageSelected} | ||||
|       renderTabBar={renderTabBar} | ||||
|       tabBarPosition="top" | ||||
|       initialPage={initialPage}> | ||||
|       <FeedPage | ||||
|         key="1" | ||||
|         testID="followingFeedPage" | ||||
|         isPageFocused={selectedPage === 0} | ||||
|         feed={store.me.mainFeed} | ||||
|         renderEmptyState={renderFollowingEmptyState} | ||||
|       /> | ||||
|       <FeedPage key="2" isPageFocused={selectedPage === 1} feed={algoFeed} /> | ||||
|       <FeedPage | ||||
|         key="2" | ||||
|         testID="whatshotFeedPage" | ||||
|         isPageFocused={selectedPage === 1} | ||||
|         feed={algoFeed} | ||||
|       /> | ||||
|     </Pager> | ||||
|   ) | ||||
| }) | ||||
| 
 | ||||
| const FeedPage = observer( | ||||
|   ({ | ||||
|     testID, | ||||
|     isPageFocused, | ||||
|     feed, | ||||
|     renderEmptyState, | ||||
|   }: { | ||||
|     testID?: string | ||||
|     feed: FeedModel | ||||
|     isPageFocused: boolean | ||||
|     renderEmptyState?: () => JSX.Element | ||||
|  | @ -163,9 +180,9 @@ const FeedPage = observer( | |||
|     }, [feed, scrollToTop]) | ||||
| 
 | ||||
|     return ( | ||||
|       <View style={s.h100pct}> | ||||
|       <View testID={testID} style={s.h100pct}> | ||||
|         <Feed | ||||
|           testID="homeFeed" | ||||
|           testID={testID ? `${testID}-feed` : undefined} | ||||
|           key="default" | ||||
|           feed={feed} | ||||
|           scrollElRef={scrollElRef} | ||||
|  |  | |||
|  | @ -1,16 +1,28 @@ | |||
| import React from 'react' | ||||
| import {StyleSheet, View} from 'react-native' | ||||
| import {useNavigation, StackActions} from '@react-navigation/native' | ||||
| import { | ||||
|   useNavigation, | ||||
|   StackActions, | ||||
|   useFocusEffect, | ||||
| } from '@react-navigation/native' | ||||
| import {ViewHeader} from '../com/util/ViewHeader' | ||||
| import {Text} from '../com/util/text/Text' | ||||
| import {Button} from 'view/com/util/forms/Button' | ||||
| import {NavigationProp} from 'lib/routes/types' | ||||
| import {usePalette} from 'lib/hooks/usePalette' | ||||
| import {useStores} from 'state/index' | ||||
| import {s} from 'lib/styles' | ||||
| 
 | ||||
| export const NotFoundScreen = () => { | ||||
|   const pal = usePalette('default') | ||||
|   const navigation = useNavigation<NavigationProp>() | ||||
|   const store = useStores() | ||||
| 
 | ||||
|   useFocusEffect( | ||||
|     React.useCallback(() => { | ||||
|       store.shell.setMinimalShellMode(false) | ||||
|     }, [store]), | ||||
|   ) | ||||
| 
 | ||||
|   const canGoBack = navigation.canGoBack() | ||||
|   const onPressHome = React.useCallback(() => { | ||||
|  |  | |||
|  | @ -72,6 +72,7 @@ export const NotificationsScreen = withAuthRequired( | |||
|     // =
 | ||||
|     useFocusEffect( | ||||
|       React.useCallback(() => { | ||||
|         store.shell.setMinimalShellMode(false) | ||||
|         store.log.debug('NotificationsScreen: Updating feed') | ||||
|         const softResetSub = store.onScreenSoftReset(scrollToTop) | ||||
|         store.me.notifications.loadUnreadCount() | ||||
|  | @ -86,7 +87,7 @@ export const NotificationsScreen = withAuthRequired( | |||
|     ) | ||||
| 
 | ||||
|     return ( | ||||
|       <View style={s.hContentRegion}> | ||||
|       <View testID="notificationsScreen" style={s.hContentRegion}> | ||||
|         <ViewHeader title="Notifications" canGoBack={false} /> | ||||
|         <Feed | ||||
|           view={store.me.notifications} | ||||
|  |  | |||
|  | @ -4,12 +4,12 @@ import {useFocusEffect} from '@react-navigation/native' | |||
| import {NativeStackScreenProps, CommonNavigatorParams} from 'lib/routes/types' | ||||
| import {withAuthRequired} from 'view/com/auth/withAuthRequired' | ||||
| import {ViewHeader} from '../com/util/ViewHeader' | ||||
| import {PostVotedBy as PostLikedByComponent} from '../com/post-thread/PostVotedBy' | ||||
| import {PostLikedBy as PostLikedByComponent} from '../com/post-thread/PostLikedBy' | ||||
| import {useStores} from 'state/index' | ||||
| import {makeRecordUri} from 'lib/strings/url-helpers' | ||||
| 
 | ||||
| type Props = NativeStackScreenProps<CommonNavigatorParams, 'PostUpvotedBy'> | ||||
| export const PostUpvotedByScreen = withAuthRequired(({route}: Props) => { | ||||
| type Props = NativeStackScreenProps<CommonNavigatorParams, 'PostLikedBy'> | ||||
| export const PostLikedByScreen = withAuthRequired(({route}: Props) => { | ||||
|   const store = useStores() | ||||
|   const {name, rkey} = route.params | ||||
|   const uri = makeRecordUri(name, 'app.bsky.feed.post', rkey) | ||||
|  | @ -23,7 +23,7 @@ export const PostUpvotedByScreen = withAuthRequired(({route}: Props) => { | |||
|   return ( | ||||
|     <View> | ||||
|       <ViewHeader title="Liked by" /> | ||||
|       <PostLikedByComponent uri={uri} direction="up" /> | ||||
|       <PostLikedByComponent uri={uri} /> | ||||
|     </View> | ||||
|   ) | ||||
| }) | ||||
|  | @ -29,8 +29,8 @@ export const PostThreadScreen = withAuthRequired(({route}: Props) => { | |||
| 
 | ||||
|   useFocusEffect( | ||||
|     React.useCallback(() => { | ||||
|       const threadCleanup = view.registerListeners() | ||||
|       store.shell.setMinimalShellMode(false) | ||||
|       const threadCleanup = view.registerListeners() | ||||
|       if (!view.hasLoaded && !view.isLoading) { | ||||
|         view.setup().catch(err => { | ||||
|           store.log.error('Failed to fetch thread', err) | ||||
|  |  | |||
|  | @ -42,6 +42,7 @@ export const ProfileScreen = withAuthRequired( | |||
|     useFocusEffect( | ||||
|       React.useCallback(() => { | ||||
|         let aborted = false | ||||
|         store.shell.setMinimalShellMode(false) | ||||
|         const feedCleanup = uiState.feed.registerListeners() | ||||
|         if (hasSetup) { | ||||
|           uiState.update() | ||||
|  | @ -57,7 +58,7 @@ export const ProfileScreen = withAuthRequired( | |||
|           aborted = true | ||||
|           feedCleanup() | ||||
|         } | ||||
|       }, [hasSetup, uiState]), | ||||
|       }, [hasSetup, uiState, store]), | ||||
|     ) | ||||
| 
 | ||||
|     // events
 | ||||
|  |  | |||
|  | @ -152,6 +152,7 @@ export const SearchScreen = withAuthRequired( | |||
|                   {autocompleteView.searchRes.map(item => ( | ||||
|                     <ProfileCard | ||||
|                       key={item.did} | ||||
|                       testID={`searchAutoCompleteResult-${item.handle}`} | ||||
|                       handle={item.handle} | ||||
|                       displayName={item.displayName} | ||||
|                       avatar={item.avatar} | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue