mirror of
https://github.com/iSoron/uhabits.git
synced 2025-12-06 09:08:52 -06:00
TargetCard: Make target more accurate for non-daily habits
This commit is contained in:
@@ -27,6 +27,7 @@ import org.isoron.uhabits.core.ui.views.Theme
|
|||||||
import org.isoron.uhabits.core.utils.DateUtils
|
import org.isoron.uhabits.core.utils.DateUtils
|
||||||
import java.util.ArrayList
|
import java.util.ArrayList
|
||||||
import java.util.Calendar
|
import java.util.Calendar
|
||||||
|
import kotlin.math.max
|
||||||
|
|
||||||
data class TargetCardState(
|
data class TargetCardState(
|
||||||
val color: PaletteColor,
|
val color: PaletteColor,
|
||||||
@@ -96,15 +97,44 @@ class TargetCardPresenter {
|
|||||||
|
|
||||||
val cal = DateUtils.getStartOfTodayCalendarWithOffset()
|
val cal = DateUtils.getStartOfTodayCalendarWithOffset()
|
||||||
val daysInMonth = cal.getActualMaximum(Calendar.DAY_OF_MONTH)
|
val daysInMonth = cal.getActualMaximum(Calendar.DAY_OF_MONTH)
|
||||||
|
val daysInWeek = 7
|
||||||
val daysInQuarter = 91
|
val daysInQuarter = 91
|
||||||
val daysInYear = cal.getActualMaximum(Calendar.DAY_OF_YEAR)
|
val daysInYear = cal.getActualMaximum(Calendar.DAY_OF_YEAR)
|
||||||
|
val weeksInMonth = daysInMonth / 7
|
||||||
|
val weeksInQuarter = 13
|
||||||
|
val weeksInYear = 52
|
||||||
|
val monthsInQuarter = 3
|
||||||
|
val monthsInYear = 12
|
||||||
|
|
||||||
|
val denominator = habit.frequency.denominator
|
||||||
val dailyTarget = habit.targetValue / habit.frequency.denominator
|
val dailyTarget = habit.targetValue / habit.frequency.denominator
|
||||||
val targetToday = dailyTarget * (1 - skippedDayToday)
|
|
||||||
val targetThisWeek = dailyTarget * (7 - skippedDaysThisWeek)
|
var targetToday = dailyTarget
|
||||||
val targetThisMonth = dailyTarget * (daysInMonth - skippedDaysThisMonth)
|
var targetThisWeek = when (denominator) {
|
||||||
val targetThisQuarter = dailyTarget * (daysInQuarter - skippedDaysThisQuarter)
|
7 -> habit.targetValue
|
||||||
val targetThisYear = dailyTarget * (daysInYear - skippedDaysThisYear)
|
else -> dailyTarget * daysInWeek
|
||||||
|
}
|
||||||
|
var targetThisMonth = when (denominator) {
|
||||||
|
30 -> habit.targetValue
|
||||||
|
7 -> habit.targetValue * weeksInMonth
|
||||||
|
else -> dailyTarget * daysInMonth
|
||||||
|
}
|
||||||
|
var targetThisQuarter = when (denominator) {
|
||||||
|
30 -> habit.targetValue * monthsInQuarter
|
||||||
|
7 -> habit.targetValue * weeksInQuarter
|
||||||
|
else -> dailyTarget * daysInQuarter
|
||||||
|
}
|
||||||
|
var targetThisYear = when (denominator) {
|
||||||
|
30 -> habit.targetValue * monthsInYear
|
||||||
|
7 -> habit.targetValue * weeksInYear
|
||||||
|
else -> dailyTarget * daysInYear
|
||||||
|
}
|
||||||
|
|
||||||
|
targetToday = max(0.0, targetToday - dailyTarget * skippedDayToday)
|
||||||
|
targetThisWeek = max(0.0, targetThisWeek - dailyTarget * skippedDaysThisWeek)
|
||||||
|
targetThisMonth = max(0.0, targetThisMonth - dailyTarget * skippedDaysThisMonth)
|
||||||
|
targetThisQuarter = max(0.0, targetThisQuarter - dailyTarget * skippedDaysThisQuarter)
|
||||||
|
targetThisYear = max(0.0, targetThisYear - dailyTarget * skippedDaysThisYear)
|
||||||
|
|
||||||
val values = ArrayList<Double>()
|
val values = ArrayList<Double>()
|
||||||
if (habit.frequency.denominator <= 1) values.add(valueToday / 1e3)
|
if (habit.frequency.denominator <= 1) values.add(valueToday / 1e3)
|
||||||
|
|||||||
Reference in New Issue
Block a user