selfprivacy.org.app/lib/logic/cubit/metrics/metrics_cubit.dart

59 lines
1.4 KiB
Dart
Raw Normal View History

2021-04-10 06:04:23 +03:00
import 'dart:async';
2022-05-24 21:55:39 +03:00
import 'package:flutter_bloc/flutter_bloc.dart';
2021-04-10 06:04:23 +03:00
import 'package:equatable/equatable.dart';
import 'package:selfprivacy/logic/common_enum/common_enum.dart';
import 'package:selfprivacy/logic/models/metrics.dart';
2021-04-10 06:04:23 +03:00
import 'package:selfprivacy/logic/cubit/metrics/metrics_repository.dart';
2021-04-10 06:04:23 +03:00
part 'metrics_state.dart';
2021-04-10 06:04:23 +03:00
class MetricsCubit extends Cubit<MetricsState> {
MetricsCubit() : super(const MetricsLoading(Period.day));
2021-04-10 06:04:23 +03:00
final MetricsRepository repository = MetricsRepository();
2021-04-10 06:04:23 +03:00
Timer? timer;
2022-05-24 21:55:39 +03:00
@override
2022-06-05 22:36:32 +03:00
Future<void> close() {
2021-04-10 06:04:23 +03:00
closeTimer();
return super.close();
}
void closeTimer() {
if (timer != null && timer!.isActive) {
timer!.cancel();
}
}
2022-06-05 22:36:32 +03:00
void changePeriod(final Period period) async {
2021-04-10 06:04:23 +03:00
closeTimer();
emit(MetricsLoading(period));
2021-04-10 06:04:23 +03:00
load(period);
}
void restart() async {
load(state.period);
}
2022-06-05 22:36:32 +03:00
void load(final Period period) async {
try {
final MetricsLoaded newState = await repository.getMetrics(period);
timer = Timer(
Duration(seconds: newState.metrics.stepsInSecond.toInt()),
() => load(newState.period),
);
emit(newState);
} on StateError {
print('Tried to emit metrics when cubit is closed');
} on MetricsLoadException {
timer = Timer(
Duration(seconds: state.period.stepPeriodInSeconds),
() => load(state.period),
);
}
2021-04-10 06:04:23 +03:00
}
}