summaryrefslogtreecommitdiff
path: root/src/main/java/design/model/ScrambleLeague.java
diff options
context:
space:
mode:
Diffstat (limited to '')
-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;
+ }
+}