- Ajout système complet de gestion des secteurs avec contours géographiques - Import des contours départementaux depuis GeoJSON - API REST pour la gestion des secteurs (/api/sectors) - Service de géolocalisation pour déterminer les secteurs - Migration base de données avec tables x_departements_contours et sectors_adresses - Interface Flutter pour visualisation et gestion des secteurs - Ajout thème sombre dans l'application - Corrections diverses et optimisations 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
108 lines
3.1 KiB
Dart
Executable File
108 lines
3.1 KiB
Dart
Executable File
/// Service API pour la communication avec le backend du chat
|
|
///
|
|
/// Ce service gère toutes les requêtes HTTP vers l'API chat
|
|
library;
|
|
|
|
class ChatApiService {
|
|
final String baseUrl;
|
|
final String? authToken;
|
|
|
|
ChatApiService({
|
|
required this.baseUrl,
|
|
this.authToken,
|
|
});
|
|
|
|
/// Récupère les conversations
|
|
Future<Map<String, dynamic>> fetchConversations() async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Récupère les messages d'une conversation
|
|
Future<Map<String, dynamic>> fetchMessages(String conversationId,
|
|
{int page = 1, int limit = 50}) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Crée une nouvelle conversation
|
|
Future<Map<String, dynamic>> createConversation(
|
|
Map<String, dynamic> data) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Envoie un message
|
|
Future<Map<String, dynamic>> sendMessage(
|
|
String conversationId, Map<String, dynamic> messageData) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Marque un message comme lu
|
|
Future<Map<String, dynamic>> markMessageAsRead(String messageId) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Ajoute un participant
|
|
Future<Map<String, dynamic>> addParticipant(
|
|
String conversationId, Map<String, dynamic> participantData) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Retire un participant
|
|
Future<Map<String, dynamic>> removeParticipant(
|
|
String conversationId, String participantId) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Crée un utilisateur anonyme
|
|
Future<Map<String, dynamic>> createAnonymousUser(
|
|
{String? name, String? email}) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Récupère les annonces
|
|
Future<Map<String, dynamic>> fetchAnnouncements() async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Crée une annonce
|
|
Future<Map<String, dynamic>> createAnnouncement(
|
|
Map<String, dynamic> data) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Récupère les statistiques d'une annonce
|
|
Future<Map<String, dynamic>> fetchAnnouncementStats(
|
|
String conversationId) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Récupère les cibles d'audience disponibles
|
|
Future<Map<String, dynamic>> fetchAvailableAudienceTargets() async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Met à jour une conversation
|
|
Future<Map<String, dynamic>> updateConversation(
|
|
String id, Map<String, dynamic> data) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
/// Supprime une conversation
|
|
Future<void> deleteConversation(String id) async {
|
|
// TODO: Implémenter la requête HTTP
|
|
throw UnimplementedError();
|
|
}
|
|
}
|