Refactoring + Checkpoint
This commit is contained in:
@@ -8,20 +8,21 @@ import '../../widgets/friend_detail_screen.dart';
|
||||
import '../../widgets/friends_appbar.dart';
|
||||
import '../../widgets/search_friends.dart';
|
||||
|
||||
/// Écran d'affichage des amis avec gestion des amis via un provider.
|
||||
class FriendsScreenWithProvider extends StatelessWidget {
|
||||
final Logger _logger = Logger(); // Logger pour une meilleure traçabilité
|
||||
final Logger _logger = Logger(); // Logger pour la traçabilité détaillée.
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
backgroundColor: Colors.black,
|
||||
appBar: FriendsAppBar(),
|
||||
backgroundColor: Colors.black, // Fond noir pour une ambiance immersive.
|
||||
appBar: FriendsAppBar(), // AppBar personnalisé pour l'écran.
|
||||
body: SafeArea(
|
||||
child: Column(
|
||||
children: [
|
||||
const Padding(
|
||||
padding: EdgeInsets.all(8.0),
|
||||
child: SearchFriends(),
|
||||
child: SearchFriends(), // Barre de recherche pour trouver des amis.
|
||||
),
|
||||
Expanded(
|
||||
child: Consumer<FriendsProvider>(
|
||||
@@ -29,10 +30,10 @@ class FriendsScreenWithProvider extends StatelessWidget {
|
||||
final friends = friendsProvider.friendsList;
|
||||
|
||||
if (friends.isEmpty) {
|
||||
_logger.i("[LOG] Aucun ami trouvé");
|
||||
_logger.i("[LOG] Aucun ami trouvé."); // Log pour la recherche sans résultat.
|
||||
return const Center(
|
||||
child: Text(
|
||||
'Aucun ami trouvé',
|
||||
'Aucun ami trouvé', // Message affiché si aucun ami n'est trouvé.
|
||||
style: TextStyle(color: Colors.white70),
|
||||
),
|
||||
);
|
||||
@@ -43,6 +44,10 @@ class FriendsScreenWithProvider extends StatelessWidget {
|
||||
itemCount: friends.length,
|
||||
itemBuilder: (context, index) {
|
||||
final friend = friends[index];
|
||||
|
||||
// Log lorsque chaque ami est affiché
|
||||
_logger.i("[LOG] Affichage de l'ami : ${friend.friendFirstName ?? 'Ami inconnu'}");
|
||||
|
||||
return Dismissible(
|
||||
key: Key(friend.friendId),
|
||||
background: Container(
|
||||
@@ -53,7 +58,7 @@ class FriendsScreenWithProvider extends StatelessWidget {
|
||||
),
|
||||
onDismissed: (direction) {
|
||||
_logger.i("[LOG] Suppression de l'ami avec l'ID : ${friend.friendId}");
|
||||
friendsProvider.removeFriend(friend.friendId);
|
||||
friendsProvider.removeFriend(friend.friendId); // Suppression de l'ami via le provider.
|
||||
ScaffoldMessenger.of(context).showSnackBar(
|
||||
SnackBar(content: Text("Ami supprimé : ${friend.friendFirstName}")),
|
||||
);
|
||||
@@ -61,14 +66,16 @@ class FriendsScreenWithProvider extends StatelessWidget {
|
||||
child: FriendExpandingCard(
|
||||
name: friend.friendFirstName ?? 'Ami inconnu',
|
||||
imageUrl: friend.imageUrl ?? '',
|
||||
description: "Amis depuis ${friend.friendId}",
|
||||
onTap: () => _navigateToFriendDetail(context, friend),
|
||||
description: "Amis depuis ${friend.dateAdded ?? 'Inconnu'}\nStatut : ${friend.status ?? 'Inconnu'}",
|
||||
onTap: () {
|
||||
_navigateToFriendDetail(context, friend); // Navigation vers les détails de l'ami.
|
||||
},
|
||||
onMessageTap: () {
|
||||
_logger.i("[LOG] Envoi d'un message à l'ami : ${friend.friendFirstName ?? 'Ami inconnu'}");
|
||||
},
|
||||
onRemoveTap: () {
|
||||
_logger.i("[LOG] Tentative de suppression de l'ami : ${friend.friendFirstName ?? 'Ami inconnu'}");
|
||||
friendsProvider.removeFriend(friend.friendId);
|
||||
friendsProvider.removeFriend(friend.friendId); // Suppression via le provider.
|
||||
},
|
||||
),
|
||||
);
|
||||
@@ -83,13 +90,19 @@ class FriendsScreenWithProvider extends StatelessWidget {
|
||||
);
|
||||
}
|
||||
|
||||
/// Navigue vers l'écran de détails de l'ami.
|
||||
void _navigateToFriendDetail(BuildContext context, Friend friend) {
|
||||
_logger.i("[LOG] Navigation vers les détails de l'ami : ${friend.friendFirstName}");
|
||||
|
||||
Navigator.of(context).push(MaterialPageRoute(
|
||||
builder: (context) => FriendDetailScreen(
|
||||
name: friend.friendFirstName,
|
||||
imageUrl: friend.imageUrl ?? '',
|
||||
friendId: friend.friendId,
|
||||
friendFirstName: friend.friendFirstName,
|
||||
friendLastName: friend.friendLastName,
|
||||
imageUrl: friend.imageUrl ?? '',
|
||||
status: friend.status,
|
||||
lastInteraction: friend.lastInteraction ?? 'Aucune',
|
||||
dateAdded: friend.dateAdded ?? 'Inconnu',
|
||||
),
|
||||
));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user