feat: WebSocket temps réel + Finance Workflow + corrections

- Task #6: WebSocket /ws/dashboard + Kafka events (5 topics)
  * Backend: KafkaEventProducer, KafkaEventConsumer
  * Mobile: WebSocketService (reconnection, heartbeat, typed events)
  * DashboardBloc: Auto-refresh depuis WebSocket events

- Finance Workflow: approbations + budgets (backend + mobile)
  * Backend: entities, services, resources, migrations Flyway V6
  * Mobile: features finance_workflow complète avec BLoC

- Corrections DI: interfaces IRepository partout
  * IProfileRepository, IOrganizationRepository, IMembreRepository
  * GetIt configuré avec @injectable

- Spec-Kit: constitution + templates mis à jour
  * .specify/memory/constitution.md enrichie
  * Templates agent, plan, spec, tasks, checklist

- Nettoyage: fichiers temporaires supprimés

Signed-off-by: lions dev Team
This commit is contained in:
dahoud
2026-03-15 02:12:17 +00:00
parent bbc409de9d
commit e8ad874015
635 changed files with 58160 additions and 20674 deletions

View File

@@ -3,12 +3,14 @@ library solidarity_bloc;
import 'package:flutter_bloc/flutter_bloc.dart';
import 'package:equatable/equatable.dart';
import 'package:injectable/injectable.dart';
import '../data/models/demande_aide_model.dart';
import '../data/repositories/demande_aide_repository.dart';
part 'solidarity_event.dart';
part 'solidarity_state.dart';
@injectable
class SolidarityBloc extends Bloc<SolidarityEvent, SolidarityState> {
final DemandeAideRepository _repository;
@@ -24,7 +26,7 @@ class SolidarityBloc extends Bloc<SolidarityEvent, SolidarityState> {
Future<void> _onLoadDemandesAide(LoadDemandesAide event, Emitter<SolidarityState> emit) async {
emit(state.copyWith(status: SolidarityStatus.loading, message: 'Chargement...'));
try {
final list = await _repository.getAll(page: event.page, size: event.size);
final list = await _repository.getMesDemandes(page: event.page, size: event.size);
emit(state.copyWith(status: SolidarityStatus.loaded, demandes: list));
} catch (e) {
emit(state.copyWith(status: SolidarityStatus.error, message: e.toString(), error: e));
@@ -80,7 +82,7 @@ class SolidarityBloc extends Bloc<SolidarityEvent, SolidarityState> {
Future<void> _onRejeterDemandeAide(RejeterDemandeAide event, Emitter<SolidarityState> emit) async {
emit(state.copyWith(status: SolidarityStatus.loading));
try {
final updated = await _repository.rejeter(event.id);
final updated = await _repository.rejeter(event.id, motif: event.motif);
emit(state.copyWith(status: SolidarityStatus.loaded, demandeDetail: updated));
add(const LoadDemandesAide());
} catch (e) {