Add profile loading shim (#1940)
This commit is contained in:
		
							parent
							
								
									22df70b3cc
								
							
						
					
					
						commit
						f89dc63801
					
				
					 3 changed files with 26 additions and 22 deletions
				
			
		|  | @ -11,12 +11,14 @@ import {s} from 'lib/styles' | |||
| import {useModerationOpts} from '#/state/queries/preferences' | ||||
| import {useProfileQuery} from '#/state/queries/profile' | ||||
| import {ErrorScreen} from '../util/error/ErrorScreen' | ||||
| import {CenteredView} from '../util/Views' | ||||
| import {cleanError} from '#/lib/strings/errors' | ||||
| import {useProfileShadow} from '#/state/cache/profile-shadow' | ||||
| 
 | ||||
| export const snapPoints = [520, '100%'] | ||||
| 
 | ||||
| export function Component({did}: {did: string}) { | ||||
|   const pal = usePalette('default') | ||||
|   const moderationOpts = useModerationOpts() | ||||
|   const { | ||||
|     data: profile, | ||||
|  | @ -30,9 +32,13 @@ export function Component({did}: {did: string}) { | |||
| 
 | ||||
|   if (isFetchingProfile || !moderationOpts) { | ||||
|     return ( | ||||
|       <View style={s.p20}> | ||||
|         <ActivityIndicator size="large" /> | ||||
|       </View> | ||||
|       <CenteredView style={[pal.view, s.flex1]}> | ||||
|         <ProfileHeader | ||||
|           profile={null} | ||||
|           moderation={null} | ||||
|           isProfilePreview={true} | ||||
|         /> | ||||
|       </CenteredView> | ||||
|     ) | ||||
|   } | ||||
|   if (profileError) { | ||||
|  |  | |||
|  | @ -53,8 +53,8 @@ import {useSession} from '#/state/session' | |||
| import {Shadow} from '#/state/cache/types' | ||||
| 
 | ||||
| interface Props { | ||||
|   profile: Shadow<AppBskyActorDefs.ProfileViewDetailed> | ||||
|   moderation: ProfileModeration | ||||
|   profile: Shadow<AppBskyActorDefs.ProfileViewDetailed> | null | ||||
|   moderation: ProfileModeration | null | ||||
|   hideBackButton?: boolean | ||||
|   isProfilePreview?: boolean | ||||
| } | ||||
|  | @ -69,7 +69,7 @@ export function ProfileHeader({ | |||
| 
 | ||||
|   // loading
 | ||||
|   // =
 | ||||
|   if (!profile) { | ||||
|   if (!profile || !moderation) { | ||||
|     return ( | ||||
|       <View style={pal.view}> | ||||
|         <LoadingPlaceholder width="100%" height={153} /> | ||||
|  | @ -81,11 +81,6 @@ export function ProfileHeader({ | |||
|           <View style={[styles.buttonsLine]}> | ||||
|             <LoadingPlaceholder width={167} height={31} style={styles.br50} /> | ||||
|           </View> | ||||
|           <View> | ||||
|             <Text type="title-2xl" style={[pal.text, styles.title]}> | ||||
|               <Trans>Loading...</Trans> | ||||
|             </Text> | ||||
|           </View> | ||||
|         </View> | ||||
|       </View> | ||||
|     ) | ||||
|  | @ -103,12 +98,19 @@ export function ProfileHeader({ | |||
|   ) | ||||
| } | ||||
| 
 | ||||
| interface LoadedProps { | ||||
|   profile: Shadow<AppBskyActorDefs.ProfileViewDetailed> | ||||
|   moderation: ProfileModeration | ||||
|   hideBackButton?: boolean | ||||
|   isProfilePreview?: boolean | ||||
| } | ||||
| 
 | ||||
| function ProfileHeaderLoaded({ | ||||
|   profile, | ||||
|   moderation, | ||||
|   hideBackButton = false, | ||||
|   isProfilePreview, | ||||
| }: Props) { | ||||
| }: LoadedProps) { | ||||
|   const pal = usePalette('default') | ||||
|   const palInverted = usePalette('inverted') | ||||
|   const {currentAccount} = useSession() | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue