- lib/theme.ts: C design tokens dans fichier dédié (plus d'import circulaire _layout)
- app/_layout.tsx: importe C depuis @/lib/theme, ré-exporte pour compatibilité
- Tous les écrans: import C depuis '@/lib/theme' au lieu de '../_layout'
- Toutes les navigations: router.push({ pathname, params }) au lieu de template strings
-> Fix réel du bug 'impossible d'ouvrir carnet/note' avec Expo Router v6
- package.json: expo-web-browser ajouté (pour Google OAuth étape suivante)
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
45 lines
1.2 KiB
TypeScript
45 lines
1.2 KiB
TypeScript
import { useEffect } from 'react'
|
|
import { Slot, useRouter, useSegments } from 'expo-router'
|
|
import { SafeAreaProvider } from 'react-native-safe-area-context'
|
|
import { StatusBar } from 'expo-status-bar'
|
|
import { View, ActivityIndicator, StyleSheet } from 'react-native'
|
|
import { useAuthStore } from '@/lib/store'
|
|
import { C } from '@/lib/theme'
|
|
|
|
// Ré-exporter C pour la compatibilité avec les anciens imports
|
|
export { C } from '@/lib/theme'
|
|
|
|
export default function RootLayout() {
|
|
const { user, loading, restore } = useAuthStore()
|
|
const router = useRouter()
|
|
const segments = useSegments()
|
|
|
|
useEffect(() => { restore() }, [])
|
|
|
|
useEffect(() => {
|
|
if (loading) return
|
|
const inAuth = segments[0] === '(auth)'
|
|
if (!user && !inAuth) router.replace('/(auth)/login')
|
|
else if (user && inAuth) router.replace('/(tabs)/home')
|
|
}, [user, loading, segments])
|
|
|
|
if (loading) {
|
|
return (
|
|
<View style={s.loader}>
|
|
<ActivityIndicator size="large" color={C.brand} />
|
|
</View>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<SafeAreaProvider>
|
|
<StatusBar style="auto" />
|
|
<Slot />
|
|
</SafeAreaProvider>
|
|
)
|
|
}
|
|
|
|
const s = StyleSheet.create({
|
|
loader: { flex: 1, alignItems: 'center', justifyContent: 'center', backgroundColor: C.paper },
|
|
})
|