Improvements to the feature explainer, including intro screen and screenshot of scenes
This commit is contained in:
		
							parent
							
								
									210082be93
								
							
						
					
					
						commit
						837ec8308a
					
				
					 4 changed files with 36 additions and 3 deletions
				
			
		
							
								
								
									
										
											BIN
										
									
								
								public/img/scene-explainer.jpg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/img/scene-explainer.jpg
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 122 KiB | 
|  | @ -1,6 +1,7 @@ | ||||||
| import React, {useState} from 'react' | import React, {useState} from 'react' | ||||||
| import { | import { | ||||||
|   Animated, |   Animated, | ||||||
|  |   Image, | ||||||
|   SafeAreaView, |   SafeAreaView, | ||||||
|   StyleSheet, |   StyleSheet, | ||||||
|   Text, |   Text, | ||||||
|  | @ -12,6 +13,23 @@ import {TabView, SceneMap, Route, TabBarProps} from 'react-native-tab-view' | ||||||
| import {UserGroupIcon} from '../../lib/icons' | import {UserGroupIcon} from '../../lib/icons' | ||||||
| import {useStores} from '../../../state' | import {useStores} from '../../../state' | ||||||
| import {s} from '../../lib/styles' | import {s} from '../../lib/styles' | ||||||
|  | import {SCENE_EXPLAINER} from '../../lib/assets' | ||||||
|  | 
 | ||||||
|  | const Intro = () => ( | ||||||
|  |   <View style={styles.explainer}> | ||||||
|  |     <Text | ||||||
|  |       style={[ | ||||||
|  |         styles.explainerHeading, | ||||||
|  |         s.normal, | ||||||
|  |         {lineHeight: 60, paddingTop: 50, paddingBottom: 50}, | ||||||
|  |       ]}> | ||||||
|  |       Welcome to <Text style={[s.bold, s.blue3, {fontSize: 56}]}>Bluesky</Text> | ||||||
|  |     </Text> | ||||||
|  |     <Text style={[styles.explainerDesc, {fontSize: 24}]}> | ||||||
|  |       Let's do a quick tour through the new features. | ||||||
|  |     </Text> | ||||||
|  |   </View> | ||||||
|  | ) | ||||||
| 
 | 
 | ||||||
| const Scenes = () => ( | const Scenes = () => ( | ||||||
|   <View style={styles.explainer}> |   <View style={styles.explainer}> | ||||||
|  | @ -25,11 +43,14 @@ const Scenes = () => ( | ||||||
|       Scenes are invite-only groups of users. Follow them to see what's trending |       Scenes are invite-only groups of users. Follow them to see what's trending | ||||||
|       with the scene's members. |       with the scene's members. | ||||||
|     </Text> |     </Text> | ||||||
|     <Text style={styles.explainerDesc}>[ TODO screenshot ]</Text> |     <Text style={styles.explainerDesc}> | ||||||
|  |       <Image source={SCENE_EXPLAINER} style={styles.explainerImg} /> | ||||||
|  |     </Text> | ||||||
|   </View> |   </View> | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const SCENE_MAP = { | const SCENE_MAP = { | ||||||
|  |   intro: Intro, | ||||||
|   scenes: Scenes, |   scenes: Scenes, | ||||||
| } | } | ||||||
| const renderScene = SceneMap(SCENE_MAP) | const renderScene = SceneMap(SCENE_MAP) | ||||||
|  | @ -38,7 +59,10 @@ export const FeatureExplainer = () => { | ||||||
|   const layout = useWindowDimensions() |   const layout = useWindowDimensions() | ||||||
|   const store = useStores() |   const store = useStores() | ||||||
|   const [index, setIndex] = useState(0) |   const [index, setIndex] = useState(0) | ||||||
|   const routes = [{key: 'scenes', title: 'Scenes'}] |   const routes = [ | ||||||
|  |     {key: 'intro', title: 'Intro'}, | ||||||
|  |     {key: 'scenes', title: 'Scenes'}, | ||||||
|  |   ] | ||||||
| 
 | 
 | ||||||
|   const onPressSkip = () => store.onboard.next() |   const onPressSkip = () => store.onboard.next() | ||||||
|   const onPressNext = () => { |   const onPressNext = () => { | ||||||
|  | @ -122,7 +146,7 @@ const styles = StyleSheet.create({ | ||||||
|   explainer: { |   explainer: { | ||||||
|     flex: 1, |     flex: 1, | ||||||
|     paddingHorizontal: 16, |     paddingHorizontal: 16, | ||||||
|     paddingVertical: 16, |     paddingTop: 80, | ||||||
|   }, |   }, | ||||||
|   explainerIcon: { |   explainerIcon: { | ||||||
|     flexDirection: 'row', |     flexDirection: 'row', | ||||||
|  | @ -138,6 +162,11 @@ const styles = StyleSheet.create({ | ||||||
|     textAlign: 'center', |     textAlign: 'center', | ||||||
|     marginBottom: 16, |     marginBottom: 16, | ||||||
|   }, |   }, | ||||||
|  |   explainerImg: { | ||||||
|  |     resizeMode: 'contain', | ||||||
|  |     maxWidth: '100%', | ||||||
|  |     maxHeight: 330, | ||||||
|  |   }, | ||||||
| 
 | 
 | ||||||
|   footer: { |   footer: { | ||||||
|     flexDirection: 'row', |     flexDirection: 'row', | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
| import {ImageSourcePropType} from 'react-native' | import {ImageSourcePropType} from 'react-native' | ||||||
| 
 | 
 | ||||||
| export const DEF_AVATAR: ImageSourcePropType = require('../../../public/img/default-avatar.jpg') | export const DEF_AVATAR: ImageSourcePropType = require('../../../public/img/default-avatar.jpg') | ||||||
|  | export const SCENE_EXPLAINER: ImageSourcePropType = require('../../../public/img/scene-explainer.jpg') | ||||||
|  |  | ||||||
|  | @ -1,3 +1,6 @@ | ||||||
| import {ImageSourcePropType} from 'react-native' | import {ImageSourcePropType} from 'react-native' | ||||||
| 
 | 
 | ||||||
| export const DEF_AVATAR: ImageSourcePropType = {uri: '/img/default-avatar.jpg'} | export const DEF_AVATAR: ImageSourcePropType = {uri: '/img/default-avatar.jpg'} | ||||||
|  | export const SCENE_EXPLAINER: ImageSourcePropType = { | ||||||
|  |   uri: '/img/scene-explainer.jpg', | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue