From 9b67c5fa4c53a558a32926ab04b59def510396ab Mon Sep 17 00:00:00 2001 From: WillemDalton Date: Sun, 5 Oct 2025 18:17:01 -0400 Subject: some progress on menu commands for searching --- .../controller/userinput/menus/MainMenu.java | 1 + .../controller/userinput/menus/SearchMenu.java | 28 ++++++++++++++++++++ .../controller/userinput/menus/SelectCourse.java | 30 ++++++++++++++++++++++ 3 files changed, 59 insertions(+) create mode 100644 src/main/java/design/controller/userinput/menus/SearchMenu.java create mode 100644 src/main/java/design/controller/userinput/menus/SelectCourse.java (limited to 'src/main/java/design/controller/userinput') diff --git a/src/main/java/design/controller/userinput/menus/MainMenu.java b/src/main/java/design/controller/userinput/menus/MainMenu.java index fb3cee9..f2c9c21 100644 --- a/src/main/java/design/controller/userinput/menus/MainMenu.java +++ b/src/main/java/design/controller/userinput/menus/MainMenu.java @@ -15,6 +15,7 @@ public class MainMenu extends Menu { public List getMenuOptions() { return List.of( new MenuOption("user settings...", (a) -> new UserSettings().present()), + new MenuOption("add course to profile...", (a) -> new SearchMenu().present()), new MenuOption("statistics...", (a) -> new StatisticsMenu().present()), new MenuOption("log round...", (a) -> {}), new MenuOption("quit", (a) -> {}) diff --git a/src/main/java/design/controller/userinput/menus/SearchMenu.java b/src/main/java/design/controller/userinput/menus/SearchMenu.java new file mode 100644 index 0000000..f02de09 --- /dev/null +++ b/src/main/java/design/controller/userinput/menus/SearchMenu.java @@ -0,0 +1,28 @@ +package design.controller.userinput.menus; + +import design.controller.userinput.Menu; +import design.controller.userinput.MenuOption; + +import java.util.List; + +public class SearchMenu extends Menu { + + @Override + public String getTitle() { + return "search menu"; + } + + @Override + public List getMenuOptions() { + return List.of( + new MenuOption("return to main menu", (a) -> new MainMenu().present()), + new MenuOption("search...", (a) -> new SelectCourse().present()), + new MenuOption("add difficulty filter...", (a) -> {}), + new MenuOption("add hole count filter...", (a) -> {}), + new MenuOption("add location filter...", (a) -> {}), + new MenuOption("add par filter...", (a) -> {}), + new MenuOption("list filters", (a) -> {}), + new MenuOption("clear all filters", (a) -> {}) + ); + } +} diff --git a/src/main/java/design/controller/userinput/menus/SelectCourse.java b/src/main/java/design/controller/userinput/menus/SelectCourse.java new file mode 100644 index 0000000..ddf8b0b --- /dev/null +++ b/src/main/java/design/controller/userinput/menus/SelectCourse.java @@ -0,0 +1,30 @@ +package design.controller.userinput.menus; + +import design.controller.userinput.Menu; +import design.controller.userinput.MenuOption; +import design.persistence.MasterDatabase; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; + +public class SelectCourse extends Menu { + MasterDatabase globalDB = MasterDatabase.INSTANCE; + + @Override + public String getTitle() { + return "select user"; + } + + + // gonna need to tweak this to only grab those from the search requirements. + @Override + public List getMenuOptions() { + var l = new ArrayList(); + l.addAll(Arrays.stream(globalDB.getCourses()) + .map(i -> new MenuOption( + i.getName() + ", " + i.getLocation() + ", Difficulty: " + i.getDifficultyRating() + ", " + i.getHoleCount() + " holes", + (a) -> {})).toList()); + return l; + } +} -- cgit v1.2.3