summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/design/controller/userinput/menus/AddClubMenu.java70
-rw-r--r--src/main/java/design/controller/userinput/menus/HolePlayMenu.java2
-rw-r--r--src/main/java/design/controller/userinput/menus/UserSettings.java2
-rw-r--r--src/main/java/design/model/Club.java13
-rw-r--r--src/main/java/design/model/Golfer.java19
5 files changed, 100 insertions, 6 deletions
diff --git a/src/main/java/design/controller/userinput/menus/AddClubMenu.java b/src/main/java/design/controller/userinput/menus/AddClubMenu.java
new file mode 100644
index 0000000..ad22eb3
--- /dev/null
+++ b/src/main/java/design/controller/userinput/menus/AddClubMenu.java
@@ -0,0 +1,70 @@
+package design.controller.userinput.menus;
+
+import design.controller.userinput.Menu;
+import design.controller.userinput.MenuOption;
+import design.model.Club;
+import design.model.Golfer;
+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 AddClubMenu extends Menu {
+
+ @Override
+ public String getTitle() {
+ return "add a club";
+ }
+
+ @Override
+ public List<MenuOption> getMenuOptions() {
+ List<MenuOption> opts = new ArrayList<>();
+
+ opts.add(new MenuOption("create new club", () -> {
+ Golfer g = Session.getCurrentGolfer();
+ if (g == null) {
+ System.out.println("No user loaded.");
+ new UserSettings().present();
+ return;
+ }
+
+ Scanner sc = new Scanner(System.in);
+
+ System.out.print("Manufacturer: ");
+ String manufacture = sc.nextLine().trim();
+
+ 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];
+ }
+
+ g.addClub(manufacture, nickname, type);
+
+ new UserSettings().present();
+ }));
+
+ opts.add(new MenuOption("cancel", () -> new UserSettings().present()));
+ return opts;
+ }
+}
diff --git a/src/main/java/design/controller/userinput/menus/HolePlayMenu.java b/src/main/java/design/controller/userinput/menus/HolePlayMenu.java
index e12bdfa..34e36f6 100644
--- a/src/main/java/design/controller/userinput/menus/HolePlayMenu.java
+++ b/src/main/java/design/controller/userinput/menus/HolePlayMenu.java
@@ -50,7 +50,7 @@ public class HolePlayMenu extends Menu {
String nick = sc.nextLine().trim();
// Defaulted to Driver for now
// TODO update logic
- Club club = new Club("Generic", nick, Club.ClubType.DRIVER);
+ Club club = new Club(0, "Generic", nick, Club.ClubType.DRIVER);
// Get shot distance (defaults to 0 of not stated)
System.out.print("Distance (yds, blank=0): ");
diff --git a/src/main/java/design/controller/userinput/menus/UserSettings.java b/src/main/java/design/controller/userinput/menus/UserSettings.java
index 04ec4d0..34b645d 100644
--- a/src/main/java/design/controller/userinput/menus/UserSettings.java
+++ b/src/main/java/design/controller/userinput/menus/UserSettings.java
@@ -60,6 +60,8 @@ public class UserSettings extends Menu {
this.present();
}));
+ opts.add(new MenuOption("add a club...", () -> new AddClubMenu().present()));
+
return opts;
}
}
diff --git a/src/main/java/design/model/Club.java b/src/main/java/design/model/Club.java
index 57a43d1..9fa3c87 100644
--- a/src/main/java/design/model/Club.java
+++ b/src/main/java/design/model/Club.java
@@ -13,16 +13,22 @@ public class Club {
PUTTER
}
+ private final int id;
private final String manufacture;
private final String nickname;
private final ClubType clubType;
- public Club(String manufacture, String nickname, ClubType clubType) {
+ public Club(int id, String manufacture, String nickname, ClubType clubType) {
+ this.id = id;
this.manufacture = manufacture;
this.nickname = nickname;
this.clubType = clubType;
}
+ public int getId() {
+ return id;
+ }
+
public String getManufacture() {
return manufacture;
}
@@ -34,4 +40,9 @@ public class Club {
public ClubType getClubType() {
return clubType;
}
+
+ @Override
+ public String toString() {
+ return String.format("#%d %s - %s (%s)", id, nickname, manufacture, clubType);
+ }
}
diff --git a/src/main/java/design/model/Golfer.java b/src/main/java/design/model/Golfer.java
index 19d6ac6..d34073f 100644
--- a/src/main/java/design/model/Golfer.java
+++ b/src/main/java/design/model/Golfer.java
@@ -11,15 +11,19 @@ public class Golfer {
private String fullName;
private final List<Course> courses;
private final List<Round> rounds;
- private final List<Club> clubs = new ArrayList<>(); // Keep track of golfer's clubs
+ private final List<Club> clubs; // Keep track of golfer's clubs
+ private int nextClubId = 1;
@JsonCreator
- private Golfer(String username, int passwordHash, String fullName, List<Course> courses, List<Round> rounds) {
+ private Golfer(String username, int passwordHash, String fullName, List<Course> courses, List<Round> rounds,
+ List<Club> clubs) {
this.username = username;
this.passwordHash = passwordHash;
this.fullName = fullName;
this.courses = courses;
this.rounds = rounds;
+ this.clubs = clubs;
+ this.nextClubId = this.clubs.stream().mapToInt(Club::getId).max().orElse(0) + 1;
}
public Golfer(String fullName, String username, String password) {
@@ -28,6 +32,8 @@ public class Golfer {
this.passwordHash = password.hashCode();
this.courses = new ArrayList<>();
this.rounds = new ArrayList<>();
+ this.clubs = new ArrayList<>();
+ this.nextClubId = 1;
}
public String getUsername() {
@@ -74,12 +80,17 @@ public class Golfer {
rounds.add(round);
}
- // Helpers dealing with clubs
- public void addClub(Club c) {
+ public Club addClub(String manufacture, String nickname, Club.ClubType type) {
+ Club c = new Club(nextClubId++, manufacture, nickname, type);
clubs.add(c);
+ return c;
}
public boolean hasClub(Club c) {
return clubs.contains(c);
}
+
+ public Club[] getClubs() {
+ return clubs.toArray(Club[]::new);
+ }
}