fix functional bugs
This commit is contained in:
@@ -4,38 +4,59 @@ import 'package:be_happy/domain/usecase/activate_subscription_usecase.dart';
|
||||
import 'package:be_happy/domain/usecase/get_subscription_by_id_usecase.dart';
|
||||
import 'package:flutter_bloc/flutter_bloc.dart';
|
||||
|
||||
import '../../domain/entities/client_subscription.dart';
|
||||
import '../../domain/usecase/get_client_subscriptions_usecase.dart';
|
||||
import '../event/subscription_details_event.dart';
|
||||
import '../state/susbcription_details_state.dart';
|
||||
|
||||
class SubscriptionDetailsBloc extends Bloc<SubscriptionDetailsEvent, SubscriptionDetailsState> {
|
||||
class SubscriptionDetailsBloc
|
||||
extends Bloc<SubscriptionDetailsEvent, SubscriptionDetailsState> {
|
||||
final GetSubscriptionByIdUsecase getSubscriptionByIdUsecase;
|
||||
final ActivateSubscriptionUsecase activateSubscriptionUsecase;
|
||||
final GetClientSubscriptionsUsecase getClientSubscriptionsUsecase;
|
||||
|
||||
SubscriptionDetailsBloc(this.getSubscriptionByIdUsecase,
|
||||
this.activateSubscriptionUsecase) : super(DetailsLoading()) {
|
||||
SubscriptionDetailsBloc(
|
||||
this.getSubscriptionByIdUsecase,
|
||||
this.activateSubscriptionUsecase,
|
||||
this.getClientSubscriptionsUsecase,
|
||||
) : super(DetailsLoading()) {
|
||||
on<LoadDetailsEvent>((event, emit) async {
|
||||
emit(DetailsLoading());
|
||||
try {
|
||||
|
||||
final result = await getSubscriptionByIdUsecase(event.subscriptionId);
|
||||
|
||||
switch (result) {
|
||||
final clientSubsResult = await getClientSubscriptionsUsecase();
|
||||
bool isPurchased = false;
|
||||
|
||||
case Success<Subscription>():
|
||||
final sub = result.data;
|
||||
|
||||
if (sub == null) return;
|
||||
|
||||
emit(DetailsContentState(
|
||||
subscription: sub,
|
||||
selectedPeriod: sub.options.first,
|
||||
));
|
||||
case Failure<Subscription>():
|
||||
emit(DetailsError("Ошибка при запросе данных"));
|
||||
switch (clientSubsResult) {
|
||||
case Success<List<ClientSubscription>>():
|
||||
isPurchased = clientSubsResult.data?.any(
|
||||
(element) => element.subscriptionId == event.subscriptionId,
|
||||
) ?? false;
|
||||
break;
|
||||
|
||||
case Failure<List<ClientSubscription>>():
|
||||
isPurchased = false;
|
||||
break;
|
||||
}
|
||||
|
||||
switch (result) {
|
||||
case Success<Subscription>():
|
||||
final sub = result.data;
|
||||
if (sub == null) return;
|
||||
|
||||
emit(
|
||||
DetailsContentState(
|
||||
subscription: sub,
|
||||
selectedPeriod: sub.options.first,
|
||||
isAlreadyPurchased: isPurchased,
|
||||
),
|
||||
);
|
||||
break;
|
||||
case Failure<Subscription>():
|
||||
emit(DetailsError("Ошибка при запросе данных"));
|
||||
break;
|
||||
}
|
||||
} catch (e) {
|
||||
emit(DetailsError("Не удалось загрузить данные"));
|
||||
}
|
||||
@@ -43,7 +64,9 @@ class SubscriptionDetailsBloc extends Bloc<SubscriptionDetailsEvent, Subscriptio
|
||||
|
||||
on<SelectPeriodEvent>((event, emit) {
|
||||
if (state is DetailsContentState) {
|
||||
emit((state as DetailsContentState).copyWith(selectedPeriod: event.period));
|
||||
emit(
|
||||
(state as DetailsContentState).copyWith(selectedPeriod: event.period),
|
||||
);
|
||||
}
|
||||
});
|
||||
|
||||
@@ -53,14 +76,23 @@ class SubscriptionDetailsBloc extends Bloc<SubscriptionDetailsEvent, Subscriptio
|
||||
}
|
||||
});
|
||||
|
||||
on<ActivateSubscriptionPressed>((event, emit) {
|
||||
switch(state) {
|
||||
on<ActivateSubscriptionPressed>((event, emit) async {
|
||||
switch (state) {
|
||||
case DetailsContentState contentState:
|
||||
activateSubscriptionUsecase(contentState.selectedPeriod.id);
|
||||
if (!contentState.isAgreed) {
|
||||
return;
|
||||
}
|
||||
|
||||
final result = await activateSubscriptionUsecase(contentState.selectedPeriod.id);
|
||||
|
||||
if (result is Success) {
|
||||
emit(contentState.copyWith(isSuccess: true));
|
||||
} else {
|
||||
}
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user