Browse Source

implemented deleting of tiles, saving of plan

lookup-tables
Stephan Richter 5 years ago
parent
commit
6f7e225604
  1. 6
      resources/css/style.css
  2. 28
      resources/js/plan.js
  3. 4
      resources/svg/Eraser.svg
  4. 6
      resources/translations/Application.de.translation
  5. 59
      src/main/java/de/srsoftware/web4rail/Plan.java
  6. 5
      src/main/java/de/srsoftware/web4rail/tiles/Eraser.java
  7. 2
      src/main/java/de/srsoftware/web4rail/tiles/Tile.java

6
resources/css/style.css

@ -60,6 +60,8 @@ svg text{
.menu > div > .list > *{ .menu > div > .list > *{
position: relative; position: relative;
border: 1px solid black;
height: 30px;
float: left; float: left;
} }
@ -71,4 +73,8 @@ svg text{
padding: 5px; padding: 5px;
border-radius: 5px; border-radius: 5px;
background: yellow; background: yellow;
}
#Eraser polygon{
stroke: red;
} }

28
resources/js/plan.js

@ -1,7 +1,9 @@
const ADD = 1; const ADD = 'add';
const SQUARE = 30; const SQUARE = 30;
const BODY = 'body'; const BODY = 'body';
const SVG = 'svg'; const SVG = 'svg';
const PLAN = 'plan';
const POST = 'POST';
var selected = null; var selected = null;
var mode = null; var mode = null;
@ -14,17 +16,14 @@ function addTile(x,y){
x = Math.floor(x/SQUARE); x = Math.floor(x/SQUARE);
y = Math.floor(y/SQUARE); y = Math.floor(y/SQUARE);
$.ajax({ $.ajax({
url : 'plan', url : PLAN,
method: 'POST', method: POST,
data : {mode:mode,tile:selected.id,x:x,y:y}, data : {action:mode,tile:selected.id,x:x,y:y},
success: function(resp){ success: function(resp){
var id = 'tile-'+x+'-'+y; var id = 'tile-'+x+'-'+y;
$('#'+id).remove(); $('#'+id).remove();
console.log("x: ",x);
var tile = $(selected).clone().css({left:(30*x)+'px',top:(30*y)+'px','border':''}).attr('id',id); var tile = $(selected).clone().css({left:(30*x)+'px',top:(30*y)+'px','border':''}).attr('id',id);
if (selected.id != 'Eraser') $(BODY).append(tile);
$(BODY).append(tile);
addMessage(resp); addMessage(resp);
} }
}); });
@ -52,7 +51,7 @@ function closeMenu(ev){
} }
function enableAdding(ev){ function enableAdding(ev){
console.log('enableAdding:',ev); // console.log('enableAdding:',ev);
if (selected != null) $(selected).css('border',''); if (selected != null) $(selected).css('border','');
selected = ev.target; selected = ev.target;
while (selected != null && selected.nodeName != SVG) selected = selected.parentNode; while (selected != null && selected.nodeName != SVG) selected = selected.parentNode;
@ -66,9 +65,20 @@ function enableAdding(ev){
return false; // otherwise body.click would also be triggered return false; // otherwise body.click would also be triggered
} }
function savePlan(ev){
$.ajax({
url : PLAN,
method : POST,
data : {action:'save',name:'default'},
success: function(resp){ addMessage(resp);}
});
return false;
}
window.onload = function () { window.onload = function () {
var isDragging = false; var isDragging = false;
$('.menu > div').click(closeMenu); $('.menu > div').click(closeMenu);
$('.menu .addtile .list svg').click(enableAdding); $('.menu .addtile .list svg').click(enableAdding);
$(BODY).click(bodyClick); $(BODY).click(bodyClick);
$('#save').click(savePlan);
} }

4
resources/svg/Eraser.svg

@ -0,0 +1,4 @@
<svg width="100" height="100" viewbox="0 0 100 100">
<polygon points="5,0 100,95 95,100 0,5" />
<polygon points="0,95 95,0 100,5 5,100" />
</svg>

After

Width:  |  Height:  |  Size: 147 B

6
resources/translations/Application.de.translation

@ -1 +1,5 @@
Added {} : {} hinzugefügt Actions : Aktionen
Added {} : {} hinzugefügt
Add tile : Kachel hinzufügen
Save plan : Plan speichern
Unknown action\: {} : Unbekannte Aktion: {}

59
src/main/java/de/srsoftware/web4rail/Plan.java

@ -1,5 +1,8 @@
package de.srsoftware.web4rail; package de.srsoftware.web4rail;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException; import java.io.IOException;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.util.HashMap; import java.util.HashMap;
@ -16,6 +19,7 @@ import de.srsoftware.web4rail.tiles.DiagSW;
import de.srsoftware.web4rail.tiles.DiagWN; import de.srsoftware.web4rail.tiles.DiagWN;
import de.srsoftware.web4rail.tiles.EndE; import de.srsoftware.web4rail.tiles.EndE;
import de.srsoftware.web4rail.tiles.EndW; import de.srsoftware.web4rail.tiles.EndW;
import de.srsoftware.web4rail.tiles.Eraser;
import de.srsoftware.web4rail.tiles.StraightH; import de.srsoftware.web4rail.tiles.StraightH;
import de.srsoftware.web4rail.tiles.StraightV; import de.srsoftware.web4rail.tiles.StraightV;
import de.srsoftware.web4rail.tiles.Tile; import de.srsoftware.web4rail.tiles.Tile;
@ -24,12 +28,14 @@ import de.srsoftware.web4rail.tiles.TurnoutSW;
import de.srsoftware.web4rail.tiles.TurnoutWS; import de.srsoftware.web4rail.tiles.TurnoutWS;
public class Plan { public class Plan {
private static final String MODE = "mode"; private static final String ACTION = "action";
private static final String MODE_ADD = "1"; private static final String ACTION_ADD = "add";
private static final String ACTION_SAVE = "save";
private static final String TILE = "tile"; private static final String TILE = "tile";
private static final Logger LOG = LoggerFactory.getLogger(Plan.class); private static final Logger LOG = LoggerFactory.getLogger(Plan.class);
private static final String X = "x"; private static final String X = "x";
private static final String Y = "y"; private static final String Y = "y";
private static final String NAME = "name";
private HashMap<Integer,HashMap<Integer,Tile>> tiles = new HashMap<Integer,HashMap<Integer,Tile>>(); private HashMap<Integer,HashMap<Integer,Tile>> tiles = new HashMap<Integer,HashMap<Integer,Tile>>();
@ -56,7 +62,7 @@ public class Plan {
for (Entry<Integer, Tile> row : column.getValue().entrySet()) { for (Entry<Integer, Tile> row : column.getValue().entrySet()) {
int y = row.getKey(); int y = row.getKey();
Tile tile = row.getValue().position(x, y); Tile tile = row.getValue().position(x, y);
page.append("\t\t"+tile.html()+"\n"); if (tile != null) page.append("\t\t"+tile.html()+"\n");
} }
} }
return page.append(menu()).append(messages()); return page.append(menu()).append(messages());
@ -75,29 +81,51 @@ public class Plan {
return menu; return menu;
} }
private Tag actionMenu() { private Tag actionMenu() throws IOException {
Tag menu = new Tag("div").clazz("actions").content("Actions");
return menu; Tag tileMenu = new Tag("div").clazz("actions").content(t("Actions"));
StringBuffer tiles = new StringBuffer();
tiles.append(new Tag("div").id("save").content(t("Save plan")));
return new Tag("div").clazz("list").content(tiles.toString()).addTo(tileMenu);
} }
public String process(HashMap<String, String> params) { public String process(HashMap<String, String> params) {
try { try {
String mode = params.get(MODE); String action = params.get(ACTION);
if (mode == null) throw new NullPointerException(MODE+" should not be null!"); if (action == null) throw new NullPointerException(ACTION+" should not be null!");
switch (mode) { switch (action) {
case MODE_ADD: case ACTION_ADD:
Tile tile = addTile(params.get(TILE),params.get(X),params.get(Y)); Tile tile = addTile(params.get(TILE),params.get(X),params.get(Y));
return t("Added {}",tile.getClass().getSimpleName()); return t("Added {}",tile.getClass().getSimpleName());
case ACTION_SAVE:
return saveTo(params.get(NAME));
default: default:
LOG.warn("Unknown mode: {}",mode); LOG.warn("Unknown action: {}",action);
} }
return t("unknown mode: {}",mode); return t("Unknown action: {}",action);
} catch (Exception e) { } catch (Exception e) {
return e.getMessage(); return e.getMessage();
} }
} }
private String saveTo(String name) throws IOException {
if (name == null || name.isEmpty()) throw new NullPointerException("Name must not be empty!");
File file = new File(name+".plan");
BufferedWriter br = new BufferedWriter(new FileWriter(file));
for (Entry<Integer, HashMap<Integer, Tile>> column : tiles.entrySet()) {
int x = column.getKey();
for (Entry<Integer, Tile> row : column.getValue().entrySet()) {
int y = row.getKey();
Tile tile = row.getValue().position(x, y);
if (tile != null) br.append(x+":"+y+":"+tile.getClass().getSimpleName()+"\n");
}
}
br.close();
return "saving "+name;
}
public Tile set(int x,int y,Tile tile) { public Tile set(int x,int y,Tile tile) {
Tile old = null; Tile old = null;
HashMap<Integer, Tile> column = tiles.get(x); HashMap<Integer, Tile> column = tiles.get(x);
@ -105,8 +133,8 @@ public class Plan {
column = new HashMap<Integer,Tile>(); column = new HashMap<Integer,Tile>();
tiles.put(x, column); tiles.put(x, column);
} }
old = column.get(y); old = column.remove(y);
column.put(y,tile.position(x, y)); if (!(tile instanceof Eraser)) column.put(y,tile.position(x, y));
return old; return old;
} }
@ -115,7 +143,7 @@ public class Plan {
} }
private Tag tileMenu() throws IOException { private Tag tileMenu() throws IOException {
Tag tileMenu = new Tag("div").clazz("addtile").content("Add tile"); Tag tileMenu = new Tag("div").clazz("addtile").content(t("Add tile"));
StringBuffer tiles = new StringBuffer(); StringBuffer tiles = new StringBuffer();
tiles.append(new StraightH().html()); tiles.append(new StraightH().html());
@ -129,6 +157,7 @@ public class Plan {
tiles.append(new TurnoutSE().html()); tiles.append(new TurnoutSE().html());
tiles.append(new TurnoutWS().html()); tiles.append(new TurnoutWS().html());
tiles.append(new TurnoutSW().html()); tiles.append(new TurnoutSW().html());
tiles.append(new Eraser().html());
return new Tag("div").clazz("list").content(tiles.toString()).addTo(tileMenu); return new Tag("div").clazz("list").content(tiles.toString()).addTo(tileMenu);
} }
} }

5
src/main/java/de/srsoftware/web4rail/tiles/Eraser.java

@ -0,0 +1,5 @@
package de.srsoftware.web4rail.tiles;
public class Eraser extends Tile {
}

2
src/main/java/de/srsoftware/web4rail/tiles/Tile.java

@ -12,7 +12,7 @@ import de.srsoftware.web4rail.Application;
public abstract class Tile { public abstract class Tile {
protected int x = -1,y = -1; protected int x = -1,y = -1;
protected HashSet<String> classes = new HashSet<String>(); protected HashSet<String> classes = new HashSet<String>();
public Tile() { public Tile() {

Loading…
Cancel
Save