220 lines
7.3 KiB
Dart
220 lines
7.3 KiB
Dart
import 'dart:async';
|
|
import 'dart:collection';
|
|
import 'package:aitrainer_app/repository/mautic_repository.dart';
|
|
import 'package:intl/intl.dart';
|
|
|
|
import 'package:aitrainer_app/main.dart';
|
|
import 'package:aitrainer_app/model/cache.dart';
|
|
import 'package:aitrainer_app/model/exercise_ability.dart';
|
|
import 'package:aitrainer_app/model/workout_menu_tree.dart';
|
|
import 'package:aitrainer_app/repository/customer_repository.dart';
|
|
import 'package:aitrainer_app/repository/exercise_device_repository.dart';
|
|
import 'package:aitrainer_app/repository/exercise_repository.dart';
|
|
import 'package:aitrainer_app/repository/workout_tree_repository.dart';
|
|
import 'package:aitrainer_app/service/logging.dart';
|
|
import 'package:aitrainer_app/util/enums.dart';
|
|
import 'package:aitrainer_app/util/track.dart';
|
|
import 'package:aitrainer_app/util/trans.dart';
|
|
import 'package:bloc/bloc.dart';
|
|
import 'package:equatable/equatable.dart';
|
|
import 'package:flutter/cupertino.dart';
|
|
import 'package:meta/meta.dart';
|
|
import 'package:aitrainer_app/library/image_cache.dart' as wt;
|
|
|
|
part 'menu_event.dart';
|
|
part 'menu_state.dart';
|
|
|
|
class MenuBloc extends Bloc<MenuEvent, MenuState> with Trans, Logging {
|
|
final WorkoutTreeRepository menuTreeRepository;
|
|
final ExerciseRepository exerciseRepository = ExerciseRepository();
|
|
ExerciseDeviceRepository exerciseDeviceRepository = ExerciseDeviceRepository();
|
|
int parent = 0;
|
|
WorkoutMenuTree? workoutItem;
|
|
final List<int> listFilterDevice = [];
|
|
|
|
int missingParent = 0;
|
|
String? missingTreeName = "";
|
|
|
|
late BuildContext context;
|
|
|
|
ExerciseAbility? ability;
|
|
|
|
MenuBloc({required this.menuTreeRepository}) : super(MenuInitial()) {
|
|
parent = 0;
|
|
}
|
|
|
|
void setContext(BuildContext context) {
|
|
this.context = context;
|
|
}
|
|
|
|
@override
|
|
Stream<MenuState> mapEventToState(
|
|
MenuEvent event,
|
|
) async* {
|
|
try {
|
|
if (event is MenuCreate) {
|
|
yield MenuLoading();
|
|
//await menuTreeRepository.createTree();
|
|
//menuTreeRepository.getBranch(this.parent);
|
|
//setMenuInfo();
|
|
if (Cache().getDevices() != null) {
|
|
exerciseDeviceRepository.setDevices(Cache().getDevices()!);
|
|
}
|
|
yield MenuReady();
|
|
} else if (event is MenuRecreateTree) {
|
|
yield MenuLoading();
|
|
// ie. at language changes
|
|
menuTreeRepository.createTree();
|
|
yield MenuReady();
|
|
} else if (event is MenuTreeDown) {
|
|
yield MenuLoading();
|
|
parent = event.parent;
|
|
workoutItem = event.item;
|
|
|
|
if (workoutItem != null) {
|
|
setAbility(workoutItem!.internalName);
|
|
}
|
|
final LinkedHashMap<String, WorkoutMenuTree> branch = menuTreeRepository.getBranch(event.parent);
|
|
|
|
await getImages(branch);
|
|
yield MenuReady();
|
|
} else if (event is MenuTreeUp) {
|
|
yield MenuLoading();
|
|
// get parent menus or exercises
|
|
parent = event.parent;
|
|
workoutItem = menuTreeRepository.getParentItem(parent);
|
|
|
|
LinkedHashMap<String, WorkoutMenuTree> branch;
|
|
if (workoutItem != null) {
|
|
setAbility(workoutItem!.internalName);
|
|
branch = menuTreeRepository.getBranch(workoutItem!.parent);
|
|
await getImages(branch);
|
|
}
|
|
|
|
yield MenuReady();
|
|
} else if (event is MenuTreeJump) {
|
|
yield MenuLoading();
|
|
parent = event.parent;
|
|
workoutItem = menuTreeRepository.getParentItem(parent);
|
|
|
|
if (workoutItem != null) {
|
|
setAbility(workoutItem!.internalName);
|
|
}
|
|
final LinkedHashMap<String, WorkoutMenuTree> branch = menuTreeRepository.getBranch(workoutItem!.parent);
|
|
await getImages(branch);
|
|
|
|
yield MenuReady();
|
|
} else if (event is MenuClickExercise) {
|
|
yield MenuLoading();
|
|
// get exercise page
|
|
yield MenuReady();
|
|
} else if (event is MenuFilterExerciseType) {
|
|
yield MenuLoading();
|
|
final int deviceId = event.deviceId;
|
|
if (selectedDevice(deviceId)) {
|
|
listFilterDevice.add(deviceId);
|
|
} else {
|
|
listFilterDevice.remove(deviceId);
|
|
}
|
|
yield MenuReady();
|
|
} else if (event is MenuStartTrial) {
|
|
yield MenuLoading();
|
|
final DateTime start = event.start;
|
|
CustomerRepository customerRepository = CustomerRepository();
|
|
customerRepository.customer = Cache().userLoggedIn;
|
|
customerRepository.customer!.trialDate = start;
|
|
Cache().userLoggedIn!.trialDate = start;
|
|
|
|
customerRepository.saveCustomer();
|
|
|
|
if (DateTime.now().difference(start).inHours < 1) {
|
|
Cache().hasPurchased = true;
|
|
log("Trial mode on!");
|
|
Track().track(TrackingEvent.trial, eventValue: DateFormat('yyyy-MM-dd HH:mm:ss').format(start));
|
|
|
|
if (!isInDebugMode) {
|
|
MauticRepository mauticRepository = MauticRepository(customerRepository: customerRepository);
|
|
await mauticRepository.sendMauticTrial();
|
|
}
|
|
}
|
|
yield MenuReady();
|
|
}
|
|
} on Exception catch (ex) {
|
|
yield MenuError(message: ex.toString());
|
|
}
|
|
}
|
|
|
|
void setAbility(String name) {
|
|
switch (name) {
|
|
case "one_rep_max":
|
|
ability = ExerciseAbility.oneRepMax;
|
|
break;
|
|
case "cardio":
|
|
ability = ExerciseAbility.running;
|
|
break;
|
|
case "test_center":
|
|
ability = ExerciseAbility.mini_test_set;
|
|
break;
|
|
case "training_plans":
|
|
ability = ExerciseAbility.training;
|
|
break;
|
|
case "my_body":
|
|
ability = ExerciseAbility.none;
|
|
break;
|
|
case "training_execute":
|
|
ability = ExerciseAbility.training_execute;
|
|
break;
|
|
}
|
|
log("Ability: " + ability.toString() + " name: " + name);
|
|
}
|
|
|
|
Future<void> getImages(LinkedHashMap<String, WorkoutMenuTree> branch) async {
|
|
wt.ImageCache().clearImageList();
|
|
await putBranchImageToHash(branch);
|
|
log("downloaded image size in KB: " + wt.ImageCache().downloadSize.toString());
|
|
}
|
|
|
|
Future<void> putBranchImageToHash(LinkedHashMap<String, WorkoutMenuTree> branch) async {
|
|
await Future.forEach(branch.keys, (key) async {
|
|
final WorkoutMenuTree? value = branch[key];
|
|
if (value != null && !value.imageName.contains("asset")) {
|
|
await wt.ImageCache().putImageToList(value.id, value.imageName);
|
|
}
|
|
});
|
|
}
|
|
|
|
String? getImage(int id, String name) {
|
|
String? imageString;
|
|
if (name.contains("http")) {
|
|
imageString = wt.ImageCache().getImageString(id, name);
|
|
}
|
|
return imageString;
|
|
}
|
|
|
|
bool selectedDevice(int deviceId) {
|
|
return !listFilterDevice.contains(deviceId);
|
|
}
|
|
|
|
LinkedHashMap<String, WorkoutMenuTree> getFilteredBranch(int? parent) {
|
|
if (parent == null) return LinkedHashMap();
|
|
|
|
LinkedHashMap<String, WorkoutMenuTree> branch = menuTreeRepository.getBranch(parent);
|
|
if (!menuTreeRepository.isChild(parent) || ability.toString() == ExerciseAbility.none.toString() || listFilterDevice.isEmpty) {
|
|
return branch;
|
|
}
|
|
LinkedHashMap<String, WorkoutMenuTree> filtered = LinkedHashMap();
|
|
|
|
branch.forEach((key, value) {
|
|
final WorkoutMenuTree elem = value;
|
|
if (elem.exerciseType != null) {
|
|
for (int i = 0; i < elem.exerciseType!.devices.length; i++) {
|
|
if (listFilterDevice.contains(elem.exerciseType!.devices[i])) {
|
|
filtered[elem.name] = elem;
|
|
}
|
|
}
|
|
}
|
|
});
|
|
return filtered;
|
|
}
|
|
}
|