|
1 | 1 | import { NavigationContainer } from '@react-navigation/native'; |
2 | | -import React from 'react'; |
| 2 | +import React, { createContext, ReactNode, useEffect, useState } from 'react'; |
3 | 3 | import { SafeAreaProvider } from 'react-native-safe-area-context'; |
4 | 4 | import { AppEnvironmentProvider } from './AppEnvironment'; |
5 | 5 | import AuthContextProvider from './Auth/AuthContextProvider'; |
| 6 | +import { useColorScheme } from 'react-native'; |
6 | 7 | import RootStack from './Navigation/RootStack'; |
| 8 | +import { DarkMode, LightMode, Theme } from './Themes/Themes'; |
7 | 9 |
|
8 | | -function App() { |
| 10 | +type AuthContextType = { |
| 11 | + authenticated: boolean | null; |
| 12 | + setAuthenticated: (u: boolean) => void; |
| 13 | +}; |
| 14 | + |
| 15 | +type AuthProviderProps = { |
| 16 | + children: ReactNode; |
| 17 | +}; |
| 18 | + |
| 19 | +export const AuthContext = createContext<AuthContextType | undefined>(undefined); |
| 20 | + |
| 21 | +function AuthProvider({ children }: AuthProviderProps) { |
| 22 | + const [authenticated, setAuthenticated] = useState(false); |
| 23 | + return ( |
| 24 | + <AuthContext.Provider value={{ authenticated, setAuthenticated }}> |
| 25 | + {children} |
| 26 | + </AuthContext.Provider> |
| 27 | + ); |
| 28 | +} |
| 29 | + |
| 30 | +type ThemeContextType = { |
| 31 | + currentTheme: Theme | null | undefined; |
| 32 | + setTheme: (t: Theme) => void; |
| 33 | +}; |
| 34 | + |
| 35 | +type ThemeProviderProps = { |
| 36 | + children: ReactNode; |
| 37 | +}; |
9 | 38 |
|
| 39 | +export const ThemeContext = createContext<ThemeContextType | undefined>(undefined); |
| 40 | + |
| 41 | +function ThemeProvider({ children }: ThemeProviderProps) { |
| 42 | + const [currentTheme, setTheme] = useState<Theme>(LightMode); |
| 43 | + const currentSystemTheme = useColorScheme(); |
| 44 | + |
| 45 | + useEffect(() => { |
| 46 | + currentSystemTheme === 'light' ? setTheme(LightMode) : setTheme(DarkMode); |
| 47 | + }, [currentSystemTheme]); |
| 48 | + |
| 49 | + return ( |
| 50 | + <ThemeContext.Provider value={{ currentTheme, setTheme }}>{children}</ThemeContext.Provider> |
| 51 | + ); |
| 52 | +} |
| 53 | + |
| 54 | +function App() { |
10 | 55 | return ( |
11 | 56 | <AppEnvironmentProvider> |
12 | 57 | <SafeAreaProvider> |
13 | 58 | <AuthContextProvider> |
14 | | - <NavigationContainer> |
15 | | - <RootStack /> |
16 | | - </NavigationContainer> |
| 59 | + <ThemeProvider> |
| 60 | + <NavigationContainer> |
| 61 | + <RootStack /> |
| 62 | + </NavigationContainer> |
| 63 | + </ThemeProvider> |
17 | 64 | </AuthContextProvider> |
18 | 65 | </SafeAreaProvider> |
19 | 66 | </AppEnvironmentProvider> |
|
0 commit comments