Move MGDL and MMOL Constants to XXXValueWithUnits
This commit is contained in:
parent
8d8abd65a7
commit
82299e430b
2 changed files with 24 additions and 49 deletions
|
@ -1,13 +1,14 @@
|
||||||
package info.nightscout.androidaps;
|
package info.nightscout.androidaps;
|
||||||
|
|
||||||
|
import info.nightscout.androidaps.database.entities.XXXValueWithUnit;
|
||||||
import info.nightscout.androidaps.utils.T;
|
import info.nightscout.androidaps.utils.T;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by mike on 07.06.2016.
|
* Created by mike on 07.06.2016.
|
||||||
*/
|
*/
|
||||||
public class Constants {
|
public class Constants {
|
||||||
public static final String MGDL = "mg/dl"; // This is Nightscout's representation
|
public static final String MGDL = XXXValueWithUnit.MGDL; // This is Nightscout's representation
|
||||||
public static final String MMOL = "mmol";
|
public static final String MMOL = XXXValueWithUnit.MMOL;
|
||||||
|
|
||||||
public static final double MMOLL_TO_MGDL = 18; // 18.0182;
|
public static final double MMOLL_TO_MGDL = 18; // 18.0182;
|
||||||
public static final double MGDL_TO_MMOLL = 1 / MMOLL_TO_MGDL;
|
public static final double MGDL_TO_MMOLL = 1 / MMOLL_TO_MGDL;
|
||||||
|
|
|
@ -38,59 +38,33 @@ sealed class XXXValueWithUnit {
|
||||||
|
|
||||||
fun value(): Any? {
|
fun value(): Any? {
|
||||||
return when(this) {
|
return when(this) {
|
||||||
is Gram -> this.value
|
is Gram -> this.value
|
||||||
is Hour -> this.value
|
is Hour -> this.value
|
||||||
is Insulin -> this.value
|
is Insulin -> this.value
|
||||||
is Mgdl -> this.value
|
is Mgdl -> this.value
|
||||||
is Minute -> this.value
|
is Minute -> this.value
|
||||||
is Mmoll -> this.value
|
is Mmoll -> this.value
|
||||||
is Percent -> this.value
|
is Percent -> this.value
|
||||||
is SimpleInt -> this.value
|
is SimpleInt -> this.value
|
||||||
is SimpleString -> this.value
|
is SimpleString -> this.value
|
||||||
is StringResource -> this.value
|
is StringResource -> this.value
|
||||||
is TherapyEventMeterType -> this.value
|
is TherapyEventMeterType -> this.value
|
||||||
is TherapyEventTTReason -> this.value
|
is TherapyEventTTReason -> this.value
|
||||||
is TherapyEventType -> this.value
|
is TherapyEventType -> this.value
|
||||||
is Timestamp -> this.value
|
is Timestamp -> this.value
|
||||||
is UnitPerHour -> this.value
|
is UnitPerHour -> this.value
|
||||||
UNKNOWN -> null
|
UNKNOWN -> null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
companion object {
|
companion object {
|
||||||
|
|
||||||
|
const val MGDL = "mg/dl" // This is Nightscout's representation
|
||||||
|
const val MMOL = "mmol"
|
||||||
|
|
||||||
fun fromGlucoseUnit(value: Double, string: String): XXXValueWithUnit? = when (string) {
|
fun fromGlucoseUnit(value: Double, string: String): XXXValueWithUnit? = when (string) {
|
||||||
"mg/dl", "mgdl" -> Mgdl(value)
|
MGDL, "mgdl" -> Mgdl(value)
|
||||||
"mmol", "mmol/l" -> Mmoll(value)
|
MMOL, "mmol/l" -> Mmoll(value)
|
||||||
else -> null
|
else -> null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/***
|
|
||||||
* Idea: Leverage sealed classes for units
|
|
||||||
* Advantage: it is clear what type of data a Unit contains. Still we are exhaustive on when
|
|
||||||
*
|
|
||||||
* The condition "condition" that is used to check if an item should be logged can be replaced by .takeIf { condition }.
|
|
||||||
* The value then would not have to be handled but the logging could simply discard null value.
|
|
||||||
*
|
|
||||||
* [x] new sealed classes
|
|
||||||
* [x] use entry type directly, not String
|
|
||||||
* [ ] database
|
|
||||||
* [x] generate presentation string
|
|
||||||
* [ ] update fragment
|
|
||||||
* [ ] generate csv
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
// just do develop in this file. Remove when done.
|
|
||||||
/*
|
|
||||||
interface Translator {
|
|
||||||
|
|
||||||
fun translate(units: UserEntry.Units): String
|
|
||||||
fun translate(meterType: TherapyEvent.MeterType): String
|
|
||||||
fun translate(type: TherapyEvent.Type): String
|
|
||||||
fun translate(reason: TemporaryTarget.Reason): String
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
Loading…
Reference in a new issue