From 4d1ac032652e857a6d6bd63cadad0727ddb3a345 Mon Sep 17 00:00:00 2001 From: Jacob Shimp Date: Tue, 11 Nov 2025 19:32:27 -0500 Subject: potential implementation for playing in a league --- src/main/java/design/model/ScrambleLeague.java | 45 +++++++++++++++++++++++--- 1 file changed, 40 insertions(+), 5 deletions(-) (limited to 'src/main/java/design/model/ScrambleLeague.java') diff --git a/src/main/java/design/model/ScrambleLeague.java b/src/main/java/design/model/ScrambleLeague.java index 92e7099..55f9893 100644 --- a/src/main/java/design/model/ScrambleLeague.java +++ b/src/main/java/design/model/ScrambleLeague.java @@ -3,32 +3,67 @@ package design.model; import com.fasterxml.jackson.annotation.JsonCreator; import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; import java.util.Date; +import java.util.HashMap; import java.util.List; +import java.util.Map; public class ScrambleLeague extends League { - private final List participants; + private List participants; + private Map totalTeamScores; @JsonCreator private ScrambleLeague(int id, String name, Date registrationDate, Date startDate, Date endDate, Golfer owner, List participants, List schedule) { super(id, name, registrationDate, startDate, endDate, owner, schedule); this.participants = participants; + this.totalTeamScores = new HashMap<>(); + participants.forEach(t -> totalTeamScores.putIfAbsent(t, 0)); } public ScrambleLeague(String name, Date registrationDate, Date startDate, Date endDate, Golfer owner) { super(name, registrationDate, startDate, endDate, owner); this.participants = new ArrayList<>(); + this.totalTeamScores = new HashMap<>(); } - public boolean addParticipants(Team e) { - return participants.add(e); + public boolean addParticipants(Team t) { + boolean added = participants.add(t); + if(added) totalTeamScores.putIfAbsent(t, 0); + return added; } - public boolean removeParticipants(Team o) { - return participants.remove(o); + public boolean removeParticipants(Team t) { + totalTeamScores.remove(t); + return participants.remove(t); } public Team[] getParticipants() { return participants.toArray(Team[]::new); } + + @Override + public void recordPlay(Golfer player, Match match, Round round){ + if(!isPlayable()) return; + Team team = player.getTeam(); + if (team == null) return; + int strokes = round.getTotalSwings(); + team.addMemberRound(player, strokes); + match.addRound(round); + } + + @Override + public void finalizeLeague(){ + markCompleted(); + for(Team team : participants){ + int score = team.computeTotalBestScore(); + totalTeamScores.put(team, score); + } + participants.sort(Comparator.comparingInt(totalTeamScores::get)); + } + + public Map getTotalTeamScores(){ + return Collections.unmodifiableMap(totalTeamScores); + } } -- cgit v1.2.3 From 0294bd3a3121d6166788594f7249bf293cb00896 Mon Sep 17 00:00:00 2001 From: sowgro Date: Thu, 13 Nov 2025 08:41:56 -0500 Subject: change league printing --- src/main/java/design/model/ScrambleLeague.java | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'src/main/java/design/model/ScrambleLeague.java') diff --git a/src/main/java/design/model/ScrambleLeague.java b/src/main/java/design/model/ScrambleLeague.java index d372264..ad115d4 100644 --- a/src/main/java/design/model/ScrambleLeague.java +++ b/src/main/java/design/model/ScrambleLeague.java @@ -43,4 +43,9 @@ public class ScrambleLeague extends League { } return null; } + + @Override + public String getType() { + return "scramble"; + } } -- cgit v1.2.3