Initial commit: unionflow-mobile-apps
Application Flutter complète (sans build artifacts). Signed-off-by: lions dev Team
This commit is contained in:
92
lib/features/solidarity/bloc/solidarity_bloc.dart
Normal file
92
lib/features/solidarity/bloc/solidarity_bloc.dart
Normal file
@@ -0,0 +1,92 @@
|
||||
/// BLoC pour les demandes d'aide (solidarité)
|
||||
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;
|
||||
|
||||
SolidarityBloc(this._repository) : super(const SolidarityState()) {
|
||||
on<LoadDemandesAide>(_onLoadDemandesAide);
|
||||
on<LoadDemandeAideById>(_onLoadDemandeAideById);
|
||||
on<SearchDemandesAide>(_onSearchDemandesAide);
|
||||
on<CreateDemandeAide>(_onCreateDemandeAide);
|
||||
on<ApprouverDemandeAide>(_onApprouverDemandeAide);
|
||||
on<RejeterDemandeAide>(_onRejeterDemandeAide);
|
||||
}
|
||||
|
||||
Future<void> _onLoadDemandesAide(LoadDemandesAide event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading, message: 'Chargement...'));
|
||||
try {
|
||||
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));
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _onLoadDemandeAideById(LoadDemandeAideById event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading));
|
||||
try {
|
||||
final demande = await _repository.getById(event.id);
|
||||
emit(state.copyWith(status: SolidarityStatus.loaded, demandeDetail: demande));
|
||||
} catch (e) {
|
||||
emit(state.copyWith(status: SolidarityStatus.error, message: e.toString(), error: e));
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _onSearchDemandesAide(SearchDemandesAide event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading));
|
||||
try {
|
||||
final list = await _repository.search(
|
||||
statut: event.statut,
|
||||
type: event.type,
|
||||
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));
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _onCreateDemandeAide(CreateDemandeAide event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading, message: 'Création...'));
|
||||
try {
|
||||
await _repository.create(event.demande);
|
||||
add(const LoadDemandesAide());
|
||||
} catch (e) {
|
||||
emit(state.copyWith(status: SolidarityStatus.error, message: e.toString(), error: e));
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _onApprouverDemandeAide(ApprouverDemandeAide event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading));
|
||||
try {
|
||||
final updated = await _repository.approuver(event.id);
|
||||
emit(state.copyWith(status: SolidarityStatus.loaded, demandeDetail: updated));
|
||||
add(const LoadDemandesAide());
|
||||
} catch (e) {
|
||||
emit(state.copyWith(status: SolidarityStatus.error, message: e.toString(), error: e));
|
||||
}
|
||||
}
|
||||
|
||||
Future<void> _onRejeterDemandeAide(RejeterDemandeAide event, Emitter<SolidarityState> emit) async {
|
||||
emit(state.copyWith(status: SolidarityStatus.loading));
|
||||
try {
|
||||
final updated = await _repository.rejeter(event.id, motif: event.motif);
|
||||
emit(state.copyWith(status: SolidarityStatus.loaded, demandeDetail: updated));
|
||||
add(const LoadDemandesAide());
|
||||
} catch (e) {
|
||||
emit(state.copyWith(status: SolidarityStatus.error, message: e.toString(), error: e));
|
||||
}
|
||||
}
|
||||
}
|
||||
54
lib/features/solidarity/bloc/solidarity_event.dart
Normal file
54
lib/features/solidarity/bloc/solidarity_event.dart
Normal file
@@ -0,0 +1,54 @@
|
||||
part of 'solidarity_bloc.dart';
|
||||
|
||||
abstract class SolidarityEvent extends Equatable {
|
||||
const SolidarityEvent();
|
||||
@override
|
||||
List<Object?> get props => [];
|
||||
}
|
||||
|
||||
class LoadDemandesAide extends SolidarityEvent {
|
||||
final int page;
|
||||
final int size;
|
||||
const LoadDemandesAide({this.page = 0, this.size = 20});
|
||||
@override
|
||||
List<Object?> get props => [page, size];
|
||||
}
|
||||
|
||||
class LoadDemandeAideById extends SolidarityEvent {
|
||||
final String id;
|
||||
const LoadDemandeAideById(this.id);
|
||||
@override
|
||||
List<Object?> get props => [id];
|
||||
}
|
||||
|
||||
class SearchDemandesAide extends SolidarityEvent {
|
||||
final String? statut;
|
||||
final String? type;
|
||||
final int page;
|
||||
final int size;
|
||||
const SearchDemandesAide({this.statut, this.type, this.page = 0, this.size = 20});
|
||||
@override
|
||||
List<Object?> get props => [statut, type, page, size];
|
||||
}
|
||||
|
||||
class CreateDemandeAide extends SolidarityEvent {
|
||||
final DemandeAideModel demande;
|
||||
const CreateDemandeAide(this.demande);
|
||||
@override
|
||||
List<Object?> get props => [demande];
|
||||
}
|
||||
|
||||
class ApprouverDemandeAide extends SolidarityEvent {
|
||||
final String id;
|
||||
const ApprouverDemandeAide(this.id);
|
||||
@override
|
||||
List<Object?> get props => [id];
|
||||
}
|
||||
|
||||
class RejeterDemandeAide extends SolidarityEvent {
|
||||
final String id;
|
||||
final String? motif;
|
||||
const RejeterDemandeAide(this.id, {this.motif});
|
||||
@override
|
||||
List<Object?> get props => [id, motif];
|
||||
}
|
||||
38
lib/features/solidarity/bloc/solidarity_state.dart
Normal file
38
lib/features/solidarity/bloc/solidarity_state.dart
Normal file
@@ -0,0 +1,38 @@
|
||||
part of 'solidarity_bloc.dart';
|
||||
|
||||
enum SolidarityStatus { initial, loading, loaded, error }
|
||||
|
||||
class SolidarityState extends Equatable {
|
||||
final SolidarityStatus status;
|
||||
final List<DemandeAideModel> demandes;
|
||||
final DemandeAideModel? demandeDetail;
|
||||
final String? message;
|
||||
final Object? error;
|
||||
|
||||
const SolidarityState({
|
||||
this.status = SolidarityStatus.initial,
|
||||
this.demandes = const [],
|
||||
this.demandeDetail,
|
||||
this.message,
|
||||
this.error,
|
||||
});
|
||||
|
||||
SolidarityState copyWith({
|
||||
SolidarityStatus? status,
|
||||
List<DemandeAideModel>? demandes,
|
||||
DemandeAideModel? demandeDetail,
|
||||
String? message,
|
||||
Object? error,
|
||||
}) {
|
||||
return SolidarityState(
|
||||
status: status ?? this.status,
|
||||
demandes: demandes ?? this.demandes,
|
||||
demandeDetail: demandeDetail ?? this.demandeDetail,
|
||||
message: message ?? this.message,
|
||||
error: error ?? this.error,
|
||||
);
|
||||
}
|
||||
|
||||
@override
|
||||
List<Object?> get props => [status, demandes, demandeDetail, message, error];
|
||||
}
|
||||
Reference in New Issue
Block a user