wear first fill bolus working
This commit is contained in:
parent
8d6760081e
commit
74107f58fe
3 changed files with 130 additions and 3 deletions
|
@ -466,7 +466,7 @@ public class ConfigBuilderPlugin implements PluginBase, PumpInterface, Constrain
|
||||||
carbs = applyCarbsConstraints(carbs);
|
carbs = applyCarbsConstraints(carbs);
|
||||||
|
|
||||||
BolusProgressDialog bolusProgressDialog = null;
|
BolusProgressDialog bolusProgressDialog = null;
|
||||||
if (context != null) {
|
if (context != null ) {
|
||||||
bolusProgressDialog = new BolusProgressDialog();
|
bolusProgressDialog = new BolusProgressDialog();
|
||||||
bolusProgressDialog.setInsulin(insulin);
|
bolusProgressDialog.setInsulin(insulin);
|
||||||
bolusProgressDialog.show(((AppCompatActivity) context).getSupportFragmentManager(), "BolusProgress");
|
bolusProgressDialog.show(((AppCompatActivity) context).getSupportFragmentManager(), "BolusProgress");
|
||||||
|
|
|
@ -0,0 +1,126 @@
|
||||||
|
package info.nightscout.androidaps.plugins.Wear;
|
||||||
|
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.HandlerThread;
|
||||||
|
import android.preference.PreferenceManager;
|
||||||
|
import android.support.v7.app.AlertDialog;
|
||||||
|
|
||||||
|
import info.nightscout.androidaps.MainApp;
|
||||||
|
import info.nightscout.androidaps.R;
|
||||||
|
import info.nightscout.androidaps.data.PumpEnactResult;
|
||||||
|
import info.nightscout.androidaps.plugins.Actions.dialogs.FillDialog;
|
||||||
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
|
import info.nightscout.utils.SafeParse;
|
||||||
|
import info.nightscout.utils.ToastUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by adrian on 09/02/17.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class ActionStringHandler {
|
||||||
|
|
||||||
|
public static final int TIMEOUT = 65 * 1000;
|
||||||
|
|
||||||
|
private static long lastSentTimestamp = 0;
|
||||||
|
private static String lastConfirmActionString = null;
|
||||||
|
private static SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(MainApp.instance().getApplicationContext());
|
||||||
|
|
||||||
|
|
||||||
|
private static HandlerThread handlerThread = new HandlerThread(FillDialog.class.getSimpleName());
|
||||||
|
static {
|
||||||
|
handlerThread.start();
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized static void handleInitiate(String actionstring){
|
||||||
|
|
||||||
|
String rTitle = "CONFIRM"; //TODO: i18n
|
||||||
|
String rMessage = "";
|
||||||
|
String rAction = "";
|
||||||
|
|
||||||
|
|
||||||
|
// do the parsing and check constraints
|
||||||
|
String[] act = actionstring.split("\\s+");
|
||||||
|
|
||||||
|
if ("fillpreset".equals(act[0])) {
|
||||||
|
double amount = 0d;
|
||||||
|
if ("1".equals(act[1])) {
|
||||||
|
amount = SafeParse.stringToDouble(DecimalFormatter.to2Decimal(SafeParse.stringToDouble(sp.getString("fill_button1", "0.3"))));
|
||||||
|
} else if ("2".equals(act[1])) {
|
||||||
|
amount = SafeParse.stringToDouble(DecimalFormatter.to2Decimal(SafeParse.stringToDouble(sp.getString("fill_button2", "0"))));
|
||||||
|
} else if ("3".equals(act[1])) {
|
||||||
|
amount = SafeParse.stringToDouble(DecimalFormatter.to2Decimal(SafeParse.stringToDouble(sp.getString("fill_button3", "0"))));
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Double insulinAfterConstraints = MainApp.getConfigBuilder().applyBolusConstraints(amount);
|
||||||
|
rMessage += MainApp.instance().getString(R.string.primefill) + ": " + insulinAfterConstraints + "U";
|
||||||
|
if (insulinAfterConstraints - amount != 0)
|
||||||
|
rMessage += "\n" + MainApp.instance().getString(R.string.constraintapllied);
|
||||||
|
|
||||||
|
rAction += "fill " + insulinAfterConstraints;
|
||||||
|
|
||||||
|
} else if(false){
|
||||||
|
//... add more actions
|
||||||
|
|
||||||
|
} else return;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// send result
|
||||||
|
WearFragment.getPlugin(MainApp.instance()).requestActionConfirmation(rTitle, rMessage, rAction);
|
||||||
|
lastSentTimestamp = System.currentTimeMillis();
|
||||||
|
lastConfirmActionString = rAction;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public synchronized static void handleConfirmation(String actionString){
|
||||||
|
|
||||||
|
//Guard from old or duplicate confirmations
|
||||||
|
if (lastConfirmActionString == null) return;
|
||||||
|
if (!lastConfirmActionString.equals(actionString)) return;
|
||||||
|
if (System.currentTimeMillis() - lastSentTimestamp > TIMEOUT) return;
|
||||||
|
lastConfirmActionString = null;
|
||||||
|
|
||||||
|
// do the parsing, check constraints and enact!
|
||||||
|
String[] act = actionString.split("\\s+");
|
||||||
|
|
||||||
|
if ("fill".equals(act[0])){
|
||||||
|
Double amount = SafeParse.stringToDouble(act[1]);
|
||||||
|
Double insulinAfterConstraints = MainApp.getConfigBuilder().applyBolusConstraints(amount);
|
||||||
|
if(amount - insulinAfterConstraints != 0){
|
||||||
|
ToastUtils.showToastInUiThread(MainApp.instance(), "aborting: previously applied constraint changed");
|
||||||
|
sendError("aborting: previously applied constraint changed");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
doFillBolus(amount);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void doFillBolus(final Double amount) {
|
||||||
|
Handler handler = new Handler(handlerThread.getLooper());
|
||||||
|
handler.post(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
PumpEnactResult result = MainApp.getConfigBuilder().deliverTreatment(amount, 0, null, false);
|
||||||
|
if (!result.success) {
|
||||||
|
sendError(MainApp.sResources.getString(R.string.treatmentdeliveryerror) +
|
||||||
|
"\n" +
|
||||||
|
result.comment);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized static void sendError(String errormessage){
|
||||||
|
WearFragment.getPlugin(MainApp.instance()).requestActionConfirmation("ERROR", errormessage, "error");
|
||||||
|
lastSentTimestamp = System.currentTimeMillis();
|
||||||
|
lastConfirmActionString = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -31,6 +31,7 @@ import info.nightscout.androidaps.db.TempBasal;
|
||||||
import info.nightscout.androidaps.interfaces.PumpInterface;
|
import info.nightscout.androidaps.interfaces.PumpInterface;
|
||||||
import info.nightscout.androidaps.data.IobTotal;
|
import info.nightscout.androidaps.data.IobTotal;
|
||||||
import info.nightscout.androidaps.plugins.Overview.OverviewPlugin;
|
import info.nightscout.androidaps.plugins.Overview.OverviewPlugin;
|
||||||
|
import info.nightscout.androidaps.plugins.Wear.ActionStringHandler;
|
||||||
import info.nightscout.androidaps.plugins.Wear.WearPlugin;
|
import info.nightscout.androidaps.plugins.Wear.WearPlugin;
|
||||||
import info.nightscout.client.data.NSProfile;
|
import info.nightscout.client.data.NSProfile;
|
||||||
import info.nightscout.utils.DecimalFormatter;
|
import info.nightscout.utils.DecimalFormatter;
|
||||||
|
@ -165,13 +166,13 @@ public class WatchUpdaterService extends WearableListenerService implements
|
||||||
|
|
||||||
String actionstring = new String(event.getData());
|
String actionstring = new String(event.getData());
|
||||||
ToastUtils.showToastInUiThread(this, "INITIATE: " + actionstring);
|
ToastUtils.showToastInUiThread(this, "INITIATE: " + actionstring);
|
||||||
//TODO: watch initiated action
|
ActionStringHandler.handleInitiate(actionstring);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event != null && event.getPath().equals(WEARABLE_CONFIRM_ACTIONSTRING_PATH)) {
|
if (event != null && event.getPath().equals(WEARABLE_CONFIRM_ACTIONSTRING_PATH)) {
|
||||||
String actionstring = new String(event.getData());
|
String actionstring = new String(event.getData());
|
||||||
ToastUtils.showToastInUiThread(this, "CONFIRM: " + actionstring);
|
ToastUtils.showToastInUiThread(this, "CONFIRM: " + actionstring);
|
||||||
//TODO: watch confirmed action
|
ActionStringHandler.handleConfirmation(actionstring);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue