From 20c66e3b6f643f362bc0118215e3be4a20ed5dfe Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 2 Nov 2017 17:39:25 +0100 Subject: [PATCH 01/15] add link to advanced settings --- .../java/info/nightscout/androidaps/PreferencesActivity.java | 1 + 1 file changed, 1 insertion(+) diff --git a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java index 181cb3fa77..8d5a174ca7 100644 --- a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java @@ -124,6 +124,7 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre if (id != -1) { addPreferencesFromResource(id); + addPreferencesFromResource(R.xml.pref_advanced); } else { if (!Config.NSCLIENT) { addPreferencesFromResource(R.xml.pref_password); From a7077a8a6a9caa66bd3119586ad91b1a817d58d6 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 2 Nov 2017 17:47:41 +0100 Subject: [PATCH 02/15] long click on name to open settings --- .../ConfigBuilder/ConfigBuilderFragment.java | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderFragment.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderFragment.java index 46c2083d0b..2e620eab70 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderFragment.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderFragment.java @@ -270,6 +270,23 @@ public class ConfigBuilderFragment extends Fragment { }, null); } }); + + holder.name.setOnLongClickListener(new View.OnLongClickListener() { + @Override + public boolean onLongClick(View v) { + final PluginBase plugin = (PluginBase) v.getTag(); + PasswordProtection.QueryPassword(getContext(), R.string.settings_password, "settings_password", new Runnable() { + @Override + public void run() { + Intent i = new Intent(getContext(), PreferencesActivity.class); + i.putExtra("id", plugin.getPreferencesId()); + startActivity(i); + } + }, null); + return false; + } + }); + } else { holder = (PluginViewHolder) view.getTag(); } From e063f3a2cb553d479411495b04325876575277af Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Thu, 2 Nov 2017 18:03:40 +0100 Subject: [PATCH 03/15] removed unneeded code --- .../nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java | 2 +- .../androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java | 2 +- .../nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java | 2 +- .../androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java index 115f612f6c..f7e1c6b92f 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaR/DanaRPlugin.java @@ -553,7 +553,7 @@ public class DanaRPlugin implements PluginBase, PumpInterface, DanaRInterface, C insulin = configBuilderPlugin.applyBolusConstraints(insulin); // needs to be rounded int durationInHalfHours = Math.max(durationInMinutes / 30, 1); - insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep * (1 + durationInHalfHours % 1)); + insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep); PumpEnactResult result = new PumpEnactResult(); ExtendedBolus runningEB = MainApp.getConfigBuilder().getExtendedBolusFromHistory(System.currentTimeMillis()); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java index c0071ecfca..cda438aded 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRKorean/DanaRKoreanPlugin.java @@ -550,7 +550,7 @@ public class DanaRKoreanPlugin implements PluginBase, PumpInterface, DanaRInterf insulin = configBuilderPlugin.applyBolusConstraints(insulin); // needs to be rounded int durationInHalfHours = Math.max(durationInMinutes / 30, 1); - insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep * (1 + durationInHalfHours % 1)); + insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep); PumpEnactResult result = new PumpEnactResult(); ExtendedBolus runningEB = MainApp.getConfigBuilder().getExtendedBolusFromHistory(System.currentTimeMillis()); diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java index 5f97999bfa..916213c270 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/DanaRSPlugin.java @@ -675,7 +675,7 @@ public class DanaRSPlugin implements PluginBase, PumpInterface, DanaRInterface, insulin = configBuilderPlugin.applyBolusConstraints(insulin); // needs to be rounded int durationInHalfHours = Math.max(durationInMinutes / 30, 1); - insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep * (1 + durationInHalfHours % 1)); + insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep); PumpEnactResult result = new PumpEnactResult(); ExtendedBolus runningEB = MainApp.getConfigBuilder().getExtendedBolusFromHistory(System.currentTimeMillis()); if (runningEB != null && Math.abs(runningEB.insulin - insulin) < getPumpDescription().extendedBolusStep) { diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java index f9156bb430..f2ad2fd659 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRv2/DanaRv2Plugin.java @@ -513,7 +513,7 @@ public class DanaRv2Plugin implements PluginBase, PumpInterface, DanaRInterface, insulin = configBuilderPlugin.applyBolusConstraints(insulin); // needs to be rounded int durationInHalfHours = Math.max(durationInMinutes / 30, 1); - insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep * (1 + durationInHalfHours % 1)); + insulin = Round.roundTo(insulin, getPumpDescription().extendedBolusStep); PumpEnactResult result = new PumpEnactResult(); ExtendedBolus runningEB = MainApp.getConfigBuilder().getExtendedBolusFromHistory(System.currentTimeMillis()); if (runningEB != null && Math.abs(runningEB.insulin - insulin) < getPumpDescription().extendedBolusStep) { From 5ad564e0e340c14b5c2b1976d5f594d83bbf1af1 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Fri, 3 Nov 2017 10:13:23 +0100 Subject: [PATCH 04/15] CS translation --- app/src/main/res/values-cs/strings.xml | 9 +++++++++ app/src/main/res/values/strings.xml | 2 +- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/app/src/main/res/values-cs/strings.xml b/app/src/main/res/values-cs/strings.xml index d8d486603c..66a2d76862 100644 --- a/app/src/main/res/values-cs/strings.xml +++ b/app/src/main/res/values-cs/strings.xml @@ -663,4 +663,13 @@ Výstraha měření glykémie Vypršel čas připojování DC + Volitelný vrchol - Oref + NS heslo + NS heslo (API secret) + Zpracovávám + Rychle působící - Oref + Spouštím bolus + Fiasp + Ultra rychlý - Oref + Čekání na konec bolusu. Zbývá %d sek. diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 0c0e9060d4..32063b67b5 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -747,7 +747,7 @@ Set Temp-Targets and enter Treatments from the watch. Connection timed out ]]> - Waiting for estimated bolus end. Remaining %d sec. + Waiting for bolus end. Remaining %d sec. Processing event Starting bolus delivery From 0af51bb6ea2c11df5fe31bbe8e5be924486b3e31 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Tue, 7 Nov 2017 13:24:08 +0100 Subject: [PATCH 05/15] show timeshift if not zero --- .../java/info/nightscout/androidaps/db/ProfileSwitch.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/info/nightscout/androidaps/db/ProfileSwitch.java b/app/src/main/java/info/nightscout/androidaps/db/ProfileSwitch.java index 8bcd192d59..7aea077e0a 100644 --- a/app/src/main/java/info/nightscout/androidaps/db/ProfileSwitch.java +++ b/app/src/main/java/info/nightscout/androidaps/db/ProfileSwitch.java @@ -72,7 +72,10 @@ public class ProfileSwitch implements Interval, DataPointWithLabelInterface { name = DecimalFormatter.to2Decimal(getProfileObject().percentageBasalSum()) + "U "; } if (isCPP) { - name += "(" + percentage + "%," + timeshift + "h)"; + name += "(" + percentage + "%"; + if (timeshift != 0) + name += "," + timeshift + "h"; + name += ")"; } return name; } From 30f16c7d3e1431766df315a58afc7484c76eff32 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 8 Nov 2017 19:13:44 +0100 Subject: [PATCH 06/15] RS fix extended bolus result --- .../PumpDanaRS/comm/DanaRS_Packet_Bolus_Set_Extended_Bolus.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Set_Extended_Bolus.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Set_Extended_Bolus.java index 887a9d852a..46fc6fdf39 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Set_Extended_Bolus.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Set_Extended_Bolus.java @@ -42,7 +42,7 @@ public class DanaRS_Packet_Bolus_Set_Extended_Bolus extends DanaRS_Packet { public void handleMessage(byte[] data) { int result = intFromBuff(data, 0, 1); if (Config.logDanaMessageDetail) { - if (result == 0) + if (result != 0) log.debug("Result OK"); else log.error("Result Error: " + result); From 676dfcc5d1cbec972449bab7fa0a57619167f6d4 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 8 Nov 2017 19:18:17 +0100 Subject: [PATCH 07/15] RS remove duplicated message --- .../androidaps/plugins/PumpDanaRS/services/DanaRSService.java | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/services/DanaRSService.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/services/DanaRSService.java index 399254f84b..f7c9b00efa 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/services/DanaRSService.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/services/DanaRSService.java @@ -130,7 +130,7 @@ public class DanaRSService extends Service { MainApp.bus().post(new EventPumpStatusChanged(MainApp.sResources.getString(R.string.gettingextendedbolusstatus))); bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Extended_Bolus_State()); MainApp.bus().post(new EventPumpStatusChanged(MainApp.sResources.getString(R.string.gettingbolusstatus))); - bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Step_Bolus_Information()); // last bolus + bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Step_Bolus_Information()); // last bolus, bolusStep, maxBolus MainApp.bus().post(new EventPumpStatusChanged(MainApp.sResources.getString(R.string.gettingtempbasalstatus))); bleComm.sendMessage(new DanaRS_Packet_Basal_Get_Temporary_Basal_State()); @@ -141,7 +141,6 @@ public class DanaRSService extends Service { bleComm.sendMessage(new DanaRS_Packet_General_Get_Pump_Check()); // firmware bleComm.sendMessage(new DanaRS_Packet_Basal_Get_Profile_Number()); bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Bolus_Option()); // isExtendedEnabled - bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Step_Bolus_Information()); // bolusStep, maxBolus bleComm.sendMessage(new DanaRS_Packet_Basal_Get_Basal_Rate()); // basal profile, basalStep, maxBasal bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_Calculation_Information()); // target bleComm.sendMessage(new DanaRS_Packet_Bolus_Get_CIR_CF_Array()); From 3a773feeeb957631fa2bee5bc836e757a8f305d3 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Wed, 8 Nov 2017 19:23:48 +0100 Subject: [PATCH 08/15] RS fix last bolus time --- .../DanaRS_Packet_Bolus_Get_Step_Bolus_Information.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Get_Step_Bolus_Information.java b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Get_Step_Bolus_Information.java index 922b7886f2..6166f7b0fb 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Get_Step_Bolus_Information.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/PumpDanaRS/comm/DanaRS_Packet_Bolus_Get_Step_Bolus_Information.java @@ -33,14 +33,14 @@ public class DanaRS_Packet_Bolus_Get_Step_Bolus_Information extends DanaRS_Packe dataSize = 2; pump.initialBolusAmount = byteArrayToInt(getBytes(data, dataIndex, dataSize)) / 100d; - Date lastBolusTime = new Date(); // it doesn't provide day only hour+min, workaround: expecting today + pump.lastBolusTime = new Date(); // it doesn't provide day only hour+min, workaround: expecting today dataIndex += dataSize; dataSize = 1; - lastBolusTime.setHours(byteArrayToInt(getBytes(data, dataIndex, dataSize))); + pump.lastBolusTime.setHours(byteArrayToInt(getBytes(data, dataIndex, dataSize))); dataIndex += dataSize; dataSize = 1; - lastBolusTime.setMinutes(byteArrayToInt(getBytes(data, dataIndex, dataSize))); + pump.lastBolusTime.setMinutes(byteArrayToInt(getBytes(data, dataIndex, dataSize))); dataIndex += dataSize; dataSize = 2; @@ -58,7 +58,7 @@ public class DanaRS_Packet_Bolus_Get_Step_Bolus_Information extends DanaRS_Packe log.debug("Result: " + error); log.debug("BolusType: " + bolusType); log.debug("Initial bolus amount: " + pump.initialBolusAmount + " U"); - log.debug("Last bolus time: " + lastBolusTime.toLocaleString()); + log.debug("Last bolus time: " + pump.lastBolusTime.toLocaleString()); log.debug("Last bolus amount: " + pump.lastBolusAmount); log.debug("Max bolus: " + pump.maxBolus + " U"); log.debug("Bolus step: " + pump.bolusStep + " U"); From 9a4acbe052aac71c4878860f3af59a34efac76b3 Mon Sep 17 00:00:00 2001 From: Johannes Mockenhaupt Date: Wed, 8 Nov 2017 10:20:49 +0100 Subject: [PATCH 09/15] Fix NPE initialising MyPreferencesFragment. --- .../nightscout/androidaps/PreferencesActivity.java | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java index 8d5a174ca7..b7ffa422f0 100644 --- a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java @@ -46,7 +46,9 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); myPreferenceFragment = new MyPreferenceFragment(); - myPreferenceFragment.setCaller(getIntent()); + Bundle args = new Bundle(); + args.putInt("id", getIntent().getIntExtra("id", -1)); + myPreferenceFragment.setArguments(args); getFragmentManager().beginTransaction().replace(android.R.id.content, myPreferenceFragment).commit(); PreferenceManager.getDefaultSharedPreferences(this).registerOnSharedPreferenceChangeListener(this); } @@ -105,10 +107,12 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre } public static class MyPreferenceFragment extends PreferenceFragment { - Intent caller; + private Integer id; - public void setCaller(Intent i) { - caller = i; + @Override + public void setArguments(Bundle args) { + super.setArguments(args); + id = args.getInt("id"); } void addPreferencesFromResourceIfEnabled(PluginBase p, int type) { @@ -120,8 +124,6 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre public void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); - Integer id = caller.getIntExtra("id", -1); - if (id != -1) { addPreferencesFromResource(id); addPreferencesFromResource(R.xml.pref_advanced); From 5839ad6a931ad85a927804e447c3a7072c417fab Mon Sep 17 00:00:00 2001 From: Johannes Mockenhaupt Date: Wed, 8 Nov 2017 18:02:13 +0100 Subject: [PATCH 10/15] Ctors Android-style. --- .../androidaps/PreferencesActivity.java | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java index b7ffa422f0..5641818993 100644 --- a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java @@ -1,6 +1,5 @@ package info.nightscout.androidaps; -import android.content.Intent; import android.content.SharedPreferences; import android.os.Bundle; import android.preference.EditTextPreference; @@ -23,7 +22,6 @@ import info.nightscout.androidaps.plugins.Loop.LoopPlugin; import info.nightscout.androidaps.plugins.NSClientInternal.NSClientInternalPlugin; import info.nightscout.androidaps.plugins.OpenAPSAMA.OpenAPSAMAPlugin; import info.nightscout.androidaps.plugins.OpenAPSMA.OpenAPSMAPlugin; -import info.nightscout.androidaps.plugins.PumpDanaR.BluetoothDevicePreference; import info.nightscout.androidaps.plugins.PumpDanaR.DanaRPlugin; import info.nightscout.androidaps.plugins.PumpDanaRKorean.DanaRKoreanPlugin; import info.nightscout.androidaps.plugins.PumpDanaRS.DanaRSPlugin; @@ -72,7 +70,7 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre } private static void updatePrefSummary(Preference pref) { - if (pref instanceof ListPreference || pref instanceof BluetoothDevicePreference) { + if (pref instanceof ListPreference) { ListPreference listPref = (ListPreference) pref; pref.setSummary(listPref.getEntry()); } @@ -85,7 +83,7 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre } else if (editTextPref.getText() != null && !editTextPref.getText().equals("")) { ((EditTextPreference) pref).setDialogMessage(editTextPref.getDialogMessage()); pref.setSummary(editTextPref.getText()); - } else if (pref.getKey().contains("smscommunicator_allowednumbers") && TextUtils.isEmpty(editTextPref.getText().toString().trim())) { + } else if (pref.getKey().contains("smscommunicator_allowednumbers") && TextUtils.isEmpty(editTextPref.getText().trim())) { pref.setSummary(MainApp.sResources.getString(R.string.smscommunicator_allowednumbers_summary)); } } @@ -124,6 +122,10 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre public void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); + if (savedInstanceState != null && savedInstanceState.containsKey("id")) { + id = savedInstanceState.getInt("id"); + } + if (id != -1) { addPreferencesFromResource(id); addPreferencesFromResource(R.xml.pref_advanced); @@ -186,6 +188,12 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre initSummary(getPreferenceScreen()); } + @Override + public void onSaveInstanceState(Bundle outState) { + super.onSaveInstanceState(outState); + outState.putInt("id", id); + } + public Preference getPreference(String key) { return findPreference(key); } From e0df4646f918a37dfb8d92a030a71bedd722b1d5 Mon Sep 17 00:00:00 2001 From: Johannes Mockenhaupt Date: Wed, 8 Nov 2017 18:49:02 +0100 Subject: [PATCH 11/15] Remove dead code. --- .../java/info/nightscout/androidaps/PreferencesActivity.java | 4 ---- 1 file changed, 4 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java index 5641818993..ad795f6421 100644 --- a/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java +++ b/app/src/main/java/info/nightscout/androidaps/PreferencesActivity.java @@ -87,10 +87,6 @@ public class PreferencesActivity extends PreferenceActivity implements SharedPre pref.setSummary(MainApp.sResources.getString(R.string.smscommunicator_allowednumbers_summary)); } } - if (pref instanceof MultiSelectListPreference) { - EditTextPreference editTextPref = (EditTextPreference) pref; - pref.setSummary(editTextPref.getText()); - } } public static void initSummary(Preference p) { From d8798e0bcf26c711b9e6a747203c9d3c61d7ba54 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 20 Nov 2017 13:23:25 +0100 Subject: [PATCH 12/15] use mills from status if available --- .../plugins/NSClientInternal/data/NSDeviceStatus.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/data/NSDeviceStatus.java b/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/data/NSDeviceStatus.java index 2df50b2bd1..2bd61aa4a9 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/data/NSDeviceStatus.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/NSClientInternal/data/NSDeviceStatus.java @@ -336,7 +336,9 @@ public class NSDeviceStatus { try { long clock = 0L; - if (object.has("created_at")) + if (object.has("mills")) + clock = object.getLong("mills"); + else if (object.has("created_at")) clock = DateUtil.fromISODateString(object.getString("created_at")).getTime(); String device = getDevice(); Integer battery = null; From 297617467e880784c04335f5bf13184385e1d047 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 20 Nov 2017 13:34:13 +0100 Subject: [PATCH 13/15] fix format and add test for fromISODateString --- .../java/info/nightscout/utils/DateUtil.java | 4 +-- .../info/nightscout/utils/DateUtilTest.java | 25 +++++++++++++++++++ 2 files changed, 27 insertions(+), 2 deletions(-) create mode 100644 app/src/test/java/info/nightscout/utils/DateUtilTest.java diff --git a/app/src/main/java/info/nightscout/utils/DateUtil.java b/app/src/main/java/info/nightscout/utils/DateUtil.java index 3e32557adb..1e399ddd58 100644 --- a/app/src/main/java/info/nightscout/utils/DateUtil.java +++ b/app/src/main/java/info/nightscout/utils/DateUtil.java @@ -27,8 +27,8 @@ public class DateUtil { /** * The date format in iso. */ - private static String FORMAT_DATE_ISO = "yyyy-MM-dd'T'HH:mm:ss'Z'"; - private static String FORMAT_DATE_ISO_MSEC = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'"; + private static String FORMAT_DATE_ISO = "yyyy-MM-dd'T'HH:mm:ssZ"; + private static String FORMAT_DATE_ISO_MSEC = "yyyy-MM-dd'T'HH:mm:ss.SSSZ"; /** * Takes in an ISO date string of the following format: diff --git a/app/src/test/java/info/nightscout/utils/DateUtilTest.java b/app/src/test/java/info/nightscout/utils/DateUtilTest.java new file mode 100644 index 0000000000..f269253ba8 --- /dev/null +++ b/app/src/test/java/info/nightscout/utils/DateUtilTest.java @@ -0,0 +1,25 @@ +package info.nightscout.utils; + + +import org.junit.Test; + +import static org.junit.Assert.*; + +/** + * Created by mike on 20.11.2017. + */ + +public class DateUtilTest { + + public DateUtilTest() { + super(); + } + + @Test + public void fromISODateStringTest() throws Exception { + assertEquals( 1511124634417L, DateUtil.fromISODateString("2017-11-19T22:50:34.417+0200").getTime()); + assertEquals( 1511124634000L, DateUtil.fromISODateString("2017-11-19T22:50:34+0200").getTime()); + } + + +} From 777aedd5db77bb839d9d980003596a60d28e0b1c Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 20 Nov 2017 15:25:44 +0100 Subject: [PATCH 14/15] fix setting of TRB when low basal rate is running --- .../androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java index 12f1f46c1c..c074e7a8d0 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java @@ -564,7 +564,7 @@ public class ConfigBuilderPlugin implements PluginBase, PumpInterface, Constrain if (Config.logCongigBuilderActions) log.debug("applyAPSRequest: " + request.toString()); - if ((request.rate == 0 && request.duration == 0) || Math.abs(request.rate - getBaseBasalRate()) < 0.05) { + if ((request.rate == 0 && request.duration == 0) || Math.abs(request.rate - getBaseBasalRate()) < getPumpDescription().basalStep) { if (isTempBasalInProgress()) { if (Config.logCongigBuilderActions) log.debug("applyAPSRequest: cancelTempBasal()"); From 0f0f39dfb4c4536f0b0936844f8547d7eff1f135 Mon Sep 17 00:00:00 2001 From: Milos Kozak Date: Mon, 20 Nov 2017 17:26:03 +0100 Subject: [PATCH 15/15] log profiles if different --- .../plugins/ConfigBuilder/ConfigBuilderPlugin.java | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java index c074e7a8d0..eb8f6cb442 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConfigBuilder/ConfigBuilderPlugin.java @@ -409,9 +409,13 @@ public class ConfigBuilderPlugin implements PluginBase, PumpInterface, Constrain @Override public boolean isThisProfileSet(Profile profile) { - if (activePump != null) - return activePump.isThisProfileSet(profile); - else return true; + if (activePump != null) { + boolean result = activePump.isThisProfileSet(profile); + if (result == false) { + log.debug("Current profile: " + getProfile().getData().toString()); + log.debug("New profile: " + profile.getData().toString()); + } + } else return true; } @Override