SW pump screen

This commit is contained in:
Milos Kozak 2018-05-09 13:38:17 +02:00
parent ed43eddc83
commit bacb3fb337
6 changed files with 68 additions and 18 deletions

View file

@ -15,6 +15,8 @@ public class SWButton extends SWItem {
int buttonText; int buttonText;
SWValidator buttonValidator; SWValidator buttonValidator;
Button button;
public SWButton() { public SWButton() {
super(Type.BUTTON); super(Type.BUTTON);
} }
@ -38,15 +40,22 @@ public class SWButton extends SWItem {
public void generateDialog(View view, LinearLayout layout) { public void generateDialog(View view, LinearLayout layout) {
Context context = view.getContext(); Context context = view.getContext();
Button button = new Button(context); button = new Button(context);
button.setText(buttonText); button.setText(buttonText);
button.setOnClickListener((v) -> { button.setOnClickListener((v) -> {
if (buttonRunnable != null) if (buttonRunnable != null)
buttonRunnable.run(); buttonRunnable.run();
}); });
if (buttonValidator != null && !buttonValidator.isValid()) processVisibility();
return;
layout.addView(button); layout.addView(button);
super.generateDialog(view, layout); super.generateDialog(view, layout);
} }
@Override
public void processVisibility() {
if (buttonValidator != null && !buttonValidator.isValid())
button.setVisibility(View.GONE);
else
button.setVisibility(View.VISIBLE);
}
} }

View file

@ -1,5 +1,8 @@
package info.nightscout.androidaps.startupwizard; package info.nightscout.androidaps.startupwizard;
import android.content.Context;
import android.content.Intent;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -7,29 +10,31 @@ import java.util.ArrayList;
import java.util.List; import java.util.List;
import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.MainApp;
import info.nightscout.androidaps.PreferencesActivity;
import info.nightscout.androidaps.R; import info.nightscout.androidaps.R;
import info.nightscout.androidaps.events.EventConfigBuilderChange; import info.nightscout.androidaps.events.EventConfigBuilderChange;
import info.nightscout.androidaps.events.EventRefreshGui; import info.nightscout.androidaps.events.EventRefreshGui;
import info.nightscout.androidaps.interfaces.PluginBase;
import info.nightscout.androidaps.interfaces.PluginType; import info.nightscout.androidaps.interfaces.PluginType;
import info.nightscout.androidaps.interfaces.PumpInterface;
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderFragment; import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderFragment;
import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin; import info.nightscout.androidaps.plugins.ConfigBuilder.ConfigBuilderPlugin;
import info.nightscout.androidaps.plugins.NSClientInternal.NSClientPlugin; import info.nightscout.androidaps.plugins.NSClientInternal.NSClientPlugin;
import info.nightscout.androidaps.startupwizard.events.EventSWUpdate; import info.nightscout.androidaps.startupwizard.events.EventSWUpdate;
import info.nightscout.utils.LocaleHelper; import info.nightscout.utils.LocaleHelper;
import info.nightscout.utils.PasswordProtection;
import info.nightscout.utils.SP; import info.nightscout.utils.SP;
public class SWDefinition { public class SWDefinition {
private static Logger log = LoggerFactory.getLogger(SWDefinition.class); private static Logger log = LoggerFactory.getLogger(SWDefinition.class);
private static SWDefinition swDefinition = null;
public static SWDefinition getInstance() {
if (swDefinition == null)
swDefinition = new SWDefinition();
return swDefinition;
}
private Context context;
static List<SWScreen> screens = new ArrayList<>(); static List<SWScreen> screens = new ArrayList<>();
public void setContext(Context context) {
this.context = context;
}
public static List<SWScreen> getScreens() { public static List<SWScreen> getScreens() {
return screens; return screens;
} }
@ -94,24 +99,43 @@ public class SWDefinition {
.skippable(false) .skippable(false)
.add(new SWPlugin() .add(new SWPlugin()
.option(PluginType.INSULIN) .option(PluginType.INSULIN)
.label(R.string.configbuilder_insulin) .label(R.string.configbuilder_insulin))
.comment(R.string.configbuilder_insulin))
.validator(() -> MainApp.getSpecificPluginsList(PluginType.INSULIN) != null) .validator(() -> MainApp.getSpecificPluginsList(PluginType.INSULIN) != null)
) )
.add(new SWScreen(R.string.configbuilder_bgsource) .add(new SWScreen(R.string.configbuilder_bgsource)
.skippable(false) .skippable(false)
.add(new SWPlugin() .add(new SWPlugin()
.option(PluginType.BGSOURCE) .option(PluginType.BGSOURCE)
.label(R.string.configbuilder_bgsource) .label(R.string.configbuilder_bgsource))
.comment(R.string.configbuilder_bgsource))
.validator(() -> MainApp.getSpecificPluginsList(PluginType.BGSOURCE) != null) .validator(() -> MainApp.getSpecificPluginsList(PluginType.BGSOURCE) != null)
) )
.add(new SWScreen(R.string.configbuilder_pump)
.skippable(false)
.add(new SWPlugin()
.option(PluginType.PUMP)
.label(R.string.configbuilder_pump))
.add(new SWButton()
.text(R.string.pumpsetup)
.action(() -> {
final PluginBase plugin = (PluginBase) MainApp.getConfigBuilder().getActivePump();
PasswordProtection.QueryPassword(context, R.string.settings_password, "settings_password", () -> {
Intent i = new Intent(context, PreferencesActivity.class);
i.putExtra("id", plugin.getPreferencesId());
context.startActivity(i);
}, null);
})
.visibility(() -> ((PluginBase) MainApp.getConfigBuilder().getActivePump()).getPreferencesId() > 0))
.add(new SWButton()
.text(R.string.readstatus)
.action(() -> ConfigBuilderPlugin.getCommandQueue().readStatus("Clicked connect to pump", null))
.visibility(() -> MainApp.getSpecificPluginsList(PluginType.PUMP) != null))
.validator(() -> MainApp.getSpecificPluginsList(PluginType.PUMP) != null && MainApp.getConfigBuilder().getActivePump().isInitialized())
)
.add(new SWScreen(R.string.configbuilder_aps) .add(new SWScreen(R.string.configbuilder_aps)
.skippable(false) .skippable(false)
.add(new SWPlugin() .add(new SWPlugin()
.option(PluginType.APS) .option(PluginType.APS)
.label(R.string.configbuilder_aps) .label(R.string.configbuilder_aps))
.comment(R.string.configbuilder_aps))
.validator(() -> MainApp.getSpecificPluginsList(PluginType.APS) != null) .validator(() -> MainApp.getSpecificPluginsList(PluginType.APS) != null)
) )
; ;

View file

@ -82,4 +82,6 @@ public class SWItem {
public void generateDialog(View view, LinearLayout layout) { public void generateDialog(View view, LinearLayout layout) {
} }
public void processVisibility() {
}
} }

