added non-track contact to tiles, re-implementes PowerOff to SetPower

This commit is contained in:
Stephan Richter
2020-11-07 19:29:32 +01:00
parent 9addb126e9
commit 880ef561dd
11 changed files with 159 additions and 58 deletions

View File

@@ -108,7 +108,7 @@ public abstract class Action extends BaseClass {
TriggerContact.class,
TurnTrain.class,
StopAuto.class,
PowerOff.class,
SetPower.class,
SetRelay.class,
DelayedAction.class
);

View File

@@ -1,10 +0,0 @@
package de.srsoftware.web4rail.actions;
public class PowerOff extends Action{
@Override
public boolean fire(Context context) {
context.contact.plan().controlUnit().emergency();
return false;
}
}

View File

@@ -0,0 +1,94 @@
package de.srsoftware.web4rail.actions;
import java.util.HashMap;
import org.json.JSONObject;
import de.srsoftware.tools.Tag;
import de.srsoftware.web4rail.ControlUnit;
import de.srsoftware.web4rail.Window;
import de.srsoftware.web4rail.tags.Button;
import de.srsoftware.web4rail.tags.Form;
import de.srsoftware.web4rail.tags.Input;
import de.srsoftware.web4rail.tags.Radio;
public class SetPower extends Action{
private static final String STATE = "state";
private POWERCHANGE pc = POWERCHANGE.OFF;
enum POWERCHANGE {
ON, OFF, TOGGLE;
}
@Override
public boolean fire(Context context) {
ControlUnit cu = context.contact.plan().controlUnit();
switch (pc) {
case ON:
cu.set(true);
break;
case TOGGLE:
cu.togglePower();
break;
default:
cu.set(false);
break;
}
return true;
}
@Override
public JSONObject json() {
JSONObject json = super.json();
json.put(STATE, pc);
return json;
}
@Override
public Action load(JSONObject json) {
super.load(json);
pc = POWERCHANGE.valueOf(json.getString(STATE));
return this;
}
@Override
public Window properties(HashMap<String, String> params) {
Window win = super.properties(params);
Form form = new Form("action-prop-form-"+id);
new Input(REALM,REALM_ACTIONS).hideIn(form);
new Input(ID,params.get(ID)).hideIn(form);
new Input(ACTION,ACTION_UPDATE).hideIn(form);
new Input(CONTEXT,params.get(CONTEXT)).hideIn(form);
new Radio(STATE, POWERCHANGE.ON, t("On"), pc == POWERCHANGE.ON).addTo(form);
new Radio(STATE, POWERCHANGE.OFF, t("Off"), pc == POWERCHANGE.OFF).addTo(form);
new Radio(STATE, POWERCHANGE.TOGGLE, t("Toggle"), pc == POWERCHANGE.TOGGLE).addTo(form);
new Button(t("Apply"),form).addTo(form).addTo(win);
return win;
}
@Override
public String toString() {
switch (pc) {
case ON:
return t("Switch power on");
case OFF:
return t("Switch power off");
default:
return t("Toggle power");
}
}
@Override
protected Object update(HashMap<String, String> params) {
LOG.debug("update: {}",params);
String error = null;
String newState = params.get(STATE);
if (isSet(newState)) pc = POWERCHANGE.valueOf(newState);
Window win = properties(params);
return new Tag("span").content(error).addTo(win);
}
}

View File

@@ -36,8 +36,7 @@ public class SetSpeed extends Action{
public Action load(JSONObject json) {
super.load(json);
maxSpeed = json.getInt(MAX_SPEED);
return this;
return this;
}
@Override