summaryrefslogtreecommitdiff
path: root/src/main/java/design/model/ScrambleLeague.java
diff options
context:
space:
mode:
authorsowgro <tpoke.ferrari@gmail.com>2025-11-13 08:20:04 -0500
committersowgro <tpoke.ferrari@gmail.com>2025-11-13 08:20:04 -0500
commitc1bf473e5c6735ae00c3fbfec0f9d16c421387db (patch)
tree703e1bfaf95d274ff10d9946e63d2e4e39ae9d6f /src/main/java/design/model/ScrambleLeague.java
parentc8e3d79f09670a94c0a2f503ca6c78f9913a1669 (diff)
parentaf23c48329b749ba3d0a4fcd841723d55a16ae95 (diff)
downloaddesignproject-design-6-c1bf473e5c6735ae00c3fbfec0f9d16c421387db.tar.gz
designproject-design-6-c1bf473e5c6735ae00c3fbfec0f9d16c421387db.tar.bz2
designproject-design-6-c1bf473e5c6735ae00c3fbfec0f9d16c421387db.zip
Merge remote-tracking branch 'origin/league-model'
# Conflicts: # src/main/java/design/controller/userinput/menus/MainMenu.java # src/main/java/design/model/Golfer.java # src/test/java/design/model/ClubTest.java # src/test/java/design/model/GolferTest.java
Diffstat (limited to 'src/main/java/design/model/ScrambleLeague.java')
-rw-r--r--src/main/java/design/model/ScrambleLeague.java46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/main/java/design/model/ScrambleLeague.java b/src/main/java/design/model/ScrambleLeague.java
new file mode 100644
index 0000000..d372264
--- /dev/null
+++ b/src/main/java/design/model/ScrambleLeague.java
@@ -0,0 +1,46 @@
+package design.model;
+
+import com.fasterxml.jackson.annotation.JsonCreator;
+import com.fasterxml.jackson.annotation.JsonTypeName;
+
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Date;
+import java.util.List;
+
+@JsonTypeName("scramble")
+public class ScrambleLeague extends League {
+ private final List<Team> participants;
+
+ @JsonCreator
+ private ScrambleLeague(int id, String name, Date registrationDate, Date startDate, Date endDate, Golfer owner, List<Team> participants, List<Match> schedule) {
+ super(id, name, registrationDate, startDate, endDate, owner, schedule);
+ this.participants = participants;
+ }
+
+ public ScrambleLeague(String name, Date registrationDate, Date startDate, Date endDate, Golfer owner) {
+ super(name, registrationDate, startDate, endDate, owner);
+ this.participants = new ArrayList<>();
+ }
+
+ public boolean addParticipants(Team e) {
+ return participants.add(e);
+ }
+
+ public boolean removeParticipants(Team o) {
+ return participants.remove(o);
+ }
+
+ public Team[] getParticipants() {
+ return participants.toArray(Team[]::new);
+ }
+
+ public Team locateTeam(Golfer golfer) {
+ for (Team participant : participants) {
+ if (List.of(participant.getMembers()).contains(golfer)) {
+ return participant;
+ }
+ }
+ return null;
+ }
+}