-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathApp.js
108 lines (100 loc) · 3.96 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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
import 'react-native-gesture-handler';
import React, { useEffect } from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { createStackNavigator } from '@react-navigation/stack';
import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
import { FontAwesomeIcon } from '@fortawesome/react-native-fontawesome';
import { faBookmark, faNewspaper, faFileAlt, faCheck, faUser, faHeadphones } from '@fortawesome/free-solid-svg-icons';
import SplashScreen from 'react-native-splash-screen';
import MarkAttendanceScreen from './screens/MarkAttendanceScreen';
import TimeTableScreen from './screens/TimeTableScreen';
import SubjectsScreen from './screens/SubjectsScreen';
import TasksScreen from './screens/TasksScreen';
import ConcentrateScreen from './screens/ConcentrateScreen';
import ProfileScreen from './screens/ProfileScreen';
const Tab = createBottomTabNavigator();
const MarkAttendanceStack = createStackNavigator();
const TimeTableStack = createStackNavigator();
const SubjectsStack = createStackNavigator();
const TasksStack = createStackNavigator();
const ConcentrateStack = createStackNavigator();
const ProfileStack = createStackNavigator();
function MarkAttendanceStackScreen() {
return (
<MarkAttendanceStack.Navigator>
<MarkAttendanceStack.Screen name="Mark Attendance" component={MarkAttendanceScreen} />
</MarkAttendanceStack.Navigator>
);
}
function TimeTableStackScreen() {
return (
<TimeTableStack.Navigator>
<TimeTableStack.Screen name="Time Table" component={TimeTableScreen} />
</TimeTableStack.Navigator>
);
}
function SubjectsStackScreen() {
return (
<SubjectsStack.Navigator>
<SubjectsStack.Screen name="Subjects" component={SubjectsScreen} />
</SubjectsStack.Navigator>
);
}
function TasksStackScreen() {
return (
<TasksStack.Navigator>
<TasksStack.Screen name="Tasks" component={TasksScreen} />
</TasksStack.Navigator>
);
}
function ConcentrateStackScreen() {
return (
<ConcentrateStack.Navigator>
<ConcentrateStack.Screen name="Concentration Music" component={ConcentrateScreen} />
</ConcentrateStack.Navigator>
);
}
function ProfileStackScreen() {
return (
<ProfileStack.Navigator>
<ProfileStack.Screen name="Profile" component={ProfileScreen} />
</ProfileStack.Navigator>
);
}
export default function App() {
useEffect(() => {
SplashScreen.hide();
}, []);
return (
<NavigationContainer>
<Tab.Navigator
initialRouteName="Profile"
screenOptions={({ route }) => ({
tabBarIcon: ({ color }) => {
if (route.name === 'Attendance') {
return (<FontAwesomeIcon icon={faBookmark} size={22} color={color} />);
} else if (route.name === 'Subjects') {
return <FontAwesomeIcon icon={faFileAlt} size={22} color={color} />;
} else if (route.name === 'Time Table') {
return (<FontAwesomeIcon icon={faNewspaper} size={33} color={color} />);
} else if (route.name === 'Tasks') {
return <FontAwesomeIcon icon={faCheck} size={22} color={color} />;
} else if (route.name === 'Concentrate') {
return <FontAwesomeIcon icon={faHeadphones} size={22} color={color} />;
} else if (route.name === 'Profile') {
return <FontAwesomeIcon icon={faUser} size={22} color={color} />;
}
},
})}
tabBarOptions={{ activeTintColor: '#24a0ed', inactiveTintColor: 'gray' }}
>
<Tab.Screen name="Attendance" component={MarkAttendanceStackScreen} />
<Tab.Screen name="Subjects" component={SubjectsStackScreen} />
<Tab.Screen name="Time Table" component={TimeTableStackScreen} />
<Tab.Screen name="Tasks" component={TasksStackScreen} />
<Tab.Screen name="Concentrate" component={ConcentrateStackScreen} />
<Tab.Screen name="Profile" component={ProfileStackScreen} />
</Tab.Navigator>
</NavigationContainer>
);
}