summaryrefslogtreecommitdiff
path: root/src/main/java/design/controller/userinput/menus/ManageClubs.java
diff options
context:
space:
mode:
authorsowgro <tpoke.ferrari@gmail.com>2025-10-11 22:24:54 -0400
committersowgro <tpoke.ferrari@gmail.com>2025-10-11 22:24:54 -0400
commitfac7fb71260b901a893b5b90aae23e86d6c23550 (patch)
tree41132296ea8e2bf124f76b9cfad1d6e492e8f0e0 /src/main/java/design/controller/userinput/menus/ManageClubs.java
parent197e1961b4b9b2ab12dc070cd6a76ccb1ef3b369 (diff)
downloaddesignproject-design-6-fac7fb71260b901a893b5b90aae23e86d6c23550.tar.gz
designproject-design-6-fac7fb71260b901a893b5b90aae23e86d6c23550.tar.bz2
designproject-design-6-fac7fb71260b901a893b5b90aae23e86d6c23550.zip
Menu cleanup - pass 2
Diffstat (limited to 'src/main/java/design/controller/userinput/menus/ManageClubs.java')
-rw-r--r--src/main/java/design/controller/userinput/menus/ManageClubs.java83
1 files changed, 34 insertions, 49 deletions
diff --git a/src/main/java/design/controller/userinput/menus/ManageClubs.java b/src/main/java/design/controller/userinput/menus/ManageClubs.java
index 56d645f..6786553 100644
--- a/src/main/java/design/controller/userinput/menus/ManageClubs.java
+++ b/src/main/java/design/controller/userinput/menus/ManageClubs.java
@@ -8,12 +8,13 @@ import design.persistence.PersonalDatabase;
import design.runtime.Session;
import java.io.IOException;
-import java.util.ArrayList;
+import java.util.Arrays;
import java.util.List;
import java.util.Scanner;
public class ManageClubs extends Menu {
- Golfer golfer = Session.getCurrentGolfer();
+ private final Golfer golfer = Session.getCurrentGolfer();
+ private final PersonalDatabase personalDB = PersonalDatabase.INSTANCE;
@Override
public String getTitle() {
@@ -33,34 +34,13 @@ public class ManageClubs extends Menu {
}));
opts.add(new MenuOption("remove club...", () -> {
- new Menu() {
- @Override
- public String getTitle() {
- return "remove club";
- }
-
- @Override
- public List<MenuOption> getMenuOptions() {
- List<MenuOption> list = new ArrayList<>();
- for (Club c : golfer.getClubs()) {
- MenuOption menuOption = new MenuOption(c.toString(), () -> {
- golfer.removeClub(c);
- this.present();
- });
- list.add(menuOption);
- }
- return list;
- }
- }.present();
+ var selector = new SelectClub(golfer);
+ selector.present();
+ golfer.removeClub(selector.getResult());
+ this.present();
}));
opts.add(new MenuOption("add club...", () -> {
- if (golfer == null) {
- System.out.println("No user loaded.");
- new UserSettings().present();
- return;
- }
-
Scanner sc = new Scanner(System.in);
System.out.print("Manufacturer: ");
@@ -69,37 +49,42 @@ public class ManageClubs extends Menu {
System.out.print("Nickname: ");
String nickname = sc.nextLine().trim();
- // Pick type
- Club.ClubType[] types = Club.ClubType.values();
- System.out.println("Club type:");
- for (int i = 0; i < types.length; i++) {
- System.out.printf("%d: %s%n", i + 1, types[i]);
- }
-
- Club.ClubType type = null;
- while (type == null) {
- System.out.print("Select (1.." + types.length + "): ");
- String line = sc.nextLine().trim();
- int idx = Integer.parseInt(line);
- if (idx < 1 || idx > types.length) {
- System.out.println("Out of range. Try again.");
- continue;
- }
- type = types[idx - 1];
- }
+ var selector = new SelectClubType();
+ selector.present();
+ Club.ClubType type = selector.getResult();
golfer.addClub(manufacture, nickname, type);
// Add club to JSON
try {
- PersonalDatabase.INSTANCE.updateGolfer(golfer);
+ personalDB.updateGolfer(golfer);
System.out.println("Club added and saved.");
} catch (IOException e) {
throw new RuntimeException("Failed to save club", e);
}
- new UserSettings().present();
- }));// Pick type
-// Add club to JSON
+ this.present();
+ }));
+
return opts;
}
+
+ private static class SelectClubType extends Menu {
+ private Club.ClubType result;
+
+ @Override
+ public String getTitle() {
+ return "select club type";
+ }
+
+ public Club.ClubType getResult() {
+ return result;
+ }
+
+ @Override
+ public List<MenuOption> getMenuOptions() {
+ return Arrays.stream(Club.ClubType.values())
+ .map(t -> new MenuOption(t.name(), () -> result = t))
+ .toList();
+ }
+ }
}