Mobile app: - Révision flashcards : liste decks, session flip-card SM-2, couleurs harmonisées web - Génération flashcards depuis note (FlashcardSheet + route /api/mobile/flashcards/generate) - Audio Whisper : hook useAudioRecorder reécrit, MicButton avec erreurs - IA : AISheet (améliorer/clarifier/résumer), TitleSheet (titre automatique) - Suppression note (soft delete + confirmation Alert) - Note du jour : titre lisible + HTML (plus JSON TipTap brut) - Parser TipTap→HTML côté mobile (tipTapToHtml) - Icône 🎓 dans header note → génération flashcards - Endpoint flashcardGenerate dans config.ts Web fixes: - Bug flashcards groupées par carnet → deck par note (migration + schema) - Bug filtre 'cartes dues' ignoré (suppression fallback buildSessionQueue) - Suppression UI création deck manuelle (inutile) - Fix setViewType is not defined dans home-client.tsx Drag handle menu: - Fix : clearNodes() avant transformation (heading→liste/code/citation) - Ajout : option 'Texte' (paragraphe) dans Transformer en - Ajout : Monter / Descendre le bloc - Ajout : Copier le contenu du bloc - Fix : sous-menu hover stable (délai 200ms) - Fix : Supprimer en rouge via classe --danger (plus :first-child) - i18n : nouvelles clés dans 15 locales Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
47 lines
1.3 KiB
TypeScript
47 lines
1.3 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({ pathname: '/(auth)/login' })
|
|
else if (user && inAuth) router.replace({ pathname: '/(tabs)/home' })
|
|
}, [user, loading, segments])
|
|
|
|
if (loading) {
|
|
return (
|
|
<SafeAreaProvider>
|
|
<View style={s.loader}>
|
|
<ActivityIndicator size="large" color={C.brand} />
|
|
</View>
|
|
</SafeAreaProvider>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<SafeAreaProvider>
|
|
<StatusBar style="auto" />
|
|
<Slot />
|
|
</SafeAreaProvider>
|
|
)
|
|
}
|
|
|
|
const s = StyleSheet.create({
|
|
loader: { flex: 1, alignItems: 'center', justifyContent: 'center', backgroundColor: C.paper },
|
|
})
|