Files
Momento/memento-mobile/app/_layout.tsx
Antigravity 0fa8978395
Some checks failed
CI / Lint, Unit Tests & Build (push) Failing after 1m32s
CI / Deploy production (on server) (push) Has been skipped
feat: mobile app complet + flashcards fixes + drag handle améliorations
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>
2026-05-29 18:49:40 +00:00

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 },
})