-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.js
63 lines (56 loc) · 1.81 KB
/
App.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import React from 'react';
import { Platform } from 'react-native';
import { Ionicons } from '@expo/vector-icons';
import { createAppContainer } from "react-navigation";
import { createStackNavigator } from "react-navigation-stack";
import { createBottomTabNavigator } from 'react-navigation-tabs';
import Home from './Screens/Home';
import Detail from './Screens/Detail';
import Settings from './Screens/Settings';
const HomeStack = createStackNavigator({
Home: {
screen: Home,
navigationOptions: { title: "Home" },
},
Detail: {
screen: Detail,
navigationOptions: { title: "Detail" },
}
});
const SettingsStack = createStackNavigator({
Settings: {
screen: Settings,
navigationOptions: { title: 'Settings' },
},
});
const AppNavigator = createBottomTabNavigator(
{
Home: HomeStack,
Settings: SettingsStack,
},
{
// initial route rendered when app first mounts
initialRouteName: 'Home',
defaultNavigationOptions: ({ navigation }) => ({
tabBarIcon: ({ tintColor }) => {
const { routeName } = navigation.state;
let iconName;
if (routeName === 'Home') {
iconName = `${Platform.OS === 'ios' ? 'ios' : 'md'}-home`;
}
else if (routeName === 'Settings') {
iconName = `${Platform.OS === 'ios' ? 'ios' : 'md'}-settings`;
}
return <Ionicons name={iconName} size={20} color={tintColor} />;
},
tabBarOptions: {
activeTintColor: 'blue',
inactiveTintColor: '#556',
},
}),
}
);
export default createAppContainer(AppNavigator);
// package.json
// expo install react-navigation react-navigation-stack react-navigation-tabs
// expo install react-native-gesture-handler react-native-reanimated react-native-screens react-native-safe-area-context @react-native-community/masked-view