af5ecaeee1
- **Refonte du démarrage** : Mise en place d'un `AppInitializer` pour gérer l'initialisation asynchrone de Firebase et du cache en arrière-plan, réduisant le travail synchrone au lancement.
- **Sécurisation de l'authentification** :
- Création d'un `AppStartGate` pour gérer proprement la restauration de la session Firebase Auth et les erreurs potentielles sur le Web.
- Amélioration du `LocalUserProvider` avec un "bootstrap léger" permettant de rendre l'UID disponible immédiatement avant le chargement complet du profil.
- Ajout de protections contre les erreurs d'accès à `FirebaseAuth.instance` (notamment pour les problèmes d'interop JS sur le Web).
- **Optimisation de l'UI** :
- Remplacement du `AutoLoginWrapper` par une gestion plus robuste de la navigation post-authentification.
- Amélioration de l'`AuthGuard` pour permettre l'affichage de certains écrans (comme le calendrier) pendant le chargement des données utilisateur (`allowWhileLoading`).
- Ajout d'un écran de splash screen uniformisé (`StartupSplashScreen`).
- **Services & Cache** :
- Introduction de `CacheService` utilisant `shared_preferences` pour le stockage local léger.
- Refactoring des services (`AlertService`, `EmailService`, `FirebaseStorageManager`) pour accéder aux instances Firebase de manière plus flexible via des getters.
- Mise à jour des dépendances dans `pubspec.yaml` pour inclure `shared_preferences`.
- **Calendrier** : Ajout d'une logique de chargement initial différé des événements (`_scheduleInitialEventsLoad`) pour éviter les appels redondants au démarrage.
- **Maintenance** : Mise à jour de la version de l'application à `1.1.23` et nettoyage des fichiers de cache de déploiement.
71 lines
2.2 KiB
Dart
71 lines
2.2 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:firebase_auth/firebase_auth.dart';
|
|
import '../providers/local_user_provider.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
class LoginViewModel extends ChangeNotifier {
|
|
final TextEditingController emailController = TextEditingController();
|
|
final TextEditingController passwordController = TextEditingController();
|
|
String errorMessage = '';
|
|
bool isLoading = false;
|
|
bool obscurePassword = true;
|
|
bool highlightPasswordField = false;
|
|
bool highlightEmailField = false;
|
|
|
|
void togglePasswordVisibility() {
|
|
obscurePassword = !obscurePassword;
|
|
notifyListeners();
|
|
}
|
|
|
|
Future<void> signIn(BuildContext context) async {
|
|
final localAuthProvider =
|
|
Provider.of<LocalUserProvider>(context, listen: false);
|
|
isLoading = true;
|
|
errorMessage = '';
|
|
highlightPasswordField = false;
|
|
highlightEmailField = false;
|
|
notifyListeners();
|
|
|
|
try {
|
|
// --- Étape 1: Connecter l'utilisateur dans Firebase Auth ---
|
|
await localAuthProvider.signInWithEmailAndPassword(
|
|
emailController.text,
|
|
passwordController.text,
|
|
);
|
|
|
|
// --- Étape 2: Charger les données utilisateur en arrière-plan ---
|
|
unawaited(
|
|
localAuthProvider.loadUserData().catchError((e) {
|
|
debugPrint('Erreur chargement profil après connexion : $e');
|
|
}),
|
|
);
|
|
|
|
// Vérifier si le contexte est toujours valide
|
|
if (context.mounted) {
|
|
Navigator.of(context, rootNavigator: true)
|
|
.pushReplacementNamed('/calendar');
|
|
}
|
|
} on FirebaseAuthException catch (e) {
|
|
// Gestion spécifique des erreurs d'authentification (email/mot de passe incorrects, etc.)
|
|
isLoading = false;
|
|
errorMessage =
|
|
e.message ?? 'Une erreur est survenue lors de la connexion Firebase.';
|
|
notifyListeners();
|
|
} catch (e) {
|
|
// Gestion des autres erreurs potentielles (ex: erreur lors de loadUserData)
|
|
isLoading = false;
|
|
errorMessage = 'Une erreur inattendue est survenue: ${e.toString()}';
|
|
notifyListeners();
|
|
}
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
emailController.dispose();
|
|
passwordController.dispose();
|
|
super.dispose();
|
|
}
|
|
}
|