wip
This commit is contained in:
parent
d851637d4f
commit
b162fcce01
1 changed files with 28 additions and 2 deletions
|
@ -84,9 +84,13 @@ public class BolusCommand implements Command {
|
||||||
progressReportCallback.report(DELIVERING, 0, 0);
|
progressReportCallback.report(DELIVERING, 0, 0);
|
||||||
Double bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
|
Double bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
|
||||||
double lastBolusReported = 0;
|
double lastBolusReported = 0;
|
||||||
|
List<String> alarmsRaised = new ArrayList<>();
|
||||||
// wait for bolus delivery to complete; the remaining units to deliver are counted
|
// wait for bolus delivery to complete; the remaining units to deliver are counted
|
||||||
// down and are displayed on the main menu.
|
// down and are displayed on the main menu.
|
||||||
// TODO extract into method
|
// TODO extract into method
|
||||||
|
|
||||||
|
// TODO 'low cartrdige' alarm must be handled inside, since the bolus continues regardless;
|
||||||
|
// it must be claread so we can see the remaining bolus again;
|
||||||
while (bolusRemaining != null) {
|
while (bolusRemaining != null) {
|
||||||
if (cancelRequested) {
|
if (cancelRequested) {
|
||||||
progressReportCallback.report(STOPPING, 0, 0);
|
progressReportCallback.report(STOPPING, 0, 0);
|
||||||
|
@ -122,13 +126,32 @@ public class BolusCommand implements Command {
|
||||||
// the data will be out of sync for a bit.
|
// the data will be out of sync for a bit.
|
||||||
// how does the dana handle pump errors? has no vibration, but sound i guess
|
// how does the dana handle pump errors? has no vibration, but sound i guess
|
||||||
// should this be configurabe? initially?
|
// should this be configurabe? initially?
|
||||||
|
|
||||||
if (scripter.currentMenu.getType() == MenuType.WARNING_OR_ERROR) {
|
if (scripter.currentMenu.getType() == MenuType.WARNING_OR_ERROR) {
|
||||||
// see errors being dealt with trying to cancel
|
String message = (String) scripter.currentMenu.getAttribute(MenuAttribute.MESSAGE);
|
||||||
|
if (message.equals("LOW CARTRIDGE")) {
|
||||||
|
alarmsRaised.add(message);
|
||||||
|
// confirm, note alert was raised and continue bolusing)
|
||||||
|
} else {
|
||||||
|
// any other alert
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
SystemClock.sleep(50);
|
SystemClock.sleep(50);
|
||||||
bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
|
bolusRemaining = (Double) scripter.currentMenu.getAttribute(MenuAttribute.BOLUS_REMAINING);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// wait up to 2s for any possible warning to be raised
|
||||||
|
long minWait = System.currentTimeMillis() + 2 * 1000;
|
||||||
|
while (scripter.currentMenu.getType() != MenuType.WARNING_OR_ERROR || System.currentTimeMillis() < minWait) {
|
||||||
|
SystemClock.sleep(50);
|
||||||
|
}
|
||||||
|
|
||||||
|
// process warnings (confirm them, report back to AAPS about them)
|
||||||
|
while (scripter.currentMenu.getType() == MenuType.WARNING_OR_ERROR || System.currentTimeMillis() < minWait) {
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
// TODO what if we hit 'cartridge low' alert here? is it immediately displayed or after the bolus?
|
// TODO what if we hit 'cartridge low' alert here? is it immediately displayed or after the bolus?
|
||||||
// TODO how are error states reported back to the caller that occur outside of calls in genal? Low battery, low cartridge?
|
// TODO how are error states reported back to the caller that occur outside of calls in genal? Low battery, low cartridge?
|
||||||
|
|
||||||
|
@ -137,7 +160,8 @@ public class BolusCommand implements Command {
|
||||||
"Bolus delivery did not complete as expected. "
|
"Bolus delivery did not complete as expected. "
|
||||||
+ "Check pump manually, the bolus might not have been delivered.");
|
+ "Check pump manually, the bolus might not have been delivered.");
|
||||||
|
|
||||||
progressReportCallback.report(DELIVERED, 100, bolus);
|
|
||||||
|
// TODO report back what was read from history
|
||||||
|
|
||||||
// read last bolus record; those menus display static data and therefore
|
// read last bolus record; those menus display static data and therefore
|
||||||
// only a single menu update is sent
|
// only a single menu update is sent
|
||||||
|
@ -167,6 +191,8 @@ public class BolusCommand implements Command {
|
||||||
+ "did not return the main menu successfully.");
|
+ "did not return the main menu successfully.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
progressReportCallback.report(DELIVERED, 100, bolus);
|
||||||
|
|
||||||
return new CommandResult().success(true).enacted(true)
|
return new CommandResult().success(true).enacted(true)
|
||||||
.message(String.format(Locale.US, "Delivered %02.1f U", bolus));
|
.message(String.format(Locale.US, "Delivered %02.1f U", bolus));
|
||||||
} catch (CommandException e) {
|
} catch (CommandException e) {
|
||||||
|
|
Loading…
Reference in a new issue