Error fix : handle logout process in HomePage
This commit is contained in:
@@ -9,6 +9,8 @@ import '../blocs/user/user_bloc.dart';
|
||||
import '../blocs/user/user_event.dart';
|
||||
import '../blocs/auth/auth_bloc.dart';
|
||||
import '../blocs/auth/auth_event.dart';
|
||||
import '../blocs/trip/trip_bloc.dart';
|
||||
import '../blocs/trip/trip_event.dart';
|
||||
|
||||
class HomePage extends StatefulWidget {
|
||||
const HomePage({super.key});
|
||||
@@ -73,6 +75,61 @@ class _HomePageState extends State<HomePage> {
|
||||
Navigator.pop(context);
|
||||
}
|
||||
|
||||
// Nouvelle méthode pour gérer la déconnexion proprement
|
||||
Future<void> _handleLogout() async {
|
||||
// Fermer le drawer
|
||||
Navigator.pop(context);
|
||||
|
||||
// Afficher un dialog de confirmation
|
||||
final shouldLogout = await showDialog<bool>(
|
||||
context: context,
|
||||
builder: (BuildContext dialogContext) {
|
||||
return AlertDialog(
|
||||
title: const Text('Déconnexion'),
|
||||
content: const Text('Êtes-vous sûr de vouloir vous déconnecter ?'),
|
||||
actions: [
|
||||
TextButton(
|
||||
onPressed: () => Navigator.pop(dialogContext, false),
|
||||
child: const Text('Annuler'),
|
||||
),
|
||||
ElevatedButton(
|
||||
onPressed: () => Navigator.pop(dialogContext, true),
|
||||
style: ElevatedButton.styleFrom(
|
||||
backgroundColor: Colors.red,
|
||||
foregroundColor: Colors.white,
|
||||
),
|
||||
child: const Text('Déconnexion'),
|
||||
),
|
||||
],
|
||||
);
|
||||
},
|
||||
);
|
||||
|
||||
if (shouldLogout != true || !mounted) return;
|
||||
|
||||
try {
|
||||
context.read<TripBloc>().add(ResetTrips());
|
||||
context.read<UserBloc>().add(UserLoggedOut());
|
||||
_pageCache.clear();
|
||||
context.read<AuthBloc>().add(AuthSignOutRequested());
|
||||
await Future.delayed(const Duration(milliseconds: 150));
|
||||
if (!mounted) return;
|
||||
Navigator.of(context).pushNamedAndRemoveUntil(
|
||||
'/login',
|
||||
(Route<dynamic> route) => false, // Supprime TOUTES les routes
|
||||
);
|
||||
} catch (e) {
|
||||
if (mounted) {
|
||||
ScaffoldMessenger.of(context).showSnackBar(
|
||||
SnackBar(
|
||||
content: Text('Erreur lors de la déconnexion: $e'),
|
||||
backgroundColor: Colors.red,
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
@@ -103,11 +160,7 @@ class _HomePageState extends State<HomePage> {
|
||||
ListTile(
|
||||
leading: const Icon(Icons.logout, color: Colors.red),
|
||||
title: const Text("Déconnexion", style: TextStyle(color: Colors.red)),
|
||||
onTap: () {
|
||||
Navigator.pop(context);
|
||||
context.read<AuthBloc>().add(AuthSignOutRequested());
|
||||
Navigator.pushNamedAndRemoveUntil(context, '/login', (route) => false);
|
||||
},
|
||||
onTap: _handleLogout, // Utiliser la nouvelle méthode
|
||||
),
|
||||
],
|
||||
),
|
||||
|
||||
Reference in New Issue
Block a user