feat: Implement group balance and expense management with new navigation and data handling

This commit is contained in:
Dayron
2025-10-28 13:06:42 +01:00
parent 94f1abfbc7
commit df1bb6da4a
10 changed files with 390 additions and 54 deletions

View File

@@ -43,6 +43,19 @@ class BalanceRepository {
}
}
Future<List<UserBalance>> calculateGroupUserBalances(String groupId) async {
try {
final expenses = await _expenseRepository
.getExpensesStream(groupId)
.first;
return _calculateUserBalances(expenses);
} catch (e) {
_errorService.logError('BalanceRepository', 'Erreur calcul user balances: $e');
rethrow;
}
}
// Calculer les balances individuelles
List<UserBalance> _calculateUserBalances(List<Expense> expenses) {
final Map<String, Map<String, dynamic>> userBalanceMap = {};

View File

@@ -7,35 +7,26 @@ class TripRepository {
CollectionReference get _tripsCollection => _firestore.collection('trips');
// Récupérer tous les voyages d'un utilisateur
Stream<List<Trip>> getTripsByUserId(String userId) {
print('🔍 Chargement des trips pour userId: $userId');
Stream<List<Trip>> getTripsByUserId(String userId) {
try {
return _tripsCollection
.where('participants', arrayContains: userId)
.snapshots()
.map((snapshot) {
print('📦 Snapshot reçu: ${snapshot.docs.length} documents');
.map((snapshot) {
final trips = snapshot.docs
.map((doc) {
try {
final data = doc.data() as Map<String, dynamic>;
print('📄 Document ${doc.id}: ${data.keys.toList()}');
return Trip.fromMap(data, doc.id);
} catch (e) {
print('❌ Erreur parsing trip ${doc.id}: $e');
return null;
}
})
.whereType<Trip>()
.toList();
print('${trips.length} trips parsés avec succès');
return trips;
});
} catch (e) {
print('❌ Erreur getTripsByUserId: $e');
throw Exception('Erreur lors de la récupération des voyages: $e');
}
}
@@ -43,16 +34,11 @@ class TripRepository {
// Créer un voyage et retourner son ID
Future<String> createTrip(Trip trip) async {
try {
print('📝 Création du voyage: ${trip.title}');
final tripData = trip.toMap();
// Ne pas modifier les timestamps ici, ils sont déjà au bon format
final docRef = await _tripsCollection.add(tripData);
print('✅ Voyage créé avec ID: ${docRef.id}');
return docRef.id;
} catch (e) {
print('❌ Erreur création voyage: $e');
throw Exception('Erreur lors de la création du voyage: $e');
}
}
@@ -63,13 +49,11 @@ class TripRepository {
final doc = await _tripsCollection.doc(tripId).get();
if (!doc.exists) {
print('⚠️ Voyage $tripId non trouvé');
return null;
}
return Trip.fromMap(doc.data() as Map<String, dynamic>, doc.id);
} catch (e) {
print('❌ Erreur getTripById: $e');
throw Exception('Erreur lors de la récupération du voyage: $e');
}
}
@@ -77,17 +61,12 @@ class TripRepository {
// Mettre à jour un voyage
Future<void> updateTrip(String tripId, Trip trip) async {
try {
print('📝 Mise à jour du voyage: $tripId');
final tripData = trip.toMap();
// Mettre à jour le timestamp de modification
tripData['updatedAt'] = Timestamp.now();
await _tripsCollection.doc(tripId).update(tripData);
print('✅ Voyage $tripId mis à jour');
} catch (e) {
print('❌ Erreur mise à jour voyage: $e');
throw Exception('Erreur lors de la mise à jour du voyage: $e');
}
}
@@ -95,13 +74,8 @@ class TripRepository {
// Supprimer un voyage
Future<void> deleteTrip(String tripId) async {
try {
print('🗑️ Suppression du voyage: $tripId');
await _tripsCollection.doc(tripId).delete();
print('✅ Voyage $tripId supprimé');
} catch (e) {
print('❌ Erreur suppression voyage: $e');
throw Exception('Erreur lors de la suppression du voyage: $e');
}
}