From baedf117555802ec967211aa74ae3e86e7c8be26 Mon Sep 17 00:00:00 2001 From: Paul Konstantin Gerke Date: Wed, 29 May 2024 01:23:09 +0200 Subject: [PATCH] Add warning if timer is running for more than 10 s already and someone tries to cancel it --- .../timers/TimerControllersV2.kt | 130 +++++++++++++----- app/src/main/res/values/strings.xml | 7 + 2 files changed, 99 insertions(+), 38 deletions(-) diff --git a/app/src/main/java/eu/pkgsoftware/babybuddywidgets/timers/TimerControllersV2.kt b/app/src/main/java/eu/pkgsoftware/babybuddywidgets/timers/TimerControllersV2.kt index 00b15aa..fbf1721 100644 --- a/app/src/main/java/eu/pkgsoftware/babybuddywidgets/timers/TimerControllersV2.kt +++ b/app/src/main/java/eu/pkgsoftware/babybuddywidgets/timers/TimerControllersV2.kt @@ -757,44 +757,11 @@ class LoggingButtonController( controller.postInit() logicMap[activity]?.addStateListener { state, userInduced -> - if (state) { - controlsInterface.insertControls(controller.controlsView) - if (userInduced && (controller is TimerBase)) { - cachedTimers.firstOrNull { it.name == activity }?.let { - runningTimerMods += 1 - timerControl.startTimer( - it, - object : Promise { - override fun succeeded(t: Timer) { - runningTimerMods -= 1 - } - - override fun failed(f: TranslatedException?) { - runningTimerMods -= 1 - newTimerListLoaded(cachedTimers) - } - }) - } - } - } else { - controlsInterface.removeControls(controller.controlsView) - if (userInduced && (controller is TimerBase)) { - controller.updateTimer(null) - cachedTimers.firstOrNull { it.name == activity }?.let { - runningTimerMods += 1 - timerControl.stopTimer( - it, - object : Promise { - override fun succeeded(s: Any?) { - runningTimerMods -= 1 - } - - override fun failed(f: TranslatedException?) { - runningTimerMods -= 1 - newTimerListLoaded(cachedTimers) - } - }) - } + fragment.mainActivity.scope.launch { + if (state) { + startTimerFromSwitch(controller, userInduced, activity) + } else { + stopTimerFromSwitch(controller, userInduced, activity) } } } @@ -821,6 +788,93 @@ class LoggingButtonController( timerHandler() } + private fun startTimerFromSwitch( + controller: LoggingControls, + userInduced: Boolean, + activity: String + ) { + controlsInterface.insertControls(controller.controlsView) + if (userInduced && (controller is TimerBase)) { + cachedTimers.firstOrNull { it.name == activity }?.let { + runningTimerMods += 1 + timerControl.startTimer( + it, + object : Promise { + override fun succeeded(t: Timer) { + runningTimerMods -= 1 + } + + override fun failed(f: TranslatedException?) { + runningTimerMods -= 1 + newTimerListLoaded(cachedTimers) + } + }) + } + } + } + + private suspend fun stopTimerFromSwitch( + controller: LoggingControls, + userInduced: Boolean, + activity: String + ) { + val timer = cachedTimers.firstOrNull { it.name == activity } + if (AsyncPromise.call { promise -> + var defaultSucceed = true + timer?.let { timer -> + if (timer.active && userInduced) { + val timeMs = nowServer().time - timer.start.time + if (timeMs > 10000) { + defaultSucceed = false; + + val message = Phrase.from( + fragment.requireContext(), + R.string.cancel_timer_warning_message + ) + .put("activity", fragment.translateActivityName(activity)) + .format().toString() + + fragment.showQuestion( + true, + fragment.getString(R.string.cancel_timer_warning_title), + message, + fragment.getString(R.string.cancel_timer_warning_stop), + fragment.getString(R.string.cancel_timer_warning_keep), + object : DialogCallback { + override fun call(b: Boolean) { + promise.succeeded(b) + } + } + ); + } + } + } + if (defaultSucceed) { + promise.succeeded(true) + } + }) { + controlsInterface.removeControls(controller.controlsView) + if (userInduced && (controller is TimerBase)) { + controller.updateTimer(null) + timer?.let { + runningTimerMods += 1 + timerControl.stopTimer( + it, + object : Promise { + override fun succeeded(s: Any?) { + runningTimerMods -= 1 + } + + override fun failed(f: TranslatedException?) { + runningTimerMods -= 1 + newTimerListLoaded(cachedTimers) + } + }) + } + } + } + } + private fun timerHandler() { timerHandler?.let { it.postDelayed(Runnable { timerHandler() }, 500) diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index ea457f5..5b953db 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -110,6 +110,13 @@ Stopping timer failed Start timer failed + + Stop timer? + The {activity} timer is running for a long time already. Do you really want to stop it or keep it running? + Stop + Keep + + Overlapping time entries