-
Notifications
You must be signed in to change notification settings - Fork 0
/
App.tsx
50 lines (44 loc) · 1.5 KB
/
App.tsx
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
import React from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { createStackNavigator } from '@react-navigation/stack';
import { AuthProvider, useAuth } from './src/contexts/AuthContext';
import { TaskProvider } from './src/contexts/TaskContext';
import LoginScreen from './src/screens/LoginScreen';
import RegisterScreen from './src/screens/RegisterScreen';
import DashboardScreen from './src/screens/DashboardScreen';
import 'react-native-gesture-handler';
import SettingsScreen from './src/screens/SettingsScreen';
const Stack = createStackNavigator();
const App = () => {
const { user, loading } = useAuth();
if (loading) {
return null;
}
return (
<NavigationContainer>
<Stack.Navigator>
{!user ? (
<>
<Stack.Screen name="LoginScreen" component={LoginScreen} options={{ headerShown: false }} />
<Stack.Screen name="RegisterScreen" component={RegisterScreen} options={{ headerShown: false }} />
</>
) : (
<>
<Stack.Screen name="DashboardScreen" component={DashboardScreen} options={{ headerShown: false }} />
<Stack.Screen name="SettingsScreen" component={SettingsScreen} options={{ headerShown: true, headerTitle: 'Settings' }} />
</>
)}
</Stack.Navigator>
</NavigationContainer>
);
};
const Root = () => {
return (
<AuthProvider>
<TaskProvider>
<App />
</TaskProvider>
</AuthProvider>
);
};
export default Root;