View file

@ -34,4 +34,9 @@ public class SWScreen {
this.validator = validator; this.validator = validator;
return this; return this;
} }
public void processVisibility() {
for (SWItem i : items)
i.processVisibility();
}
} }

View file

@ -17,6 +17,7 @@ import java.util.List;
import info.nightscout.androidaps.MainActivity; import info.nightscout.androidaps.MainActivity;
import info.nightscout.androidaps.MainApp; import info.nightscout.androidaps.MainApp;
import info.nightscout.androidaps.R; import info.nightscout.androidaps.R;
import info.nightscout.androidaps.events.EventPumpStatusChanged;
import info.nightscout.androidaps.plugins.NSClientInternal.events.EventNSClientStatus; import info.nightscout.androidaps.plugins.NSClientInternal.events.EventNSClientStatus;
import info.nightscout.androidaps.startupwizard.events.EventSWUpdate; import info.nightscout.androidaps.startupwizard.events.EventSWUpdate;
import info.nightscout.utils.LocaleHelper; import info.nightscout.utils.LocaleHelper;
@ -27,7 +28,7 @@ public class SetupWizardActivity extends AppCompatActivity {
private TextView screenName; private TextView screenName;
SWDefinition swDefinition = SWDefinition.getInstance(); SWDefinition swDefinition = new SWDefinition();
List<SWScreen> screens = swDefinition.getScreens(); List<SWScreen> screens = swDefinition.getScreens();
private int currentWizardPage = 0; private int currentWizardPage = 0;
public static final String INTENT_MESSAGE = "WIZZARDPAGE"; public static final String INTENT_MESSAGE = "WIZZARDPAGE";
@ -63,6 +64,7 @@ public class SetupWizardActivity extends AppCompatActivity {
protected void onResume() { protected void onResume() {
super.onResume(); super.onResume();
MainApp.bus().register(this); MainApp.bus().register(this);
swDefinition.setContext(this);
} }
@Subscribe @Subscribe
@ -73,7 +75,12 @@ public class SetupWizardActivity extends AppCompatActivity {
} }
@Subscribe @Subscribe
public void onContentUpdate(EventNSClientStatus ev) { public void onEventNSClientStatus(EventNSClientStatus ignored) {
updateButtons();
}
@Subscribe
public void onEventPumpStatusChanged(EventPumpStatusChanged ignored) {
updateButtons(); updateButtons();
} }
@ -104,6 +111,7 @@ public class SetupWizardActivity extends AppCompatActivity {
findViewById(R.id.previous_button).setVisibility(View.GONE); findViewById(R.id.previous_button).setVisibility(View.GONE);
else else
findViewById(R.id.previous_button).setVisibility(View.VISIBLE); findViewById(R.id.previous_button).setVisibility(View.VISIBLE);
currentScreen.processVisibility();
} }
public void showNextPage(View view) { public void showNextPage(View view) {

View file

@ -1061,5 +1061,7 @@
<string name="dummy_content">DUMMY\nCONTENT</string> <string name="dummy_content">DUMMY\nCONTENT</string>
<string name="enable_nsclient">Enable NSClient</string> <string name="enable_nsclient">Enable NSClient</string>
<string name="welcometosetupwizard">Welcome to setup wizard. It will guide you through the setup process</string> <string name="welcometosetupwizard">Welcome to setup wizard. It will guide you through the setup process</string>
<string name="pumpsetup">Pump setup</string>
<string name="readstatus">Read status</string>
</resources> </resources>