Merge pull request #2821 from summetdev/schems-description

Descriptions for schematics.
This commit is contained in:
Anuken
2020-10-10 16:22:00 -04:00
committed by GitHub
3 changed files with 37 additions and 12 deletions

View File

@@ -62,6 +62,10 @@ public class Schematic implements Publishable, Comparable<Schematic>{
return tags.get("name", "unknown"); return tags.get("name", "unknown");
} }
public String description(){
return tags.get("description", "");
}
public void save(){ public void save(){
schematics.saveChanges(this); schematics.saveChanges(this);
} }
@@ -90,7 +94,7 @@ public class Schematic implements Publishable, Comparable<Schematic>{
@Override @Override
public String steamDescription(){ public String steamDescription(){
return null; return description();
} }
@Override @Override

View File

@@ -10,6 +10,7 @@ import arc.math.*;
import arc.math.geom.*; import arc.math.geom.*;
import arc.scene.*; import arc.scene.*;
import arc.scene.event.*; import arc.scene.event.*;
import arc.scene.ui.*;
import arc.scene.ui.layout.*; import arc.scene.ui.layout.*;
import arc.struct.*; import arc.struct.*;
import arc.util.*; import arc.util.*;
@@ -531,6 +532,7 @@ public abstract class InputHandler implements InputProcessor, GestureListener{
}); });
}else{ }else{
lastSchematic.tags.put("name", text); lastSchematic.tags.put("name", text);
lastSchematic.tags.put("description", "");
schematics.add(lastSchematic); schematics.add(lastSchematic);
ui.showInfoFade("@schematic.saved"); ui.showInfoFade("@schematic.saved");
ui.schematics.showInfo(lastSchematic); ui.schematics.showInfo(lastSchematic);

View File

@@ -4,6 +4,7 @@ import arc.*;
import arc.graphics.*; import arc.graphics.*;
import arc.graphics.Texture.*; import arc.graphics.Texture.*;
import arc.graphics.g2d.*; import arc.graphics.g2d.*;
import arc.input.*;
import arc.math.*; import arc.math.*;
import arc.scene.style.*; import arc.scene.style.*;
import arc.scene.ui.*; import arc.scene.ui.*;
@@ -106,18 +107,36 @@ public class SchematicsDialog extends BaseDialog{
}); });
buttons.button(Icon.pencil, style, () -> { buttons.button(Icon.pencil, style, () -> {
ui.showTextInput("@schematic.rename", "@name", s.name(), res -> { new Dialog("@schematic.rename"){{
Schematic replacement = schematics.all().find(other -> other.name().equals(res) && other != s); cont.margin(30).add("@name").padRight(6f);
if(replacement != null){ TextField nameField = cont.field(s.name(), null).size(400f, 55f).addInputDialog().get();
//renaming to an existing schematic is not allowed, as it is not clear how the tags would be merged, and which one should be removed
ui.showErrorMessage("@schematic.exists");
return;
}
s.tags.put("name", res); cont.row();
cont.margin(30).add("@editor.description").padRight(6f);
TextField descripionField = cont.area(s.description(), Styles.areaField, t -> {}).size(400f, 140f).addInputDialog().get();
Runnable accept = () -> {
s.tags.put("name", nameField.getText());
s.tags.put("description", descripionField.getText());
s.save(); s.save();
hide();
rebuildPane[0].run(); rebuildPane[0].run();
};
buttons.defaults().size(120, 54).pad(4);
buttons.button("@ok", accept).disabled(b -> nameField.getText().isEmpty());
buttons.button("@cancel", this::hide);
keyDown(KeyCode.enter, () -> {
if(!nameField.getText().isEmpty() && Core.scene.getKeyboardFocus() != descripionField){
accept.run();
}
}); });
keyDown(KeyCode.escape, this::hide);
keyDown(KeyCode.back, this::hide);
show();
}};
}); });
if(s.hasSteamID()){ if(s.hasSteamID()){