This commit is contained in:
Hamza-Ayed
2023-09-25 02:48:18 +03:00
parent ebcc644d8c
commit 7290e5ecc7
8 changed files with 172 additions and 38 deletions

View File

@@ -0,0 +1,51 @@
import 'package:get/get.dart';
import 'package:ride/constant/box_name.dart';
import 'dart:async';
import '../../../main.dart';
class HomeCaptainController extends GetxController {
bool isActive = false;
DateTime? activeStartTime;
Duration activeDuration = Duration.zero;
Timer? activeTimer;
void onButtonSelected() {
isActive = !isActive;
if (isActive) {
activeStartTime = DateTime.now();
activeTimer = Timer.periodic(const Duration(seconds: 1), (timer) {
activeDuration = DateTime.now().difference(activeStartTime!);
update();
});
} else {
activeStartTime = null;
activeTimer?.cancel();
savePeriod(activeDuration);
activeDuration = Duration.zero;
}
update();
}
void savePeriod(Duration period) {
final periods = box.read<List<dynamic>>(BoxName.periods) ?? [];
periods.add(period.inSeconds);
box.write(BoxName.periods, periods);
}
Duration calculateTotalDuration() {
final periods = box.read<List<dynamic>>(BoxName.periods) ?? [];
Duration totalDuration = Duration.zero;
for (dynamic periodInSeconds in periods) {
final periodDuration = Duration(seconds: periodInSeconds);
totalDuration += periodDuration;
}
return totalDuration;
}
@override
void dispose() {
activeTimer?.cancel();
super.dispose();
}
}

View File

@@ -0,0 +1,27 @@
import 'package:flutter/cupertino.dart';
import 'package:get/get.dart';
import '../home_captain_controller.dart';
class ConnectWidget extends StatelessWidget {
const ConnectWidget({
super.key,
});
@override
Widget build(BuildContext context) {
return Center(
child: GetBuilder<HomeCaptainController>(
builder: (homeCaptainController) => CupertinoButton(
child: Text(homeCaptainController.isActive
? 'Connected'.tr
: 'Not Connected'.tr),
onPressed: homeCaptainController.onButtonSelected,
color: homeCaptainController.isActive
? CupertinoColors.activeGreen
: CupertinoColors.inactiveGray,
),
),
);
}
}

View File

@@ -233,6 +233,7 @@ class MapController extends GetxController {
void timerEnded() async {
print('Timer ended');
runEvery50SecondsUntilConditionMet();
isCancelRidePageShown = false;
update();