bugfixes + added new condition TrainWasInBlock

This commit is contained in:
Stephan Richter
2021-01-12 00:53:25 +01:00
parent 887d557d5e
commit 3cd72cffb6
6 changed files with 112 additions and 5 deletions

View File

@@ -32,7 +32,7 @@ public class BlockFree extends Condition {
public Condition load(JSONObject json) {
super.load(json);
block(Block.get(new Id(json.getString(BLOCK))));
if (json.has(BLOCK)) block(Block.get(new Id(json.getString(BLOCK))));
return this;
}
@@ -60,7 +60,7 @@ public class BlockFree extends Condition {
if (!params.containsKey(BLOCK)) return t("No block id passed to BlockFree.update()!");
Id bid = new Id(params.get(BLOCK));
Block block = Block.get(bid);
if (block == null) return t("No block with id {} found!",bid);
if (isNull(block)) return t("No block with id {} found!",bid);
this.block = block;
return super.update(params);
}

View File

@@ -125,7 +125,8 @@ public abstract class Condition extends BaseClass {
TrainHasTag.class,
TrainLength.class,
TrainSelect.class,
TrainSpeed.class);
TrainSpeed.class,
TrainWasInBlock.class);
}
public Condition load(JSONObject json) {

View File

@@ -0,0 +1,77 @@
package de.srsoftware.web4rail.conditions;
import java.util.HashMap;
import java.util.List;
import org.json.JSONObject;
import de.srsoftware.tools.Tag;
import de.srsoftware.web4rail.BaseClass;
import de.srsoftware.web4rail.Window;
import de.srsoftware.web4rail.moving.Train;
import de.srsoftware.web4rail.tags.Fieldset;
import de.srsoftware.web4rail.tags.Input;
import de.srsoftware.web4rail.tiles.Block;
public class TrainWasInBlock extends Condition {
private static final String BLOCK = Block.class.getSimpleName();
private static final String COUNT = "count";
private Block block;
private int count = 5;
private TrainWasInBlock block(Block block) {
this.block = block;
return this;
}
@Override
public boolean fulfilledBy(Context context) {
Train train = context.train();
if (isNull(train)) return false;
return train.lastBlocks(count).contains(block) != inverted;
}
@Override
public JSONObject json() {
return super.json().put(BLOCK, block.id()).put(COUNT, count);
}
public Condition load(JSONObject json) {
super.load(json);
if (json.has(BLOCK)) block(Block.get(new Id(json.getString(BLOCK))));
if (json.has(COUNT)) count = json.getInt(COUNT);
return this;
}
@Override
protected Window properties(List<Fieldset> preForm, FormInput formInputs, List<Fieldset> postForm) {
formInputs.add(t("Select block"), Block.selector(block, null));
formInputs.add(t("Seek in last"), new Input(COUNT, count).numeric().addTo(new Tag("span")).content(NBSP+t("blocks of train")));
return super.properties(preForm, formInputs, postForm);
}
@Override
protected void removeChild(BaseClass child) {
if (child == block) block = null;
super.removeChild(child);
}
@Override
public String toString() {
if (block == null) return "["+t("Click here to select block!")+"]";
return t(inverted ? "{} not within last {} blocks of train":"{} within last {} blocks of train",block,count);
}
@Override
protected Object update(HashMap<String, String> params) {
if (!params.containsKey(BLOCK)) return t("No block id passed to TrainWasInBlock.update()!");
Id bid = new Id(params.get(BLOCK));
Block block = Block.get(bid);
if (isNull(block)) return t("No block with id {} found!",bid);
this.block = block;
if (params.containsKey(COUNT)) count=Integer.parseInt(params.get(COUNT));
return super.update(params);
}
}