Add current user profile to header and enlarge the header
This commit is contained in:
		
							parent
							
								
									ccae52f612
								
							
						
					
					
						commit
						60c72087ff
					
				
					 3 changed files with 49 additions and 13 deletions
				
			
		|  | @ -42,6 +42,11 @@ export const ProfileHeader = observer(function ProfileHeader({ | ||||||
|   const onPressBack = () => { |   const onPressBack = () => { | ||||||
|     store.nav.tab.goBack() |     store.nav.tab.goBack() | ||||||
|   } |   } | ||||||
|  |   const onPressMyAvatar = () => { | ||||||
|  |     if (store.me.handle) { | ||||||
|  |       store.nav.navigate(`/profile/${store.me.handle}`) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|   const onPressToggleFollow = () => { |   const onPressToggleFollow = () => { | ||||||
|     view?.toggleFollowing().then( |     view?.toggleFollowing().then( | ||||||
|       () => { |       () => { | ||||||
|  | @ -143,12 +148,21 @@ export const ProfileHeader = observer(function ProfileHeader({ | ||||||
|       {store.nav.tab.canGoBack ? ( |       {store.nav.tab.canGoBack ? ( | ||||||
|         <TouchableOpacity style={styles.backButton} onPress={onPressBack}> |         <TouchableOpacity style={styles.backButton} onPress={onPressBack}> | ||||||
|           <FontAwesomeIcon |           <FontAwesomeIcon | ||||||
|             size={14} |             size={18} | ||||||
|             icon="angle-left" |             icon="angle-left" | ||||||
|             style={styles.backIcon} |             style={styles.backIcon} | ||||||
|           /> |           /> | ||||||
|         </TouchableOpacity> |         </TouchableOpacity> | ||||||
|       ) : undefined} |       ) : undefined} | ||||||
|  |       {store.me.did ? ( | ||||||
|  |         <TouchableOpacity style={styles.myAvatar} onPress={onPressMyAvatar}> | ||||||
|  |           <UserAvatar | ||||||
|  |             size={30} | ||||||
|  |             handle={store.me.handle || ''} | ||||||
|  |             displayName={store.me.displayName} | ||||||
|  |           /> | ||||||
|  |         </TouchableOpacity> | ||||||
|  |       ) : undefined} | ||||||
|       <View style={styles.avi}> |       <View style={styles.avi}> | ||||||
|         <UserAvatar |         <UserAvatar | ||||||
|           size={80} |           size={80} | ||||||
|  | @ -321,6 +335,14 @@ const styles = StyleSheet.create({ | ||||||
|     height: 14, |     height: 14, | ||||||
|     color: colors.black, |     color: colors.black, | ||||||
|   }, |   }, | ||||||
|  |   myAvatar: { | ||||||
|  |     position: 'absolute', | ||||||
|  |     top: 10, | ||||||
|  |     right: 12, | ||||||
|  |     backgroundColor: '#ffff', | ||||||
|  |     padding: 1, | ||||||
|  |     borderRadius: 30, | ||||||
|  |   }, | ||||||
|   avi: { |   avi: { | ||||||
|     position: 'absolute', |     position: 'absolute', | ||||||
|     top: 80, |     top: 80, | ||||||
|  |  | ||||||
|  | @ -1,7 +1,8 @@ | ||||||
| import React from 'react' | import React from 'react' | ||||||
| import {StyleSheet, Text, TouchableOpacity, View} from 'react-native' | import {StyleSheet, Text, TouchableOpacity, View} from 'react-native' | ||||||
| import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' | ||||||
| import {s, colors} from '../../lib/styles' | import {UserAvatar} from './UserAvatar' | ||||||
|  | import {colors} from '../../lib/styles' | ||||||
| import {useStores} from '../../../state' | import {useStores} from '../../../state' | ||||||
| 
 | 
 | ||||||
| export function ViewHeader({ | export function ViewHeader({ | ||||||
|  | @ -15,15 +16,16 @@ export function ViewHeader({ | ||||||
|   const onPressBack = () => { |   const onPressBack = () => { | ||||||
|     store.nav.tab.goBack() |     store.nav.tab.goBack() | ||||||
|   } |   } | ||||||
|  |   const onPressAvatar = () => { | ||||||
|  |     if (store.me.handle) { | ||||||
|  |       store.nav.navigate(`/profile/${store.me.handle}`) | ||||||
|  |     } | ||||||
|  |   } | ||||||
|   return ( |   return ( | ||||||
|     <View style={styles.header}> |     <View style={styles.header}> | ||||||
|       {store.nav.tab.canGoBack ? ( |       {store.nav.tab.canGoBack ? ( | ||||||
|         <TouchableOpacity onPress={onPressBack}> |         <TouchableOpacity onPress={onPressBack} style={styles.backIcon}> | ||||||
|           <FontAwesomeIcon |           <FontAwesomeIcon size={18} icon="angle-left" style={{marginTop: 3}} /> | ||||||
|             size={14} |  | ||||||
|             icon="angle-left" |  | ||||||
|             style={styles.backIcon} |  | ||||||
|           /> |  | ||||||
|         </TouchableOpacity> |         </TouchableOpacity> | ||||||
|       ) : ( |       ) : ( | ||||||
|         <View style={styles.cornerPlaceholder} /> |         <View style={styles.cornerPlaceholder} /> | ||||||
|  | @ -36,7 +38,17 @@ export function ViewHeader({ | ||||||
|           </Text> |           </Text> | ||||||
|         ) : undefined} |         ) : undefined} | ||||||
|       </View> |       </View> | ||||||
|  |       {store.me.did ? ( | ||||||
|  |         <TouchableOpacity onPress={onPressAvatar}> | ||||||
|  |           <UserAvatar | ||||||
|  |             size={24} | ||||||
|  |             handle={store.me.handle || ''} | ||||||
|  |             displayName={store.me.displayName} | ||||||
|  |           /> | ||||||
|  |         </TouchableOpacity> | ||||||
|  |       ) : ( | ||||||
|         <View style={styles.cornerPlaceholder} /> |         <View style={styles.cornerPlaceholder} /> | ||||||
|  |       )} | ||||||
|     </View> |     </View> | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
|  | @ -47,7 +59,8 @@ const styles = StyleSheet.create({ | ||||||
|     alignItems: 'center', |     alignItems: 'center', | ||||||
|     backgroundColor: colors.white, |     backgroundColor: colors.white, | ||||||
|     paddingHorizontal: 12, |     paddingHorizontal: 12, | ||||||
|     paddingBottom: 6, |     paddingTop: 2, | ||||||
|  |     paddingBottom: 8, | ||||||
|     borderBottomColor: colors.gray1, |     borderBottomColor: colors.gray1, | ||||||
|     borderBottomWidth: 1, |     borderBottomWidth: 1, | ||||||
|   }, |   }, | ||||||
|  | @ -70,8 +83,8 @@ const styles = StyleSheet.create({ | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   cornerPlaceholder: { |   cornerPlaceholder: { | ||||||
|     width: 14, |     width: 24, | ||||||
|     height: 14, |     height: 24, | ||||||
|   }, |   }, | ||||||
|   backIcon: {width: 14, height: 14}, |   backIcon: {width: 24, height: 24}, | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | @ -115,6 +115,7 @@ export const Profile = observer(({visible, params}: ScreenParams) => { | ||||||
|       renderItem = (item: any) => ( |       renderItem = (item: any) => ( | ||||||
|         <View style={s.p5}> |         <View style={s.p5}> | ||||||
|           <ErrorMessage |           <ErrorMessage | ||||||
|  |             dark | ||||||
|             message={item.error} |             message={item.error} | ||||||
|             onPressTryAgain={onPressTryAgain} |             onPressTryAgain={onPressTryAgain} | ||||||
|           /> |           /> | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue