Merge pull request #771 from jotomo/remove-pre-bolus
Next round of button updates
This commit is contained in:
commit
1c413cc49f
7 changed files with 263 additions and 162 deletions
|
@ -39,10 +39,13 @@ public class Constants {
|
||||||
// Temp targets
|
// Temp targets
|
||||||
public static final int defaultActivityTTDuration = 90; // min
|
public static final int defaultActivityTTDuration = 90; // min
|
||||||
public static final double defaultActivityTTmgdl = 90d;
|
public static final double defaultActivityTTmgdl = 90d;
|
||||||
public static final double defaultActivityTTmmol = 5d;
|
public static final double defaultActivityTTmmol = 8d;
|
||||||
public static final int defaultEatingSoonTTDuration = 45; // min
|
public static final int defaultEatingSoonTTDuration = 45; // min
|
||||||
public static final double defaultEatingSoonTTmgdl = 140d;
|
public static final double defaultEatingSoonTTmgdl = 140d;
|
||||||
public static final double defaultEatingSoonTTmmol = 8d;
|
public static final double defaultEatingSoonTTmmol = 5d;
|
||||||
|
public static final int defaultHypoTTDuration = 30; // min
|
||||||
|
public static final double defaultHypoTTmgdl = 120d;
|
||||||
|
public static final double defaultHypoTTmmol = 6.5d;
|
||||||
|
|
||||||
//NSClientInternal
|
//NSClientInternal
|
||||||
public static final int MAX_LOG_LINES = 100;
|
public static final int MAX_LOG_LINES = 100;
|
||||||
|
|
|
@ -17,21 +17,23 @@ import android.view.ViewGroup;
|
||||||
import android.view.Window;
|
import android.view.Window;
|
||||||
import android.view.WindowManager;
|
import android.view.WindowManager;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.CheckBox;
|
import android.widget.CompoundButton;
|
||||||
import android.widget.EditText;
|
import android.widget.RadioButton;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.google.common.base.Joiner;
|
||||||
import com.wdullaer.materialdatetimepicker.date.DatePickerDialog;
|
import com.wdullaer.materialdatetimepicker.date.DatePickerDialog;
|
||||||
import com.wdullaer.materialdatetimepicker.time.RadialPickerLayout;
|
import com.wdullaer.materialdatetimepicker.time.RadialPickerLayout;
|
||||||
import com.wdullaer.materialdatetimepicker.time.TimePickerDialog;
|
import com.wdullaer.materialdatetimepicker.time.TimePickerDialog;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import info.nightscout.androidaps.Constants;
|
import info.nightscout.androidaps.Constants;
|
||||||
import info.nightscout.androidaps.MainApp;
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
@ -42,7 +44,6 @@ import info.nightscout.androidaps.db.CareportalEvent;
|
||||||
import info.nightscout.androidaps.db.Source;
|
import info.nightscout.androidaps.db.Source;
|
||||||
import info.nightscout.androidaps.db.TempTarget;
|
import info.nightscout.androidaps.db.TempTarget;
|
||||||
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
||||||
import info.nightscout.androidaps.plugins.Loop.LoopPlugin;
|
|
||||||
import info.nightscout.androidaps.queue.Callback;
|
import info.nightscout.androidaps.queue.Callback;
|
||||||
import info.nightscout.utils.DateUtil;
|
import info.nightscout.utils.DateUtil;
|
||||||
import info.nightscout.utils.DecimalFormatter;
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
|
@ -51,7 +52,7 @@ import info.nightscout.utils.SP;
|
||||||
import info.nightscout.utils.SafeParse;
|
import info.nightscout.utils.SafeParse;
|
||||||
import info.nightscout.utils.ToastUtils;
|
import info.nightscout.utils.ToastUtils;
|
||||||
|
|
||||||
public class NewCarbsDialog extends DialogFragment implements OnClickListener, DatePickerDialog.OnDateSetListener, TimePickerDialog.OnTimeSetListener {
|
public class NewCarbsDialog extends DialogFragment implements OnClickListener, DatePickerDialog.OnDateSetListener, TimePickerDialog.OnTimeSetListener, CompoundButton.OnCheckedChangeListener {
|
||||||
private static Logger log = LoggerFactory.getLogger(NewCarbsDialog.class);
|
private static Logger log = LoggerFactory.getLogger(NewCarbsDialog.class);
|
||||||
|
|
||||||
private NumberPicker editCarbs;
|
private NumberPicker editCarbs;
|
||||||
|
@ -69,9 +70,10 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
private static final int FAV1_DEFAULT = 5;
|
private static final int FAV1_DEFAULT = 5;
|
||||||
private static final int FAV2_DEFAULT = 10;
|
private static final int FAV2_DEFAULT = 10;
|
||||||
private static final int FAV3_DEFAULT = 20;
|
private static final int FAV3_DEFAULT = 20;
|
||||||
private CheckBox suspendLoopCheckbox;
|
private RadioButton startActivityTTCheckbox;
|
||||||
private CheckBox startActivityTTCheckbox;
|
private RadioButton startEatingSoonTTCheckbox;
|
||||||
private CheckBox startEatingSoonTTCheckbox;
|
private RadioButton startHypoTTCheckbox;
|
||||||
|
private boolean togglingTT;
|
||||||
|
|
||||||
private Integer maxCarbs;
|
private Integer maxCarbs;
|
||||||
|
|
||||||
|
@ -125,7 +127,11 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
editCarbs.setParams(0d, 0d, (double) maxCarbs, 1d, new DecimalFormat("0"), false, textWatcher);
|
editCarbs.setParams(0d, 0d, (double) maxCarbs, 1d, new DecimalFormat("0"), false, textWatcher);
|
||||||
|
|
||||||
startActivityTTCheckbox = view.findViewById(R.id.newcarbs_activity_tt);
|
startActivityTTCheckbox = view.findViewById(R.id.newcarbs_activity_tt);
|
||||||
startEatingSoonTTCheckbox = view.findViewById(R.id.carbs_eating_soon_tt);
|
startActivityTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
startEatingSoonTTCheckbox = view.findViewById(R.id.newcarbs_eating_soon_tt);
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
startHypoTTCheckbox = view.findViewById(R.id.newcarbs_hypo_tt);
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
|
||||||
dateButton = view.findViewById(R.id.newcarbs_eventdate);
|
dateButton = view.findViewById(R.id.newcarbs_eventdate);
|
||||||
timeButton = view.findViewById(R.id.newcarb_eventtime);
|
timeButton = view.findViewById(R.id.newcarb_eventtime);
|
||||||
|
@ -137,10 +143,6 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
dateButton.setOnClickListener(this);
|
dateButton.setOnClickListener(this);
|
||||||
timeButton.setOnClickListener(this);
|
timeButton.setOnClickListener(this);
|
||||||
|
|
||||||
//To be able to select only one TT at a time
|
|
||||||
startEatingSoonTTCheckbox.setOnClickListener(this);
|
|
||||||
startActivityTTCheckbox.setOnClickListener(this);
|
|
||||||
|
|
||||||
fav1Button = view.findViewById(R.id.newcarbs_plus1);
|
fav1Button = view.findViewById(R.id.newcarbs_plus1);
|
||||||
fav1Button.setOnClickListener(this);
|
fav1Button.setOnClickListener(this);
|
||||||
fav1Button.setText(toSignedString(SP.getInt(R.string.key_carbs_button_increment_1, FAV1_DEFAULT)));
|
fav1Button.setText(toSignedString(SP.getInt(R.string.key_carbs_button_increment_1, FAV1_DEFAULT)));
|
||||||
|
@ -153,8 +155,6 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
fav3Button.setOnClickListener(this);
|
fav3Button.setOnClickListener(this);
|
||||||
fav3Button.setText(toSignedString(SP.getInt(R.string.key_carbs_button_increment_3, FAV3_DEFAULT)));
|
fav3Button.setText(toSignedString(SP.getInt(R.string.key_carbs_button_increment_3, FAV3_DEFAULT)));
|
||||||
|
|
||||||
suspendLoopCheckbox = view.findViewById(R.id.newcarbs_suspend_loop);
|
|
||||||
|
|
||||||
setCancelable(true);
|
setCancelable(true);
|
||||||
getDialog().setCanceledOnTouchOutside(false);
|
getDialog().setCanceledOnTouchOutside(false);
|
||||||
return view;
|
return view;
|
||||||
|
@ -213,12 +213,84 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
validateInputs();
|
validateInputs();
|
||||||
break;
|
break;
|
||||||
case R.id.newcarbs_activity_tt:
|
case R.id.newcarbs_activity_tt:
|
||||||
startEatingSoonTTCheckbox.setChecked(false);
|
if (togglingTT) {
|
||||||
|
togglingTT = false;
|
||||||
break;
|
break;
|
||||||
case R.id.carbs_eating_soon_tt:
|
}
|
||||||
|
startActivityTTCheckbox.setOnClickListener(null);
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
startActivityTTCheckbox.setChecked(false);
|
startActivityTTCheckbox.setChecked(false);
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
break;
|
break;
|
||||||
|
case R.id.newcarbs_eating_soon_tt:
|
||||||
|
if (togglingTT) {
|
||||||
|
togglingTT = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
startEatingSoonTTCheckbox.setOnClickListener(null);
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startEatingSoonTTCheckbox.setChecked(false);
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
break;
|
||||||
|
case R.id.newcarbs_hypo_tt:
|
||||||
|
if (togglingTT) {
|
||||||
|
togglingTT = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
startHypoTTCheckbox.setOnClickListener(null);
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startHypoTTCheckbox.setChecked(false);
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
|
||||||
|
// Logic to disable a selected radio when pressed. When a checked radio
|
||||||
|
// is pressed, no CheckChanged event is trigger, so register a Click event
|
||||||
|
// when checking a radio. Since Click events come after CheckChanged events,
|
||||||
|
// the Click event is triggered immediately after this. Thus, set toggingTT
|
||||||
|
// var to true, so that the first Click event fired after this is ignored.
|
||||||
|
// Radios remove themselves from Click events once unchecked.
|
||||||
|
// Since radios are not in a group, manually update their state.
|
||||||
|
switch (buttonView.getId()) {
|
||||||
|
case R.id.newcarbs_activity_tt:
|
||||||
|
togglingTT = true;
|
||||||
|
startActivityTTCheckbox.setOnClickListener(this);
|
||||||
|
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startEatingSoonTTCheckbox.setChecked(false);
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startHypoTTCheckbox.setChecked(false);
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
break;
|
||||||
|
case R.id.newcarbs_eating_soon_tt:
|
||||||
|
togglingTT = true;
|
||||||
|
startEatingSoonTTCheckbox.setOnClickListener(this);
|
||||||
|
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startActivityTTCheckbox.setChecked(false);
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startHypoTTCheckbox.setChecked(false);
|
||||||
|
startHypoTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
break;
|
||||||
|
case R.id.newcarbs_hypo_tt:
|
||||||
|
togglingTT = true;
|
||||||
|
startHypoTTCheckbox.setOnClickListener(this);
|
||||||
|
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startActivityTTCheckbox.setChecked(false);
|
||||||
|
startActivityTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(null);
|
||||||
|
startEatingSoonTTCheckbox.setChecked(false);
|
||||||
|
startEatingSoonTTCheckbox.setOnCheckedChangeListener(this);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -233,14 +305,11 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
final Integer carbs = SafeParse.stringToInt(editCarbs.getText());
|
final Integer carbs = SafeParse.stringToInt(editCarbs.getText());
|
||||||
Integer carbsAfterConstraints = MainApp.getConfigBuilder().applyCarbsConstraints(carbs);
|
Integer carbsAfterConstraints = MainApp.getConfigBuilder().applyCarbsConstraints(carbs);
|
||||||
|
|
||||||
String confirmMessage = "";
|
List<String> actions = new LinkedList<>();
|
||||||
if (carbs > 0)
|
if (carbs > 0)
|
||||||
confirmMessage += MainApp.gs(R.string.carbs) + ": " + "<font color='" + MainApp.gc(R.color.colorCarbsButton) + "'>" + carbsAfterConstraints + "g" + "</font>";
|
actions.add(MainApp.gs(R.string.carbs) + ": " + "<font color='" + MainApp.gc(R.color.colorCarbsButton) + "'>" + carbsAfterConstraints + "g" + "</font>");
|
||||||
if (!carbsAfterConstraints.equals(carbs))
|
if (!carbsAfterConstraints.equals(carbs))
|
||||||
confirmMessage += "<br/><font color='" + MainApp.gc(R.color.low) + "'>" + MainApp.gs(R.string.carbsconstraintapplied) + "</font>";
|
actions.add("<font color='" + MainApp.gc(R.color.low) + "'>" + MainApp.gs(R.string.carbsconstraintapplied) + "</font>");
|
||||||
if (suspendLoopCheckbox.isChecked()) {
|
|
||||||
confirmMessage += "<br/>" + MainApp.gs(R.string.loop) + ": " + "<font color='" + MainApp.gc(R.color.low) + "'>" + MainApp.gs(R.string.suspendloopfor30min) + "</font>";
|
|
||||||
}
|
|
||||||
|
|
||||||
final Profile currentProfile = MainApp.getConfigBuilder().getProfile();
|
final Profile currentProfile = MainApp.getConfigBuilder().getProfile();
|
||||||
if (currentProfile == null)
|
if (currentProfile == null)
|
||||||
|
@ -256,29 +325,41 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
double eatingSoonTT = SP.getDouble(R.string.key_eatingsoon_target, currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultEatingSoonTTmmol : Constants.defaultEatingSoonTTmgdl);
|
double eatingSoonTT = SP.getDouble(R.string.key_eatingsoon_target, currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultEatingSoonTTmmol : Constants.defaultEatingSoonTTmgdl);
|
||||||
eatingSoonTT = eatingSoonTT > 0 ? eatingSoonTT : currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultEatingSoonTTmmol : Constants.defaultEatingSoonTTmgdl;
|
eatingSoonTT = eatingSoonTT > 0 ? eatingSoonTT : currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultEatingSoonTTmmol : Constants.defaultEatingSoonTTmgdl;
|
||||||
|
|
||||||
|
int hypoTTDuration = SP.getInt(R.string.key_hypo_duration, Constants.defaultHypoTTDuration);
|
||||||
|
hypoTTDuration = hypoTTDuration > 0 ? hypoTTDuration : Constants.defaultHypoTTDuration;
|
||||||
|
double hypoTT = SP.getDouble(R.string.key_hypo_target, currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultHypoTTmmol : Constants.defaultHypoTTmgdl);
|
||||||
|
hypoTT = hypoTT > 0 ? hypoTT : currentProfile.getUnits().equals(Constants.MMOL) ? Constants.defaultHypoTTmmol : Constants.defaultHypoTTmgdl;
|
||||||
|
|
||||||
if (startActivityTTCheckbox.isChecked()) {
|
if (startActivityTTCheckbox.isChecked()) {
|
||||||
if (currentProfile.getUnits().equals(Constants.MMOL)) {
|
if (currentProfile.getUnits().equals(Constants.MMOL)) {
|
||||||
confirmMessage += "<br/>" + MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to1Decimal(activityTT) + " mmol/l (" + ((int) activityTTDuration) + " min)</font>";
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to1Decimal(activityTT) + " mmol/l (" + activityTTDuration + " min)</font>");
|
||||||
} else
|
} else
|
||||||
confirmMessage += "<br/>" + MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to0Decimal(activityTT) + " mg/dl (" + ((int) activityTTDuration) + " min)</font>";
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to0Decimal(activityTT) + " mg/dl (" + activityTTDuration + " min)</font>");
|
||||||
|
|
||||||
}
|
}
|
||||||
if (startEatingSoonTTCheckbox.isChecked() && !startActivityTTCheckbox.isChecked()) {
|
if (startEatingSoonTTCheckbox.isChecked()) {
|
||||||
if (currentProfile.getUnits().equals(Constants.MMOL)) {
|
if (currentProfile.getUnits().equals(Constants.MMOL)) {
|
||||||
confirmMessage += "<br/>" + MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to1Decimal(eatingSoonTT) + " mmol/l (" + eatingSoonTTDuration + " min)</font>";
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to1Decimal(eatingSoonTT) + " mmol/l (" + eatingSoonTTDuration + " min)</font>");
|
||||||
} else
|
} else
|
||||||
confirmMessage += "<br/>" + MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to0Decimal(eatingSoonTT) + " mg/dl (" + eatingSoonTTDuration + " min)</font>";
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to0Decimal(eatingSoonTT) + " mg/dl (" + eatingSoonTTDuration + " min)</font>");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
if (startHypoTTCheckbox.isChecked()) {
|
||||||
|
if (currentProfile.getUnits().equals(Constants.MMOL)) {
|
||||||
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to1Decimal(hypoTT) + " mmol/l (" + hypoTTDuration + " min)</font>");
|
||||||
|
} else
|
||||||
|
actions.add(MainApp.gs(R.string.temptargetshort) + ": " + "<font color='" + MainApp.gc(R.color.high) + "'>" + DecimalFormatter.to0Decimal(hypoTT) + " mg/dl (" + hypoTTDuration + " min)</font>");
|
||||||
|
}
|
||||||
|
|
||||||
final double finalActivityTT = activityTT;
|
final double finalActivityTT = activityTT;
|
||||||
final double finalEatigSoonTT = eatingSoonTT;
|
|
||||||
final int finalActivityTTDuration = activityTTDuration;
|
final int finalActivityTTDuration = activityTTDuration;
|
||||||
|
final double finalEatigSoonTT = eatingSoonTT;
|
||||||
final int finalEatingSoonTTDuration = eatingSoonTTDuration;
|
final int finalEatingSoonTTDuration = eatingSoonTTDuration;
|
||||||
|
final double finalHypoTT = hypoTT;
|
||||||
|
final int finalHypoTTDuration = hypoTTDuration;
|
||||||
|
|
||||||
if (!initialEventTime.equals(eventTime)) {
|
if (!initialEventTime.equals(eventTime)) {
|
||||||
confirmMessage += "<br/> Time: " + DateUtil.dateAndTimeString(eventTime);
|
actions.add("Time: " + DateUtil.dateAndTimeString(eventTime));
|
||||||
}
|
}
|
||||||
if (confirmMessage.length() > 0) {
|
|
||||||
|
|
||||||
final int finalCarbsAfterConstraints = carbsAfterConstraints;
|
final int finalCarbsAfterConstraints = carbsAfterConstraints;
|
||||||
|
|
||||||
|
@ -286,11 +367,10 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
final AlertDialog.Builder builder = new AlertDialog.Builder(context);
|
final AlertDialog.Builder builder = new AlertDialog.Builder(context);
|
||||||
|
|
||||||
builder.setTitle(MainApp.gs(R.string.confirmation));
|
builder.setTitle(MainApp.gs(R.string.confirmation));
|
||||||
if (confirmMessage.startsWith("<br/>"))
|
builder.setMessage(actions.isEmpty()
|
||||||
confirmMessage = confirmMessage.substring("<br/>".length());
|
? MainApp.gs(R.string.no_action_selected)
|
||||||
|
: Html.fromHtml(Joiner.on("<br/>").join(actions)));
|
||||||
builder.setMessage(Html.fromHtml(confirmMessage));
|
builder.setPositiveButton(MainApp.gs(R.string.ok), actions.isEmpty() ? null : (dialog, id) -> {
|
||||||
builder.setPositiveButton(MainApp.gs(R.string.ok), (dialog, id) -> {
|
|
||||||
synchronized (builder) {
|
synchronized (builder) {
|
||||||
if (accepted) {
|
if (accepted) {
|
||||||
log.debug("guarding: already accepted");
|
log.debug("guarding: already accepted");
|
||||||
|
@ -298,19 +378,6 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
}
|
}
|
||||||
accepted = true;
|
accepted = true;
|
||||||
|
|
||||||
if (suspendLoopCheckbox.isChecked()) {
|
|
||||||
final LoopPlugin activeloop = ConfigBuilderPlugin.getActiveLoop();
|
|
||||||
activeloop.suspendTo(System.currentTimeMillis() + 30L * 60 * 1000);
|
|
||||||
ConfigBuilderPlugin.getCommandQueue().cancelTempBasal(true, new Callback() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
if (!result.success) {
|
|
||||||
ToastUtils.showToastInUiThread(MainApp.instance().getApplicationContext(), MainApp.gs(R.string.tempbasaldeliveryerror));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (startActivityTTCheckbox.isChecked()) {
|
if (startActivityTTCheckbox.isChecked()) {
|
||||||
TempTarget tempTarget = new TempTarget();
|
TempTarget tempTarget = new TempTarget();
|
||||||
tempTarget.date = System.currentTimeMillis();
|
tempTarget.date = System.currentTimeMillis();
|
||||||
|
@ -329,6 +396,15 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
tempTarget.low = Profile.toMgdl(finalEatigSoonTT, currentProfile.getUnits());
|
tempTarget.low = Profile.toMgdl(finalEatigSoonTT, currentProfile.getUnits());
|
||||||
tempTarget.high = Profile.toMgdl(finalEatigSoonTT, currentProfile.getUnits());
|
tempTarget.high = Profile.toMgdl(finalEatigSoonTT, currentProfile.getUnits());
|
||||||
MainApp.getDbHelper().createOrUpdate(tempTarget);
|
MainApp.getDbHelper().createOrUpdate(tempTarget);
|
||||||
|
} else if (startHypoTTCheckbox.isChecked()) {
|
||||||
|
TempTarget tempTarget = new TempTarget();
|
||||||
|
tempTarget.date = System.currentTimeMillis();
|
||||||
|
tempTarget.durationInMinutes = finalHypoTTDuration;
|
||||||
|
tempTarget.reason = MainApp.gs(R.string.hypo);
|
||||||
|
tempTarget.source = Source.USER;
|
||||||
|
tempTarget.low = Profile.toMgdl(finalHypoTT, currentProfile.getUnits());
|
||||||
|
tempTarget.high = Profile.toMgdl(finalHypoTT, currentProfile.getUnits());
|
||||||
|
MainApp.getDbHelper().createOrUpdate(tempTarget);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (finalCarbsAfterConstraints > 0) {
|
if (finalCarbsAfterConstraints > 0) {
|
||||||
|
@ -361,12 +437,9 @@ public class NewCarbsDialog extends DialogFragment implements OnClickListener, D
|
||||||
builder.setNegativeButton(MainApp.gs(R.string.cancel), null);
|
builder.setNegativeButton(MainApp.gs(R.string.cancel), null);
|
||||||
builder.show();
|
builder.show();
|
||||||
dismiss();
|
dismiss();
|
||||||
} else
|
|
||||||
dismiss();
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("Unhandled exception", e);
|
log.error("Unhandled exception", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -22,6 +22,7 @@ import android.widget.TextView;
|
||||||
|
|
||||||
import com.crashlytics.android.answers.Answers;
|
import com.crashlytics.android.answers.Answers;
|
||||||
import com.crashlytics.android.answers.CustomEvent;
|
import com.crashlytics.android.answers.CustomEvent;
|
||||||
|
import com.google.common.base.Joiner;
|
||||||
import com.wdullaer.materialdatetimepicker.date.DatePickerDialog;
|
import com.wdullaer.materialdatetimepicker.date.DatePickerDialog;
|
||||||
import com.wdullaer.materialdatetimepicker.time.RadialPickerLayout;
|
import com.wdullaer.materialdatetimepicker.time.RadialPickerLayout;
|
||||||
import com.wdullaer.materialdatetimepicker.time.TimePickerDialog;
|
import com.wdullaer.materialdatetimepicker.time.TimePickerDialog;
|
||||||
|
@ -32,6 +33,8 @@ import org.slf4j.LoggerFactory;
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import info.nightscout.androidaps.Constants;
|
import info.nightscout.androidaps.Constants;
|
||||||
import info.nightscout.androidaps.MainApp;
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
@ -42,8 +45,6 @@ import info.nightscout.androidaps.db.CareportalEvent;
|
||||||
import info.nightscout.androidaps.db.Source;
|
import info.nightscout.androidaps.db.Source;
|
||||||
import info.nightscout.androidaps.db.TempTarget;
|
import info.nightscout.androidaps.db.TempTarget;
|
||||||
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
|
||||||
import info.nightscout.androidaps.plugins.Loop.APSResult;
|
|
||||||
import info.nightscout.androidaps.plugins.OpenAPSSMB.DetermineBasalResultSMB;
|
|
||||||
import info.nightscout.androidaps.queue.Callback;
|
import info.nightscout.androidaps.queue.Callback;
|
||||||
import info.nightscout.utils.DateUtil;
|
import info.nightscout.utils.DateUtil;
|
||||||
import info.nightscout.utils.NumberPicker;
|
import info.nightscout.utils.NumberPicker;
|
||||||
|
@ -145,16 +146,6 @@ public class NewInsulinDialog extends DialogFragment implements OnClickListener,
|
||||||
plus3Button.setText(toSignedString(SP.getDouble(MainApp.gs(R.string.key_insulin_button_increment_3), PLUS3_DEFAULT)));
|
plus3Button.setText(toSignedString(SP.getDouble(MainApp.gs(R.string.key_insulin_button_increment_3), PLUS3_DEFAULT)));
|
||||||
|
|
||||||
startESMCheckbox = (CheckBox) view.findViewById(R.id.newinsulin_start_eating_soon_tt);
|
startESMCheckbox = (CheckBox) view.findViewById(R.id.newinsulin_start_eating_soon_tt);
|
||||||
startESMCheckbox.setOnCheckedChangeListener((buttonView, isChecked) -> {
|
|
||||||
final Profile profile = MainApp.getConfigBuilder().getProfile();
|
|
||||||
if (profile != null) {
|
|
||||||
double tt = SP.getDouble(MainApp.gs(R.string.key_eatingsoon_target), 0d);
|
|
||||||
if (tt > 0) {
|
|
||||||
double ttBgAdd = (profile.getTargetLow() - tt) / profile.getIsf();
|
|
||||||
editInsulin.setValue(editInsulin.getValue() + (isChecked ? ttBgAdd : -ttBgAdd));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
recordOnlyCheckbox = (CheckBox) view.findViewById(R.id.newinsulin_record_only);
|
recordOnlyCheckbox = (CheckBox) view.findViewById(R.id.newinsulin_record_only);
|
||||||
recordOnlyCheckbox.setOnCheckedChangeListener((buttonView, isChecked) -> {
|
recordOnlyCheckbox.setOnCheckedChangeListener((buttonView, isChecked) -> {
|
||||||
|
@ -223,49 +214,50 @@ public class NewInsulinDialog extends DialogFragment implements OnClickListener,
|
||||||
}
|
}
|
||||||
|
|
||||||
private void submit() {
|
private void submit() {
|
||||||
if (okClicked){
|
if (okClicked) {
|
||||||
log.debug("guarding: ok already clicked");
|
log.debug("guarding: ok already clicked");
|
||||||
dismiss();
|
dismiss();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
okClicked = true;
|
okClicked = true;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
Double insulin = SafeParse.stringToDouble(editInsulin.getText());
|
Double insulin = SafeParse.stringToDouble(editInsulin.getText());
|
||||||
Double insulinAfterConstraints = MainApp.getConfigBuilder().applyBolusConstraints(insulin);
|
Double insulinAfterConstraints = MainApp.getConfigBuilder().applyBolusConstraints(insulin);
|
||||||
|
|
||||||
String confirmMessage = "";
|
List<String> actions = new LinkedList<>();
|
||||||
if (insulin > 0) {
|
if (insulin > 0) {
|
||||||
confirmMessage += MainApp.gs(R.string.bolus) + ": " + "<font color='" + MainApp.gc(R.color.colorCarbsButton) + "'>" + insulinAfterConstraints + "U" + "</font>";
|
actions.add(MainApp.gs(R.string.bolus) + ": " + "<font color='" + MainApp.gc(R.color.colorCarbsButton) + "'>" + insulinAfterConstraints + "U" + "</font>");
|
||||||
if (recordOnlyCheckbox.isChecked()) {
|
if (recordOnlyCheckbox.isChecked()) {
|
||||||
confirmMessage += "<br/><font color='" + MainApp.gc(R.color.low) + "'>" + MainApp.gs(R.string.bolusrecordedonly) + "</font>";
|
actions.add("<font color='" + MainApp.gc(R.color.low) + "'>" + MainApp.gs(R.string.bolusrecordedonly) + "</font>");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!insulinAfterConstraints.equals(insulin))
|
if (!insulinAfterConstraints.equals(insulin))
|
||||||
confirmMessage += "<br/><font color='" + MainApp.sResources.getColor(R.color.low) + "'>" + MainApp.gs(R.string.bolusconstraintapplied) + "</font>";
|
actions.add("<font color='" + MainApp.sResources.getColor(R.color.low) + "'>" + MainApp.gs(R.string.bolusconstraintapplied) + "</font>");
|
||||||
|
|
||||||
double prefTTDuration = SP.getDouble(R.string.key_eatingsoon_duration, 45d);
|
double prefTTDuration = SP.getDouble(R.string.key_eatingsoon_duration, 45d);
|
||||||
double ttDuration = prefTTDuration > 0 ? prefTTDuration : 45d;
|
double ttDuration = prefTTDuration > 0 ? prefTTDuration : 45d;
|
||||||
double prefTT = SP.getDouble(R.string.key_eatingsoon_target, 80d);
|
double prefTT = SP.getDouble(R.string.key_eatingsoon_target, 80d);
|
||||||
Profile currentProfile = MainApp.getConfigBuilder().getProfile();
|
Profile currentProfile = MainApp.getConfigBuilder().getProfile();
|
||||||
if(currentProfile == null)
|
if (currentProfile == null)
|
||||||
return;
|
return;
|
||||||
double tt;
|
double tt;
|
||||||
if(currentProfile.getUnits().equals(Constants.MMOL))
|
if (currentProfile.getUnits().equals(Constants.MMOL))
|
||||||
tt = prefTT > 0 ? Profile.toMgdl(prefTT, Constants.MMOL) : 80d;
|
tt = prefTT > 0 ? Profile.toMgdl(prefTT, Constants.MMOL) : 80d;
|
||||||
else
|
else
|
||||||
tt = prefTT > 0 ? prefTT : 80d;
|
tt = prefTT > 0 ? prefTT : 80d;
|
||||||
final double finalTT = tt;
|
final double finalTT = tt;
|
||||||
|
|
||||||
if (startESMCheckbox.isChecked()) {
|
if (startESMCheckbox.isChecked()) {
|
||||||
if(currentProfile.getUnits().equals("mmol")){
|
if (currentProfile.getUnits().equals("mmol")) {
|
||||||
confirmMessage += "<br/>" + "TT: " + "<font color='" + MainApp.sResources.getColor(R.color.high) + "'>" + Profile.toMmol(tt, Constants.MGDL) + " mmol for " + ((int) ttDuration) + " min </font>";
|
actions.add("TT: " + "<font color='" + MainApp.sResources.getColor(R.color.high) + "'>" + Profile.toMmol(tt, Constants.MGDL) + " mmol for " + ((int) ttDuration) + " min </font>");
|
||||||
} else
|
} else
|
||||||
confirmMessage += "<br/>" + "TT: " + "<font color='" + MainApp.sResources.getColor(R.color.high) + "'>" + ((int) tt) + "mg/dl for " + ((int) ttDuration) + " min </font>";
|
actions.add("TT: " + "<font color='" + MainApp.sResources.getColor(R.color.high) + "'>" + ((int) tt) + "mg/dl for " + ((int) ttDuration) + " min </font>");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!initialEventTime.equals(eventTime)) {
|
if (!initialEventTime.equals(eventTime)) {
|
||||||
confirmMessage += "<br/>Time: " + DateUtil.dateAndTimeString(eventTime);
|
actions.add("Time: " + DateUtil.dateAndTimeString(eventTime));
|
||||||
}
|
}
|
||||||
|
|
||||||
final double finalInsulinAfterConstraints = insulinAfterConstraints;
|
final double finalInsulinAfterConstraints = insulinAfterConstraints;
|
||||||
|
@ -274,10 +266,10 @@ public class NewInsulinDialog extends DialogFragment implements OnClickListener,
|
||||||
final AlertDialog.Builder builder = new AlertDialog.Builder(context);
|
final AlertDialog.Builder builder = new AlertDialog.Builder(context);
|
||||||
|
|
||||||
builder.setTitle(MainApp.gs(R.string.confirmation));
|
builder.setTitle(MainApp.gs(R.string.confirmation));
|
||||||
if (confirmMessage.startsWith("<br/>"))
|
builder.setMessage(actions.isEmpty()
|
||||||
confirmMessage = confirmMessage.substring("<br/>".length());
|
? MainApp.gs(R.string.no_action_selected)
|
||||||
builder.setMessage(Html.fromHtml(confirmMessage));
|
: Html.fromHtml(Joiner.on("<br/>").join(actions)));
|
||||||
builder.setPositiveButton(MainApp.gs(R.string.ok), (dialog, id) -> {
|
builder.setPositiveButton(MainApp.gs(R.string.ok), actions.isEmpty() ? null : (dialog, id) -> {
|
||||||
synchronized (builder) {
|
synchronized (builder) {
|
||||||
if (accepted) {
|
if (accepted) {
|
||||||
log.debug("guarding: already accepted");
|
log.debug("guarding: already accepted");
|
||||||
|
|
|
@ -32,25 +32,33 @@
|
||||||
android:padding="5dp"
|
android:padding="5dp"
|
||||||
android:src="@drawable/icon_cp_bolus_carbs" />
|
android:src="@drawable/icon_cp_bolus_carbs" />
|
||||||
|
|
||||||
<CheckBox
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center_horizontal"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<RadioButton
|
||||||
android:id="@+id/newcarbs_activity_tt"
|
android:id="@+id/newcarbs_activity_tt"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_marginTop="5dp"
|
android:layout_marginTop="5dp"
|
||||||
android:text="@string/start_activity_tt" />
|
android:text="@string/start_activity_tt" />
|
||||||
|
|
||||||
<CheckBox
|
<RadioButton
|
||||||
android:id="@+id/carbs_eating_soon_tt"
|
android:id="@+id/newcarbs_eating_soon_tt"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:text="@string/start_eating_soon_tt" />
|
android:text="@string/start_eating_soon_tt" />
|
||||||
|
|
||||||
<CheckBox
|
<RadioButton
|
||||||
android:id="@+id/newcarbs_suspend_loop"
|
android:id="@+id/newcarbs_hypo_tt"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_marginBottom="5dp"
|
android:layout_marginBottom="5dp"
|
||||||
android:text="@string/suspendloopfor30min" />
|
android:text="@string/start_hypo_tt" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
|
|
|
@ -33,6 +33,12 @@
|
||||||
android:padding="5dp"
|
android:padding="5dp"
|
||||||
android:src="@drawable/icon_bolus" />
|
android:src="@drawable/icon_bolus" />
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:layout_gravity="center_horizontal">
|
||||||
|
|
||||||
<CheckBox
|
<CheckBox
|
||||||
android:id="@+id/newinsulin_start_eating_soon_tt"
|
android:id="@+id/newinsulin_start_eating_soon_tt"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
|
@ -46,6 +52,8 @@
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:text="@string/don_t_bolus_record_only" />
|
android:text="@string/don_t_bolus_record_only" />
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
|
|
@ -412,6 +412,7 @@
|
||||||
<string name="openapsama_useautosens">Use AMA autosens feature</string>
|
<string name="openapsama_useautosens">Use AMA autosens feature</string>
|
||||||
<string name="refresheventsfromnightscout">Refresh events from NS</string>
|
<string name="refresheventsfromnightscout">Refresh events from NS</string>
|
||||||
<string name="eatingsoon">Eating Soon</string>
|
<string name="eatingsoon">Eating Soon</string>
|
||||||
|
<string name="hypo">Hypo</string>
|
||||||
<string name="activity">Activity</string>
|
<string name="activity">Activity</string>
|
||||||
<string name="removerecord">Remove record:</string>
|
<string name="removerecord">Remove record:</string>
|
||||||
<string name="danar_stats">DanaR Stats</string>
|
<string name="danar_stats">DanaR Stats</string>
|
||||||
|
@ -738,10 +739,14 @@
|
||||||
<string name="eatingsoon_target">eatingsoon target</string>
|
<string name="eatingsoon_target">eatingsoon target</string>
|
||||||
<string name="activity_duration">activity duration</string>
|
<string name="activity_duration">activity duration</string>
|
||||||
<string name="activity_target">activity target</string>
|
<string name="activity_target">activity target</string>
|
||||||
|
<string name="hypo_duration">hypo duration</string>
|
||||||
|
<string name="hypo_target">hypo target</string>
|
||||||
<string name="key_eatingsoon_duration" translatable="false">eatingsoon_duration</string>
|
<string name="key_eatingsoon_duration" translatable="false">eatingsoon_duration</string>
|
||||||
<string name="key_eatingsoon_target" translatable="false">eatingsoon_target</string>
|
<string name="key_eatingsoon_target" translatable="false">eatingsoon_target</string>
|
||||||
<string name="key_activity_duration" translatable="false">activity_duration</string>
|
<string name="key_activity_duration" translatable="false">activity_duration</string>
|
||||||
<string name="key_activity_target" translatable="false">activity_target</string>
|
<string name="key_activity_target" translatable="false">activity_target</string>
|
||||||
|
<string name="key_hypo_duration" translatable="false">hypo_duration</string>
|
||||||
|
<string name="key_hypo_target" translatable="false">hypo_target</string>
|
||||||
<string name="danar_history_prime">Prime</string>
|
<string name="danar_history_prime">Prime</string>
|
||||||
<string name="gettingextendedbolusstatus">Getting extended bolus status</string>
|
<string name="gettingextendedbolusstatus">Getting extended bolus status</string>
|
||||||
<string name="gettingbolusstatus">Getting bolus status</string>
|
<string name="gettingbolusstatus">Getting bolus status</string>
|
||||||
|
@ -984,6 +989,8 @@
|
||||||
<string name="overview_show_cob">Carbs On Board</string>
|
<string name="overview_show_cob">Carbs On Board</string>
|
||||||
<string name="overview_show_iob">Insulin On Board</string>
|
<string name="overview_show_iob">Insulin On Board</string>
|
||||||
<string name="overview_show_basals">Basals</string>
|
<string name="overview_show_basals">Basals</string>
|
||||||
|
<string name="no_action_selected">No action selected, nothing will happen</string>
|
||||||
|
<string name="start_hypo_tt">Start Hypo TT</string>
|
||||||
<string name="closed_loop_disabled_on_dev_branch">Running dev version. Closed loop is disabled.</string>
|
<string name="closed_loop_disabled_on_dev_branch">Running dev version. Closed loop is disabled.</string>
|
||||||
<string name="key_fromNSAreCommingFakedExtendedBoluses" translatable="false">fromNSAreCommingFakedExtendedBoluses</string>
|
<string name="key_fromNSAreCommingFakedExtendedBoluses" translatable="false">fromNSAreCommingFakedExtendedBoluses</string>
|
||||||
<string name="engineering_mode_enabled">Engineering mode enabled</string>
|
<string name="engineering_mode_enabled">Engineering mode enabled</string>
|
||||||
|
|
|
@ -25,6 +25,16 @@
|
||||||
android:inputType="numberDecimal"
|
android:inputType="numberDecimal"
|
||||||
android:key="@string/key_activity_target"
|
android:key="@string/key_activity_target"
|
||||||
android:title="@string/activity_target"></EditTextPreference>
|
android:title="@string/activity_target"></EditTextPreference>
|
||||||
|
<EditTextPreference
|
||||||
|
android:defaultValue="0"
|
||||||
|
android:inputType="number"
|
||||||
|
android:key="@string/key_hypo_duration"
|
||||||
|
android:title="@string/hypo_duration"></EditTextPreference>
|
||||||
|
<EditTextPreference
|
||||||
|
android:defaultValue="0"
|
||||||
|
android:inputType="numberDecimal"
|
||||||
|
android:key="@string/key_hypo_target"
|
||||||
|
android:title="@string/hypo_target"></EditTextPreference>
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
<PreferenceScreen android:title="@string/fillbolus_title">
|
<PreferenceScreen android:title="@string/fillbolus_title">
|
||||||
<EditTextPreference
|
<EditTextPreference
|
||||||
|
|
Loading…
Reference in a new issue