changed ParticipantFormular to change existing objects and don't repl… #22

Merged
schrom01 merged 1 commits from fix_participanFormular_and_placesFormular into main 2022-05-12 11:39:16 +02:00
8 changed files with 53 additions and 7 deletions

View File

@ -6,4 +6,5 @@ public interface Participant extends Serializable {
String getName();
void setName(String name);
boolean equals(Participant participant);
void change(Participant participant);
}

View File

@ -4,7 +4,7 @@ import java.io.Serializable;
public class Person implements Serializable {
private final String NAME_MATCHING_REGEX = "[a-zA-Z]{1,20}";
private final String PHONE_MATCHING_REGEX = "[\\+0-9]+";
private final String PHONE_MATCHING_REGEX = "[\\+]?[0-9]*";
private String name;
private String firstName;

View File

@ -29,12 +29,27 @@ public class Player extends Person implements Participant{
}
public void setDateOfBirth(String dateOfBirth) {
if(dateOfBirth.length() > 0) {
String[] date = dateOfBirth.split("\\.");
this.dateOfBirth = LocalDate.of(Integer.valueOf(date[2]), Integer.valueOf(date[1]), Integer.valueOf(date[0]));
} else {
dateOfBirth = null;
}
}
public void setDateOfBirth(LocalDate dateOfBirth) {
this.dateOfBirth = dateOfBirth;
}
@Override
public boolean equals(Participant participant) {
return getClass().equals(participant.getClass()) && toString().toLowerCase().equals(participant.toString().toLowerCase());
}
@Override
public void change(Participant participant) {
Player player = (Player) participant;
setDateOfBirth(player.getDateOfBirth());
setPhoneNumber(player.getPhoneNumber());
}
}

View File

@ -27,11 +27,24 @@ public class Team implements Participant {
this.name = name;
}
public void setPlayers(List<Player> players) {
this.players = players;
}
public List<Player> getPlayers() {
return players;
}
@Override
public boolean equals(Participant participant) {
return getClass().equals(participant.getClass()) && toString().toLowerCase().equals(participant.toString().toLowerCase());
}
@Override
public void change(Participant participant) {
return;
}
public Person getContactPerson() {
return contactPerson;
}

View File

@ -31,8 +31,13 @@ public class Tournament implements Serializable {
places = new ArrayList<>();
}
public void addParticipant(Participant newParticipant) throws ParticipantExistsException {
participants.removeIf(participant -> participant.equals(newParticipant));
public void saveParticipant(Participant newParticipant) throws ParticipantExistsException {
for(Participant participant: participants){
if(participant.equals(newParticipant)){
participant.change(newParticipant);
return;
}
}
participants.add(newParticipant);
}

View File

@ -2,7 +2,6 @@ package ch.zhaw.projekt2.turnierverwaltung;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
public class TournamentDecorator implements IsObservable{
@ -81,7 +80,7 @@ public class TournamentDecorator implements IsObservable{
public void savePlayer(String firstName, String name, String phoneNumber, String dateOfBirth){
try {
tournament.addParticipant(new Player(firstName, name, phoneNumber, dateOfBirth));
tournament.saveParticipant(new Player(firstName, name, phoneNumber, dateOfBirth));
informListener();
} catch (Tournament.ParticipantExistsException e) {
e.printStackTrace(); //TODO handle and logging

View File

@ -79,6 +79,14 @@ public class ParticipantFormularController extends FXController {
@FXML
void saveParticipant(ActionEvent event) {
getTournamentDecorator().savePlayer(firstNameTextField.getText(), participantNameTextField.getText(), phoneNumberTextField.getText(), birthDateTextField.getText());
clearFormular();
}
private void clearFormular() {
firstNameTextField.clear();
participantNameTextField.clear();
phoneNumberTextField.clear();
birthDateTextField.clear();
}
@FXML

View File

@ -58,6 +58,11 @@ public class PlacesFormularController extends FXController {
@FXML
void savePlace(ActionEvent event) {
getTournamentDecorator().savePlace(placeNameTextField.getText());
clearFormular();
}
private void clearFormular() {
placeNameTextField.clear();
}
@FXML