Files
react-navigation/packages/stack/example/src/HeaderBackgrounds.js
2019-05-25 00:58:11 +02:00

116 lines
2.9 KiB
JavaScript

import * as React from 'react';
import { StyleSheet, View, Text } from 'react-native';
import Animated from 'react-native-reanimated';
import {
createStackNavigator,
TransitionPresets,
HeaderStyleInterpolators,
} from 'react-navigation-stack';
function createHeaderBackgroundExample(options = {}) {
return createStackNavigator(
{
Login: {
screen: ({ navigation }) => (
<View style={styles.container}>
<Text
style={styles.tips}
onPress={() => navigation.navigate('Games')}
>
Login Screen
</Text>
</View>
),
navigationOptions: {
headerTitle: 'Login Screen',
headerTintColor: '#fff',
headerBackground: () => (
<View style={{ flex: 1, backgroundColor: '#FF0066' }} />
),
},
},
Games: {
screen: ({ navigation }) => (
<View style={styles.container}>
<Text
style={styles.tips}
onPress={() => navigation.navigate('Main')}
>
Games Screen
</Text>
</View>
),
navigationOptions: {
headerTitle: 'Games Screen',
headerTintColor: '#fff',
headerBackground: () => (
<View style={{ flex: 1, backgroundColor: '#3388FF' }} />
),
},
},
Main: {
screen: ({ navigation }) => (
<View style={styles.container}>
<Text style={styles.tips} onPress={() => navigation.navigate('My')}>
Main Screen
</Text>
</View>
),
navigationOptions: {
headerTitle: 'Main Screen',
},
},
My: {
screen: ({ navigation }) => (
<View style={styles.container}>
<Text
style={styles.tips}
onPress={() => navigation.navigate('News')}
>
My Screen
</Text>
</View>
),
navigationOptions: {
headerTitle: 'My Screen',
},
},
News: {
screen: () => (
<View style={styles.container}>
<Text style={styles.tips} onPress={() => {}}>
News Screen
</Text>
</View>
),
navigationOptions: {
headerTitle: 'News Screen',
},
},
},
{
initialRouteName: 'Login',
...options,
}
);
}
export const HeaderBackgroundDefault = createHeaderBackgroundExample();
export const HeaderBackgroundFade = createHeaderBackgroundExample({
...TransitionPresets.SlideFromRightIOS,
headerStyleInterpolator: HeaderStyleInterpolators.forFade,
headerMode: 'float',
});
const styles = StyleSheet.create({
container: {
flex: 1,
backgroundColor: '#F5FCFF',
justifyContent: 'center',
alignItems: 'center',
},
tips: {
fontSize: 20,
},
});