From d08a172227e45cfc2a0f29eea4cd118edc888913 Mon Sep 17 00:00:00 2001 From: Yvonne Schmidt Date: Mon, 2 Dec 2024 00:59:10 +0100 Subject: [PATCH 1/4] added selector and selection display to SellHouse --- .../monopoly/client/gui/popups/SellHouse.java | 128 +++++++++++++----- 1 file changed, 92 insertions(+), 36 deletions(-) diff --git a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java index ed6e7d7..d1ea377 100644 --- a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java +++ b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java @@ -3,14 +3,19 @@ package pp.monopoly.client.gui.popups; import com.jme3.math.ColorRGBA; import com.jme3.math.Vector2f; import com.jme3.math.Vector3f; +import com.simsilica.lemur.Axis; import com.simsilica.lemur.Button; import com.simsilica.lemur.Checkbox; import com.simsilica.lemur.Container; import com.simsilica.lemur.Label; import com.simsilica.lemur.ListBox; +import com.simsilica.lemur.Selector; +import com.simsilica.lemur.TextField; import com.simsilica.lemur.component.IconComponent; import com.simsilica.lemur.component.QuadBackgroundComponent; +import com.simsilica.lemur.component.SpringGridLayout; import com.simsilica.lemur.core.VersionedList; +import com.simsilica.lemur.core.VersionedReference; import com.simsilica.lemur.style.ElementId; import pp.dialog.Dialog; import pp.monopoly.client.MonopolyApp; @@ -21,7 +26,9 @@ import pp.monopoly.model.fields.BoardManager; import pp.monopoly.model.fields.BuildingProperty; import pp.monopoly.notification.Sound; +import java.util.HashSet; import java.util.List; +import java.util.Set; import java.util.stream.Collectors; /** @@ -31,6 +38,12 @@ public class SellHouse extends Dialog { private final MonopolyApp app; private final Container sellhouseContainer; private final Container backgroundContainer; + private TextField selectionDisplay; // TextField to display selections + private VersionedReference> selectionRef; + private Selector propertySelector; + private Set selectedProperties = new HashSet<>(); + + private Label cost = new Label("0", new ElementId("label-Text")); public SellHouse(MonopolyApp app) { @@ -67,42 +80,12 @@ public class SellHouse extends Dialog { middleContainer.setPreferredSize(new Vector3f(100, 150, 0)); middleContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); - // Create a VersionedList for the ListBox model - VersionedList listModel = new VersionedList<>(); - - // Retrieve current player and their properties - Player currentPlayer = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); - BoardManager boardManager = app.getGameLogic().getBoardManager(); - - List playerProperties = boardManager.getPropertyFields( - currentPlayer.getProperties()).stream() - .filter(property -> property instanceof BuildingProperty) - .map(property -> (BuildingProperty) property) - .filter(property -> property.getHouses() > 0 || property.getHotel() == 1) - .collect(Collectors.toList()); - - // Populate the list model - listModel.addAll(playerProperties); - - // Create a ListBox with the "glass" style and the model - ListBox listBox = new ListBox<>(listModel, "glass"); - listBox.setPreferredSize(new Vector3f(300, 200, 0)); // Adjust size as needed - - // Add selection listener - listBox.addClickCommands(item -> { - BuildingProperty selected = listBox.getSelectedItem(); // Correct method to retrieve the selected item - if (selected != null) { - System.out.println("Selected property: " + selected.getName()); - } - }); - - // Add the ListBox to the middle container - middleContainer.addChild(listBox); - + middleContainer.addChild(createPropertyDropdown()); downContainer.addChild(new Label("", new ElementId("label-Text")));// Leerzeile downContainer.addChild(new Label("Erstattung:", new ElementId("label-Text")));// Leerzeile downContainer.addChild(new Label("Hier die tätsächliche Erstattung", new ElementId("label-Text"))); + downContainer.addChild(cost); // Cost details downContainer.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.4657f, 0.4735f, 0.4892f, 1.0f))); // Beenden-Button @@ -117,12 +100,9 @@ public class SellHouse extends Dialog { confirmButton.setFontSize(32); confirmButton.addClickCommands(s -> ifTopDialog( () -> { app.getGameLogic().playSound(Sound.BUTTON); - BuildingProperty selected = listBox.getSelectedItem(); - if (selected != null) { - System.out.println("Confirmed property: " + selected.getName()); // Send the "alter building" message to the server //app.getGameLogic().sendMessage(new AlterBuildingMessage(selected.getId(), false)); TODO Message an Server - } + })); // Zentriere das Popup @@ -142,6 +122,82 @@ public class SellHouse extends Dialog { app.getGuiNode().attachChild(sellhouseContainer); } + /** + * Creates a dropdown menu for selecting a property. + * + * @return The dropdown container. + */ + private Container createPropertyDropdown() { + Container dropdownContainer = new Container(new SpringGridLayout(Axis.Y, Axis.X)); + dropdownContainer.setPreferredSize(new Vector3f(300, 200, 0)); + dropdownContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); + + VersionedList propertyOptions = new VersionedList<>(); + List playerProperties = getPlayerProperties(); + + // Populate the dropdown with property names + for (BuildingProperty property : playerProperties) { + propertyOptions.add(property.getName()); + } + + propertySelector = new Selector<>(propertyOptions, "glass"); + dropdownContainer.addChild(propertySelector); + + // Track selection changes + selectionRef = propertySelector.getSelectionModel().createReference(); + + // Initialize the selection display here + selectionDisplay = new TextField(""); // Create TextField for displaying selections + selectionDisplay.setPreferredSize(new Vector3f(300, 30, 0)); + dropdownContainer.addChild(selectionDisplay); // Add it to the dropdown container + + return dropdownContainer; + } + /** + * Retrieves the list of properties owned by the current player. + * + * @return List of BuildingProperty objects owned by the player. + */ + private List getPlayerProperties() { + Player self = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); + BoardManager boardManager = app.getGameLogic().getBoardManager(); + + return boardManager.getPropertyFields(self.getProperties()).stream() + .filter(property -> property instanceof BuildingProperty) + .map(property -> (BuildingProperty) property) + .collect(Collectors.toList()); + } + + @Override + public void update(float delta) { + if(selectionRef.update()) { + onDropdownSelectionChanged(propertySelector); + } + } + + /** + * Handles property selection changes. + */ + private void onDropdownSelectionChanged(Selector playerProperties) { + String selected = playerProperties.getSelectedItem(); + app.getGameLogic().playSound(Sound.BUTTON); + if (selectedProperties.contains(selected)) { + selectedProperties.remove(selected); + } else { + selectedProperties.add(selected); + } + + int cost = 0; + for (String s : selectedProperties) { + cost += ((BuildingProperty) app.getGameLogic().getBoardManager().getFieldByName(s)).getHousePrice(); + } + + String display = String.join(" | ", selectedProperties); + selectionDisplay.setText(display); + + this.cost.setText(cost+""); + } + /** * Schließt das Menü und entfernt die GUI-Elemente. */ From e05ad71ffffcf460a3603519fa8b70a19319145a Mon Sep 17 00:00:00 2001 From: Yvonne Schmidt Date: Mon, 2 Dec 2024 01:03:55 +0100 Subject: [PATCH 2/4] added selector and selection display to TakeMortage --- .../monopoly/client/gui/popups/SellHouse.java | 1 - .../client/gui/popups/TakeMortage.java | 128 +++++++++++++----- 2 files changed, 91 insertions(+), 38 deletions(-) diff --git a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java index d1ea377..08d78c5 100644 --- a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java +++ b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/SellHouse.java @@ -84,7 +84,6 @@ public class SellHouse extends Dialog { downContainer.addChild(new Label("", new ElementId("label-Text")));// Leerzeile downContainer.addChild(new Label("Erstattung:", new ElementId("label-Text")));// Leerzeile - downContainer.addChild(new Label("Hier die tätsächliche Erstattung", new ElementId("label-Text"))); downContainer.addChild(cost); // Cost details downContainer.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.4657f, 0.4735f, 0.4892f, 1.0f))); diff --git a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/TakeMortage.java b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/TakeMortage.java index f2c615a..3211df9 100644 --- a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/TakeMortage.java +++ b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/TakeMortage.java @@ -2,12 +2,17 @@ package pp.monopoly.client.gui.popups; import com.jme3.math.ColorRGBA; import com.jme3.math.Vector3f; +import com.simsilica.lemur.Axis; import com.simsilica.lemur.Button; import com.simsilica.lemur.Container; import com.simsilica.lemur.Label; import com.simsilica.lemur.ListBox; +import com.simsilica.lemur.Selector; +import com.simsilica.lemur.TextField; import com.simsilica.lemur.component.QuadBackgroundComponent; +import com.simsilica.lemur.component.SpringGridLayout; import com.simsilica.lemur.core.VersionedList; +import com.simsilica.lemur.core.VersionedReference; import com.simsilica.lemur.style.ElementId; import pp.dialog.Dialog; import pp.monopoly.client.MonopolyApp; @@ -17,7 +22,9 @@ import pp.monopoly.model.fields.BoardManager; import pp.monopoly.model.fields.BuildingProperty; import pp.monopoly.notification.Sound; +import java.util.HashSet; import java.util.List; +import java.util.Set; import java.util.stream.Collectors; /** @@ -27,6 +34,12 @@ public class TakeMortage extends Dialog { private final MonopolyApp app; private final Container takeMortageContainer; private final Container backgroundContainer; + private TextField selectionDisplay; // TextField to display selections + private VersionedReference> selectionRef; + private Selector propertySelector; + private Set selectedProperties = new HashSet<>(); + + private Label cost = new Label("0", new ElementId("label-Text")); public TakeMortage(MonopolyApp app) { @@ -63,42 +76,11 @@ public class TakeMortage extends Dialog { middleContainer.setPreferredSize(new Vector3f(100, 150, 0)); middleContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); - // Create a VersionedList for the ListBox model - VersionedList listModel = new VersionedList<>(); - - // Retrieve current player and their properties //TODO hier Prüfen, ob abweichungen zur SellHouse-Klasse beachtet werden müssen - Player currentPlayer = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); - BoardManager boardManager = app.getGameLogic().getBoardManager(); - - List playerProperties = boardManager.getPropertyFields( - currentPlayer.getProperties()).stream() - .filter(property -> property instanceof BuildingProperty) - .map(property -> (BuildingProperty) property) - .filter(property -> property.getHouses() > 0 || property.getHotel() == 1) - .collect(Collectors.toList()); - - // Populate the list model - listModel.addAll(playerProperties); - - // Create a ListBox with the "glass" style and the model - ListBox listBox = new ListBox<>(listModel, "glass"); - listBox.setPreferredSize(new Vector3f(300, 200, 0)); // Adjust size as needed - - // Add selection listener - listBox.addClickCommands(item -> { - BuildingProperty selected = listBox.getSelectedItem(); // Correct method to retrieve the selected item - if (selected != null) { - System.out.println("Selected property: " + selected.getName()); - } - }); - - // Add the ListBox to the middle container - middleContainer.addChild(listBox); - + middleContainer.addChild(createPropertyDropdown()); downContainer.addChild(new Label("", new ElementId("label-Text")));// Leerzeile downContainer.addChild(new Label("Erstattung:", new ElementId("label-Text")));// Leerzeile - downContainer.addChild(new Label("Hier die tätsächliche Erstattung", new ElementId("label-Text"))); + downContainer.addChild(cost); downContainer.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.4657f, 0.4735f, 0.4892f, 1.0f))); // Beenden-Button @@ -113,12 +95,8 @@ public class TakeMortage extends Dialog { confirmButton.setFontSize(32); confirmButton.addClickCommands(s -> ifTopDialog( () -> { app.getGameLogic().playSound(Sound.BUTTON); - BuildingProperty selected = listBox.getSelectedItem(); - if (selected != null) { - System.out.println("Confirmed property: " + selected.getName()); // Send the "alter building" message to the server //app.getGameLogic().sendMessage(new AlterBuildingMessage(selected.getId(), false)); TODO Message an Server - } })); // Zentriere das Popup @@ -138,6 +116,82 @@ public class TakeMortage extends Dialog { app.getGuiNode().attachChild(takeMortageContainer); } + /** + * Creates a dropdown menu for selecting a property. + * + * @return The dropdown container. + */ + private Container createPropertyDropdown() { + Container dropdownContainer = new Container(new SpringGridLayout(Axis.Y, Axis.X)); + dropdownContainer.setPreferredSize(new Vector3f(300, 200, 0)); + dropdownContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); + + VersionedList propertyOptions = new VersionedList<>(); + List playerProperties = getPlayerProperties(); + + // Populate the dropdown with property names + for (BuildingProperty property : playerProperties) { + propertyOptions.add(property.getName()); + } + + propertySelector = new Selector<>(propertyOptions, "glass"); + dropdownContainer.addChild(propertySelector); + + // Track selection changes + selectionRef = propertySelector.getSelectionModel().createReference(); + + // Initialize the selection display here + selectionDisplay = new TextField(""); // Create TextField for displaying selections + selectionDisplay.setPreferredSize(new Vector3f(300, 30, 0)); + dropdownContainer.addChild(selectionDisplay); // Add it to the dropdown container + + return dropdownContainer; + } + /** + * Retrieves the list of properties owned by the current player. + * + * @return List of BuildingProperty objects owned by the player. + */ + private List getPlayerProperties() { + Player self = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); + BoardManager boardManager = app.getGameLogic().getBoardManager(); + + return boardManager.getPropertyFields(self.getProperties()).stream() + .filter(property -> property instanceof BuildingProperty) + .map(property -> (BuildingProperty) property) + .collect(Collectors.toList()); + } + + @Override + public void update(float delta) { + if(selectionRef.update()) { + onDropdownSelectionChanged(propertySelector); + } + } + + /** + * Handles property selection changes. + */ + private void onDropdownSelectionChanged(Selector playerProperties) { + String selected = playerProperties.getSelectedItem(); + app.getGameLogic().playSound(Sound.BUTTON); + if (selectedProperties.contains(selected)) { + selectedProperties.remove(selected); + } else { + selectedProperties.add(selected); + } + + int cost = 0; + for (String s : selectedProperties) { + cost += ((BuildingProperty) app.getGameLogic().getBoardManager().getFieldByName(s)).getHousePrice(); + } + + String display = String.join(" | ", selectedProperties); + selectionDisplay.setText(display); + + this.cost.setText(cost+""); + } + /** * Schließt das Menü und entfernt die GUI-Elemente. */ From 411f7ea25b59d152ee9a6d50ef30f3d2793f3618 Mon Sep 17 00:00:00 2001 From: Yvonne Schmidt Date: Mon, 2 Dec 2024 01:06:58 +0100 Subject: [PATCH 3/4] added selector and selection display to RepayMortage --- .../client/gui/popups/RepayMortage.java | 129 +++++++++++++----- 1 file changed, 92 insertions(+), 37 deletions(-) diff --git a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/RepayMortage.java b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/RepayMortage.java index 14a9487..bc03f00 100644 --- a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/RepayMortage.java +++ b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/popups/RepayMortage.java @@ -2,12 +2,17 @@ package pp.monopoly.client.gui.popups; import com.jme3.math.ColorRGBA; import com.jme3.math.Vector3f; +import com.simsilica.lemur.Axis; import com.simsilica.lemur.Button; import com.simsilica.lemur.Container; import com.simsilica.lemur.Label; import com.simsilica.lemur.ListBox; +import com.simsilica.lemur.Selector; +import com.simsilica.lemur.TextField; import com.simsilica.lemur.component.QuadBackgroundComponent; +import com.simsilica.lemur.component.SpringGridLayout; import com.simsilica.lemur.core.VersionedList; +import com.simsilica.lemur.core.VersionedReference; import com.simsilica.lemur.style.ElementId; import pp.dialog.Dialog; import pp.monopoly.client.MonopolyApp; @@ -17,7 +22,9 @@ import pp.monopoly.model.fields.BoardManager; import pp.monopoly.model.fields.BuildingProperty; import pp.monopoly.notification.Sound; +import java.util.HashSet; import java.util.List; +import java.util.Set; import java.util.stream.Collectors; /** @@ -27,6 +34,12 @@ public class RepayMortage extends Dialog { private final MonopolyApp app; private final Container repayMortageContainer; private final Container backgroundContainer; + private TextField selectionDisplay; // TextField to display selections + private VersionedReference> selectionRef; + private Selector propertySelector; + private Set selectedProperties = new HashSet<>(); + + private Label cost = new Label("0", new ElementId("label-Text")); public RepayMortage(MonopolyApp app) { @@ -63,42 +76,11 @@ public class RepayMortage extends Dialog { middleContainer.setPreferredSize(new Vector3f(100, 150, 0)); middleContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); - // Create a VersionedList for the ListBox model - VersionedList listModel = new VersionedList<>(); - - // Retrieve current player and their properties //TODO hier Prüfen, ob abweichungen zur SellHouse-Klasse beachtet werden müssen - Player currentPlayer = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); - BoardManager boardManager = app.getGameLogic().getBoardManager(); - - List playerProperties = boardManager.getPropertyFields( - currentPlayer.getProperties()).stream() - .filter(property -> property instanceof BuildingProperty) - .map(property -> (BuildingProperty) property) - .filter(property -> property.getHouses() > 0 || property.getHotel() == 1) - .collect(Collectors.toList()); - - // Populate the list model - listModel.addAll(playerProperties); - - // Create a ListBox with the "glass" style and the model - ListBox listBox = new ListBox<>(listModel, "glass"); - listBox.setPreferredSize(new Vector3f(300, 200, 0)); // Adjust size as needed - - // Add selection listener - listBox.addClickCommands(item -> { - BuildingProperty selected = listBox.getSelectedItem(); // Correct method to retrieve the selected item - if (selected != null) { - System.out.println("Selected property: " + selected.getName()); - } - }); - - // Add the ListBox to the middle container - middleContainer.addChild(listBox); - + middleContainer.addChild(createPropertyDropdown()); downContainer.addChild(new Label("", new ElementId("label-Text")));// Leerzeile downContainer.addChild(new Label("Kosten:", new ElementId("label-Text")));// Leerzeile - downContainer.addChild(new Label("Hier die tätsächliche Erstattung", new ElementId("label-Text"))); + downContainer.addChild(cost); downContainer.setBackground(new QuadBackgroundComponent(new ColorRGBA(0.4657f, 0.4735f, 0.4892f, 1.0f))); // Beenden-Button @@ -113,12 +95,9 @@ public class RepayMortage extends Dialog { confirmButton.setFontSize(32); confirmButton.addClickCommands(s -> ifTopDialog( () -> { app.getGameLogic().playSound(Sound.BUTTON); - BuildingProperty selected = listBox.getSelectedItem(); - if (selected != null) { - System.out.println("Confirmed property: " + selected.getName()); // Send the "alter building" message to the server //app.getGameLogic().sendMessage(new AlterBuildingMessage(selected.getId(), false)); TODO Message an Server - } + })); // Zentriere das Popup @@ -138,6 +117,82 @@ public class RepayMortage extends Dialog { app.getGuiNode().attachChild(repayMortageContainer); } + /** + * Creates a dropdown menu for selecting a property. + * + * @return The dropdown container. + */ + private Container createPropertyDropdown() { + Container dropdownContainer = new Container(new SpringGridLayout(Axis.Y, Axis.X)); + dropdownContainer.setPreferredSize(new Vector3f(300, 200, 0)); + dropdownContainer.setBackground(new QuadBackgroundComponent(ColorRGBA.Orange)); + + VersionedList propertyOptions = new VersionedList<>(); + List playerProperties = getPlayerProperties(); + + // Populate the dropdown with property names + for (BuildingProperty property : playerProperties) { + propertyOptions.add(property.getName()); + } + + propertySelector = new Selector<>(propertyOptions, "glass"); + dropdownContainer.addChild(propertySelector); + + // Track selection changes + selectionRef = propertySelector.getSelectionModel().createReference(); + + // Initialize the selection display here + selectionDisplay = new TextField(""); // Create TextField for displaying selections + selectionDisplay.setPreferredSize(new Vector3f(300, 30, 0)); + dropdownContainer.addChild(selectionDisplay); // Add it to the dropdown container + + return dropdownContainer; + } + /** + * Retrieves the list of properties owned by the current player. + * + * @return List of BuildingProperty objects owned by the player. + */ + private List getPlayerProperties() { + Player self = app.getGameLogic().getPlayerHandler().getPlayerById(app.getId()); + BoardManager boardManager = app.getGameLogic().getBoardManager(); + + return boardManager.getPropertyFields(self.getProperties()).stream() + .filter(property -> property instanceof BuildingProperty) + .map(property -> (BuildingProperty) property) + .collect(Collectors.toList()); + } + + @Override + public void update(float delta) { + if(selectionRef.update()) { + onDropdownSelectionChanged(propertySelector); + } + } + + /** + * Handles property selection changes. + */ + private void onDropdownSelectionChanged(Selector playerProperties) { + String selected = playerProperties.getSelectedItem(); + app.getGameLogic().playSound(Sound.BUTTON); + if (selectedProperties.contains(selected)) { + selectedProperties.remove(selected); + } else { + selectedProperties.add(selected); + } + + int cost = 0; + for (String s : selectedProperties) { + cost += ((BuildingProperty) app.getGameLogic().getBoardManager().getFieldByName(s)).getHousePrice(); + } + + String display = String.join(" | ", selectedProperties); + selectionDisplay.setText(display); + + this.cost.setText(cost+""); + } + /** * Schließt das Menü und entfernt die GUI-Elemente. */ From fcb55e52fcf49d913b819c0417abfbef15a90619 Mon Sep 17 00:00:00 2001 From: Yvonne Schmidt Date: Mon, 2 Dec 2024 01:11:38 +0100 Subject: [PATCH 4/4] fixed esc in BuildingAdminMenu --- .../java/pp/monopoly/client/gui/BuildingAdminMenu.java | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/BuildingAdminMenu.java b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/BuildingAdminMenu.java index a96d8e2..d903c03 100644 --- a/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/BuildingAdminMenu.java +++ b/Projekte/monopoly/client/src/main/java/pp/monopoly/client/gui/BuildingAdminMenu.java @@ -163,14 +163,6 @@ public class BuildingAdminMenu extends Dialog { app.getGuiNode().attachChild(background); } - /** - * Handles the "Zurück" action. - */ - private void handleBack() { - app.getGameLogic().playSound(Sound.BUTTON); - close(); - } - @Override public void close() { app.getGuiNode().detachChild(mainContainer); @@ -180,7 +172,7 @@ public class BuildingAdminMenu extends Dialog { @Override public void escape() { - handleBack(); + new SettingsMenu(app).open(); } @Override