This repository has been archived on 2024-11-20. You can view files and clone it, but cannot push or open issues or pull requests.
p61-project/app/_layout.tsx

76 lines
1.6 KiB
TypeScript
Raw Normal View History

2024-02-16 22:51:50 +01:00
import { Stack } from "expo-router"
import * as SplashScreen from "expo-splash-screen"
import {
MD3LightTheme as DefaultTheme,
PaperProvider,
} from "react-native-paper"
import { StatusBar } from "expo-status-bar"
import { useEffect } from "react"
2024-02-16 22:51:50 +01:00
2024-03-16 00:36:44 +01:00
import { HabitsTrackerProvider } from "@/presentation/react/contexts/HabitsTracker"
import {
AuthenticationProvider,
useAuthentication,
} from "@/presentation/react/contexts/Authentication"
2024-02-16 22:51:50 +01:00
export { ErrorBoundary } from "expo-router"
export const unstableSettings = {
initialRouteName: "index",
}
SplashScreen.preventAutoHideAsync().catch((error) => {
console.error(error)
})
const StackLayout: React.FC = () => {
const { hasLoaded } = useAuthentication()
2024-02-16 22:51:50 +01:00
useEffect(() => {
if (!hasLoaded) {
2024-02-16 22:51:50 +01:00
SplashScreen.hideAsync().catch((error) => {
console.error(error)
})
}
}, [hasLoaded])
2024-02-16 22:51:50 +01:00
if (hasLoaded) {
return <></>
2024-02-16 22:51:50 +01:00
}
return (
<Stack
screenOptions={{
headerShown: false,
}}
>
<Stack.Screen name="(pages)" />
</Stack>
)
}
const RootLayout: React.FC = () => {
return (
<AuthenticationProvider>
<HabitsTrackerProvider>
<PaperProvider
theme={{
...DefaultTheme,
colors: {
...DefaultTheme.colors,
primary: "#f57c00",
secondary: "#fbc02d",
},
2024-03-15 22:48:28 +01:00
}}
>
<StackLayout />
<StatusBar style="dark" />
</PaperProvider>
</HabitsTrackerProvider>
</AuthenticationProvider>
2024-02-16 22:51:50 +01:00
)
}
export default RootLayout