Visually improve the empty state of feeds (#4466)
This commit is contained in:
		
							parent
							
								
									c2d7d23423
								
							
						
					
					
						commit
						4efd576f6a
					
				
					 4 changed files with 40 additions and 21 deletions
				
			
		|  | @ -56,7 +56,7 @@ export const ProfileFeedSection = React.forwardRef< | ||||||
|   })) |   })) | ||||||
| 
 | 
 | ||||||
|   const renderPostsEmpty = React.useCallback(() => { |   const renderPostsEmpty = React.useCallback(() => { | ||||||
|     return <EmptyState icon="feed" message={_(msg`This feed is empty!`)} /> |     return <EmptyState icon="growth" message={_(msg`No posts yet.`)} /> | ||||||
|   }, [_]) |   }, [_]) | ||||||
| 
 | 
 | ||||||
|   React.useEffect(() => { |   React.useEffect(() => { | ||||||
|  |  | ||||||
|  | @ -5,10 +5,13 @@ import { | ||||||
|   FontAwesomeIcon, |   FontAwesomeIcon, | ||||||
|   FontAwesomeIconStyle, |   FontAwesomeIconStyle, | ||||||
| } from '@fortawesome/react-native-fontawesome' | } from '@fortawesome/react-native-fontawesome' | ||||||
| import {Text} from './text/Text' | 
 | ||||||
| import {UserGroupIcon} from 'lib/icons' | import {useWebMediaQueries} from '#/lib/hooks/useWebMediaQueries' | ||||||
| import {usePalette} from 'lib/hooks/usePalette' | import {usePalette} from 'lib/hooks/usePalette' | ||||||
|  | import {UserGroupIcon} from 'lib/icons' | ||||||
| import {isWeb} from 'platform/detection' | import {isWeb} from 'platform/detection' | ||||||
|  | import {Growth_Stroke2_Corner0_Rounded as Growth} from '#/components/icons/Growth' | ||||||
|  | import {Text} from './text/Text' | ||||||
| 
 | 
 | ||||||
| export function EmptyState({ | export function EmptyState({ | ||||||
|   testID, |   testID, | ||||||
|  | @ -17,32 +20,41 @@ export function EmptyState({ | ||||||
|   style, |   style, | ||||||
| }: { | }: { | ||||||
|   testID?: string |   testID?: string | ||||||
|   icon: IconProp | 'user-group' |   icon: IconProp | 'user-group' | 'growth' | ||||||
|   message: string |   message: string | ||||||
|   style?: StyleProp<ViewStyle> |   style?: StyleProp<ViewStyle> | ||||||
| }) { | }) { | ||||||
|   const pal = usePalette('default') |   const pal = usePalette('default') | ||||||
|  |   const {isTabletOrDesktop} = useWebMediaQueries() | ||||||
|  |   const iconSize = isTabletOrDesktop ? 80 : 64 | ||||||
|   return ( |   return ( | ||||||
|     <View |     <View | ||||||
|       testID={testID} |       testID={testID} | ||||||
|       style={[styles.container, isWeb && pal.border, style]}> |       style={[ | ||||||
|       <View style={styles.iconContainer}> |         styles.container, | ||||||
|  |         isWeb && pal.border, | ||||||
|  |         isTabletOrDesktop && {paddingRight: 20}, | ||||||
|  |         style, | ||||||
|  |       ]}> | ||||||
|  |       <View | ||||||
|  |         style={[ | ||||||
|  |           styles.iconContainer, | ||||||
|  |           isTabletOrDesktop && styles.iconContainerBig, | ||||||
|  |           pal.viewLight, | ||||||
|  |         ]}> | ||||||
|         {icon === 'user-group' ? ( |         {icon === 'user-group' ? ( | ||||||
|           <UserGroupIcon size="64" style={styles.icon} /> |           <UserGroupIcon size={iconSize} /> | ||||||
|  |         ) : icon === 'growth' ? ( | ||||||
|  |           <Growth width={iconSize} fill={pal.colors.emptyStateIcon} /> | ||||||
|         ) : ( |         ) : ( | ||||||
|           <FontAwesomeIcon |           <FontAwesomeIcon | ||||||
|             icon={icon} |             icon={icon} | ||||||
|             size={64} |             size={iconSize} | ||||||
|             style={[ |             style={[{color: pal.colors.emptyStateIcon} as FontAwesomeIconStyle]} | ||||||
|               styles.icon, |  | ||||||
|               {color: pal.colors.emptyStateIcon} as FontAwesomeIconStyle, |  | ||||||
|             ]} |  | ||||||
|           /> |           /> | ||||||
|         )} |         )} | ||||||
|       </View> |       </View> | ||||||
|       <Text |       <Text type="xl" style={[{color: pal.colors.textLight}, styles.text]}> | ||||||
|         type="xl-medium" |  | ||||||
|         style={[{color: pal.colors.textVeryLight}, styles.text]}> |  | ||||||
|         {message} |         {message} | ||||||
|       </Text> |       </Text> | ||||||
|     </View> |     </View> | ||||||
|  | @ -51,16 +63,23 @@ export function EmptyState({ | ||||||
| 
 | 
 | ||||||
| const styles = StyleSheet.create({ | const styles = StyleSheet.create({ | ||||||
|   container: { |   container: { | ||||||
|     paddingVertical: 24, |  | ||||||
|     paddingHorizontal: 36, |  | ||||||
|     borderTopWidth: isWeb ? 1 : undefined, |     borderTopWidth: isWeb ? 1 : undefined, | ||||||
|   }, |   }, | ||||||
|   iconContainer: { |   iconContainer: { | ||||||
|     flexDirection: 'row', |     flexDirection: 'row', | ||||||
|   }, |     alignItems: 'center', | ||||||
|   icon: { |     justifyContent: 'center', | ||||||
|  |     height: 100, | ||||||
|  |     width: 100, | ||||||
|     marginLeft: 'auto', |     marginLeft: 'auto', | ||||||
|     marginRight: 'auto', |     marginRight: 'auto', | ||||||
|  |     borderRadius: 80, | ||||||
|  |     marginTop: 30, | ||||||
|  |   }, | ||||||
|  |   iconContainerBig: { | ||||||
|  |     width: 140, | ||||||
|  |     height: 140, | ||||||
|  |     marginTop: 50, | ||||||
|   }, |   }, | ||||||
|   text: { |   text: { | ||||||
|     textAlign: 'center', |     textAlign: 'center', | ||||||
|  |  | ||||||
|  | @ -468,7 +468,7 @@ const FeedSection = React.forwardRef<SectionRef, FeedSectionProps>( | ||||||
|     }, [onScrollToTop, isScreenFocused]) |     }, [onScrollToTop, isScreenFocused]) | ||||||
| 
 | 
 | ||||||
|     const renderPostsEmpty = useCallback(() => { |     const renderPostsEmpty = useCallback(() => { | ||||||
|       return <EmptyState icon="feed" message={_(msg`This feed is empty!`)} /> |       return <EmptyState icon="hashtag" message={_(msg`This feed is empty.`)} /> | ||||||
|     }, [_]) |     }, [_]) | ||||||
| 
 | 
 | ||||||
|     return ( |     return ( | ||||||
|  |  | ||||||
|  | @ -726,7 +726,7 @@ const FeedSection = React.forwardRef<SectionRef, FeedSectionProps>( | ||||||
|     }, [onScrollToTop, isScreenFocused]) |     }, [onScrollToTop, isScreenFocused]) | ||||||
| 
 | 
 | ||||||
|     const renderPostsEmpty = useCallback(() => { |     const renderPostsEmpty = useCallback(() => { | ||||||
|       return <EmptyState icon="feed" message={_(msg`This feed is empty!`)} /> |       return <EmptyState icon="hashtag" message={_(msg`This feed is empty.`)} /> | ||||||
|     }, [_]) |     }, [_]) | ||||||
| 
 | 
 | ||||||
|     return ( |     return ( | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue