Merge branch 'dev' into medtronic_andy
This commit is contained in:
commit
8fc694e812
85 changed files with 20469 additions and 18572 deletions
|
@ -1,6 +1,6 @@
|
||||||
Reporting bugs
|
Reporting bugs
|
||||||
--------------
|
--------------
|
||||||
- Note the precise time the problem occurred and describe the circumstances and steps that caused
|
- **Note the precise time the problem occurred** and describe the circumstances and steps that caused
|
||||||
the problem
|
the problem
|
||||||
- Note the Build version (found in the About dialog in the app, when pressing the three dots in the
|
- Note the Build version (found in the About dialog in the app, when pressing the three dots in the
|
||||||
upper-right corner).
|
upper-right corner).
|
||||||
|
|
|
@ -13,7 +13,7 @@ There you can find the Project (Medtronic), with nice board with all the tasks (
|
||||||
|
|
||||||
# AndroidAPS - Default README content
|
# AndroidAPS - Default README content
|
||||||
|
|
||||||
* Check the wiki: https://github.com/MilosKozak/AndroidAPS/wiki
|
* Check the wiki: http://wiki.androidaps.org
|
||||||
* Everyone who’s been looping with AndroidAPS needs to fill out the form after 3 days of looping https://docs.google.com/forms/d/14KcMjlINPMJHVt28MDRupa4sz4DDIooI4SrW0P3HSN8/viewform?c=0&w=1
|
* Everyone who’s been looping with AndroidAPS needs to fill out the form after 3 days of looping https://docs.google.com/forms/d/14KcMjlINPMJHVt28MDRupa4sz4DDIooI4SrW0P3HSN8/viewform?c=0&w=1
|
||||||
|
|
||||||
[![Gitter](https://badges.gitter.im/MilosKozak/AndroidAPS.svg)](https://gitter.im/MilosKozak/AndroidAPS?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
[![Gitter](https://badges.gitter.im/MilosKozak/AndroidAPS.svg)](https://gitter.im/MilosKozak/AndroidAPS?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
|
|
|
@ -63,7 +63,7 @@ android {
|
||||||
targetSdkVersion 25
|
targetSdkVersion 25
|
||||||
multiDexEnabled true
|
multiDexEnabled true
|
||||||
versionCode 1500
|
versionCode 1500
|
||||||
// dev_version: 2.0i
|
// dev_version: 2.0
|
||||||
version "medtronic-0.5"
|
version "medtronic-0.5"
|
||||||
buildConfigField "String", "VERSION", '"' + version + '"'
|
buildConfigField "String", "VERSION", '"' + version + '"'
|
||||||
buildConfigField "String", "BUILDVERSION", '"' + generateGitBuild() + '-' + generateDate() + '"'
|
buildConfigField "String", "BUILDVERSION", '"' + generateGitBuild() + '-' + generateDate() + '"'
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
<uses-permission android:name="android.permission.RECEIVE_SMS" />
|
<uses-permission android:name="android.permission.RECEIVE_SMS" />
|
||||||
<uses-permission android:name="android.permission.RECEIVE_MMS" />
|
<uses-permission android:name="android.permission.RECEIVE_MMS" />
|
||||||
<uses-permission android:name="android.permission.SEND_SMS" />
|
<uses-permission android:name="android.permission.SEND_SMS" />
|
||||||
|
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
|
||||||
<uses-permission android:name="android.permission.SEND_MMS" />
|
<uses-permission android:name="android.permission.SEND_MMS" />
|
||||||
<uses-permission android:name="android.permission.VIBRATE" />
|
<uses-permission android:name="android.permission.VIBRATE" />
|
||||||
<uses-permission android:name="android.permission.INTERNET" />
|
<uses-permission android:name="android.permission.INTERNET" />
|
||||||
|
@ -34,6 +35,9 @@
|
||||||
android:label="@string/app_name"
|
android:label="@string/app_name"
|
||||||
android:supportsRtl="true"
|
android:supportsRtl="true"
|
||||||
android:theme="@style/AppTheme.NoActionBar">
|
android:theme="@style/AppTheme.NoActionBar">
|
||||||
|
<meta-data
|
||||||
|
android:name="com.google.android.gms.car.application"
|
||||||
|
android:resource="@xml/automotive_app_desc" />
|
||||||
<activity android:name=".MainActivity">
|
<activity android:name=".MainActivity">
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="android.intent.action.MAIN" />
|
<action android:name="android.intent.action.MAIN" />
|
||||||
|
|
|
@ -9,33 +9,32 @@ var tempBasalFunctions = {};
|
||||||
|
|
||||||
tempBasalFunctions.getMaxSafeBasal = function getMaxSafeBasal(profile) {
|
tempBasalFunctions.getMaxSafeBasal = function getMaxSafeBasal(profile) {
|
||||||
|
|
||||||
var max_daily_safety_multiplier = (isNaN(profile.max_daily_safety_multiplier) || profile.max_daily_safety_multiplier == null) ? 3 : profile.max_daily_safety_multiplier;
|
var max_daily_safety_multiplier = (isNaN(profile.max_daily_safety_multiplier) || profile.max_daily_safety_multiplier == null) ? 3 : profile.max_daily_safety_multiplier;
|
||||||
var current_basal_safety_multiplier = (isNaN(profile.current_basal_safety_multiplier) || profile.current_basal_safety_multiplier == null) ? 4 : profile.current_basal_safety_multiplier;
|
var current_basal_safety_multiplier = (isNaN(profile.current_basal_safety_multiplier) || profile.current_basal_safety_multiplier == null) ? 4 : profile.current_basal_safety_multiplier;
|
||||||
|
|
||||||
return Math.min(profile.max_basal, max_daily_safety_multiplier * profile.max_daily_basal, current_basal_safety_multiplier * profile.current_basal);
|
return Math.min(profile.max_basal, max_daily_safety_multiplier * profile.max_daily_basal, current_basal_safety_multiplier * profile.current_basal);
|
||||||
};
|
};
|
||||||
|
|
||||||
tempBasalFunctions.setTempBasal = function setTempBasal(rate, duration, profile, rT, currenttemp) {
|
tempBasalFunctions.setTempBasal = function setTempBasal(rate, duration, profile, rT, currenttemp) {
|
||||||
//var maxSafeBasal = Math.min(profile.max_basal, 3 * profile.max_daily_basal, 4 * profile.current_basal);
|
//var maxSafeBasal = Math.min(profile.max_basal, 3 * profile.max_daily_basal, 4 * profile.current_basal);
|
||||||
|
|
||||||
var maxSafeBasal = tempBasalFunctions.getMaxSafeBasal(profile);
|
var maxSafeBasal = tempBasalFunctions.getMaxSafeBasal(profile);
|
||||||
var round_basal = require('./round-basal');
|
var round_basal = require('./round-basal');
|
||||||
|
|
||||||
if (rate < 0) {
|
if (rate < 0) {
|
||||||
rate = 0;
|
rate = 0;
|
||||||
} // if >30m @ 0 required, zero temp will be extended to 30m instead
|
} else if (rate > maxSafeBasal) {
|
||||||
else if (rate > maxSafeBasal) {
|
|
||||||
rate = maxSafeBasal;
|
rate = maxSafeBasal;
|
||||||
}
|
}
|
||||||
|
|
||||||
var suggestedRate = round_basal(rate, profile);
|
var suggestedRate = round_basal(rate, profile);
|
||||||
if (typeof(currenttemp) !== 'undefined' && typeof(currenttemp.duration) !== 'undefined' && typeof(currenttemp.rate) !== 'undefined' && currenttemp.duration > (duration-10) && currenttemp.duration <= 120 && suggestedRate <= currenttemp.rate * 1.2 && suggestedRate >= currenttemp.rate * 0.8) {
|
if (typeof(currenttemp) !== 'undefined' && typeof(currenttemp.duration) !== 'undefined' && typeof(currenttemp.rate) !== 'undefined' && currenttemp.duration > (duration-10) && currenttemp.duration <= 120 && suggestedRate <= currenttemp.rate * 1.2 && suggestedRate >= currenttemp.rate * 0.8 && duration > 0 ) {
|
||||||
rT.reason += " "+currenttemp.duration+"m left and " + currenttemp.rate + " ~ req " + suggestedRate + "U/hr: no temp required";
|
rT.reason += " "+currenttemp.duration+"m left and " + currenttemp.rate + " ~ req " + suggestedRate + "U/hr: no temp required";
|
||||||
return rT;
|
return rT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (suggestedRate === profile.current_basal) {
|
if (suggestedRate === profile.current_basal) {
|
||||||
if (profile.skip_neutral_temps) {
|
if (profile.skip_neutral_temps === true) {
|
||||||
if (typeof(currenttemp) !== 'undefined' && typeof(currenttemp.duration) !== 'undefined' && currenttemp.duration > 0) {
|
if (typeof(currenttemp) !== 'undefined' && typeof(currenttemp.duration) !== 'undefined' && currenttemp.duration > 0) {
|
||||||
reason(rT, 'Suggested rate is same as profile rate, a temp basal is active, canceling current temp');
|
reason(rT, 'Suggested rate is same as profile rate, a temp basal is active, canceling current temp');
|
||||||
rT.duration = 0;
|
rT.duration = 0;
|
||||||
|
|
|
@ -326,6 +326,7 @@ public class MainActivity extends AppCompatActivity {
|
||||||
case AndroidPermission.CASE_LOCATION:
|
case AndroidPermission.CASE_LOCATION:
|
||||||
case AndroidPermission.CASE_SMS:
|
case AndroidPermission.CASE_SMS:
|
||||||
case AndroidPermission.CASE_BATTERY:
|
case AndroidPermission.CASE_BATTERY:
|
||||||
|
case AndroidPermission.CASE_PHONESTATE:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import info.nightscout.androidaps.plugins.Overview.notifications.Notification;
|
||||||
import info.nightscout.utils.DateUtil;
|
import info.nightscout.utils.DateUtil;
|
||||||
import info.nightscout.utils.DecimalFormatter;
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
import info.nightscout.utils.FabricPrivacy;
|
import info.nightscout.utils.FabricPrivacy;
|
||||||
|
import info.nightscout.utils.MidnightTime;
|
||||||
|
|
||||||
public class Profile {
|
public class Profile {
|
||||||
private static Logger log = LoggerFactory.getLogger(Profile.class);
|
private static Logger log = LoggerFactory.getLogger(Profile.class);
|
||||||
|
@ -381,7 +382,7 @@ public class Profile {
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getIsf() {
|
public double getIsf() {
|
||||||
return getIsfTimeFromMidnight(secondsFromMidnight(System.currentTimeMillis()));
|
return getIsfTimeFromMidnight(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getIsf(long time) {
|
public double getIsf(long time) {
|
||||||
|
@ -397,11 +398,11 @@ public class Profile {
|
||||||
public String getIsfList() {
|
public String getIsfList() {
|
||||||
if (isf_v == null)
|
if (isf_v == null)
|
||||||
isf_v = convertToSparseArray(isf);
|
isf_v = convertToSparseArray(isf);
|
||||||
return getValuesList(isf_v, null, new DecimalFormat("0.0"), getUnits() + "/U");
|
return getValuesList(isf_v, null, new DecimalFormat("0.0"), getUnits() + MainApp.gs(R.string.profile_per_unit));
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getIc() {
|
public double getIc() {
|
||||||
return getIcTimeFromMidnight(secondsFromMidnight(System.currentTimeMillis()));
|
return getIcTimeFromMidnight(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getIc(long time) {
|
public double getIc(long time) {
|
||||||
|
@ -417,11 +418,11 @@ public class Profile {
|
||||||
public String getIcList() {
|
public String getIcList() {
|
||||||
if (ic_v == null)
|
if (ic_v == null)
|
||||||
ic_v = convertToSparseArray(ic);
|
ic_v = convertToSparseArray(ic);
|
||||||
return getValuesList(ic_v, null, new DecimalFormat("0.0"), "g/U");
|
return getValuesList(ic_v, null, new DecimalFormat("0.0"), MainApp.gs(R.string.profile_carbs_per_unit));
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getBasal() {
|
public double getBasal() {
|
||||||
return getBasalTimeFromMidnight(secondsFromMidnight(System.currentTimeMillis()));
|
return getBasalTimeFromMidnight(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getBasal(long time) {
|
public double getBasal(long time) {
|
||||||
|
@ -438,7 +439,7 @@ public class Profile {
|
||||||
public String getBasalList() {
|
public String getBasalList() {
|
||||||
if (basal_v == null)
|
if (basal_v == null)
|
||||||
basal_v = convertToSparseArray(basal);
|
basal_v = convertToSparseArray(basal);
|
||||||
return getValuesList(basal_v, null, new DecimalFormat("0.00"), "U/h");
|
return getValuesList(basal_v, null, new DecimalFormat("0.00"), MainApp.gs(R.string.profile_ins_units_per_hout));
|
||||||
}
|
}
|
||||||
|
|
||||||
public class BasalValue {
|
public class BasalValue {
|
||||||
|
@ -465,7 +466,7 @@ public class Profile {
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getTarget() {
|
public double getTarget() {
|
||||||
return getTarget(secondsFromMidnight(System.currentTimeMillis()));
|
return getTarget(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected double getTarget(int timeAsSeconds) {
|
protected double getTarget(int timeAsSeconds) {
|
||||||
|
@ -473,7 +474,7 @@ public class Profile {
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getTargetLow() {
|
public double getTargetLow() {
|
||||||
return getTargetLowTimeFromMidnight(secondsFromMidnight(System.currentTimeMillis()));
|
return getTargetLowTimeFromMidnight(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getTargetLow(long time) {
|
public double getTargetLow(long time) {
|
||||||
|
@ -487,7 +488,7 @@ public class Profile {
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getTargetHigh() {
|
public double getTargetHigh() {
|
||||||
return getTargetHighTimeFromMidnight(secondsFromMidnight(System.currentTimeMillis()));
|
return getTargetHighTimeFromMidnight(secondsFromMidnight());
|
||||||
}
|
}
|
||||||
|
|
||||||
public double getTargetHigh(long time) {
|
public double getTargetHigh(long time) {
|
||||||
|
@ -518,24 +519,13 @@ public class Profile {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int secondsFromMidnight() {
|
public static int secondsFromMidnight() {
|
||||||
Calendar c = Calendar.getInstance();
|
long passed = DateUtil.now() - MidnightTime.calc();
|
||||||
long now = c.getTimeInMillis();
|
|
||||||
c.set(Calendar.HOUR_OF_DAY, 0);
|
|
||||||
c.set(Calendar.MINUTE, 0);
|
|
||||||
c.set(Calendar.SECOND, 0);
|
|
||||||
c.set(Calendar.MILLISECOND, 0);
|
|
||||||
long passed = now - c.getTimeInMillis();
|
|
||||||
return (int) (passed / 1000);
|
return (int) (passed / 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int secondsFromMidnight(long date) {
|
public static int secondsFromMidnight(long date) {
|
||||||
Calendar c = Calendar.getInstance();
|
long midnight = MidnightTime.calc(date);
|
||||||
c.setTimeInMillis(date);
|
long passed = date - midnight;
|
||||||
c.set(Calendar.HOUR_OF_DAY, 0);
|
|
||||||
c.set(Calendar.MINUTE, 0);
|
|
||||||
c.set(Calendar.SECOND, 0);
|
|
||||||
c.set(Calendar.MILLISECOND, 0);
|
|
||||||
long passed = date - c.getTimeInMillis();
|
|
||||||
return (int) (passed / 1000);
|
return (int) (passed / 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -164,6 +164,13 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {
|
||||||
|
log.info("Do nothing for downgrading...");
|
||||||
|
log.debug("oldVersion: {}, newVersion: {}", oldVersion, newVersion);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public int getOldVersion() {
|
public int getOldVersion() {
|
||||||
return oldVersion;
|
return oldVersion;
|
||||||
}
|
}
|
||||||
|
@ -428,7 +435,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
|
||||||
QueryBuilder<BgReading, Long> queryBuilder = daoBgReadings.queryBuilder();
|
QueryBuilder<BgReading, Long> queryBuilder = daoBgReadings.queryBuilder();
|
||||||
queryBuilder.orderBy("date", false);
|
queryBuilder.orderBy("date", false);
|
||||||
queryBuilder.limit(1L);
|
queryBuilder.limit(1L);
|
||||||
queryBuilder.where().gt("value", 38).and().eq("isValid", true);
|
queryBuilder.where().ge("value", 39).and().eq("isValid", true);
|
||||||
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
||||||
bgList = daoBgReadings.query(preparedQuery);
|
bgList = daoBgReadings.query(preparedQuery);
|
||||||
|
|
||||||
|
@ -467,7 +474,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
|
||||||
QueryBuilder<BgReading, Long> queryBuilder = daoBgreadings.queryBuilder();
|
QueryBuilder<BgReading, Long> queryBuilder = daoBgreadings.queryBuilder();
|
||||||
queryBuilder.orderBy("date", ascending);
|
queryBuilder.orderBy("date", ascending);
|
||||||
Where where = queryBuilder.where();
|
Where where = queryBuilder.where();
|
||||||
where.ge("date", mills).and().gt("value", 38).and().eq("isValid", true);
|
where.ge("date", mills).and().ge("value", 39).and().eq("isValid", true);
|
||||||
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
||||||
bgReadings = daoBgreadings.query(preparedQuery);
|
bgReadings = daoBgreadings.query(preparedQuery);
|
||||||
return bgReadings;
|
return bgReadings;
|
||||||
|
@ -485,7 +492,7 @@ public class DatabaseHelper extends OrmLiteSqliteOpenHelper {
|
||||||
QueryBuilder<BgReading, Long> queryBuilder = daoBgreadings.queryBuilder();
|
QueryBuilder<BgReading, Long> queryBuilder = daoBgreadings.queryBuilder();
|
||||||
queryBuilder.orderBy("date", ascending);
|
queryBuilder.orderBy("date", ascending);
|
||||||
Where where = queryBuilder.where();
|
Where where = queryBuilder.where();
|
||||||
where.between("date", start, end).and().gt("value", 38).and().eq("isValid", true);
|
where.between("date", start, end).and().ge("value", 39).and().eq("isValid", true);
|
||||||
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
PreparedQuery<BgReading> preparedQuery = queryBuilder.prepare();
|
||||||
bgReadings = daoBgreadings.query(preparedQuery);
|
bgReadings = daoBgreadings.query(preparedQuery);
|
||||||
return bgReadings;
|
return bgReadings;
|
||||||
|
|
|
@ -101,6 +101,11 @@ public class ProfileSwitch implements Interval, DataPointWithLabelInterface {
|
||||||
return profile;
|
return profile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Note: the name returned here is used as the PS name when uploading to NS. When such a PS is retrieved
|
||||||
|
* again from NS, the added parts must be removed again, see
|
||||||
|
* {@link info.nightscout.utils.PercentageSplitter#pureName}
|
||||||
|
*/
|
||||||
public String getCustomizedName() {
|
public String getCustomizedName() {
|
||||||
String name = profileName;
|
String name = profileName;
|
||||||
if(LocalProfilePlugin.LOCAL_PROFILE.equals(name)){
|
if(LocalProfilePlugin.LOCAL_PROFILE.equals(name)){
|
||||||
|
|
|
@ -99,13 +99,13 @@ public class L {
|
||||||
private static void initialize() {
|
private static void initialize() {
|
||||||
logElements = new ArrayList<>();
|
logElements = new ArrayList<>();
|
||||||
logElements.add(new LogElement(APS, true));
|
logElements.add(new LogElement(APS, true));
|
||||||
logElements.add(new LogElement(AUTOSENS, true));
|
logElements.add(new LogElement(AUTOSENS, false));
|
||||||
logElements.add(new LogElement(BGSOURCE, true));
|
logElements.add(new LogElement(BGSOURCE, true));
|
||||||
logElements.add(new LogElement(CONFIGBUILDER, true));
|
logElements.add(new LogElement(CONFIGBUILDER, false));
|
||||||
logElements.add(new LogElement(CONSTRAINTS, true));
|
logElements.add(new LogElement(CONSTRAINTS, true));
|
||||||
logElements.add(new LogElement(CORE, true));
|
logElements.add(new LogElement(CORE, true));
|
||||||
logElements.add(new LogElement(DATABASE, true));
|
logElements.add(new LogElement(DATABASE, true));
|
||||||
logElements.add(new LogElement(DATAFOOD, true));
|
logElements.add(new LogElement(DATAFOOD, false));
|
||||||
logElements.add(new LogElement(DATASERVICE, true));
|
logElements.add(new LogElement(DATASERVICE, true));
|
||||||
logElements.add(new LogElement(DATATREATMENTS, true));
|
logElements.add(new LogElement(DATATREATMENTS, true));
|
||||||
logElements.add(new LogElement(EVENTS, false, true));
|
logElements.add(new LogElement(EVENTS, false, true));
|
||||||
|
|
|
@ -270,7 +270,7 @@ public class NewNSTreatmentDialog extends DialogFragment implements View.OnClick
|
||||||
if (profile == null) {
|
if (profile == null) {
|
||||||
editBg.setParams(bg, 0d, 500d, 0.1d, new DecimalFormat("0.0"), false, bgTextWatcher);
|
editBg.setParams(bg, 0d, 500d, 0.1d, new DecimalFormat("0.0"), false, bgTextWatcher);
|
||||||
editTemptarget.setParams(bg, 0d, 500d, 0.1d, new DecimalFormat("0.0"), false);
|
editTemptarget.setParams(bg, 0d, 500d, 0.1d, new DecimalFormat("0.0"), false);
|
||||||
} else if (profile.getUnits().equals(Constants.MMOL)) {
|
} else if (units.equals(Constants.MMOL)) {
|
||||||
editBg.setParams(bg, 0d, 30d, 0.1d, new DecimalFormat("0.0"), false, bgTextWatcher);
|
editBg.setParams(bg, 0d, 30d, 0.1d, new DecimalFormat("0.0"), false, bgTextWatcher);
|
||||||
editTemptarget.setParams(bg, 0d, 30d, 0.1d, new DecimalFormat("0.0"), false);
|
editTemptarget.setParams(bg, 0d, 30d, 0.1d, new DecimalFormat("0.0"), false);
|
||||||
} else {
|
} else {
|
||||||
|
@ -279,7 +279,7 @@ public class NewNSTreatmentDialog extends DialogFragment implements View.OnClick
|
||||||
}
|
}
|
||||||
|
|
||||||
sensorRadioButton.setOnCheckedChangeListener((buttonView, isChecked) -> {
|
sensorRadioButton.setOnCheckedChangeListener((buttonView, isChecked) -> {
|
||||||
Double bg1 = Profile.fromMgdlToUnits(GlucoseStatus.getGlucoseStatusData() != null ? GlucoseStatus.getGlucoseStatusData().glucose : 0d, profile.getUnits());
|
Double bg1 = Profile.fromMgdlToUnits(GlucoseStatus.getGlucoseStatusData() != null ? GlucoseStatus.getGlucoseStatusData().glucose : 0d, units);
|
||||||
if (savedInstanceState != null && savedInstanceState.getDouble("editBg") != bg1) {
|
if (savedInstanceState != null && savedInstanceState.getDouble("editBg") != bg1) {
|
||||||
editBg.setValue(savedInstanceState.getDouble("editBg"));
|
editBg.setValue(savedInstanceState.getDouble("editBg"));
|
||||||
} else {
|
} else {
|
||||||
|
@ -459,7 +459,7 @@ public class NewNSTreatmentDialog extends DialogFragment implements View.OnClick
|
||||||
if ((data.size() > 0) &&
|
if ((data.size() > 0) &&
|
||||||
(data.get(0).date > millis - 7 * 60 * 1000L) &&
|
(data.get(0).date > millis - 7 * 60 * 1000L) &&
|
||||||
(data.get(0).date < millis + 7 * 60 * 1000L)) {
|
(data.get(0).date < millis + 7 * 60 * 1000L)) {
|
||||||
editBg.setValue(Profile.fromMgdlToUnits(data.get(0).value, profile != null ? profile.getUnits() : Constants.MGDL));
|
editBg.setValue(Profile.fromMgdlToUnits(data.get(0).value, units));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -736,8 +736,8 @@ public class NewNSTreatmentDialog extends DialogFragment implements View.OnClick
|
||||||
.reason(reason)
|
.reason(reason)
|
||||||
.source(Source.USER);
|
.source(Source.USER);
|
||||||
if (tempTarget.durationInMinutes != 0) {
|
if (tempTarget.durationInMinutes != 0) {
|
||||||
tempTarget.low(Profile.toMgdl(targetBottom, profile.getUnits()))
|
tempTarget.low(Profile.toMgdl(targetBottom, units))
|
||||||
.high(Profile.toMgdl(targetTop, profile.getUnits()));
|
.high(Profile.toMgdl(targetTop, units));
|
||||||
} else {
|
} else {
|
||||||
tempTarget.low(0).high(0);
|
tempTarget.low(0).high(0);
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,8 @@ import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
||||||
import info.nightscout.utils.DateUtil;
|
import info.nightscout.utils.DateUtil;
|
||||||
import info.nightscout.utils.DecimalFormatter;
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
import info.nightscout.utils.FabricPrivacy;
|
import info.nightscout.utils.FabricPrivacy;
|
||||||
|
import info.nightscout.utils.MidnightTime;
|
||||||
|
import info.nightscout.utils.Profiler;
|
||||||
import info.nightscout.utils.SP;
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
import static info.nightscout.utils.DateUtil.now;
|
import static info.nightscout.utils.DateUtil.now;
|
||||||
|
@ -75,6 +77,7 @@ public class IobCobOref1Thread extends Thread {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void run() {
|
public final void run() {
|
||||||
|
long start = DateUtil.now();
|
||||||
mWakeLock.acquire();
|
mWakeLock.acquire();
|
||||||
try {
|
try {
|
||||||
if (L.isEnabled(L.AUTOSENS))
|
if (L.isEnabled(L.AUTOSENS))
|
||||||
|
@ -393,8 +396,11 @@ public class IobCobOref1Thread extends Thread {
|
||||||
} finally {
|
} finally {
|
||||||
mWakeLock.release();
|
mWakeLock.release();
|
||||||
MainApp.bus().post(new EventIobCalculationProgress(""));
|
MainApp.bus().post(new EventIobCalculationProgress(""));
|
||||||
if (L.isEnabled(L.AUTOSENS))
|
if (L.isEnabled(L.AUTOSENS)) {
|
||||||
log.debug("AUTOSENSDATA thread ended: " + from);
|
log.debug("AUTOSENSDATA thread ended: " + from);
|
||||||
|
log.debug("Midnights: " + MidnightTime.log());
|
||||||
|
}
|
||||||
|
Profiler.log(log, "IobCobOref1Thread", start);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -38,6 +38,8 @@ import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
||||||
import info.nightscout.utils.DateUtil;
|
import info.nightscout.utils.DateUtil;
|
||||||
import info.nightscout.utils.DecimalFormatter;
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
import info.nightscout.utils.FabricPrivacy;
|
import info.nightscout.utils.FabricPrivacy;
|
||||||
|
import info.nightscout.utils.MidnightTime;
|
||||||
|
import info.nightscout.utils.Profiler;
|
||||||
import info.nightscout.utils.SP;
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
import static info.nightscout.utils.DateUtil.now;
|
import static info.nightscout.utils.DateUtil.now;
|
||||||
|
@ -74,6 +76,7 @@ public class IobCobThread extends Thread {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void run() {
|
public final void run() {
|
||||||
|
long start = DateUtil.now();
|
||||||
mWakeLock.acquire();
|
mWakeLock.acquire();
|
||||||
try {
|
try {
|
||||||
if (L.isEnabled(L.AUTOSENS))
|
if (L.isEnabled(L.AUTOSENS))
|
||||||
|
@ -320,8 +323,11 @@ public class IobCobThread extends Thread {
|
||||||
} finally {
|
} finally {
|
||||||
mWakeLock.release();
|
mWakeLock.release();
|
||||||
MainApp.bus().post(new EventIobCalculationProgress(""));
|
MainApp.bus().post(new EventIobCalculationProgress(""));
|
||||||
if (L.isEnabled(L.AUTOSENS))
|
if (L.isEnabled(L.AUTOSENS)) {
|
||||||
log.debug("AUTOSENSDATA thread ended: " + from);
|
log.debug("AUTOSENSDATA thread ended: " + from);
|
||||||
|
log.debug("Midnights: " + MidnightTime.log());
|
||||||
|
}
|
||||||
|
Profiler.log(log, "IobCobThread", start);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -307,6 +307,11 @@ public class APSResult {
|
||||||
PumpInterface pump = ConfigBuilderPlugin.getPlugin().getActivePump();
|
PumpInterface pump = ConfigBuilderPlugin.getPlugin().getActivePump();
|
||||||
Profile profile = ProfileFunctions.getInstance().getProfile();
|
Profile profile = ProfileFunctions.getInstance().getProfile();
|
||||||
|
|
||||||
|
if (profile == null) {
|
||||||
|
log.error("FALSE: No Profile");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (usePercent) {
|
if (usePercent) {
|
||||||
if (activeTemp == null && percent == 100) {
|
if (activeTemp == null && percent == 100) {
|
||||||
if (L.isEnabled(L.APS))
|
if (L.isEnabled(L.APS))
|
||||||
|
|
|
@ -409,8 +409,10 @@ public class LoopPlugin extends PluginBase {
|
||||||
.setAutoCancel(true)
|
.setAutoCancel(true)
|
||||||
.setPriority(Notification.PRIORITY_HIGH)
|
.setPriority(Notification.PRIORITY_HIGH)
|
||||||
.setCategory(Notification.CATEGORY_ALARM)
|
.setCategory(Notification.CATEGORY_ALARM)
|
||||||
.setVisibility(Notification.VISIBILITY_PUBLIC)
|
.setVisibility(Notification.VISIBILITY_PUBLIC);
|
||||||
.setLocalOnly(true);
|
if (SP.getBoolean("wearcontrol", false)) {
|
||||||
|
builder.setLocalOnly(true);
|
||||||
|
}
|
||||||
|
|
||||||
// Creates an explicit intent for an Activity in your app
|
// Creates an explicit intent for an Activity in your app
|
||||||
Intent resultIntent = new Intent(MainApp.instance().getApplicationContext(), MainActivity.class);
|
Intent resultIntent = new Intent(MainApp.instance().getApplicationContext(), MainActivity.class);
|
||||||
|
|
|
@ -107,9 +107,9 @@ public class BolusProgressDialog extends DialogFragment implements View.OnClickL
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
|
running = false;
|
||||||
super.onPause();
|
super.onPause();
|
||||||
MainApp.unsubscribe(this);
|
MainApp.unsubscribe(this);
|
||||||
running = false;
|
|
||||||
if (L.isEnabled(L.UI))
|
if (L.isEnabled(L.UI))
|
||||||
log.debug("onPause");
|
log.debug("onPause");
|
||||||
}
|
}
|
||||||
|
@ -173,10 +173,12 @@ public class BolusProgressDialog extends DialogFragment implements View.OnClickL
|
||||||
Activity activity = getActivity();
|
Activity activity = getActivity();
|
||||||
if (activity != null) {
|
if (activity != null) {
|
||||||
activity.runOnUiThread(() -> {
|
activity.runOnUiThread(() -> {
|
||||||
if (L.isEnabled(L.UI))
|
|
||||||
log.debug("executing");
|
|
||||||
try {
|
try {
|
||||||
dismiss();
|
if (running) {
|
||||||
|
if (L.isEnabled(L.UI))
|
||||||
|
log.debug("executing");
|
||||||
|
dismiss();
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("Unhandled exception", e);
|
log.error("Unhandled exception", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -446,7 +446,8 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
super.onCreateContextMenu(menu, v, menuInfo);
|
super.onCreateContextMenu(menu, v, menuInfo);
|
||||||
if (v == apsModeView) {
|
if (v == apsModeView) {
|
||||||
final LoopPlugin loopPlugin = LoopPlugin.getPlugin();
|
final LoopPlugin loopPlugin = LoopPlugin.getPlugin();
|
||||||
final PumpDescription pumpDescription = ConfigBuilderPlugin.getPlugin().getActivePump().getPumpDescription();
|
final PumpDescription pumpDescription =
|
||||||
|
ConfigBuilderPlugin.getPlugin().getActivePump().getPumpDescription();
|
||||||
if (!ProfileFunctions.getInstance().isProfileValid("ContexMenuCreation"))
|
if (!ProfileFunctions.getInstance().isProfileValid("ContexMenuCreation"))
|
||||||
return;
|
return;
|
||||||
menu.setHeaderTitle(MainApp.gs(R.string.loop));
|
menu.setHeaderTitle(MainApp.gs(R.string.loop));
|
||||||
|
@ -457,19 +458,23 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
menu.add(MainApp.gs(R.string.suspendloopfor2h));
|
menu.add(MainApp.gs(R.string.suspendloopfor2h));
|
||||||
menu.add(MainApp.gs(R.string.suspendloopfor3h));
|
menu.add(MainApp.gs(R.string.suspendloopfor3h));
|
||||||
menu.add(MainApp.gs(R.string.suspendloopfor10h));
|
menu.add(MainApp.gs(R.string.suspendloopfor10h));
|
||||||
if (pumpDescription.tempDurationStep15mAllowed)
|
} else {
|
||||||
menu.add(MainApp.gs(R.string.disconnectpumpfor15m));
|
if (!loopPlugin.isDisconnected()) {
|
||||||
if (pumpDescription.tempDurationStep30mAllowed)
|
menu.add(MainApp.gs(R.string.resume));
|
||||||
menu.add(MainApp.gs(R.string.disconnectpumpfor30m));
|
}
|
||||||
menu.add(MainApp.gs(R.string.disconnectpumpfor1h));
|
|
||||||
menu.add(MainApp.gs(R.string.disconnectpumpfor2h));
|
|
||||||
menu.add(MainApp.gs(R.string.disconnectpumpfor3h));
|
|
||||||
} else {
|
|
||||||
menu.add(MainApp.gs(R.string.resume));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!loopPlugin.isEnabled(PluginType.LOOP))
|
|
||||||
|
if (!loopPlugin.isEnabled(PluginType.LOOP)) {
|
||||||
menu.add(MainApp.gs(R.string.enableloop));
|
menu.add(MainApp.gs(R.string.enableloop));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!loopPlugin.isDisconnected()) {
|
||||||
|
showSuspendtPump(menu, pumpDescription);
|
||||||
|
} else {
|
||||||
|
menu.add(MainApp.gs(R.string.reconnect));
|
||||||
|
}
|
||||||
|
|
||||||
} else if (v == activeProfileView) {
|
} else if (v == activeProfileView) {
|
||||||
menu.setHeaderTitle(MainApp.gs(R.string.profile));
|
menu.setHeaderTitle(MainApp.gs(R.string.profile));
|
||||||
menu.add(MainApp.gs(R.string.danar_viewprofile));
|
menu.add(MainApp.gs(R.string.danar_viewprofile));
|
||||||
|
@ -488,6 +493,17 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void showSuspendtPump(ContextMenu menu,
|
||||||
|
PumpDescription pumpDescription) {
|
||||||
|
if (pumpDescription.tempDurationStep15mAllowed)
|
||||||
|
menu.add(MainApp.gs(R.string.disconnectpumpfor15m));
|
||||||
|
if (pumpDescription.tempDurationStep30mAllowed)
|
||||||
|
menu.add(MainApp.gs(R.string.disconnectpumpfor30m));
|
||||||
|
menu.add(MainApp.gs(R.string.disconnectpumpfor1h));
|
||||||
|
menu.add(MainApp.gs(R.string.disconnectpumpfor2h));
|
||||||
|
menu.add(MainApp.gs(R.string.disconnectpumpfor3h));
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onContextItemSelected(MenuItem item) {
|
public boolean onContextItemSelected(MenuItem item) {
|
||||||
final Profile profile = ProfileFunctions.getInstance().getProfile();
|
final Profile profile = ProfileFunctions.getInstance().getProfile();
|
||||||
|
@ -516,7 +532,8 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
updateGUI("suspendmenu");
|
updateGUI("suspendmenu");
|
||||||
NSUpload.uploadOpenAPSOffline(0);
|
NSUpload.uploadOpenAPSOffline(0);
|
||||||
return true;
|
return true;
|
||||||
} else if (item.getTitle().equals(MainApp.gs(R.string.resume))) {
|
} else if (item.getTitle().equals(MainApp.gs(R.string.resume)) ||
|
||||||
|
item.getTitle().equals(MainApp.gs(R.string.reconnect))) {
|
||||||
loopPlugin.suspendTo(0L);
|
loopPlugin.suspendTo(0L);
|
||||||
updateGUI("suspendmenu");
|
updateGUI("suspendmenu");
|
||||||
ConfigBuilderPlugin.getPlugin().getCommandQueue().cancelTempBasal(true, new Callback() {
|
ConfigBuilderPlugin.getPlugin().getCommandQueue().cancelTempBasal(true, new Callback() {
|
||||||
|
@ -1095,7 +1112,7 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
apsModeView.setBackgroundColor(MainApp.gc(R.color.looppumpsuspended));
|
apsModeView.setBackgroundColor(MainApp.gc(R.color.looppumpsuspended));
|
||||||
apsModeView.setText(String.format(MainApp.gs(R.string.loopsuperbolusfor), loopPlugin.minutesToEndOfSuspend()));
|
apsModeView.setText(String.format(MainApp.gs(R.string.loopsuperbolusfor), loopPlugin.minutesToEndOfSuspend()));
|
||||||
apsModeView.setTextColor(Color.WHITE);
|
apsModeView.setTextColor(Color.WHITE);
|
||||||
} else if (loopPlugin.isEnabled(PluginType.LOOP) && loopPlugin.isDisconnected()) {
|
} else if (loopPlugin.isDisconnected()) {
|
||||||
apsModeView.setBackgroundColor(MainApp.gc(R.color.looppumpsuspended));
|
apsModeView.setBackgroundColor(MainApp.gc(R.color.looppumpsuspended));
|
||||||
apsModeView.setText(String.format(MainApp.gs(R.string.loopdisconnectedfor), loopPlugin.minutesToEndOfSuspend()));
|
apsModeView.setText(String.format(MainApp.gs(R.string.loopdisconnectedfor), loopPlugin.minutesToEndOfSuspend()));
|
||||||
apsModeView.setTextColor(Color.WHITE);
|
apsModeView.setTextColor(Color.WHITE);
|
||||||
|
@ -1364,7 +1381,7 @@ public class OverviewFragment extends Fragment implements View.OnClickListener,
|
||||||
|
|
||||||
// Sensitivity
|
// Sensitivity
|
||||||
if (sensitivityView != null) {
|
if (sensitivityView != null) {
|
||||||
AutosensData autosensData = IobCobCalculatorPlugin.getPlugin().getLastAutosensDataSynchronized("Overview");
|
AutosensData autosensData = IobCobCalculatorPlugin.getPlugin().getLastAutosensData("Overview");
|
||||||
if (autosensData != null)
|
if (autosensData != null)
|
||||||
sensitivityView.setText(String.format("%.0f%%", autosensData.autosensResult.ratio * 100));
|
sensitivityView.setText(String.format("%.0f%%", autosensData.autosensResult.ratio * 100));
|
||||||
else
|
else
|
||||||
|
|
|
@ -68,6 +68,7 @@ public class Notification {
|
||||||
public static final int DEVICENOTPAIRED = 43;
|
public static final int DEVICENOTPAIRED = 43;
|
||||||
public static final int MEDTRONIC_PUMP_ALARM = 44;
|
public static final int MEDTRONIC_PUMP_ALARM = 44;
|
||||||
public static final int RILEYLINK_CONNECTION = 45;
|
public static final int RILEYLINK_CONNECTION = 45;
|
||||||
|
public static final int PERMISSION_PHONESTATE = 46;
|
||||||
|
|
||||||
public int id;
|
public int id;
|
||||||
public Date date;
|
public Date date;
|
||||||
|
|
|
@ -13,6 +13,14 @@ import android.os.Build;
|
||||||
import android.support.v4.app.NotificationCompat;
|
import android.support.v4.app.NotificationCompat;
|
||||||
import android.support.v4.app.TaskStackBuilder;
|
import android.support.v4.app.TaskStackBuilder;
|
||||||
|
|
||||||
|
// Android Auto
|
||||||
|
import android.support.v4.app.NotificationCompat;
|
||||||
|
import android.support.v4.app.NotificationManagerCompat;
|
||||||
|
import android.support.v4.app.RemoteInput;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import com.squareup.otto.Subscribe;
|
import com.squareup.otto.Subscribe;
|
||||||
|
|
||||||
import info.nightscout.androidaps.Config;
|
import info.nightscout.androidaps.Config;
|
||||||
|
@ -60,6 +68,18 @@ public class PersistentNotificationPlugin extends PluginBase {
|
||||||
public static final int ONGOING_NOTIFICATION_ID = 4711;
|
public static final int ONGOING_NOTIFICATION_ID = 4711;
|
||||||
private final Context ctx;
|
private final Context ctx;
|
||||||
|
|
||||||
|
/// For Android Auto
|
||||||
|
/// Intents are not declared in manifest and not consumed, this is intentionally because actually we can't do anything with
|
||||||
|
private static final String PACKAGE = "info.nightscout";
|
||||||
|
private static final String READ_ACTION =
|
||||||
|
"info.nightscout.androidaps.ACTION_MESSAGE_READ";
|
||||||
|
private static final String REPLY_ACTION =
|
||||||
|
"info.nightscout.androidaps.ACTION_MESSAGE_REPLY";
|
||||||
|
private static final String CONVERSATION_ID = "conversation_id";
|
||||||
|
private static final String EXTRA_VOICE_REPLY = "extra_voice_reply";
|
||||||
|
/// End Android Auto
|
||||||
|
|
||||||
|
|
||||||
public PersistentNotificationPlugin(Context ctx) {
|
public PersistentNotificationPlugin(Context ctx) {
|
||||||
super(new PluginDescription()
|
super(new PluginDescription()
|
||||||
.mainType(PluginType.GENERAL)
|
.mainType(PluginType.GENERAL)
|
||||||
|
@ -107,7 +127,8 @@ public class PersistentNotificationPlugin extends PluginBase {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String line1 = "";
|
String line1;
|
||||||
|
String line1_aa;
|
||||||
|
|
||||||
if (ConfigBuilderPlugin.getPlugin().getActiveProfileInterface() == null || !ProfileFunctions.getInstance().isProfileValid("Notificiation"))
|
if (ConfigBuilderPlugin.getPlugin().getActiveProfileInterface() == null || !ProfileFunctions.getInstance().isProfileValid("Notificiation"))
|
||||||
return null;
|
return null;
|
||||||
|
@ -118,22 +139,25 @@ public class PersistentNotificationPlugin extends PluginBase {
|
||||||
GlucoseStatus glucoseStatus = GlucoseStatus.getGlucoseStatusData();
|
GlucoseStatus glucoseStatus = GlucoseStatus.getGlucoseStatusData();
|
||||||
|
|
||||||
if (lastBG != null) {
|
if (lastBG != null) {
|
||||||
line1 = lastBG.valueToUnitsToString(units);
|
line1 = line1_aa = lastBG.valueToUnitsToString(units);
|
||||||
if (glucoseStatus != null) {
|
if (glucoseStatus != null) {
|
||||||
line1 += " Δ" + deltastring(glucoseStatus.delta, glucoseStatus.delta * Constants.MGDL_TO_MMOLL, units)
|
line1 += " Δ" + deltastring(glucoseStatus.delta, glucoseStatus.delta * Constants.MGDL_TO_MMOLL, units)
|
||||||
+ " avgΔ" + deltastring(glucoseStatus.avgdelta, glucoseStatus.avgdelta * Constants.MGDL_TO_MMOLL, units);
|
+ " avgΔ" + deltastring(glucoseStatus.avgdelta, glucoseStatus.avgdelta * Constants.MGDL_TO_MMOLL, units);
|
||||||
|
line1_aa += " " + lastBG.directionToSymbol();
|
||||||
} else {
|
} else {
|
||||||
line1 += " " +
|
line1 += " " +
|
||||||
MainApp.gs(R.string.old_data) +
|
MainApp.gs(R.string.old_data) +
|
||||||
" ";
|
" ";
|
||||||
|
line1_aa += line1 + ".";
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
line1 = MainApp.gs(R.string.missed_bg_readings);
|
line1 = line1_aa = MainApp.gs(R.string.missed_bg_readings);
|
||||||
}
|
}
|
||||||
|
|
||||||
TemporaryBasal activeTemp = TreatmentsPlugin.getPlugin().getTempBasalFromHistory(System.currentTimeMillis());
|
TemporaryBasal activeTemp = TreatmentsPlugin.getPlugin().getTempBasalFromHistory(System.currentTimeMillis());
|
||||||
if (activeTemp != null) {
|
if (activeTemp != null) {
|
||||||
line1 += " " + activeTemp.toStringShort();
|
line1 += " " + activeTemp.toStringShort();
|
||||||
|
line1_aa += " " + activeTemp.toStringShort() + ".";
|
||||||
}
|
}
|
||||||
|
|
||||||
//IOB
|
//IOB
|
||||||
|
@ -143,12 +167,55 @@ public class PersistentNotificationPlugin extends PluginBase {
|
||||||
IobTotal basalIob = TreatmentsPlugin.getPlugin().getLastCalculationTempBasals().round();
|
IobTotal basalIob = TreatmentsPlugin.getPlugin().getLastCalculationTempBasals().round();
|
||||||
|
|
||||||
|
|
||||||
String line2 = MainApp.gs(R.string.treatments_iob_label_string) + " " + DecimalFormatter.to2Decimal(bolusIob.iob + basalIob.basaliob) + "U " + MainApp.gs(R.string.cob)+": " + IobCobCalculatorPlugin.getPlugin().getCobInfo(false, "PersistentNotificationPlugin").generateCOBString();;
|
String line2 = MainApp.gs(R.string.treatments_iob_label_string) + " " + DecimalFormatter.to2Decimal(bolusIob.iob + basalIob.basaliob) + "U " + MainApp.gs(R.string.cob)+": " + IobCobCalculatorPlugin.getPlugin().getCobInfo(false, "PersistentNotificationPlugin").generateCOBString();
|
||||||
|
String line2_aa = MainApp.gs(R.string.treatments_iob_label_string) + " " + DecimalFormatter.to2Decimal(bolusIob.iob + basalIob.basaliob) + "U. " + MainApp.gs(R.string.cob)+": " + IobCobCalculatorPlugin.getPlugin().getCobInfo(false, "PersistentNotificationPlugin").generateCOBString() + ".";
|
||||||
|
|
||||||
|
|
||||||
String line3 = DecimalFormatter.to2Decimal(ConfigBuilderPlugin.getPlugin().getActivePump().getBaseBasalRate()) + " U/h";
|
String line3 = DecimalFormatter.to2Decimal(ConfigBuilderPlugin.getPlugin().getActivePump().getBaseBasalRate()) + " U/h";
|
||||||
|
String line3_aa = DecimalFormatter.to2Decimal(ConfigBuilderPlugin.getPlugin().getActivePump().getBaseBasalRate()) + " U/h.";
|
||||||
|
|
||||||
|
|
||||||
line3 += " - " + ProfileFunctions.getInstance().getProfileName();
|
line3 += " - " + ProfileFunctions.getInstance().getProfileName();
|
||||||
|
line3_aa += " - " + ProfileFunctions.getInstance().getProfileName() + ".";
|
||||||
|
|
||||||
|
/// For Android Auto
|
||||||
|
Intent msgReadIntent = new Intent()
|
||||||
|
.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES)
|
||||||
|
.setAction(READ_ACTION)
|
||||||
|
.putExtra(CONVERSATION_ID, ONGOING_NOTIFICATION_ID)
|
||||||
|
.setPackage(PACKAGE);
|
||||||
|
|
||||||
|
PendingIntent msgReadPendingIntent =
|
||||||
|
PendingIntent.getBroadcast(ctx,
|
||||||
|
ONGOING_NOTIFICATION_ID,
|
||||||
|
msgReadIntent,
|
||||||
|
PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
|
|
||||||
|
Intent msgReplyIntent = new Intent()
|
||||||
|
.addFlags(Intent.FLAG_INCLUDE_STOPPED_PACKAGES)
|
||||||
|
.setAction(REPLY_ACTION)
|
||||||
|
.putExtra(CONVERSATION_ID, ONGOING_NOTIFICATION_ID)
|
||||||
|
.setPackage(PACKAGE);
|
||||||
|
|
||||||
|
PendingIntent msgReplyPendingIntent = PendingIntent.getBroadcast(
|
||||||
|
ctx,
|
||||||
|
ONGOING_NOTIFICATION_ID,
|
||||||
|
msgReplyIntent,
|
||||||
|
PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
|
|
||||||
|
// Build a RemoteInput for receiving voice input from devices
|
||||||
|
RemoteInput remoteInput = new RemoteInput.Builder(EXTRA_VOICE_REPLY).build();
|
||||||
|
|
||||||
|
// Create the UnreadConversation
|
||||||
|
NotificationCompat.CarExtender.UnreadConversation.Builder unreadConversationBuilder =
|
||||||
|
new NotificationCompat.CarExtender.UnreadConversation.Builder(line1_aa + "\n" + line2_aa)
|
||||||
|
.setLatestTimestamp(System.currentTimeMillis())
|
||||||
|
.setReadPendingIntent(msgReadPendingIntent)
|
||||||
|
.setReplyAction(msgReplyPendingIntent, remoteInput);
|
||||||
|
|
||||||
|
/// Add dot to produce a "more natural sounding result"
|
||||||
|
unreadConversationBuilder.addMessage(line3_aa);
|
||||||
|
/// End Android Auto
|
||||||
|
|
||||||
|
|
||||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(ctx, CHANNEL_ID);
|
NotificationCompat.Builder builder = new NotificationCompat.Builder(ctx, CHANNEL_ID);
|
||||||
|
@ -167,6 +234,11 @@ public class PersistentNotificationPlugin extends PluginBase {
|
||||||
builder.setContentTitle(line1);
|
builder.setContentTitle(line1);
|
||||||
builder.setContentText(line2);
|
builder.setContentText(line2);
|
||||||
builder.setSubText(line3);
|
builder.setSubText(line3);
|
||||||
|
/// Android Auto
|
||||||
|
builder.extend(new NotificationCompat.CarExtender()
|
||||||
|
.setUnreadConversation(unreadConversationBuilder.build()));
|
||||||
|
/// End Android Auto
|
||||||
|
|
||||||
|
|
||||||
Intent resultIntent = new Intent(ctx, MainActivity.class);
|
Intent resultIntent = new Intent(ctx, MainActivity.class);
|
||||||
|
|
||||||
|
|
|
@ -156,7 +156,7 @@ public class LocalProfileFragment extends SubscriberFragment {
|
||||||
public String getSumLabel() {
|
public String getSumLabel() {
|
||||||
ProfileStore profile = LocalProfilePlugin.getPlugin().createProfileStore();
|
ProfileStore profile = LocalProfilePlugin.getPlugin().createProfileStore();
|
||||||
if (profile != null)
|
if (profile != null)
|
||||||
return " ∑" + DecimalFormatter.to2Decimal(profile.getDefaultProfile().baseBasalSum()) + "U";
|
return " ∑" + DecimalFormatter.to2Decimal(profile.getDefaultProfile().baseBasalSum()) + MainApp.gs(R.string.insulin_unit_shortname);
|
||||||
else
|
else
|
||||||
return MainApp.gs(R.string.localprofile);
|
return MainApp.gs(R.string.localprofile);
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,8 @@ public class NSProfileFragment extends SubscriberFragment {
|
||||||
TextView isf;
|
TextView isf;
|
||||||
@BindView(R.id.profileview_basal)
|
@BindView(R.id.profileview_basal)
|
||||||
TextView basal;
|
TextView basal;
|
||||||
|
@BindView(R.id.profileview_basaltotal)
|
||||||
|
TextView basaltotal;
|
||||||
@BindView(R.id.profileview_target)
|
@BindView(R.id.profileview_target)
|
||||||
TextView target;
|
TextView target;
|
||||||
@BindView(R.id.basal_graph)
|
@BindView(R.id.basal_graph)
|
||||||
|
@ -116,6 +118,7 @@ public class NSProfileFragment extends SubscriberFragment {
|
||||||
ic.setText(profile.getIcList());
|
ic.setText(profile.getIcList());
|
||||||
isf.setText(profile.getIsfList());
|
isf.setText(profile.getIsfList());
|
||||||
basal.setText(profile.getBasalList());
|
basal.setText(profile.getBasalList());
|
||||||
|
basaltotal.setText(String.format(MainApp.gs(R.string.profile_total), DecimalFormatter.to2Decimal(profile.baseBasalSum())));
|
||||||
target.setText(profile.getTargetList());
|
target.setText(profile.getTargetList());
|
||||||
basalGraph.show(profile);
|
basalGraph.show(profile);
|
||||||
}
|
}
|
||||||
|
@ -141,6 +144,7 @@ public class NSProfileFragment extends SubscriberFragment {
|
||||||
ic.setText("");
|
ic.setText("");
|
||||||
isf.setText("");
|
isf.setText("");
|
||||||
basal.setText("");
|
basal.setText("");
|
||||||
|
basaltotal.setText("");
|
||||||
target.setText("");
|
target.setText("");
|
||||||
activateButton.setVisibility(View.GONE);
|
activateButton.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,12 @@ public class DanaRS_Packet_APS_History_Events extends DanaRS_Packet {
|
||||||
public DanaRS_Packet_APS_History_Events(long from) {
|
public DanaRS_Packet_APS_History_Events(long from) {
|
||||||
this();
|
this();
|
||||||
GregorianCalendar cal = new GregorianCalendar();
|
GregorianCalendar cal = new GregorianCalendar();
|
||||||
|
|
||||||
|
if (from > DateUtil.now()) {
|
||||||
|
log.debug("Asked to load from the future");
|
||||||
|
from = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (from != 0)
|
if (from != 0)
|
||||||
cal.setTimeInMillis(from);
|
cal.setTimeInMillis(from);
|
||||||
else
|
else
|
||||||
|
|
|
@ -144,9 +144,9 @@ public class BLEComm {
|
||||||
|
|
||||||
if (L.isEnabled(L.PUMPBTCOMM))
|
if (L.isEnabled(L.PUMPBTCOMM))
|
||||||
log.debug("Trying to create a new connection from: " + from);
|
log.debug("Trying to create a new connection from: " + from);
|
||||||
|
mBluetoothDeviceName = device.getName();
|
||||||
mBluetoothGatt = device.connectGatt(service.getApplicationContext(), false, mGattCallback);
|
mBluetoothGatt = device.connectGatt(service.getApplicationContext(), false, mGattCallback);
|
||||||
setCharacteristicNotification(getUARTReadBTGattChar(), true);
|
setCharacteristicNotification(getUARTReadBTGattChar(), true);
|
||||||
mBluetoothDeviceName = device.getName();
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -663,7 +663,7 @@ public class BLEComm {
|
||||||
private void SendPumpCheck() {
|
private void SendPumpCheck() {
|
||||||
// 1st message sent to pump after connect
|
// 1st message sent to pump after connect
|
||||||
String devicename = getConnectDeviceName();
|
String devicename = getConnectDeviceName();
|
||||||
if(devicename == null || devicename == ""){
|
if(devicename == null || devicename.equals("")){
|
||||||
Notification n = new Notification(Notification.DEVICENOTPAIRED, MainApp.gs(R.string.pairfirst), Notification.URGENT);
|
Notification n = new Notification(Notification.DEVICENOTPAIRED, MainApp.gs(R.string.pairfirst), Notification.URGENT);
|
||||||
MainApp.bus().post(new EventNewNotification(n));
|
MainApp.bus().post(new EventNewNotification(n));
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -26,23 +26,30 @@ public class MsgHistoryEvents_v2 extends MessageBase {
|
||||||
|
|
||||||
public static long lastEventTimeLoaded = 0;
|
public static long lastEventTimeLoaded = 0;
|
||||||
|
|
||||||
public MsgHistoryEvents_v2(long from) {
|
public MsgHistoryEvents_v2() {
|
||||||
SetCommand(0xE003);
|
this(0);
|
||||||
GregorianCalendar gfrom = new GregorianCalendar();
|
|
||||||
gfrom.setTimeInMillis(from);
|
|
||||||
AddParamDate(gfrom);
|
|
||||||
done = false;
|
|
||||||
if (L.isEnabled(L.PUMPCOMM))
|
|
||||||
log.debug("New message");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public MsgHistoryEvents_v2() {
|
public MsgHistoryEvents_v2(long from) {
|
||||||
SetCommand(0xE003);
|
SetCommand(0xE003);
|
||||||
AddParamByte((byte) 0);
|
|
||||||
AddParamByte((byte) 1);
|
if (from > DateUtil.now()) {
|
||||||
AddParamByte((byte) 1);
|
log.debug("Asked to load from the future");
|
||||||
AddParamByte((byte) 0);
|
from = 0;
|
||||||
AddParamByte((byte) 0);
|
}
|
||||||
|
|
||||||
|
if (from == 0) {
|
||||||
|
AddParamByte((byte) 0);
|
||||||
|
AddParamByte((byte) 1);
|
||||||
|
AddParamByte((byte) 1);
|
||||||
|
AddParamByte((byte) 0);
|
||||||
|
AddParamByte((byte) 0);
|
||||||
|
} else {
|
||||||
|
GregorianCalendar gfrom = new GregorianCalendar();
|
||||||
|
gfrom.setTimeInMillis(from);
|
||||||
|
AddParamDate(gfrom);
|
||||||
|
}
|
||||||
|
|
||||||
done = false;
|
done = false;
|
||||||
if (L.isEnabled(L.PUMPCOMM))
|
if (L.isEnabled(L.PUMPCOMM))
|
||||||
log.debug("New message");
|
log.debug("New message");
|
||||||
|
|
|
@ -465,16 +465,10 @@ public class DanaRv2ExecutionService extends AbstractDanaRExecutionService {
|
||||||
if (!isConnected())
|
if (!isConnected())
|
||||||
return new PumpEnactResult().success(false);
|
return new PumpEnactResult().success(false);
|
||||||
SystemClock.sleep(300);
|
SystemClock.sleep(300);
|
||||||
MsgHistoryEvents_v2 msg;
|
MsgHistoryEvents_v2 msg = new MsgHistoryEvents_v2(lastHistoryFetched);
|
||||||
if (lastHistoryFetched == 0) {
|
if (L.isEnabled(L.PUMP))
|
||||||
msg = new MsgHistoryEvents_v2();
|
log.debug("Loading event history from: " + DateUtil.dateAndTimeFullString(lastHistoryFetched));
|
||||||
if (L.isEnabled(L.PUMP))
|
|
||||||
log.debug("Loading complete event history");
|
|
||||||
} else {
|
|
||||||
msg = new MsgHistoryEvents_v2(lastHistoryFetched);
|
|
||||||
if (L.isEnabled(L.PUMP))
|
|
||||||
log.debug("Loading event history from: " + DateUtil.dateAndTimeFullString(lastHistoryFetched));
|
|
||||||
}
|
|
||||||
mSerialIOThread.sendMessage(msg);
|
mSerialIOThread.sendMessage(msg);
|
||||||
while (!msg.done && mRfcommSocket.isConnected()) {
|
while (!msg.done && mRfcommSocket.isConnected()) {
|
||||||
SystemClock.sleep(100);
|
SystemClock.sleep(100);
|
||||||
|
|
|
@ -81,7 +81,7 @@ public class SWItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static LinearLayout generateLayout(View view) {
|
public static LinearLayout generateLayout(View view) {
|
||||||
LinearLayout layout = (LinearLayout) view.findViewById(view.getId());
|
LinearLayout layout = (LinearLayout) view;
|
||||||
layout.removeAllViews();
|
layout.removeAllViews();
|
||||||
return layout;
|
return layout;
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@ public class AndroidPermission {
|
||||||
public static final int CASE_SMS = 0x2;
|
public static final int CASE_SMS = 0x2;
|
||||||
public static final int CASE_LOCATION = 0x3;
|
public static final int CASE_LOCATION = 0x3;
|
||||||
public static final int CASE_BATTERY = 0x4;
|
public static final int CASE_BATTERY = 0x4;
|
||||||
|
public static final int CASE_PHONESTATE = 0x5;
|
||||||
|
|
||||||
public static void askForPermission(Activity activity, String[] permission, Integer requestCode) {
|
public static void askForPermission(Activity activity, String[] permission, Integer requestCode) {
|
||||||
boolean test = false;
|
boolean test = false;
|
||||||
|
@ -55,6 +56,16 @@ public class AndroidPermission {
|
||||||
} else
|
} else
|
||||||
MainApp.bus().post(new EventDismissNotification(Notification.PERMISSION_SMS));
|
MainApp.bus().post(new EventDismissNotification(Notification.PERMISSION_SMS));
|
||||||
}
|
}
|
||||||
|
// Following is a bug in Android 8
|
||||||
|
if (Build.VERSION.SDK_INT == Build.VERSION_CODES.O) {
|
||||||
|
if (!checkForPermission(activity, Manifest.permission.READ_PHONE_STATE)) {
|
||||||
|
NotificationWithAction notification = new NotificationWithAction(Notification.PERMISSION_PHONESTATE, MainApp.gs(R.string.smscommunicator_missingphonestatepermission), Notification.URGENT);
|
||||||
|
notification.action(MainApp.gs(R.string.request), () ->
|
||||||
|
AndroidPermission.askForPermission(activity, new String[]{Manifest.permission.READ_PHONE_STATE}, AndroidPermission.CASE_PHONESTATE));
|
||||||
|
MainApp.bus().post(new EventNewNotification(notification));
|
||||||
|
} else
|
||||||
|
MainApp.bus().post(new EventDismissNotification(Notification.PERMISSION_PHONESTATE));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ public class JsonHelper {
|
||||||
public static Object safeGetObject(JSONObject json, String fieldName, Object defaultValue) {
|
public static Object safeGetObject(JSONObject json, String fieldName, Object defaultValue) {
|
||||||
Object result = defaultValue;
|
Object result = defaultValue;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.get(fieldName);
|
result = json.get(fieldName);
|
||||||
} catch (JSONException ignored) {
|
} catch (JSONException ignored) {
|
||||||
|
@ -36,7 +36,7 @@ public class JsonHelper {
|
||||||
public static String safeGetString(JSONObject json, String fieldName) {
|
public static String safeGetString(JSONObject json, String fieldName) {
|
||||||
String result = null;
|
String result = null;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getString(fieldName);
|
result = json.getString(fieldName);
|
||||||
} catch (JSONException ignored) {
|
} catch (JSONException ignored) {
|
||||||
|
@ -49,7 +49,7 @@ public class JsonHelper {
|
||||||
public static String safeGetString(JSONObject json, String fieldName, String defaultValue) {
|
public static String safeGetString(JSONObject json, String fieldName, String defaultValue) {
|
||||||
String result = defaultValue;
|
String result = defaultValue;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getString(fieldName);
|
result = json.getString(fieldName);
|
||||||
} catch (JSONException ignored) {
|
} catch (JSONException ignored) {
|
||||||
|
@ -62,7 +62,7 @@ public class JsonHelper {
|
||||||
public static double safeGetDouble(JSONObject json, String fieldName) {
|
public static double safeGetDouble(JSONObject json, String fieldName) {
|
||||||
double result = 0d;
|
double result = 0d;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getDouble(fieldName);
|
result = json.getDouble(fieldName);
|
||||||
} catch (JSONException ignored) {
|
} catch (JSONException ignored) {
|
||||||
|
@ -75,7 +75,7 @@ public class JsonHelper {
|
||||||
public static int safeGetInt(JSONObject json, String fieldName) {
|
public static int safeGetInt(JSONObject json, String fieldName) {
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getInt(fieldName);
|
result = json.getInt(fieldName);
|
||||||
} catch (JSONException ignored) {
|
} catch (JSONException ignored) {
|
||||||
|
@ -88,7 +88,7 @@ public class JsonHelper {
|
||||||
public static long safeGetLong(JSONObject json, String fieldName) {
|
public static long safeGetLong(JSONObject json, String fieldName) {
|
||||||
long result = 0;
|
long result = 0;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getLong(fieldName);
|
result = json.getLong(fieldName);
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
|
@ -101,7 +101,7 @@ public class JsonHelper {
|
||||||
public static boolean safeGetBoolean(JSONObject json, String fieldName) {
|
public static boolean safeGetBoolean(JSONObject json, String fieldName) {
|
||||||
boolean result = false;
|
boolean result = false;
|
||||||
|
|
||||||
if (json.has(fieldName)) {
|
if (json != null && json.has(fieldName)) {
|
||||||
try {
|
try {
|
||||||
result = json.getBoolean(fieldName);
|
result = json.getBoolean(fieldName);
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
|
|
43
app/src/main/java/info/nightscout/utils/MidnightTime.java
Normal file
43
app/src/main/java/info/nightscout/utils/MidnightTime.java
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
package info.nightscout.utils;
|
||||||
|
|
||||||
|
import android.util.LongSparseArray;
|
||||||
|
|
||||||
|
import java.util.Calendar;
|
||||||
|
|
||||||
|
public class MidnightTime {
|
||||||
|
private static LongSparseArray times = new LongSparseArray();
|
||||||
|
|
||||||
|
private static long hits = 0;
|
||||||
|
private static long misses = 0;
|
||||||
|
|
||||||
|
public static long calc() {
|
||||||
|
Calendar c = Calendar.getInstance();
|
||||||
|
c.set(Calendar.HOUR_OF_DAY, 0);
|
||||||
|
c.set(Calendar.MINUTE, 0);
|
||||||
|
c.set(Calendar.SECOND, 0);
|
||||||
|
c.set(Calendar.MILLISECOND, 0);
|
||||||
|
return c.getTimeInMillis();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long calc(long time) {
|
||||||
|
Long m = (Long) times.get(time);
|
||||||
|
if (m != null) {
|
||||||
|
++hits;
|
||||||
|
return m;
|
||||||
|
}
|
||||||
|
Calendar c = Calendar.getInstance();
|
||||||
|
c.setTimeInMillis(time);
|
||||||
|
c.set(Calendar.HOUR_OF_DAY, 0);
|
||||||
|
c.set(Calendar.MINUTE, 0);
|
||||||
|
c.set(Calendar.SECOND, 0);
|
||||||
|
c.set(Calendar.MILLISECOND, 0);
|
||||||
|
m = c.getTimeInMillis();
|
||||||
|
times.append(time, m);
|
||||||
|
++misses;
|
||||||
|
return m;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String log() {
|
||||||
|
return "Hits: " + hits + " misses: " + misses + " stored: " + times.size();
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,23 +8,15 @@ import java.util.regex.Pattern;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class PercentageSplitter {
|
public class PercentageSplitter {
|
||||||
// "Profile name (200%,2h)"
|
// Matches "Profile name (200%,-2h)", "Profile name (50%)
|
||||||
private static final Pattern percentagePattern = Pattern.compile("(.+)\\(\\d+%,\\d+h\\)");
|
private static final Pattern splitPattern = Pattern.compile("(.+)\\(\\d+%(,-?\\d+h)?\\)");
|
||||||
// "Profile name (200%)"
|
|
||||||
private static final Pattern percentageShiftPattern = Pattern.compile("(.+)\\(\\d+%\\)");
|
|
||||||
|
|
||||||
/** Removes the suffix for percentage and timeshift from a profile name. */
|
/** Removes the suffix for percentage and timeshift from a profile name. This is the inverse of what
|
||||||
|
* {@link info.nightscout.androidaps.db.ProfileSwitch#getCustomizedName()} does.
|
||||||
|
* Since the customized name is used for the PS upload to NS, this is needed get the original profile name
|
||||||
|
* when retrieving the PS from NS again. */
|
||||||
public static String pureName(String name) {
|
public static String pureName(String name) {
|
||||||
Matcher percentageMatch = percentagePattern.matcher(name);
|
Matcher percentageMatch = splitPattern.matcher(name);
|
||||||
if (percentageMatch.find()) {
|
return percentageMatch.find() ? percentageMatch.group(1).trim() : name;
|
||||||
return percentageMatch.group(1).trim();
|
|
||||||
}
|
|
||||||
|
|
||||||
Matcher percentageShiftMatch = percentageShiftPattern.matcher(name);
|
|
||||||
if (percentageShiftMatch.find()) {
|
|
||||||
return percentageShiftMatch.group(1).trim();
|
|
||||||
}
|
|
||||||
|
|
||||||
return name;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -345,6 +345,42 @@
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="2"
|
||||||
|
android:gravity="end"
|
||||||
|
android:paddingRight="5dp"
|
||||||
|
android:text=""
|
||||||
|
android:textSize="14sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:layout_width="5dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="0"
|
||||||
|
android:gravity="center_horizontal"
|
||||||
|
android:paddingEnd="2dp"
|
||||||
|
android:paddingStart="2dp"
|
||||||
|
android:text=""
|
||||||
|
android:textSize="14sp" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/profileview_basaltotal"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:gravity="start"
|
||||||
|
android:paddingLeft="17dp"
|
||||||
|
android:textColor="@android:color/white"
|
||||||
|
android:textSize="14sp" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<info.nightscout.androidaps.plugins.Treatments.fragments.ProfileGraph
|
<info.nightscout.androidaps.plugins.Treatments.fragments.ProfileGraph
|
||||||
android:id="@+id/basal_graph"
|
android:id="@+id/basal_graph"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Waarskuwing W31: Kasset laag</string>
|
<string name="alert_w31">Waarskuwing W31: Kasset laag</string>
|
||||||
<string name="alert_w32">Waarskuwing W32: Battery laag</string>
|
<string name="alert_w32">Waarskuwing W32: Battery laag</string>
|
||||||
<string name="alert_w33">Waarskuwing W33: Ongeldige tyd/datum</string>
|
<string name="alert_w33">Waarskuwing W33: Ongeldige tyd/datum</string>
|
||||||
<string name="alert_w34">Waakskuwing W34: Einde van waarborg</string>
|
<string name="alert_w34">Waakskuwing W34: Einde van waarborg</string>
|
||||||
<string name="alert_w36">Waarskuwing W36: TBR gekanselleer</string>
|
<string name="alert_w36">Waarskuwing W36: TBR gekanselleer</string>
|
||||||
<string name="alert_w38">Waarskuwing W38: Bolus gekanselleer</string>
|
<string name="alert_w38">Waarskuwing W38: Bolus gekanselleer</string>
|
||||||
<string name="alert_w39">Waarskuwing W39: Leentyd waarskuwing</string>
|
<string name="alert_w39">Waarskuwing W39: Leentyd waarskuwing</string>
|
||||||
<string name="alert_m20">Onderhoud M20: Kasset nie ingevoeg</string>
|
<string name="alert_m20">Onderhoud M20: Kasset nie ingevoeg</string>
|
||||||
<string name="alert_m21">Onderhoud M21: kasset leeg</string>
|
<string name="alert_m21">Onderhoud M21: kasset leeg</string>
|
||||||
<string name="alert_m22">Onderhoud M22: Battery leeg</string>
|
<string name="alert_m22">Onderhoud M22: Battery leeg</string>
|
||||||
<string name="alert_m23">Onderhoud M23: Outomaties af</string>
|
<string name="alert_m23">Onderhoud M23: Outomaties af</string>
|
||||||
<string name="alert_m24">Onderhoud M24: verstopping</string>
|
<string name="alert_m24">Onderhoud M24: verstopping</string>
|
||||||
<string name="alert_m25">Onderhoud M25: Leentyd oor - einde van bewerking</string>
|
<string name="alert_m25">Onderhoud M25: Leentyd oor - einde van bewerking</string>
|
||||||
<string name="alert_m26">Onderhoud M26: Kasset-verandering nie voltooi nie</string>
|
<string name="alert_m26">Onderhoud M26: Kasset-verandering nie voltooi nie</string>
|
||||||
<string name="alert_m27">Onderhoud M27: Data aflaai het misluk</string>
|
<string name="alert_m27">Onderhoud M27: Data aflaai het misluk</string>
|
||||||
<string name="alert_m28">Onderhoud M28: Wag-modus uit tyd uit</string>
|
<string name="alert_m28">Onderhoud M28: Wag-modus uit tyd uit</string>
|
||||||
<string name="alert_m29">Onderhoud M29: Battery-tipe nie voltooi nie</string>
|
<string name="alert_m29">Onderhoud M29: Battery-tipe nie voltooi nie</string>
|
||||||
<string name="alert_m30">Onderhoud M30: Kasset-tipe nie voltooi nie</string>
|
<string name="alert_m30">Onderhoud M30: Kasset-tipe nie voltooi nie</string>
|
||||||
<string name="alert_e6">Fout E6: Meganiese fout</string>
|
<string name="alert_e6">Fout E6: Meganiese fout</string>
|
||||||
<string name="alert_e7">Fout E7: Elektroniese fout</string>
|
<string name="alert_e7">Fout E7: Elektroniese fout</string>
|
||||||
<string name="alert_e10">Fout E10: Terugdraai fout</string>
|
<string name="alert_e10">Fout E10: Terugdraai fout</string>
|
||||||
<string name="alert_e13">Fout E13: Taal fout</string>
|
<string name="alert_e13">Fout E13: Taal fout</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Предупреждение за W31: Празен резервоар</string>
|
<string name="alert_w31">Предупреждение за W31: Празен резервоар</string>
|
||||||
<string name="alert_w32">Предупреждение W32: Изтощена батерия</string>
|
<string name="alert_w32">Предупреждение W32: Изтощена батерия</string>
|
||||||
<string name="alert_w33">Предупреждение W33: Невалиден час/дата</string>
|
<string name="alert_w33">Предупреждение W33: Невалиден час/дата</string>
|
||||||
<string name="alert_w34">Предупреждение за W34: Край на гаранция</string>
|
<string name="alert_w34">Предупреждение за W34: Край на гаранция</string>
|
||||||
<string name="alert_w36">Предупреждение за W36: Временен базал отменен</string>
|
<string name="alert_w36">Предупреждение за W36: Временен базал отменен</string>
|
||||||
<string name="alert_w38">Предупреждение за W38: Болус отказан</string>
|
<string name="alert_w38">Предупреждение за W38: Болус отказан</string>
|
||||||
<string name="alert_w39">Предупреждение за W39: Loantime предупреждение</string>
|
<string name="alert_w39">Предупреждение за W39: Loantime предупреждение</string>
|
||||||
<string name="alert_m20">Поддръжка M20: Резервоарът не е поставен</string>
|
<string name="alert_m20">Поддръжка M20: Резервоарът не е поставен</string>
|
||||||
<string name="alert_m21">Поддръжка M21: Резервоарът е празен</string>
|
<string name="alert_m21">Поддръжка M21: Резервоарът е празен</string>
|
||||||
<string name="alert_m22">Поддръжка M22: Батерията е изтощена</string>
|
<string name="alert_m22">Поддръжка M22: Батерията е изтощена</string>
|
||||||
<string name="alert_m23">Поддръжка M23: Автоматично изключване</string>
|
<string name="alert_m23">Поддръжка M23: Автоматично изключване</string>
|
||||||
<string name="alert_m24">Поддръжка М24: Запушване</string>
|
<string name="alert_m24">Поддръжка М24: Запушване</string>
|
||||||
<string name="alert_m25">Поддръжка M25: Loantime приключи - край на операцията</string>
|
<string name="alert_m25">Поддръжка M25: Loantime приключи - край на операцията</string>
|
||||||
<string name="alert_m26">Поддръжка M26: Смяната на резервоар не е завършена</string>
|
<string name="alert_m26">Поддръжка M26: Смяната на резервоар не е завършена</string>
|
||||||
<string name="alert_m27">Поддръжка M27: Неуспешно изтегляне данни</string>
|
<string name="alert_m27">Поддръжка M27: Неуспешно изтегляне данни</string>
|
||||||
<string name="alert_m28">Поддръжка Месие 28: Режим пауза - таймаут</string>
|
<string name="alert_m28">Поддръжка Месие 28: Режим пауза - таймаут</string>
|
||||||
<string name="alert_m29">Поддръжка M29: Незададен тип батерия</string>
|
<string name="alert_m29">Поддръжка M29: Незададен тип батерия</string>
|
||||||
<string name="alert_m30">Поддръжка M30: Незададен тип резетвоар</string>
|
<string name="alert_m30">Поддръжка M30: Незададен тип резетвоар</string>
|
||||||
<string name="alert_e6">Грешка E6: Механична грешка</string>
|
<string name="alert_e6">Грешка E6: Механична грешка</string>
|
||||||
<string name="alert_e7">Грешка E7: Гешка в електрониката</string>
|
<string name="alert_e7">Грешка E7: Гешка в електрониката</string>
|
||||||
<string name="alert_e10">Грешка E10: Грешка в превъртането</string>
|
<string name="alert_e10">Грешка E10: Грешка в превъртането</string>
|
||||||
<string name="alert_e13">Грешка E13: Езикова грешка</string>
|
<string name="alert_e13">Грешка E13: Езикова грешка</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Varování W31: Zásobník</string>
|
<string name="alert_w31">Varování W31: Zásobník</string>
|
||||||
<string name="alert_w32">Varování W32: Nízký stav baterie</string>
|
<string name="alert_w32">Varování W32: Nízký stav baterie</string>
|
||||||
<string name="alert_w33">Varování W33: Neplatný čas/datum</string>
|
<string name="alert_w33">Varování W33: Neplatný čas/datum</string>
|
||||||
<string name="alert_w34">Varování W34: Konec záruky</string>
|
<string name="alert_w34">Varování W34: Konec záruky</string>
|
||||||
<string name="alert_w36">Varování W36: Dočasný bazál zrušen</string>
|
<string name="alert_w36">Varování W36: Dočasný bazál zrušen</string>
|
||||||
<string name="alert_w38">Varování W38: Bolus zrušen</string>
|
<string name="alert_w38">Varování W38: Bolus zrušen</string>
|
||||||
<string name="alert_w39">Varování W39: Varování doba výpůjčky</string>
|
<string name="alert_w39">Varování W39: Varování doba výpůjčky</string>
|
||||||
<string name="alert_m20">Údržba M20: Není vložen zásobník</string>
|
<string name="alert_m20">Údržba M20: Není vložen zásobník</string>
|
||||||
<string name="alert_m21">Údržba M21: Prázdný zásobník</string>
|
<string name="alert_m21">Údržba M21: Prázdný zásobník</string>
|
||||||
<string name="alert_m22">Údržba M22: Vybitá baterie</string>
|
<string name="alert_m22">Údržba M22: Vybitá baterie</string>
|
||||||
<string name="alert_m23">Údržba M23: Automatické vypnutí</string>
|
<string name="alert_m23">Údržba M23: Automatické vypnutí</string>
|
||||||
<string name="alert_m24">Údržba M24: Okluze</string>
|
<string name="alert_m24">Údržba M24: Okluze</string>
|
||||||
<string name="alert_m25">Údržba M25: Doba vypůjčení vypršela - ukončení provozu</string>
|
<string name="alert_m25">Údržba M25: Doba vypůjčení vypršela - ukončení provozu</string>
|
||||||
<string name="alert_m26">Údržba M26: Výměna zásobníku nedokončena</string>
|
<string name="alert_m26">Údržba M26: Výměna zásobníku nedokončena</string>
|
||||||
<string name="alert_m27">Údržba M27: Stahování se nezdařilo</string>
|
<string name="alert_m27">Údržba M27: Stahování se nezdařilo</string>
|
||||||
<string name="alert_m28">Údržba M28: Časový limit režimu pauza</string>
|
<string name="alert_m28">Údržba M28: Časový limit režimu pauza</string>
|
||||||
<string name="alert_m29">Údržba M29: Nenastavený typ baterie</string>
|
<string name="alert_m29">Údržba M29: Nenastavený typ baterie</string>
|
||||||
<string name="alert_m30">Údržba M30: Nenastavený typ zásobníku</string>
|
<string name="alert_m30">Údržba M30: Nenastavený typ zásobníku</string>
|
||||||
<string name="alert_e6">Chyba E6: Mechanická chyba</string>
|
<string name="alert_e6">Chyba E6: Mechanická chyba</string>
|
||||||
<string name="alert_e7">Chyba E7: Elektronická chyba</string>
|
<string name="alert_e7">Chyba E7: Elektronická chyba</string>
|
||||||
<string name="alert_e10">Chyba E10: Chyba převinutí</string>
|
<string name="alert_e10">Chyba E10: Chyba převinutí</string>
|
||||||
<string name="alert_e13">Chyba E13: Chyba jazyka</string>
|
<string name="alert_e13">Chyba E13: Chyba jazyka</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Warnung W31: Ampulle fast leer</string>
|
<string name="alert_w31">Warnung W31: Ampulle fast leer</string>
|
||||||
<string name="alert_w32">Warnung W32: Batterie fast leer</string>
|
<string name="alert_w32">Warnung W32: Batterie fast leer</string>
|
||||||
<string name="alert_w33">Warnung W33: Zeit/Datum ungültig</string>
|
<string name="alert_w33">Warnung W33: Zeit/Datum ungültig</string>
|
||||||
<string name="alert_w34">Warnung W34: Garantie abgelaufen</string>
|
<string name="alert_w34">Warnung W34: Garantie abgelaufen</string>
|
||||||
<string name="alert_w36">Warnung W36: TBR abgebrochen</string>
|
<string name="alert_w36">Warnung W36: TBR abgebrochen</string>
|
||||||
<string name="alert_w38">Warnung W38: Bolus abgebrochen</string>
|
<string name="alert_w38">Warnung W38: Bolus abgebrochen</string>
|
||||||
<string name="alert_w39">Warnung W39: Leihdauer-Warnung</string>
|
<string name="alert_w39">Warnung W39: Leihdauer-Warnung</string>
|
||||||
<string name="alert_m20">Wartung M20: Keine Ampulle eingesetzt</string>
|
<string name="alert_m20">Wartung M20: Keine Ampulle eingesetzt</string>
|
||||||
<string name="alert_m21">Wartung M21: Ampulle leer</string>
|
<string name="alert_m21">Wartung M21: Ampulle leer</string>
|
||||||
<string name="alert_m22">Wartung M22: Batterie leer</string>
|
<string name="alert_m22">Wartung M22: Batterie leer</string>
|
||||||
<string name="alert_m23">Wartung M23: Sicherheitsabschaltung</string>
|
<string name="alert_m23">Wartung M23: Sicherheitsabschaltung</string>
|
||||||
<string name="alert_m24">Wartung M24: Verstopfung</string>
|
<string name="alert_m24">Wartung M24: Verstopfung</string>
|
||||||
<string name="alert_m25">Wartung M25: Leihdauer abgelaufen</string>
|
<string name="alert_m25">Wartung M25: Leihdauer abgelaufen</string>
|
||||||
<string name="alert_m26">Wartung M26: Ampullenwechsel nicht abgeschlossen</string>
|
<string name="alert_m26">Wartung M26: Ampullenwechsel nicht abgeschlossen</string>
|
||||||
<string name="alert_m27">Wartung M27: Datenübertragung fehlgeschlagen</string>
|
<string name="alert_m27">Wartung M27: Datenübertragung fehlgeschlagen</string>
|
||||||
<string name="alert_m28">Wartung M28: Zeitüberschreitung bei Pause</string>
|
<string name="alert_m28">Wartung M28: Zeitüberschreitung bei Pause</string>
|
||||||
<string name="alert_m29">Wartung M29: Batterietyp nicht eingestellt</string>
|
<string name="alert_m29">Wartung M29: Batterietyp nicht eingestellt</string>
|
||||||
<string name="alert_m30">Wartung M30: Ampullentyp nicht eingestellt</string>
|
<string name="alert_m30">Wartung M30: Ampullentyp nicht eingestellt</string>
|
||||||
<string name="alert_e6">Fehler E6: Mechanikfehler</string>
|
<string name="alert_e6">Fehler E6: Mechanikfehler</string>
|
||||||
<string name="alert_e7">Fehler E7: Elektronikfehler</string>
|
<string name="alert_e7">Fehler E7: Elektronikfehler</string>
|
||||||
<string name="alert_e10">Fehler E10: Fehler beim Zurückfahren</string>
|
<string name="alert_e10">Fehler E10: Fehler beim Zurückfahren</string>
|
||||||
<string name="alert_e13">Fehler E13: Fehler in der Sprachanzeige</string>
|
<string name="alert_e13">Fehler E13: Fehler in der Sprachanzeige</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Ειδοποίηση W31: Χαμηλή αμπούλα</string>
|
<string name="alert_w31">Ειδοποίηση W31: Χαμηλή αμπούλα</string>
|
||||||
<string name="alert_w32">Ειδοποίηση W32: Χαμηλή μπαταρία</string>
|
<string name="alert_w32">Ειδοποίηση W32: Χαμηλή μπαταρία</string>
|
||||||
<string name="alert_w33">Ειδοποίηση W33: Μη έγκυρη ώρα/ημερομηνία</string>
|
<string name="alert_w33">Ειδοποίηση W33: Μη έγκυρη ώρα/ημερομηνία</string>
|
||||||
<string name="alert_w34">Ειδοποίηση W34: Λήξη εγγύησης</string>
|
<string name="alert_w34">Ειδοποίηση W34: Λήξη εγγύησης</string>
|
||||||
<string name="alert_w36">Ειδοποίηση W36: Ακύρωση TBR</string>
|
<string name="alert_w36">Ειδοποίηση W36: Ακύρωση TBR</string>
|
||||||
<string name="alert_w38">Ειδοποίηση W38: Ακύρωση bolus</string>
|
<string name="alert_w38">Ειδοποίηση W38: Ακύρωση bolus</string>
|
||||||
<string name="alert_w39">Ειδοποίηση W39: Ειδοποίηση διάρκειας</string>
|
<string name="alert_w39">Ειδοποίηση W39: Ειδοποίηση διάρκειας</string>
|
||||||
<string name="alert_m20">Συντήρηση M20: Η αμπούλα δεν έχει τοποθετηθεί</string>
|
<string name="alert_m20">Συντήρηση M20: Η αμπούλα δεν έχει τοποθετηθεί</string>
|
||||||
<string name="alert_m21">Συντήρηση M21: Αμπούλα άδεια</string>
|
<string name="alert_m21">Συντήρηση M21: Αμπούλα άδεια</string>
|
||||||
<string name="alert_m22">Συντήρηση M22: Μπαταρία άδεια</string>
|
<string name="alert_m22">Συντήρηση M22: Μπαταρία άδεια</string>
|
||||||
<string name="alert_m23">Συντήρηση Μ23: Αυτόματη απενεργοποίηση</string>
|
<string name="alert_m23">Συντήρηση Μ23: Αυτόματη απενεργοποίηση</string>
|
||||||
<string name="alert_m24">Συντήρηση M24: Έμφραξη</string>
|
<string name="alert_m24">Συντήρηση M24: Έμφραξη</string>
|
||||||
<string name="alert_m25">Συντήρηση M25: Διάρκεια τέλος - τέλος της λειτουργίας</string>
|
<string name="alert_m25">Συντήρηση M25: Διάρκεια τέλος - τέλος της λειτουργίας</string>
|
||||||
<string name="alert_m26">Συντήρηση M26: Η αλλαγή αμπούλας δεν έχει ολοκληρωθεί</string>
|
<string name="alert_m26">Συντήρηση M26: Η αλλαγή αμπούλας δεν έχει ολοκληρωθεί</string>
|
||||||
<string name="alert_m27">Συντήρηση Μ27: Απέτυχε η λήψη δεδομένων</string>
|
<string name="alert_m27">Συντήρηση Μ27: Απέτυχε η λήψη δεδομένων</string>
|
||||||
<string name="alert_m28">Συντήρηση M28: Λειτουργία παύσης έληξε</string>
|
<string name="alert_m28">Συντήρηση M28: Λειτουργία παύσης έληξε</string>
|
||||||
<string name="alert_m29">Συντήρηση M29: Ο τύπος μπαταρίας δεν ταιριάζει</string>
|
<string name="alert_m29">Συντήρηση M29: Ο τύπος μπαταρίας δεν ταιριάζει</string>
|
||||||
<string name="alert_m30">Συντήρηση M30: Ο τύπος αμπούλας δεν ταιριάζει</string>
|
<string name="alert_m30">Συντήρηση M30: Ο τύπος αμπούλας δεν ταιριάζει</string>
|
||||||
<string name="alert_e6">Σφάλμα Ε6: Μηχανικό σφάλμα</string>
|
<string name="alert_e6">Σφάλμα Ε6: Μηχανικό σφάλμα</string>
|
||||||
<string name="alert_e7">Σφάλμα Ε7: Ηλεκτρονικό σφάλμα</string>
|
<string name="alert_e7">Σφάλμα Ε7: Ηλεκτρονικό σφάλμα</string>
|
||||||
<string name="alert_e10">Σφάλματος E10: Σφάλμα Rewind</string>
|
<string name="alert_e10">Σφάλματος E10: Σφάλμα Rewind</string>
|
||||||
<string name="alert_e13">Σφάλματος E13: Λάθος γλώσσα</string>
|
<string name="alert_e13">Σφάλματος E13: Λάθος γλώσσα</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">ADVERTENCIA W31: Cartucho bajo</string>
|
<string name="alert_w31">ADVERTENCIA W31: Cartucho bajo</string>
|
||||||
<string name="alert_w32">ADVERTENCIA W32: Batería baja</string>
|
<string name="alert_w32">ADVERTENCIA W32: Batería baja</string>
|
||||||
<string name="alert_w33">ADVERTENCIA W33: Fecha/Hora no válida</string>
|
<string name="alert_w33">ADVERTENCIA W33: Fecha/Hora no válida</string>
|
||||||
<string name="alert_w34">ADVERTENCIA W34: Fin de la garantía</string>
|
<string name="alert_w34">ADVERTENCIA W34: Fin de la garantía</string>
|
||||||
<string name="alert_w36">ADVERTENCIA W36: TBR cancelada</string>
|
<string name="alert_w36">ADVERTENCIA W36: TBR cancelada</string>
|
||||||
<string name="alert_w38">ADVERTENCIA W38: Bolo cancelado</string>
|
<string name="alert_w38">ADVERTENCIA W38: Bolo cancelado</string>
|
||||||
<string name="alert_w39">W39 Advertencia: Advertencia de tiempo préstamo</string>
|
<string name="alert_w39">W39 Advertencia: Advertencia de tiempo préstamo</string>
|
||||||
<string name="alert_m20">Mantenimiento M20: Cartucho no insertado</string>
|
<string name="alert_m20">Mantenimiento M20: Cartucho no insertado</string>
|
||||||
<string name="alert_m21">Mantenimiento M21: Cartucho vacío</string>
|
<string name="alert_m21">Mantenimiento M21: Cartucho vacío</string>
|
||||||
<string name="alert_m22">Mantenimiento M22: Batería vacía</string>
|
<string name="alert_m22">Mantenimiento M22: Batería vacía</string>
|
||||||
<string name="alert_m23">Mantenimiento M23: Apagado automático</string>
|
<string name="alert_m23">Mantenimiento M23: Apagado automático</string>
|
||||||
<string name="alert_m24">Mantenimiento M24: oclusión</string>
|
<string name="alert_m24">Mantenimiento M24: oclusión</string>
|
||||||
<string name="alert_m25">Mantenimiento M25: Tiempo préstamo finalizado - final de la operación</string>
|
<string name="alert_m25">Mantenimiento M25: Tiempo préstamo finalizado - final de la operación</string>
|
||||||
<string name="alert_m26">Mantenimiento M26: Cambio de cartucho no completado</string>
|
<string name="alert_m26">Mantenimiento M26: Cambio de cartucho no completado</string>
|
||||||
<string name="alert_m27">Mantenimiento M27: Error de descarga de datos</string>
|
<string name="alert_m27">Mantenimiento M27: Error de descarga de datos</string>
|
||||||
<string name="alert_m28">Mantenimiento M28: Tiempo de espera vencido</string>
|
<string name="alert_m28">Mantenimiento M28: Tiempo de espera vencido</string>
|
||||||
<string name="alert_m29">Mantenimiento M29: Tipo de batería no establecido</string>
|
<string name="alert_m29">Mantenimiento M29: Tipo de batería no establecido</string>
|
||||||
<string name="alert_m30">Mantenimiento M30: Tipo cartucho no establecido</string>
|
<string name="alert_m30">Mantenimiento M30: Tipo cartucho no establecido</string>
|
||||||
<string name="alert_e6">Error E6: Error mecánico</string>
|
<string name="alert_e6">Error E6: Error mecánico</string>
|
||||||
<string name="alert_e7">Error E7: Error electrónico</string>
|
<string name="alert_e7">Error E7: Error electrónico</string>
|
||||||
<string name="alert_e10">Error E10: Error de rebobinado</string>
|
<string name="alert_e10">Error E10: Error de rebobinado</string>
|
||||||
<string name="alert_e13">Error E13: Error de lenguaje</string>
|
<string name="alert_e13">Error E13: Error de lenguaje</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Alerte W31 : Réservoir presque vide</string>
|
<string name="alert_w31">Alerte W31 : Réservoir presque vide</string>
|
||||||
<string name="alert_w32">Alerte W32 : Batterie presque déchargée</string>
|
<string name="alert_w32">Alerte W32 : Batterie presque déchargée</string>
|
||||||
<string name="alert_w33">Avertissement W33 : Heure/date non valides</string>
|
<string name="alert_w33">Avertissement W33 : Heure/date non valides</string>
|
||||||
<string name="alert_w34">Alerte W34 : Fin de garantie</string>
|
<string name="alert_w34">Alerte W34 : Fin de garantie</string>
|
||||||
<string name="alert_w36">Alerte W36 : TBR annulé</string>
|
<string name="alert_w36">Alerte W36 : TBR annulé</string>
|
||||||
<string name="alert_w38">Alerte W38 : Bolus annulé</string>
|
<string name="alert_w38">Alerte W38 : Bolus annulé</string>
|
||||||
<string name="alert_w39">Alerte W39 : Avertissement Loantime</string>
|
<string name="alert_w39">Alerte W39 : Avertissement Loantime</string>
|
||||||
<string name="alert_m20">Maintenance M20 : Cartouche pas inséré</string>
|
<string name="alert_m20">Maintenance M20 : Cartouche pas inséré</string>
|
||||||
<string name="alert_m21">Maintenance M21 : Cartouche vide</string>
|
<string name="alert_m21">Maintenance M21 : Cartouche vide</string>
|
||||||
<string name="alert_m22">Maintenance M22 : Batterie vide</string>
|
<string name="alert_m22">Maintenance M22 : Batterie vide</string>
|
||||||
<string name="alert_m23">Maintenance M23 : Arrêt automatique</string>
|
<string name="alert_m23">Maintenance M23 : Arrêt automatique</string>
|
||||||
<string name="alert_m24">Maintenance M24 : Occlusion</string>
|
<string name="alert_m24">Maintenance M24 : Occlusion</string>
|
||||||
<string name="alert_m25">Maintenance M25 : Loantime terminé - fin d’opération</string>
|
<string name="alert_m25">Maintenance M25 : Loantime terminé - fin d’opération</string>
|
||||||
<string name="alert_m26">Maintenance M26 : Changement de cartouche non terminé</string>
|
<string name="alert_m26">Maintenance M26 : Changement de cartouche non terminé</string>
|
||||||
<string name="alert_m27">Maintenance M27 : Le téléchargement de données a échoué</string>
|
<string name="alert_m27">Maintenance M27 : Le téléchargement de données a échoué</string>
|
||||||
<string name="alert_m28">Maintenance M28 : Pause mode timeout</string>
|
<string name="alert_m28">Maintenance M28 : Pause mode timeout</string>
|
||||||
<string name="alert_m29">Maintenance M29 : Type de batterie non défini</string>
|
<string name="alert_m29">Maintenance M29 : Type de batterie non défini</string>
|
||||||
<string name="alert_m30">Maintenance M30 : Réservoir type non défini</string>
|
<string name="alert_m30">Maintenance M30 : Réservoir type non défini</string>
|
||||||
<string name="alert_e6">Erreur E6 : Problème mécanique</string>
|
<string name="alert_e6">Erreur E6 : Problème mécanique</string>
|
||||||
<string name="alert_e7">Erreur E7 : Problème d\'électronique</string>
|
<string name="alert_e7">Erreur E7 : Problème d\'électronique</string>
|
||||||
<string name="alert_e10">Erreur E10 : Erreur de rembobinage</string>
|
<string name="alert_e10">Erreur E10 : Erreur de rembobinage</string>
|
||||||
<string name="alert_e13">Erreur E13 : Erreur de langage</string>
|
<string name="alert_e13">Erreur E13 : Erreur de langage</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,12 +1,12 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="nav_refreshtreatments">רענן טיפול מ-Nightscout</string>
|
<string name="nav_refreshtreatments">רענן טיפול מ-Nightscout</string>
|
||||||
<string name="danar_useextended_title">השתמש בבולוס מורחב של 200%</string>
|
<string name="danar_useextended_title">השתמש בבולוס מורחב של 200%</string>
|
||||||
<string name="alert_dialog_storage_permission_text">בבקשה אתחל את הסמרטפון שלך או תרענן את אפלקצית AndroidAPS בהגדרות המערכת
|
<string name="alert_dialog_storage_permission_text">בבקשה אתחל את הסמרטפון שלך או תרענן את אפלקצית AndroidAPS בהגדרות המערכת
|
||||||
אחרת AndroidAPS לא יוכל לבצע רישום (חשוב לעקוב אחר ולוודא כי האלגוריתמים פועלים כראוי)!</string>
|
אחרת AndroidAPS לא יוכל לבצע רישום (חשוב לעקוב אחר ולוודא כי האלגוריתמים פועלים כראוי)!</string>
|
||||||
<string name="description_food">מציג את ההגדרות הקבועות מראש עבור מזון המוגדר ב-Nightscout</string>
|
<string name="description_food">מציג את ההגדרות הקבועות מראש עבור מזון המוגדר ב-Nightscout</string>
|
||||||
<string name="description_loop">להפעיל או לכבות את הלולאה.</string>
|
<string name="description_loop">להפעיל או לכבות את הלולאה.</string>
|
||||||
<string name="description_ns_client">מסנכרן את הנתונים שלך עם Nightscout</string>
|
<string name="description_ns_client">מסנכרן את הנתונים שלך עם Nightscout</string>
|
||||||
<string name="description_profile_nightscout">יבא פרופיל מ- Nightscout</string>
|
<string name="description_profile_nightscout">יבא פרופיל מ- Nightscout</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Avviso W31: Cartuccia in esaurimento</string>
|
<string name="alert_w31">Avviso W31: Cartuccia in esaurimento</string>
|
||||||
<string name="alert_w32">Avviso W32: Batteria bassa</string>
|
<string name="alert_w32">Avviso W32: Batteria bassa</string>
|
||||||
<string name="alert_w33">W33 avviso: Data/ora non valido</string>
|
<string name="alert_w33">W33 avviso: Data/ora non valido</string>
|
||||||
<string name="alert_w34">W34 avviso: Fine della garanzia</string>
|
<string name="alert_w34">W34 avviso: Fine della garanzia</string>
|
||||||
<string name="alert_w36">Avviso W36: TBR annullato</string>
|
<string name="alert_w36">Avviso W36: TBR annullato</string>
|
||||||
<string name="alert_w38">Avviso W38: Bolo annullato</string>
|
<string name="alert_w38">Avviso W38: Bolo annullato</string>
|
||||||
<string name="alert_w39">Avviso W39: Avviso Loantime</string>
|
<string name="alert_w39">Avviso W39: Avviso Loantime</string>
|
||||||
<string name="alert_m20">Manutenzione M20: Cartuccia non inserita</string>
|
<string name="alert_m20">Manutenzione M20: Cartuccia non inserita</string>
|
||||||
<string name="alert_m21">Manutenzione M21: Cartuccia vuota</string>
|
<string name="alert_m21">Manutenzione M21: Cartuccia vuota</string>
|
||||||
<string name="alert_m22">Manutenzione M22: Batteria scarica</string>
|
<string name="alert_m22">Manutenzione M22: Batteria scarica</string>
|
||||||
<string name="alert_m23">Manutenzione M23: Spegnimento automatico</string>
|
<string name="alert_m23">Manutenzione M23: Spegnimento automatico</string>
|
||||||
<string name="alert_m24">Manutenzione M24: occlusione</string>
|
<string name="alert_m24">Manutenzione M24: occlusione</string>
|
||||||
<string name="alert_m25">Manutenzione M25: Loantime sopra - fine dell\'operazione</string>
|
<string name="alert_m25">Manutenzione M25: Loantime sopra - fine dell\'operazione</string>
|
||||||
<string name="alert_m26">Manutenzione M26: Sostituzione cartuccia non completata</string>
|
<string name="alert_m26">Manutenzione M26: Sostituzione cartuccia non completata</string>
|
||||||
<string name="alert_m27">Manutenzione M27: Download dati fallito</string>
|
<string name="alert_m27">Manutenzione M27: Download dati fallito</string>
|
||||||
<string name="alert_m28">Manutenzione M28: Timeout modalità pausa</string>
|
<string name="alert_m28">Manutenzione M28: Timeout modalità pausa</string>
|
||||||
<string name="alert_m29">Manutenzione M29: Tipo di batteria non impostata</string>
|
<string name="alert_m29">Manutenzione M29: Tipo di batteria non impostata</string>
|
||||||
<string name="alert_m30">Manutenzione M30: Tipo di cartuccia non impostata</string>
|
<string name="alert_m30">Manutenzione M30: Tipo di cartuccia non impostata</string>
|
||||||
<string name="alert_e6">Errore E6: Errore meccanico</string>
|
<string name="alert_e6">Errore E6: Errore meccanico</string>
|
||||||
<string name="alert_e7">E7 errore: Errore elettronico</string>
|
<string name="alert_e7">E7 errore: Errore elettronico</string>
|
||||||
<string name="alert_e10">Errore E10: Errore Rewind</string>
|
<string name="alert_e10">Errore E10: Errore Rewind</string>
|
||||||
<string name="alert_e13">Errore E13: Errore lingua</string>
|
<string name="alert_e13">Errore E13: Errore lingua</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
3
app/src/main/res/values-ja/insight_alerts.xml
Normal file
3
app/src/main/res/values-ja/insight_alerts.xml
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--Generated by crowdin.com-->
|
||||||
|
<resources></resources>
|
3
app/src/main/res/values-ja/strings.xml
Normal file
3
app/src/main/res/values-ja/strings.xml
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--Generated by crowdin.com-->
|
||||||
|
<resources></resources>
|
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">경고 W31: 주사기양 낮음</string>
|
<string name="alert_w31">경고 W31: 주사기양 낮음</string>
|
||||||
<string name="alert_w32">경고 W32: 배터리양 낮음</string>
|
<string name="alert_w32">경고 W32: 배터리양 낮음</string>
|
||||||
<string name="alert_w33">경고 W33: 시간/날짜 유효하지 않음</string>
|
<string name="alert_w33">경고 W33: 시간/날짜 유효하지 않음</string>
|
||||||
<string name="alert_w34">경고 W34: 보증만료</string>
|
<string name="alert_w34">경고 W34: 보증만료</string>
|
||||||
<string name="alert_w36">경고 W36: 임시Basal 취소</string>
|
<string name="alert_w36">경고 W36: 임시Basal 취소</string>
|
||||||
<string name="alert_w38">경고 W38: Bolus 취소</string>
|
<string name="alert_w38">경고 W38: Bolus 취소</string>
|
||||||
<string name="alert_w39">경고 W39: Loantime 경고</string>
|
<string name="alert_w39">경고 W39: Loantime 경고</string>
|
||||||
<string name="alert_m20">정비 M20: 주사기가 삽입되지 않았습니다.</string>
|
<string name="alert_m20">정비 M20: 주사기가 삽입되지 않았습니다.</string>
|
||||||
<string name="alert_m21">정비 M21: 주사기가 비었습니다.</string>
|
<string name="alert_m21">정비 M21: 주사기가 비었습니다.</string>
|
||||||
<string name="alert_m22">정비 M22: 배터리가 방전되었습니다.</string>
|
<string name="alert_m22">정비 M22: 배터리가 방전되었습니다.</string>
|
||||||
<string name="alert_m23">정비 M23: 자동 OFF</string>
|
<string name="alert_m23">정비 M23: 자동 OFF</string>
|
||||||
<string name="alert_m24">정비 M24: 막힘</string>
|
<string name="alert_m24">정비 M24: 막힘</string>
|
||||||
<string name="alert_m25">정비 M25: Loantime 종료 - 작업 종료</string>
|
<string name="alert_m25">정비 M25: Loantime 종료 - 작업 종료</string>
|
||||||
<string name="alert_m26">정비 M26: 주사기 교체가 완료되지 않았습니다.</string>
|
<string name="alert_m26">정비 M26: 주사기 교체가 완료되지 않았습니다.</string>
|
||||||
<string name="alert_m27">정비 M27: 데이터 다운로드가 실패하였습니다.</string>
|
<string name="alert_m27">정비 M27: 데이터 다운로드가 실패하였습니다.</string>
|
||||||
<string name="alert_m28">정비 M28: 일시정지모드 시간만료</string>
|
<string name="alert_m28">정비 M28: 일시정지모드 시간만료</string>
|
||||||
<string name="alert_m29">정비 M29: 배터리 타입이 설정되지 않았습니다.</string>
|
<string name="alert_m29">정비 M29: 배터리 타입이 설정되지 않았습니다.</string>
|
||||||
<string name="alert_m30">정비 M30: 주사기 타입이 설정되지 않았습니다.</string>
|
<string name="alert_m30">정비 M30: 주사기 타입이 설정되지 않았습니다.</string>
|
||||||
<string name="alert_e6">에러 E6: 기계적 에러</string>
|
<string name="alert_e6">에러 E6: 기계적 에러</string>
|
||||||
<string name="alert_e7">에러 E7: 전기적 에러</string>
|
<string name="alert_e7">에러 E7: 전기적 에러</string>
|
||||||
<string name="alert_e10">에러 E10: Rewind 에러</string>
|
<string name="alert_e10">에러 E10: Rewind 에러</string>
|
||||||
<string name="alert_e13">에러 E13: 언어 에러</string>
|
<string name="alert_e13">에러 E13: 언어 에러</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Waarschuwing W31: Cartridge bijna leeg</string>
|
<string name="alert_w31">Waarschuwing W31: Cartridge bijna leeg</string>
|
||||||
<string name="alert_w32">Waarschuwing W32: Batterij bijna leeg</string>
|
<string name="alert_w32">Waarschuwing W32: Batterij bijna leeg</string>
|
||||||
<string name="alert_w33">Waarschuwing W33: Onjuiste tijd/datum</string>
|
<string name="alert_w33">Waarschuwing W33: Onjuiste tijd/datum</string>
|
||||||
<string name="alert_w34">Waarschuwing W34: Einde van garantie</string>
|
<string name="alert_w34">Waarschuwing W34: Einde van garantie</string>
|
||||||
<string name="alert_w36">Waarschuwing W36: TBR geannuleerd</string>
|
<string name="alert_w36">Waarschuwing W36: TBR geannuleerd</string>
|
||||||
<string name="alert_w38">Waarschuwing W38: Bolus geannuleerd</string>
|
<string name="alert_w38">Waarschuwing W38: Bolus geannuleerd</string>
|
||||||
<string name="alert_w39">Waarschuwing W39: Leentijd waarschuwing</string>
|
<string name="alert_w39">Waarschuwing W39: Leentijd waarschuwing</string>
|
||||||
<string name="alert_m20">Onderhoud M20: Cartridge niet geplaatst</string>
|
<string name="alert_m20">Onderhoud M20: Cartridge niet geplaatst</string>
|
||||||
<string name="alert_m21">Onderhoud M21: Cartridge leeg</string>
|
<string name="alert_m21">Onderhoud M21: Cartridge leeg</string>
|
||||||
<string name="alert_m22">Onderhoud M22: Batterij leeg</string>
|
<string name="alert_m22">Onderhoud M22: Batterij leeg</string>
|
||||||
<string name="alert_m23">Onderhoud M23: Automatisch uit</string>
|
<string name="alert_m23">Onderhoud M23: Automatisch uit</string>
|
||||||
<string name="alert_m24">Onderhoud M24: Verstopping</string>
|
<string name="alert_m24">Onderhoud M24: Verstopping</string>
|
||||||
<string name="alert_m25">Onderhoud M25: Leentijd verstreken - werking geëindigd</string>
|
<string name="alert_m25">Onderhoud M25: Leentijd verstreken - werking geëindigd</string>
|
||||||
<string name="alert_m26">Onderhoud M26: Cartridge verwisselen niet afgerond</string>
|
<string name="alert_m26">Onderhoud M26: Cartridge verwisselen niet afgerond</string>
|
||||||
<string name="alert_m27">Onderhoud M27: Data download mislukt</string>
|
<string name="alert_m27">Onderhoud M27: Data download mislukt</string>
|
||||||
<string name="alert_m28">Onderhoud M28: Pauze modus timeout</string>
|
<string name="alert_m28">Onderhoud M28: Pauze modus timeout</string>
|
||||||
<string name="alert_m29">Onderhoud M29: Batterij type niet ingesteld</string>
|
<string name="alert_m29">Onderhoud M29: Batterij type niet ingesteld</string>
|
||||||
<string name="alert_m30">Onderhoud M30: Cartridge type niet ingesteld</string>
|
<string name="alert_m30">Onderhoud M30: Cartridge type niet ingesteld</string>
|
||||||
<string name="alert_e6">Fout E6: Mechanische fout</string>
|
<string name="alert_e6">Fout E6: Mechanische fout</string>
|
||||||
<string name="alert_e7">Fout E7: Elektronische fout</string>
|
<string name="alert_e7">Fout E7: Elektronische fout</string>
|
||||||
<string name="alert_e10">Fout E10: Terugdraaien fout</string>
|
<string name="alert_e10">Fout E10: Terugdraaien fout</string>
|
||||||
<string name="alert_e13">Fout E13: Taal fout</string>
|
<string name="alert_e13">Fout E13: Taal fout</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Ostrzeżenie W31: Niski poziom insuliny</string>
|
<string name="alert_w31">Ostrzeżenie W31: Niski poziom insuliny</string>
|
||||||
<string name="alert_w32">Ostrzeżenie W32: Niski stan baterii</string>
|
<string name="alert_w32">Ostrzeżenie W32: Niski stan baterii</string>
|
||||||
<string name="alert_w33">Ostrzeżenie W33: Nieprawidłowa godzina/data</string>
|
<string name="alert_w33">Ostrzeżenie W33: Nieprawidłowa godzina/data</string>
|
||||||
<string name="alert_w34">Ostrzeżenie W34: Koniec gwarancji</string>
|
<string name="alert_w34">Ostrzeżenie W34: Koniec gwarancji</string>
|
||||||
<string name="alert_w36">Ostrzeżenie W36: Anulowana baza tymczasowa [TBR]</string>
|
<string name="alert_w36">Ostrzeżenie W36: Anulowana baza tymczasowa [TBR]</string>
|
||||||
<string name="alert_w38">Ostrzeżenie W38: Bolus anulowany</string>
|
<string name="alert_w38">Ostrzeżenie W38: Bolus anulowany</string>
|
||||||
<string name="alert_w39">Ostrzeżenie W39: ostrzeżenie o użyczonym/przyznanym czasie</string>
|
<string name="alert_w39">Ostrzeżenie W39: ostrzeżenie o użyczonym/przyznanym czasie</string>
|
||||||
<string name="alert_m20">Konserwacja M20: Brak pojemnika na isulinę</string>
|
<string name="alert_m20">Konserwacja M20: Brak pojemnika na isulinę</string>
|
||||||
<string name="alert_m21">Konserwacja M21: Pusty zbiornik na insulinę</string>
|
<string name="alert_m21">Konserwacja M21: Pusty zbiornik na insulinę</string>
|
||||||
<string name="alert_m22">Konserwacja M22: Koniec baterii</string>
|
<string name="alert_m22">Konserwacja M22: Koniec baterii</string>
|
||||||
<string name="alert_m23">Konserwacja M23: Wyłącz automatycznie</string>
|
<string name="alert_m23">Konserwacja M23: Wyłącz automatycznie</string>
|
||||||
<string name="alert_m24">Konserwacja M24: Niedrożność</string>
|
<string name="alert_m24">Konserwacja M24: Niedrożność</string>
|
||||||
<string name="alert_m25">Obsługa M25: koniec użyczonego czasu - koniec działania</string>
|
<string name="alert_m25">Obsługa M25: koniec użyczonego czasu - koniec działania</string>
|
||||||
<string name="alert_m26">Konserwacja M26: Nie zakończono wymiany zbiornika</string>
|
<string name="alert_m26">Konserwacja M26: Nie zakończono wymiany zbiornika</string>
|
||||||
<string name="alert_m27">Konserwacja M27: Błąd pobierania danych</string>
|
<string name="alert_m27">Konserwacja M27: Błąd pobierania danych</string>
|
||||||
<string name="alert_m28">Obsługa M28: koniec czasu trybu pauza</string>
|
<string name="alert_m28">Obsługa M28: koniec czasu trybu pauza</string>
|
||||||
<string name="alert_m29">Konserwacja M29: Nie wybrano rodzaju baterii</string>
|
<string name="alert_m29">Konserwacja M29: Nie wybrano rodzaju baterii</string>
|
||||||
<string name="alert_m30">Konserwacja M30: Nie ustawiono rodzaju pojemnika</string>
|
<string name="alert_m30">Konserwacja M30: Nie ustawiono rodzaju pojemnika</string>
|
||||||
<string name="alert_e6">Błąd E6: Usterka mechaniczna</string>
|
<string name="alert_e6">Błąd E6: Usterka mechaniczna</string>
|
||||||
<string name="alert_e7">Błąd E7: Usterka elektroniczna</string>
|
<string name="alert_e7">Błąd E7: Usterka elektroniczna</string>
|
||||||
<string name="alert_e10">Błąd E10: Usterka przewijania</string>
|
<string name="alert_e10">Błąd E10: Usterka przewijania</string>
|
||||||
<string name="alert_e13">Błąd E6: Błąd języka</string>
|
<string name="alert_e13">Błąd E6: Błąd języka</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Alerta W31: Cartucho com pouca insulina</string>
|
<string name="alert_w31">Alerta W31: Cartucho com pouca insulina</string>
|
||||||
<string name="alert_w32">Aviso W32: Bateria baixa</string>
|
<string name="alert_w32">Aviso W32: Bateria baixa</string>
|
||||||
<string name="alert_w33">Aviso W33: Data/hora inválida</string>
|
<string name="alert_w33">Aviso W33: Data/hora inválida</string>
|
||||||
<string name="alert_w34">Aviso W34: Fim da garantia</string>
|
<string name="alert_w34">Aviso W34: Fim da garantia</string>
|
||||||
<string name="alert_w36">W36 aviso: DTB cancelada</string>
|
<string name="alert_w36">W36 aviso: DTB cancelada</string>
|
||||||
<string name="alert_w38">Aviso W38: Bolus cancelado</string>
|
<string name="alert_w38">Aviso W38: Bolus cancelado</string>
|
||||||
<string name="alert_w39">Alerta W39: Alerta Tempo de Empréstimo</string>
|
<string name="alert_w39">Alerta W39: Alerta Tempo de Empréstimo</string>
|
||||||
<string name="alert_m20">Manutenção M20: Cartucho não inserido</string>
|
<string name="alert_m20">Manutenção M20: Cartucho não inserido</string>
|
||||||
<string name="alert_m21">Manutenção M21: Cartucho vazio</string>
|
<string name="alert_m21">Manutenção M21: Cartucho vazio</string>
|
||||||
<string name="alert_m22">Manutenção M22: Bateria vazia</string>
|
<string name="alert_m22">Manutenção M22: Bateria vazia</string>
|
||||||
<string name="alert_m23">Manutenção M23: Desligar automático</string>
|
<string name="alert_m23">Manutenção M23: Desligar automático</string>
|
||||||
<string name="alert_m24">Manutenção M24: Oclusão</string>
|
<string name="alert_m24">Manutenção M24: Oclusão</string>
|
||||||
<string name="alert_m25">Manutenção M25: Tempo de empréstimo expirado - operação finalizada</string>
|
<string name="alert_m25">Manutenção M25: Tempo de empréstimo expirado - operação finalizada</string>
|
||||||
<string name="alert_m26">Manutenção M26: Mudança de cartucho não concluída</string>
|
<string name="alert_m26">Manutenção M26: Mudança de cartucho não concluída</string>
|
||||||
<string name="alert_m27">Manutenção M27: Transferência de dados falhada</string>
|
<string name="alert_m27">Manutenção M27: Transferência de dados falhada</string>
|
||||||
<string name="alert_m28">Manutenção M28: Tempo pausa expirado</string>
|
<string name="alert_m28">Manutenção M28: Tempo pausa expirado</string>
|
||||||
<string name="alert_m29">Manutenção M29: Tipo de bateria não definido</string>
|
<string name="alert_m29">Manutenção M29: Tipo de bateria não definido</string>
|
||||||
<string name="alert_m30">Manutenção M30: Tipo de cartucho não definido</string>
|
<string name="alert_m30">Manutenção M30: Tipo de cartucho não definido</string>
|
||||||
<string name="alert_e6">E6 de erro: Erro mecânico</string>
|
<string name="alert_e6">E6 de erro: Erro mecânico</string>
|
||||||
<string name="alert_e7">E7 de erro: Erro electrónico</string>
|
<string name="alert_e7">E7 de erro: Erro electrónico</string>
|
||||||
<string name="alert_e10">Erro E10: Erro a recuar embolo</string>
|
<string name="alert_e10">Erro E10: Erro a recuar embolo</string>
|
||||||
<string name="alert_e13">E13 de erro: Erro de idioma</string>
|
<string name="alert_e13">E13 de erro: Erro de idioma</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Atenționarea W31: rezervor pe terminate</string>
|
<string name="alert_w31">Atenționarea W31: rezervor pe terminate</string>
|
||||||
<string name="alert_w32">Atenționarea W32: baterie pe terminate</string>
|
<string name="alert_w32">Atenționarea W32: baterie pe terminate</string>
|
||||||
<string name="alert_w33">Atenționarea W33: Timp/dată invalide</string>
|
<string name="alert_w33">Atenționarea W33: Timp/dată invalide</string>
|
||||||
<string name="alert_w34">Atenționarea W34: Sfârșitul perioadei de garanție</string>
|
<string name="alert_w34">Atenționarea W34: Sfârșitul perioadei de garanție</string>
|
||||||
<string name="alert_w36">Atenționarea W36: RBT anulată</string>
|
<string name="alert_w36">Atenționarea W36: RBT anulată</string>
|
||||||
<string name="alert_w38">Atenționarea W38: Bolus anulat</string>
|
<string name="alert_w38">Atenționarea W38: Bolus anulat</string>
|
||||||
<string name="alert_w39">Atenționarea W39: Atenționare perioadă de închiriere</string>
|
<string name="alert_w39">Atenționarea W39: Atenționare perioadă de închiriere</string>
|
||||||
<string name="alert_m20">Mentenanță M20: Rezervor neinserat</string>
|
<string name="alert_m20">Mentenanță M20: Rezervor neinserat</string>
|
||||||
<string name="alert_m21">Mentenanță M21: Rezervor gol</string>
|
<string name="alert_m21">Mentenanță M21: Rezervor gol</string>
|
||||||
<string name="alert_m22">Mentenanță M22: Baterie terminată</string>
|
<string name="alert_m22">Mentenanță M22: Baterie terminată</string>
|
||||||
<string name="alert_m23">Mentenanță M23: Oprire automată</string>
|
<string name="alert_m23">Mentenanță M23: Oprire automată</string>
|
||||||
<string name="alert_m24">Mentenanță M24: Ocluzie</string>
|
<string name="alert_m24">Mentenanță M24: Ocluzie</string>
|
||||||
<string name="alert_m25">Mentenanță M25: Perioadă de închiriere terminată - sfârșitul operării</string>
|
<string name="alert_m25">Mentenanță M25: Perioadă de închiriere terminată - sfârșitul operării</string>
|
||||||
<string name="alert_m26">Mentenanță M26: Schimbarea rezervorului este incompletă</string>
|
<string name="alert_m26">Mentenanță M26: Schimbarea rezervorului este incompletă</string>
|
||||||
<string name="alert_m27">Mentenanță M27: Descărcarea datelor a eșuat</string>
|
<string name="alert_m27">Mentenanță M27: Descărcarea datelor a eșuat</string>
|
||||||
<string name="alert_m28">Mentenanță M28: Sfârșitul modului de pauză</string>
|
<string name="alert_m28">Mentenanță M28: Sfârșitul modului de pauză</string>
|
||||||
<string name="alert_m29">Mentenanță M29: Tipul de baterie nu este configurat</string>
|
<string name="alert_m29">Mentenanță M29: Tipul de baterie nu este configurat</string>
|
||||||
<string name="alert_m30">Mentenanță M30: Tipul de rezervor nu este configurat</string>
|
<string name="alert_m30">Mentenanță M30: Tipul de rezervor nu este configurat</string>
|
||||||
<string name="alert_e6">Eroarea E6: Eroare mecanică</string>
|
<string name="alert_e6">Eroarea E6: Eroare mecanică</string>
|
||||||
<string name="alert_e7">Eroarea E7: Eroare de electronică</string>
|
<string name="alert_e7">Eroarea E7: Eroare de electronică</string>
|
||||||
<string name="alert_e10">Eroarea E10: Eroare de derulare</string>
|
<string name="alert_e10">Eroarea E10: Eroare de derulare</string>
|
||||||
<string name="alert_e13">Eroarea E13: Eroare de limbaj</string>
|
<string name="alert_e13">Eroarea E13: Eroare de limbaj</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Предупреждение W31: Картридж заканчивается</string>
|
<string name="alert_w31">Предупреждение W31: Картридж заканчивается</string>
|
||||||
<string name="alert_w32">Предупреждение W32: Низкий заряд батареи</string>
|
<string name="alert_w32">Предупреждение W32: Низкий заряд батареи</string>
|
||||||
<string name="alert_w33">Предупреждение W33: Недопустимое время/Дата</string>
|
<string name="alert_w33">Предупреждение W33: Недопустимое время/Дата</string>
|
||||||
<string name="alert_w34">Предупреждение W34: Окончание гарантии</string>
|
<string name="alert_w34">Предупреждение W34: Окончание гарантии</string>
|
||||||
<string name="alert_w36">W36 предупреждение: временный базал TBR отменен</string>
|
<string name="alert_w36">W36 предупреждение: временный базал TBR отменен</string>
|
||||||
<string name="alert_w38">Предупреждение W38: Болюс отменен</string>
|
<string name="alert_w38">Предупреждение W38: Болюс отменен</string>
|
||||||
<string name="alert_w39">Предупреждение W39: окончание заемного периода</string>
|
<string name="alert_w39">Предупреждение W39: окончание заемного периода</string>
|
||||||
<string name="alert_m20">Техническое обслуживание M20: Картридж не вставлен</string>
|
<string name="alert_m20">Техническое обслуживание M20: Картридж не вставлен</string>
|
||||||
<string name="alert_m21">Техническое обслуживание M21: Картридж пуст</string>
|
<string name="alert_m21">Техническое обслуживание M21: Картридж пуст</string>
|
||||||
<string name="alert_m22">Техническое обслуживание M22: Батарея разряжена</string>
|
<string name="alert_m22">Техническое обслуживание M22: Батарея разряжена</string>
|
||||||
<string name="alert_m23">Техническое обслуживание: M23: Автоматическое выключение</string>
|
<string name="alert_m23">Техническое обслуживание: M23: Автоматическое выключение</string>
|
||||||
<string name="alert_m24">Техническое обслуживание M24: закупорка</string>
|
<string name="alert_m24">Техническое обслуживание M24: закупорка</string>
|
||||||
<string name="alert_m25">Техническое обслуживание M25: Конец заемного периода - конец операции</string>
|
<string name="alert_m25">Техническое обслуживание M25: Конец заемного периода - конец операции</string>
|
||||||
<string name="alert_m26">Техническое обслуживание M26: Замена картриджа не завершена</string>
|
<string name="alert_m26">Техническое обслуживание M26: Замена картриджа не завершена</string>
|
||||||
<string name="alert_m27">Техническое обслуживание M27: Ошибка загрузки данных</string>
|
<string name="alert_m27">Техническое обслуживание M27: Ошибка загрузки данных</string>
|
||||||
<string name="alert_m28">Техническое обслуживание M28: Тайм-аут режима паузы</string>
|
<string name="alert_m28">Техническое обслуживание M28: Тайм-аут режима паузы</string>
|
||||||
<string name="alert_m29">Техническое обслуживание M29: Тип батареи не задан</string>
|
<string name="alert_m29">Техническое обслуживание M29: Тип батареи не задан</string>
|
||||||
<string name="alert_m30">Техническое обслуживание M30: Тип картриджа не задан</string>
|
<string name="alert_m30">Техническое обслуживание M30: Тип картриджа не задан</string>
|
||||||
<string name="alert_e6">Ошибка E6: Механическая ошибка</string>
|
<string name="alert_e6">Ошибка E6: Механическая ошибка</string>
|
||||||
<string name="alert_e7">Ошибка E7: Ошибка электроники</string>
|
<string name="alert_e7">Ошибка E7: Ошибка электроники</string>
|
||||||
<string name="alert_e10">Ошибка Е10: Ошибка возврата</string>
|
<string name="alert_e10">Ошибка Е10: Ошибка возврата</string>
|
||||||
<string name="alert_e13">Ошибка E13: Ошибка языка</string>
|
<string name="alert_e13">Ошибка E13: Ошибка языка</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Upozornenie W31: Zásobník takmer prázdny</string>
|
<string name="alert_w31">Upozornenie W31: Zásobník takmer prázdny</string>
|
||||||
<string name="alert_w32">Upozornenie W32: Batéria takmer vybitá</string>
|
<string name="alert_w32">Upozornenie W32: Batéria takmer vybitá</string>
|
||||||
<string name="alert_w33">Upozornenie W33: Neplatný čas/dátum</string>
|
<string name="alert_w33">Upozornenie W33: Neplatný čas/dátum</string>
|
||||||
<string name="alert_w34">Upozornenie W34: Koniec záruky</string>
|
<string name="alert_w34">Upozornenie W34: Koniec záruky</string>
|
||||||
<string name="alert_w36">Upozornenie W36: Dočasný bazál zrušený</string>
|
<string name="alert_w36">Upozornenie W36: Dočasný bazál zrušený</string>
|
||||||
<string name="alert_w38">Upozornenie W38: Bolus zrušený</string>
|
<string name="alert_w38">Upozornenie W38: Bolus zrušený</string>
|
||||||
<string name="alert_w39">Upozornenie W39: Upozornenie na dobu zapožičania</string>
|
<string name="alert_w39">Upozornenie W39: Upozornenie na dobu zapožičania</string>
|
||||||
<string name="alert_m20">Údržba M20: Nie je vložený zásobník</string>
|
<string name="alert_m20">Údržba M20: Nie je vložený zásobník</string>
|
||||||
<string name="alert_m21">Údržba M21: Prázdny zásobník</string>
|
<string name="alert_m21">Údržba M21: Prázdny zásobník</string>
|
||||||
<string name="alert_m22">Údržba M22: Vybitá batéria</string>
|
<string name="alert_m22">Údržba M22: Vybitá batéria</string>
|
||||||
<string name="alert_m23">Údržba M23: Automatické vypnutie</string>
|
<string name="alert_m23">Údržba M23: Automatické vypnutie</string>
|
||||||
<string name="alert_m24">Údržba M24: Oklúzia</string>
|
<string name="alert_m24">Údržba M24: Oklúzia</string>
|
||||||
<string name="alert_m25">Údržba M25: Doba zapožičania uplynula - koniec prevádzky</string>
|
<string name="alert_m25">Údržba M25: Doba zapožičania uplynula - koniec prevádzky</string>
|
||||||
<string name="alert_m26">Údržba M26: Výmena zásobníka nedokončená</string>
|
<string name="alert_m26">Údržba M26: Výmena zásobníka nedokončená</string>
|
||||||
<string name="alert_m27">Údržba M27: Sťahovanie sa nepodarilo</string>
|
<string name="alert_m27">Údržba M27: Sťahovanie sa nepodarilo</string>
|
||||||
<string name="alert_m28">Údržba M28: Časový limit režimu pauza</string>
|
<string name="alert_m28">Údržba M28: Časový limit režimu pauza</string>
|
||||||
<string name="alert_m29">Údržba M29: Nenastavený typ batérie</string>
|
<string name="alert_m29">Údržba M29: Nenastavený typ batérie</string>
|
||||||
<string name="alert_m30">Údržba M30: Nenastavený typ zásobníka</string>
|
<string name="alert_m30">Údržba M30: Nenastavený typ zásobníka</string>
|
||||||
<string name="alert_e6">Chyba E6: Mechanická chyba</string>
|
<string name="alert_e6">Chyba E6: Mechanická chyba</string>
|
||||||
<string name="alert_e7">Chyba E7: Elektronická chyba</string>
|
<string name="alert_e7">Chyba E7: Elektronická chyba</string>
|
||||||
<string name="alert_e10">Chyba E10: Chyba previnutia</string>
|
<string name="alert_e10">Chyba E10: Chyba previnutia</string>
|
||||||
<string name="alert_e13">Chyba E13: Chyba jazyka</string>
|
<string name="alert_e13">Chyba E13: Chyba jazyka</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">Varning W31: Reservoarnivå låg</string>
|
<string name="alert_w31">Varning W31: Reservoarnivå låg</string>
|
||||||
<string name="alert_w32">Varning W32: Batterinivå låg</string>
|
<string name="alert_w32">Varning W32: Batterinivå låg</string>
|
||||||
<string name="alert_w33">Varning W33: Ogiltig tid/datum</string>
|
<string name="alert_w33">Varning W33: Ogiltig tid/datum</string>
|
||||||
<string name="alert_w34">Varning W34: Garantiperioden har upphört</string>
|
<string name="alert_w34">Varning W34: Garantiperioden har upphört</string>
|
||||||
<string name="alert_w36">Varning W36: Tempbasal avbruten</string>
|
<string name="alert_w36">Varning W36: Tempbasal avbruten</string>
|
||||||
<string name="alert_w38">Varning W38: Bolus avbruten</string>
|
<string name="alert_w38">Varning W38: Bolus avbruten</string>
|
||||||
<string name="alert_w39">Varning W39: Låneperioden upphör snart</string>
|
<string name="alert_w39">Varning W39: Låneperioden upphör snart</string>
|
||||||
<string name="alert_m20">Underhåll M20: Reservoar inte monterad</string>
|
<string name="alert_m20">Underhåll M20: Reservoar inte monterad</string>
|
||||||
<string name="alert_m21">Underhåll M21: Reservoar tom</string>
|
<string name="alert_m21">Underhåll M21: Reservoar tom</string>
|
||||||
<string name="alert_m22">Underhåll M22: Batteri tomt</string>
|
<string name="alert_m22">Underhåll M22: Batteri tomt</string>
|
||||||
<string name="alert_m23">Underhåll M23: Automatisk avstängning</string>
|
<string name="alert_m23">Underhåll M23: Automatisk avstängning</string>
|
||||||
<string name="alert_m24">Underhåll M24: Ocklusion</string>
|
<string name="alert_m24">Underhåll M24: Ocklusion</string>
|
||||||
<string name="alert_m25">Underhåll M25: Låneperioden över. Stänger av pumpen</string>
|
<string name="alert_m25">Underhåll M25: Låneperioden över. Stänger av pumpen</string>
|
||||||
<string name="alert_m26">Underhåll M26: Reservoarbyte ej slutfört</string>
|
<string name="alert_m26">Underhåll M26: Reservoarbyte ej slutfört</string>
|
||||||
<string name="alert_m27">Underhåll M27: Datanedladdning misslyckades</string>
|
<string name="alert_m27">Underhåll M27: Datanedladdning misslyckades</string>
|
||||||
<string name="alert_m28">Underhåll M28: Pausläge timeout</string>
|
<string name="alert_m28">Underhåll M28: Pausläge timeout</string>
|
||||||
<string name="alert_m29">Underhåll M29: Batterityp inte inställd</string>
|
<string name="alert_m29">Underhåll M29: Batterityp inte inställd</string>
|
||||||
<string name="alert_m30">Underhåll M30: Reservoartyp inte inställd</string>
|
<string name="alert_m30">Underhåll M30: Reservoartyp inte inställd</string>
|
||||||
<string name="alert_e6">Fel E6: Mekaniskt fel</string>
|
<string name="alert_e6">Fel E6: Mekaniskt fel</string>
|
||||||
<string name="alert_e7">Fel E7: Elektroniskt fel</string>
|
<string name="alert_e7">Fel E7: Elektroniskt fel</string>
|
||||||
<string name="alert_e10">Felet E10: Återställningsfel</string>
|
<string name="alert_e10">Felet E10: Återställningsfel</string>
|
||||||
<string name="alert_e13">Fel E13: Språkfel</string>
|
<string name="alert_e13">Fel E13: Språkfel</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,3 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources></resources>
|
<resources>
|
||||||
|
<string name="alert_w31">Uyarı W31: Kartuş düşük</string>
|
||||||
|
<string name="alert_w32">Uyarı W32: Pil bitmek üzere</string>
|
||||||
|
<string name="alert_w33">Uyarı W33: Geçersiz saat/tarih</string>
|
||||||
|
<string name="alert_w34">Garanti süresi doldu</string>
|
||||||
|
<string name="alert_w36">Uyarı W36: Geçici bazal iptal edildi</string>
|
||||||
|
<string name="alert_w38">Uyarı W38: Bolus iptal edildi</string>
|
||||||
|
<string name="alert_w39">Uyarı W39: Kiralama süresi uyarısı</string>
|
||||||
|
<string name="alert_m20">Bakım M20: Kartuş takılı değil</string>
|
||||||
|
<string name="alert_m21">Bakım M21: Kartuş boş</string>
|
||||||
|
<string name="alert_m22">Bakım M22: Pil boş</string>
|
||||||
|
<string name="alert_m23">Bakım M23: Otomatik kapalı</string>
|
||||||
|
<string name="alert_m24">Bakım M24: Tıkanıklık</string>
|
||||||
|
<string name="alert_m25">Bakım M25: Kiralama süresi doldu</string>
|
||||||
|
<string name="alert_m26">Bakım M26: Kartuş değişimi tamamlanamadı</string>
|
||||||
|
<string name="alert_m27">Bakım M27: Veri yükleme başarısız</string>
|
||||||
|
<string name="alert_m28">Bakım M28: Duraklat modunda zaman aşımı</string>
|
||||||
|
<string name="alert_m29">Bakım M29: Pil türü seçili değil</string>
|
||||||
|
<string name="alert_m30">Bakım M30: Kartuş türü ayarlı değil</string>
|
||||||
|
<string name="alert_e6">Hata E6: Mekanik hata</string>
|
||||||
|
<string name="alert_e7">Hata E7: Elektronik hata</string>
|
||||||
|
<string name="alert_e10">Hata E10: Geri sarma hata</string>
|
||||||
|
<string name="alert_e13">Hata E13: Dil ekranında hata</string>
|
||||||
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,26 +1,26 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<!--Generated by crowdin.com-->
|
<!--Generated by crowdin.com-->
|
||||||
<resources>
|
<resources>
|
||||||
<string name="alert_w31">警告 W31:储药器药量低</string>
|
<string name="alert_w31">警告 W31:储药器药量低</string>
|
||||||
<string name="alert_w32">警告 W32:电池电量低</string>
|
<string name="alert_w32">警告 W32:电池电量低</string>
|
||||||
<string name="alert_w33">警告 W33:不合规的时间/日期</string>
|
<string name="alert_w33">警告 W33:不合规的时间/日期</string>
|
||||||
<string name="alert_w34">警告 W34:保修期结束</string>
|
<string name="alert_w34">警告 W34:保修期结束</string>
|
||||||
<string name="alert_w36">警告 W36:临时基础率被取消了</string>
|
<string name="alert_w36">警告 W36:临时基础率被取消了</string>
|
||||||
<string name="alert_w38">警告 W38:大剂量被取消了</string>
|
<string name="alert_w38">警告 W38:大剂量被取消了</string>
|
||||||
<string name="alert_w39">警告 W39:Loantime 警告</string>
|
<string name="alert_w39">警告 W39:Loantime 警告</string>
|
||||||
<string name="alert_m20">维护 M10:储药器没有插入</string>
|
<string name="alert_m20">维护 M10:储药器没有插入</string>
|
||||||
<string name="alert_m21">维护 M21:储药器空了</string>
|
<string name="alert_m21">维护 M21:储药器空了</string>
|
||||||
<string name="alert_m22">维护 M22:电池没有插入</string>
|
<string name="alert_m22">维护 M22:电池没有插入</string>
|
||||||
<string name="alert_m23">维护 M23:自动关机</string>
|
<string name="alert_m23">维护 M23:自动关机</string>
|
||||||
<string name="alert_m24">维护 M24:堵管</string>
|
<string name="alert_m24">维护 M24:堵管</string>
|
||||||
<string name="alert_m25">维护 M25:Loantime结束,操作结束</string>
|
<string name="alert_m25">维护 M25:Loantime结束,操作结束</string>
|
||||||
<string name="alert_m26">维护 M26:储药器更换没有完成</string>
|
<string name="alert_m26">维护 M26:储药器更换没有完成</string>
|
||||||
<string name="alert_m27">维护 M27:数据下载失败</string>
|
<string name="alert_m27">维护 M27:数据下载失败</string>
|
||||||
<string name="alert_m28">维护 M28:暂停模式超时</string>
|
<string name="alert_m28">维护 M28:暂停模式超时</string>
|
||||||
<string name="alert_m29">维护 M29:电池类型没有设置</string>
|
<string name="alert_m29">维护 M29:电池类型没有设置</string>
|
||||||
<string name="alert_m30">维护 M30:储药器类型没有设置</string>
|
<string name="alert_m30">维护 M30:储药器类型没有设置</string>
|
||||||
<string name="alert_e6">错误 E6:机械错误</string>
|
<string name="alert_e6">错误 E6:机械错误</string>
|
||||||
<string name="alert_e7">错误 E7:电子错误</string>
|
<string name="alert_e7">错误 E7:电子错误</string>
|
||||||
<string name="alert_e10">错误 E10:复位错误</string>
|
<string name="alert_e10">错误 E10:复位错误</string>
|
||||||
<string name="alert_e13">错误 E13:语言错误</string>
|
<string name="alert_e13">错误 E13:语言错误</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -29,6 +29,7 @@
|
||||||
<item>@string/sk_lang</item>
|
<item>@string/sk_lang</item>
|
||||||
<item>@string/sv_lang</item>
|
<item>@string/sv_lang</item>
|
||||||
<item>@string/pl_lang</item>
|
<item>@string/pl_lang</item>
|
||||||
|
<item>@string/tr_lang</item>
|
||||||
<item>@string/zh_lang</item>
|
<item>@string/zh_lang</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
<string-array name="languagesValues" translatable="false">
|
<string-array name="languagesValues" translatable="false">
|
||||||
|
@ -50,6 +51,7 @@
|
||||||
<item>sk</item>
|
<item>sk</item>
|
||||||
<item>sv</item>
|
<item>sv</item>
|
||||||
<item>pl</item>
|
<item>pl</item>
|
||||||
|
<item>tr</item>
|
||||||
<item>zh</item>
|
<item>zh</item>
|
||||||
</string-array>
|
</string-array>
|
||||||
|
|
||||||
|
|
|
@ -248,6 +248,7 @@
|
||||||
<string name="sv_lang" translatable="false">Swedish</string>
|
<string name="sv_lang" translatable="false">Swedish</string>
|
||||||
<string name="fr_lang" translatable="false">French</string>
|
<string name="fr_lang" translatable="false">French</string>
|
||||||
<string name="zh_lang" translatable="false">Chinese</string>
|
<string name="zh_lang" translatable="false">Chinese</string>
|
||||||
|
<string name="tr_lang" translatable="false">Turkish</string>
|
||||||
<string name="pl_lang" translatable="false">Polish</string>
|
<string name="pl_lang" translatable="false">Polish</string>
|
||||||
<string name="openapsma_maxbasal_title">Max U/hr a Temp Basal can be set to</string>
|
<string name="openapsma_maxbasal_title">Max U/hr a Temp Basal can be set to</string>
|
||||||
<string name="openapsma_maxbasal_summary">This value is called max basal in OpenAPS context</string>
|
<string name="openapsma_maxbasal_summary">This value is called max basal in OpenAPS context</string>
|
||||||
|
@ -584,6 +585,7 @@
|
||||||
<string name="disconnectpumpfor2h">Disconnect pump for 2 h</string>
|
<string name="disconnectpumpfor2h">Disconnect pump for 2 h</string>
|
||||||
<string name="disconnectpumpfor3h">Disconnect pump for 3 h</string>
|
<string name="disconnectpumpfor3h">Disconnect pump for 3 h</string>
|
||||||
<string name="resume">Resume</string>
|
<string name="resume">Resume</string>
|
||||||
|
<string name="reconnect">Reconnect Pump</string>
|
||||||
<string name="smscommunicator_wrongduration">Wrong duration</string>
|
<string name="smscommunicator_wrongduration">Wrong duration</string>
|
||||||
<string name="smscommunicator_loopsuspended">Loop suspended</string>
|
<string name="smscommunicator_loopsuspended">Loop suspended</string>
|
||||||
<string name="smscommunicator_loopresumed">Loop resumed</string>
|
<string name="smscommunicator_loopresumed">Loop resumed</string>
|
||||||
|
@ -610,6 +612,7 @@
|
||||||
<string name="danar_bluetooth_status">Bluetooth status</string>
|
<string name="danar_bluetooth_status">Bluetooth status</string>
|
||||||
<string name="nav_about">About</string>
|
<string name="nav_about">About</string>
|
||||||
<string name="smscommunicator_missingsmspermission">Missing SMS permission</string>
|
<string name="smscommunicator_missingsmspermission">Missing SMS permission</string>
|
||||||
|
<string name="smscommunicator_missingphonestatepermission">Missing phone state permission</string>
|
||||||
<string name="xdripstatus_settings">xDrip Status (watch)</string>
|
<string name="xdripstatus_settings">xDrip Status (watch)</string>
|
||||||
<string name="xdripstatus">xDrip Statusline (watch)</string>
|
<string name="xdripstatus">xDrip Statusline (watch)</string>
|
||||||
<string name="xdripstatus_shortname">xds</string>
|
<string name="xdripstatus_shortname">xds</string>
|
||||||
|
@ -1210,6 +1213,11 @@
|
||||||
<string name="loop_openmode_min_change_summary">Loop will popup new change request only if change is bigger than this value. Default value is 20%</string>
|
<string name="loop_openmode_min_change_summary">Loop will popup new change request only if change is bigger than this value. Default value is 20%</string>
|
||||||
<string name="key_short_tabtitles" translatable="false">short_tabtitles</string>
|
<string name="key_short_tabtitles" translatable="false">short_tabtitles</string>
|
||||||
<string name="pairfirst">Please pair your pump with your phone!</string>
|
<string name="pairfirst">Please pair your pump with your phone!</string>
|
||||||
|
<string name="profile_total">== ∑ %1$s U</string>
|
||||||
|
<string name="profile_ins_units_per_hout">U/h</string>
|
||||||
|
<string name="profile_carbs_per_unit">g/U</string>
|
||||||
|
<string name="profile_per_unit">/U</string>
|
||||||
|
|
||||||
|
|
||||||
<!-- Pump Abstract -->
|
<!-- Pump Abstract -->
|
||||||
<string name="pump_operation_not_supported_by_pump_driver">Operation not supported by pump and/or driver.</string>
|
<string name="pump_operation_not_supported_by_pump_driver">Operation not supported by pump and/or driver.</string>
|
||||||
|
|
4
app/src/main/res/xml/automotive_app_desc.xml
Normal file
4
app/src/main/res/xml/automotive_app_desc.xml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<automotiveApp>
|
||||||
|
<uses name="notification" />
|
||||||
|
</automotiveApp>
|
|
@ -24,6 +24,7 @@ import info.nightscout.androidaps.logging.L;
|
||||||
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
||||||
import info.nightscout.androidaps.plugins.ConfigBuilder.ProfileFunctions;
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ProfileFunctions;
|
||||||
import info.nightscout.androidaps.plugins.NSClientInternal.NSUpload;
|
import info.nightscout.androidaps.plugins.NSClientInternal.NSUpload;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
import info.nightscout.androidaps.plugins.Treatments.TreatmentService;
|
import info.nightscout.androidaps.plugins.Treatments.TreatmentService;
|
||||||
import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
||||||
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
||||||
|
@ -100,6 +101,9 @@ public class AAPSMocker {
|
||||||
when(MainApp.gs(R.string.careportal_profileswitch)).thenReturn("Profile Switch");
|
when(MainApp.gs(R.string.careportal_profileswitch)).thenReturn("Profile Switch");
|
||||||
when(MainApp.gs(R.string.configbuilder_insulin)).thenReturn("Insulin");
|
when(MainApp.gs(R.string.configbuilder_insulin)).thenReturn("Insulin");
|
||||||
when(MainApp.gs(R.string.bolusdelivering)).thenReturn("Delivering 0.0U");
|
when(MainApp.gs(R.string.bolusdelivering)).thenReturn("Delivering 0.0U");
|
||||||
|
when(MainApp.gs(R.string.profile_per_unit)).thenReturn("/U");
|
||||||
|
when(MainApp.gs(R.string.profile_carbs_per_unit)).thenReturn("g/U");
|
||||||
|
when(MainApp.gs(R.string.profile_ins_units_per_hout)).thenReturn("U/h");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static MainApp mockMainApp() {
|
public static MainApp mockMainApp() {
|
||||||
|
@ -176,8 +180,10 @@ public class AAPSMocker {
|
||||||
public static DanaRPlugin mockDanaRPlugin() {
|
public static DanaRPlugin mockDanaRPlugin() {
|
||||||
PowerMockito.mockStatic(DanaRPlugin.class);
|
PowerMockito.mockStatic(DanaRPlugin.class);
|
||||||
DanaRPlugin danaRPlugin = mock(DanaRPlugin.class);
|
DanaRPlugin danaRPlugin = mock(DanaRPlugin.class);
|
||||||
|
DanaRv2Plugin danaRv2Plugin = mock(DanaRv2Plugin.class);
|
||||||
DanaRKoreanPlugin danaRKoreanPlugin = mock(DanaRKoreanPlugin.class);
|
DanaRKoreanPlugin danaRKoreanPlugin = mock(DanaRKoreanPlugin.class);
|
||||||
when(MainApp.getSpecificPlugin(DanaRPlugin.class)).thenReturn(danaRPlugin);
|
when(MainApp.getSpecificPlugin(DanaRPlugin.class)).thenReturn(danaRPlugin);
|
||||||
|
when(MainApp.getSpecificPlugin(DanaRv2Plugin.class)).thenReturn(danaRv2Plugin);
|
||||||
when(MainApp.getSpecificPlugin(DanaRKoreanPlugin.class)).thenReturn(danaRKoreanPlugin);
|
when(MainApp.getSpecificPlugin(DanaRKoreanPlugin.class)).thenReturn(danaRKoreanPlugin);
|
||||||
return danaRPlugin;
|
return danaRPlugin;
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,6 +117,7 @@ public class MainAppTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isEngineeringModeOrReleaseTest() {
|
public void isEngineeringModeOrReleaseTest() {
|
||||||
|
mainApp.devBranch = true;
|
||||||
Assert.assertEquals(!Config.APS, mainApp.isEngineeringModeOrRelease());
|
Assert.assertEquals(!Config.APS, mainApp.isEngineeringModeOrRelease());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,82 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import junit.framework.Assert;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.Constants;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.R;
|
||||||
|
import info.nightscout.androidaps.interfaces.Constraint;
|
||||||
|
import info.nightscout.androidaps.interfaces.PluginType;
|
||||||
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
import info.nightscout.utils.ToastUtils;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Rumen on 01.08.2018
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, ConfigBuilderPlugin.class, ToastUtils.class, Context.class, SP.class})
|
||||||
|
public class DanaRv2PluginTest {
|
||||||
|
DanaRv2Plugin danaRv2Plugin;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getPlugin() {
|
||||||
|
danaRv2Plugin.getPlugin();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void basalRateShouldBeLimited() throws Exception {
|
||||||
|
danaRv2Plugin.setPluginEnabled(PluginType.PUMP, true);
|
||||||
|
danaRv2Plugin.setPluginEnabled(PluginType.PUMP, true);
|
||||||
|
DanaRPump.getInstance().maxBasal = 0.8d;
|
||||||
|
|
||||||
|
Constraint<Double> c = new Constraint<>(Constants.REALLYHIGHBASALRATE);
|
||||||
|
danaRv2Plugin.applyBasalConstraints(c, AAPSMocker.getValidProfile());
|
||||||
|
Assert.assertEquals(0.8d, c.value());
|
||||||
|
Assert.assertEquals("DanaRv2: Limiting basal rate to 0.80 U/h because of pump limit", c.getReasons());
|
||||||
|
Assert.assertEquals("DanaRv2: Limiting basal rate to 0.80 U/h because of pump limit", c.getMostLimitedReasons());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void percentBasalRateShouldBeLimited() throws Exception {
|
||||||
|
danaRv2Plugin.setPluginEnabled(PluginType.PUMP, true);
|
||||||
|
danaRv2Plugin.setPluginEnabled(PluginType.PUMP, true);
|
||||||
|
DanaRPump.getInstance().maxBasal = 0.8d;
|
||||||
|
|
||||||
|
Constraint<Integer> c = new Constraint<>(Constants.REALLYHIGHPERCENTBASALRATE);
|
||||||
|
danaRv2Plugin.applyBasalPercentConstraints(c, AAPSMocker.getValidProfile());
|
||||||
|
Assert.assertEquals((Integer) 200, c.value());
|
||||||
|
Assert.assertEquals("DanaRv2: Limiting percent rate to 200% because of pump limit", c.getReasons());
|
||||||
|
Assert.assertEquals("DanaRv2: Limiting percent rate to 200% because of pump limit", c.getMostLimitedReasons());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void prepareMocks() throws Exception {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockConfigBuilder();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
AAPSMocker.mockStrings();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockCommandQueue();
|
||||||
|
|
||||||
|
// when(SP.getString(R.string.key_danars_address, "")).thenReturn("");
|
||||||
|
|
||||||
|
danaRv2Plugin = DanaRv2Plugin.getPlugin();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.comm.MessageBase;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MessageHashTable_v2;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgStatusAPS_v2;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class})
|
||||||
|
public class MessageHashTable_v2Test {
|
||||||
|
@Test
|
||||||
|
public void runTest() {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
|
||||||
|
MessageHashTable_v2 packet = new MessageHashTable_v2();
|
||||||
|
|
||||||
|
MessageBase forTesting = new MsgStatusAPS_v2();
|
||||||
|
MessageBase testPacket = MessageHashTable_v2.findMessage(forTesting.getCommand());
|
||||||
|
assertEquals(0xE001, testPacket.getCommand());
|
||||||
|
// try putting another command
|
||||||
|
MessageBase testMessage = new MessageBase();
|
||||||
|
testMessage.SetCommand(0xE005);
|
||||||
|
packet.put(testMessage);
|
||||||
|
assertEquals(0xE005, packet.findMessage(0xE005).getCommand());
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
double[] createArray(int length, double fillWith){
|
||||||
|
double[] ret = new double[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,61 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.comm.MsgCheckValue;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgCheckValue_v2;
|
||||||
|
import info.nightscout.androidaps.plugins.Treatments.Treatment;
|
||||||
|
import info.nightscout.androidaps.queue.CommandQueue;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
import static org.powermock.api.mockito.PowerMockito.when;
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class, DanaRv2Plugin.class, DanaRPlugin.class, ConfigBuilderPlugin.class, CommandQueue.class})
|
||||||
|
public class MsgCheckValue_v2Test {
|
||||||
|
@Test
|
||||||
|
public void runTest() {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
AAPSMocker.mockDanaRPlugin();
|
||||||
|
AAPSMocker.mockConfigBuilder();
|
||||||
|
AAPSMocker.mockCommandQueue();
|
||||||
|
Treatment t = new Treatment();
|
||||||
|
MsgCheckValue_v2 packet = new MsgCheckValue_v2();
|
||||||
|
// test message decoding
|
||||||
|
packet.handleMessage(createArray(34, (byte) 3));
|
||||||
|
DanaRPump pump = DanaRPump.getInstance();
|
||||||
|
assertEquals(DanaRPump.EXPORT_MODEL, pump.model);
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
double[] createArray(int length, double fillWith){
|
||||||
|
double[] ret = new double[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,67 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.NSClientInternal.NSUpload;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgHistoryEvents_v2;
|
||||||
|
import info.nightscout.androidaps.plugins.Treatments.Treatment;
|
||||||
|
import info.nightscout.androidaps.plugins.Treatments.TreatmentService;
|
||||||
|
import info.nightscout.androidaps.plugins.Treatments.TreatmentsPlugin;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class, TreatmentsPlugin.class, TreatmentService.class})
|
||||||
|
public class MsgHistoryEvents_v2Test {
|
||||||
|
@Test
|
||||||
|
public void runTest() throws Exception {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
AAPSMocker.mockDatabaseHelper();
|
||||||
|
AAPSMocker.mockTreatmentPlugin();
|
||||||
|
AAPSMocker.mockTreatmentService();
|
||||||
|
MsgHistoryEvents_v2 packet = new MsgHistoryEvents_v2();
|
||||||
|
|
||||||
|
// test message decoding
|
||||||
|
//last message in history
|
||||||
|
packet.handleMessage(createArray(34, (byte) 0xFF));
|
||||||
|
assertEquals(true, packet.done);
|
||||||
|
// passing an bigger number
|
||||||
|
packet = new MsgHistoryEvents_v2();
|
||||||
|
packet.handleMessage(createArray(34, (byte) 17));
|
||||||
|
assertEquals(false, packet.done);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
double[] createArray(int length, double fillWith){
|
||||||
|
double[] ret = new double[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,61 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgSetHistoryEntry_v2;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class, DanaRv2Plugin.class, DanaRPlugin.class})
|
||||||
|
public class MsgSetHistoryEntry_v2Test {
|
||||||
|
@Test
|
||||||
|
public void runTest() {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
AAPSMocker.mockDanaRPlugin();
|
||||||
|
|
||||||
|
MsgSetHistoryEntry_v2 initializerTest = new MsgSetHistoryEntry_v2((byte) 1, System.currentTimeMillis(), 1, 0);
|
||||||
|
MsgSetHistoryEntry_v2 packet = new MsgSetHistoryEntry_v2();
|
||||||
|
// test message decoding
|
||||||
|
// != 1 fails
|
||||||
|
packet.handleMessage(createArray(34, (byte) 2));
|
||||||
|
assertEquals(true, packet.failed);
|
||||||
|
// passing an bigger number
|
||||||
|
packet = new MsgSetHistoryEntry_v2();
|
||||||
|
packet.handleMessage(createArray(34, (byte) 1));
|
||||||
|
assertEquals(false, packet.failed);
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
double[] createArray(int length, double fillWith){
|
||||||
|
double[] ret = new double[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,58 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.comm.MessageBase;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgStatusAPS_v2;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class})
|
||||||
|
public class MsgStatusAPS_v2Test {
|
||||||
|
@Mock
|
||||||
|
Context context;
|
||||||
|
@Test
|
||||||
|
public void runTest() throws Exception{
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
|
||||||
|
try {
|
||||||
|
AAPSMocker.mockTreatmentService();
|
||||||
|
} catch (Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
MsgStatusAPS_v2 packet = new MsgStatusAPS_v2();
|
||||||
|
// test iob
|
||||||
|
//TODO Find a way to mock treatments plugin
|
||||||
|
byte[] testArray = createArray(34, (byte) 7);
|
||||||
|
double iob = MessageBase.intFromBuff(testArray, 0, 2) / 100d;
|
||||||
|
packet.handleMessage(testArray);
|
||||||
|
DanaRPump pump = DanaRPump.getInstance();
|
||||||
|
assertEquals(iob, pump.iob, 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.NSClientInternal.NSUpload;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgStatusBolusExtended_v2;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.comm.MessageBase;
|
||||||
|
import info.nightscout.androidaps.plugins.Treatments.Treatment;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class})
|
||||||
|
public class MsgStatusBolusExtended_v2Test {
|
||||||
|
@Mock
|
||||||
|
Context context;
|
||||||
|
@Test
|
||||||
|
public void runTest() throws Exception{
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
try {
|
||||||
|
AAPSMocker.mockTreatmentService();
|
||||||
|
} catch (Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
MsgStatusBolusExtended_v2 packet = new MsgStatusBolusExtended_v2();
|
||||||
|
// test message decoding
|
||||||
|
//TODO Find a way to mock treatments plugin
|
||||||
|
packet.handleMessage(createArray(34, (byte) 7));
|
||||||
|
DanaRPump pump = DanaRPump.getInstance();
|
||||||
|
assertEquals((double) MessageBase.intFromBuff(createArray(10, (byte) 7), 2, 2)/100d, pump.extendedBolusAmount,0);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,62 @@
|
||||||
|
package info.nightscout.androidaps.plugins.PumpdanaRv2.comm;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.powermock.core.classloader.annotations.PrepareForTest;
|
||||||
|
import org.powermock.modules.junit4.PowerMockRunner;
|
||||||
|
|
||||||
|
import info.AAPSMocker;
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.logging.L;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPump;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.DanaRv2Plugin;
|
||||||
|
import info.nightscout.androidaps.plugins.PumpDanaRv2.comm.MsgStatusTempBasal_v2;
|
||||||
|
import info.nightscout.utils.SP;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
/**
|
||||||
|
* Created by Rumen Georgiev on 30.10.2018.
|
||||||
|
*/
|
||||||
|
|
||||||
|
@RunWith(PowerMockRunner.class)
|
||||||
|
@PrepareForTest({MainApp.class, SP.class, L.class, DanaRv2Plugin.class, DanaRPlugin.class})
|
||||||
|
public class MsgStatusTempBasal_v2Test {
|
||||||
|
@Test
|
||||||
|
public void runTest() {
|
||||||
|
AAPSMocker.mockMainApp();
|
||||||
|
AAPSMocker.mockApplicationContext();
|
||||||
|
AAPSMocker.mockSP();
|
||||||
|
AAPSMocker.mockL();
|
||||||
|
AAPSMocker.mockBus();
|
||||||
|
AAPSMocker.mockDanaRPlugin();
|
||||||
|
|
||||||
|
MsgStatusTempBasal_v2 packet = new MsgStatusTempBasal_v2();
|
||||||
|
DanaRPump pump = DanaRPump.getInstance();
|
||||||
|
// test message decoding
|
||||||
|
packet.handleMessage(createArray(34, (byte) 1));
|
||||||
|
assertEquals(true, pump.isTempBasalInProgress);
|
||||||
|
// passing an bigger number
|
||||||
|
packet = new MsgStatusTempBasal_v2();
|
||||||
|
|
||||||
|
packet.handleMessage(createArray(34, (byte) 2));
|
||||||
|
assertEquals(false, pump.isTempBasalInProgress);
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] createArray(int length, byte fillWith){
|
||||||
|
byte[] ret = new byte[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
double[] createArray(int length, double fillWith){
|
||||||
|
double[] ret = new double[length];
|
||||||
|
for(int i = 0; i<length; i++){
|
||||||
|
ret[i] = fillWith;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -19,7 +19,12 @@ public class PercentageSplitterTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void pureNameTestPercentageAndShift() {
|
public void pureNameTestPercentageAndPositiveTimeShift() {
|
||||||
assertEquals("Fiasp", PercentageSplitter.pureName("Fiasp (101%,2h)"));
|
assertEquals("Fiasp", PercentageSplitter.pureName("Fiasp (101%,2h)"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void pureNameTestPercentageAndNegtiveTimeShift() {
|
||||||
|
assertEquals("Fiasp", PercentageSplitter.pureName("Fiasp (50%,-2h)"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,8 @@
|
||||||
|
|
||||||
buildscript {
|
buildscript {
|
||||||
repositories {
|
repositories {
|
||||||
jcenter()
|
|
||||||
google()
|
google()
|
||||||
|
jcenter()
|
||||||
maven { url "https://oss.sonatype.org/content/repositories/snapshots/" }
|
maven { url "https://oss.sonatype.org/content/repositories/snapshots/" }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue