-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathApp.js
More file actions
43 lines (34 loc) · 1.42 KB
/
App.js
File metadata and controls
43 lines (34 loc) · 1.42 KB
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
import React, { useState, useMemo } from 'react';
import { StatusBar } from 'expo-status-bar';
import { StyleSheet, Text, View } from 'react-native';
import { SafeAreaProvider } from 'react-native-safe-area-context';
import { NavigationContainer } from '@react-navigation/native';
import { createNativeStackNavigator } from '@react-navigation/native-stack';
import HomeScreen from './src/screens/HomeScreen';
import SettingsScreen from './src/screens/SettingsScreen';
const Stack = createNativeStackNavigator();
import DarkTheme from './src/theme/DarkTheme';
import DefaultTheme from './src/theme/DefaultTheme';
import { AppContext } from './src/context/AppContext';
export default function App() {
const [isDarkTheme, setIsDarkTheme] = useState(false);
const appContext = useMemo(() => {
return {
isDarkTheme,
setIsDarkTheme
}
});
return (
<SafeAreaProvider style={{ flex: 1 }}>
<StatusBar style={isDarkTheme ? 'light' : 'dark'} />
<NavigationContainer theme={isDarkTheme ? DarkTheme : DefaultTheme}>
<AppContext.Provider value={appContext}>
<Stack.Navigator initialRouteName='Home' screenOptions={{ headerShown: false }}>
<Stack.Screen name='Home' component={HomeScreen} />
<Stack.Screen name='Settings' component={SettingsScreen} />
</Stack.Navigator>
</AppContext.Provider>
</NavigationContainer>
</SafeAreaProvider>
);
}