Merge pull request #33 from PM2-IT21bWIN-ruiz-mach-krea/develope_Game_branch
Develope game branch
This commit is contained in:
		
						commit
						b0aa0ab1ad
					
				| 
						 | 
				
			
			@ -7,40 +7,65 @@ public abstract class FXController {
 | 
			
		|||
    FactoryDecorator factoryDecorator;
 | 
			
		||||
    FileIO fileIO;
 | 
			
		||||
    Pane pane;
 | 
			
		||||
    IsObserver listener;
 | 
			
		||||
 | 
			
		||||
    public FXController(){
 | 
			
		||||
        listener = new IsObserver() {
 | 
			
		||||
            @Override
 | 
			
		||||
            public void update() {
 | 
			
		||||
                loadContent();
 | 
			
		||||
            }
 | 
			
		||||
        };
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void setup(TournamentDecorator tournamentDecorator, FileIO fileIO, FactoryDecorator factoryDecorator, Pane pane){
 | 
			
		||||
        this.tournamentDecorator = tournamentDecorator;
 | 
			
		||||
        this.fileIO = fileIO;
 | 
			
		||||
        this.factoryDecorator = factoryDecorator;
 | 
			
		||||
        this.pane = pane;
 | 
			
		||||
        tournamentDecorator.addListener(new IsObserver() {
 | 
			
		||||
            @Override
 | 
			
		||||
            public void update() {
 | 
			
		||||
                loadContent();
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
        factoryDecorator.addListener(new IsObserver() {
 | 
			
		||||
            @Override
 | 
			
		||||
            public void update() {
 | 
			
		||||
                loadContent();
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
        addListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public abstract void loadContent();
 | 
			
		||||
 | 
			
		||||
    protected void setTournamentDecorator(TournamentDecorator tournamentDecorator) {
 | 
			
		||||
        this.tournamentDecorator = tournamentDecorator;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void addListener(){
 | 
			
		||||
        tournamentDecorator.addListener(listener);
 | 
			
		||||
        factoryDecorator.addListener(listener);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected void removeListener(){
 | 
			
		||||
        tournamentDecorator.removeListener(listener);
 | 
			
		||||
        factoryDecorator.removeListener(listener);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected TournamentDecorator getTournamentDecorator() {
 | 
			
		||||
        return tournamentDecorator;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected void setFactoryDecorator(FactoryDecorator factoryDecorator) {
 | 
			
		||||
        this.factoryDecorator = factoryDecorator;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected FactoryDecorator getFactoryDecorator() {
 | 
			
		||||
        return factoryDecorator;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected void setFileIO(FileIO fileIO) {
 | 
			
		||||
        this.fileIO = fileIO;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected FileIO getFileIO() {
 | 
			
		||||
        return fileIO;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected void setPane(Pane pane) {
 | 
			
		||||
        this.pane = pane;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    protected Pane getPane() {
 | 
			
		||||
        return pane;
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,8 +1,11 @@
 | 
			
		|||
package ch.zhaw.projekt2.turnierverwaltung;
 | 
			
		||||
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController;
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameDecorator;
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.main.tournamentList.TournamentListController;
 | 
			
		||||
import javafx.fxml.FXMLLoader;
 | 
			
		||||
import javafx.scene.layout.BorderPane;
 | 
			
		||||
import javafx.scene.layout.VBox;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.net.URL;
 | 
			
		||||
| 
						 | 
				
			
			@ -10,6 +13,7 @@ import java.net.URL;
 | 
			
		|||
public class Factory {
 | 
			
		||||
    private TournamentDecorator tournamentDecorator;
 | 
			
		||||
    private FileIO fileIO;
 | 
			
		||||
    //TODO save views instead of recreate them.
 | 
			
		||||
 | 
			
		||||
    public Factory(FileIO fileIO, TournamentDecorator tournamentDecorator){
 | 
			
		||||
        this.fileIO = fileIO;
 | 
			
		||||
| 
						 | 
				
			
			@ -54,6 +58,20 @@ public class Factory {
 | 
			
		|||
        setCenterOfBorderPane(pane, getClass().getResource("gameScheduleView/GameSchedule.fxml"), factoryDecorator);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public GameController loadGameView(VBox box, GameDecorator gameDecorator, FactoryDecorator factoryDecorator) {
 | 
			
		||||
        try {
 | 
			
		||||
            FXMLLoader loader = new FXMLLoader(getClass().getResource("gameScheduleView/Game.fxml"));
 | 
			
		||||
            box.getChildren().add(loader.load());
 | 
			
		||||
            GameController controller = loader.getController();
 | 
			
		||||
            controller.setup(tournamentDecorator, fileIO, factoryDecorator, box, gameDecorator);
 | 
			
		||||
            return controller;
 | 
			
		||||
        } catch (IOException e) {
 | 
			
		||||
            e.printStackTrace();
 | 
			
		||||
            //TODO LOGGER
 | 
			
		||||
        }
 | 
			
		||||
        return null;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private FXController setCenterOfBorderPane(BorderPane pane, URL location, FactoryDecorator factoryDecorator) {
 | 
			
		||||
        FXController controller = null;
 | 
			
		||||
        try {
 | 
			
		||||
| 
						 | 
				
			
			@ -61,7 +79,6 @@ public class Factory {
 | 
			
		|||
            pane.setCenter(loader.load());
 | 
			
		||||
            controller = loader.getController();
 | 
			
		||||
            controller.setup(tournamentDecorator, fileIO, factoryDecorator, pane);
 | 
			
		||||
            controller.loadContent();
 | 
			
		||||
        } catch (IOException e) {
 | 
			
		||||
            e.printStackTrace();
 | 
			
		||||
            //TODO handle and logging?
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,14 @@
 | 
			
		|||
package ch.zhaw.projekt2.turnierverwaltung;
 | 
			
		||||
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController;
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameDecorator;
 | 
			
		||||
import javafx.geometry.Pos;
 | 
			
		||||
import javafx.scene.Node;
 | 
			
		||||
import javafx.scene.layout.BorderPane;
 | 
			
		||||
import javafx.scene.layout.HBox;
 | 
			
		||||
import javafx.scene.layout.Pane;
 | 
			
		||||
import javafx.scene.layout.VBox;
 | 
			
		||||
import javafx.scene.shape.Line;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
| 
						 | 
				
			
			@ -44,8 +51,7 @@ public class FactoryDecorator implements IsObservable{
 | 
			
		|||
    public void openTournament(FileIO.TournamentFile tournamentFile){
 | 
			
		||||
        try {
 | 
			
		||||
            factory.setTournament(fileIO.loadTournament(tournamentFile));
 | 
			
		||||
            factory.loadGameScheduler((BorderPane) pane, this);
 | 
			
		||||
            informListener();
 | 
			
		||||
            openScheduleView();
 | 
			
		||||
        } catch (IOException e) {
 | 
			
		||||
            e.printStackTrace();
 | 
			
		||||
        } catch (ClassNotFoundException e) {
 | 
			
		||||
| 
						 | 
				
			
			@ -53,18 +59,106 @@ public class FactoryDecorator implements IsObservable{
 | 
			
		|||
        } //TODO handle and logging
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void openTournamentList() {
 | 
			
		||||
        factory.loadTournamentList((BorderPane) pane, this);
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void openParticipantFormular() {
 | 
			
		||||
        factory.loadParticipantFormular((BorderPane) pane, this);
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void openPlacesFormular() {
 | 
			
		||||
        factory.loadPlacesFormular((BorderPane) pane, this);
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void openScheduleView() {
 | 
			
		||||
        factory.loadGameScheduler((BorderPane) pane, this);
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void loadGameList(HBox hBoxCenter, TournamentDecorator tournamentDecorator, boolean treeView) {
 | 
			
		||||
        hBoxCenter.getChildren().clear();
 | 
			
		||||
 | 
			
		||||
        List<List<Game>> gameList = tournamentDecorator.getTournament().getGameList();
 | 
			
		||||
 | 
			
		||||
        List<GameDecorator> gameDecoratorsList = new ArrayList<>();
 | 
			
		||||
        double gameBoxHeight = 0;
 | 
			
		||||
        double spacingFactor = 0;
 | 
			
		||||
        for (int i = 0; i < gameList.size(); i++) {
 | 
			
		||||
            List<GameDecorator> newGameDecoratorsList = new ArrayList<>();
 | 
			
		||||
            VBox vBox = new VBox();
 | 
			
		||||
            if(treeView){
 | 
			
		||||
                vBox.setAlignment(Pos.CENTER);
 | 
			
		||||
                vBox.setSpacing(gameBoxHeight * spacingFactor);
 | 
			
		||||
            } else {
 | 
			
		||||
                vBox.setAlignment(Pos.TOP_CENTER);
 | 
			
		||||
            }
 | 
			
		||||
            spacingFactor = spacingFactor * 2 + 1;
 | 
			
		||||
            for (int j = 0; j < gameList.get(i).size(); j++) {
 | 
			
		||||
                GameDecorator gameDecorator = new GameDecorator(gameList.get(i).get(j));
 | 
			
		||||
                newGameDecoratorsList.add(gameDecorator);
 | 
			
		||||
                GameController gameController = openGameView(vBox,gameDecorator);
 | 
			
		||||
                if(i>0){
 | 
			
		||||
                    gameController.addListener(gameDecoratorsList.get(j*2));
 | 
			
		||||
                    gameController.addListener(gameDecoratorsList.get(j*2+1));
 | 
			
		||||
                } else if(gameBoxHeight == 0) {
 | 
			
		||||
                    gameBoxHeight = gameController.getGameBoxHeigth();
 | 
			
		||||
                }
 | 
			
		||||
                gameDecorator.addListener(new IsObserver() {
 | 
			
		||||
                    @Override
 | 
			
		||||
                    public void update() {
 | 
			
		||||
                        tournamentDecorator.saveTournament();
 | 
			
		||||
                    }
 | 
			
		||||
                });
 | 
			
		||||
                gameController.loadContent();
 | 
			
		||||
            }
 | 
			
		||||
            hBoxCenter.getChildren().add(vBox);
 | 
			
		||||
            if(treeView){
 | 
			
		||||
                if(i+1 < gameList.size())
 | 
			
		||||
                hBoxCenter.getChildren().add(drawLines(vBox, gameBoxHeight, 30));
 | 
			
		||||
            }
 | 
			
		||||
            gameDecoratorsList = newGameDecoratorsList;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public VBox drawLines(VBox gameVBox, double gameBoxHeight, double lineLength){
 | 
			
		||||
        VBox completeLineVBox = new VBox();
 | 
			
		||||
        completeLineVBox.setAlignment(Pos.CENTER_LEFT);
 | 
			
		||||
        double lineSpacing = gameVBox.getSpacing() + gameBoxHeight - 1;
 | 
			
		||||
        completeLineVBox.setSpacing(lineSpacing);
 | 
			
		||||
        for(int i = 0; i < gameVBox.getChildren().size(); i+=2){
 | 
			
		||||
            HBox lineBox = new HBox();
 | 
			
		||||
            lineBox.setAlignment(Pos.CENTER);
 | 
			
		||||
 | 
			
		||||
            //add Lines from left Game to center
 | 
			
		||||
            VBox vBox = new VBox();
 | 
			
		||||
            vBox.setSpacing(lineSpacing);
 | 
			
		||||
            vBox.getChildren().add(new Line(0,0,lineLength,0));
 | 
			
		||||
            vBox.getChildren().add(new Line(0,0,lineLength,0));
 | 
			
		||||
            lineBox.getChildren().add(vBox);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            //add vertical line
 | 
			
		||||
            lineBox.getChildren().add(new Line(0, 0, 0, lineSpacing));
 | 
			
		||||
 | 
			
		||||
            //add line to right game
 | 
			
		||||
            lineBox.getChildren().add(new Line(0, 0, lineLength, 0));
 | 
			
		||||
 | 
			
		||||
            completeLineVBox.getChildren().add(lineBox);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
        return completeLineVBox;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public GameController openGameView(VBox vBox, GameDecorator gameDecorator) {
 | 
			
		||||
        return factory.loadGameView(vBox ,gameDecorator, this);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void informListener() {
 | 
			
		||||
        for(IsObserver observer : listener) {
 | 
			
		||||
            observer.update();
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -81,7 +81,7 @@ public class FileIO {
 | 
			
		|||
     * @throws IOException            File not readable
 | 
			
		||||
     * @throws FileNotFoundException  File not found
 | 
			
		||||
     */
 | 
			
		||||
    public Tournament loadTournament(File tournamentFile) throws IOException, ClassNotFoundException, FileNotFoundException {
 | 
			
		||||
    public synchronized Tournament loadTournament(File tournamentFile) throws IOException, ClassNotFoundException, FileNotFoundException {
 | 
			
		||||
        if (tournamentFile == null) {
 | 
			
		||||
            logger.warning("Given tournament file is empty");
 | 
			
		||||
            throw new IllegalArgumentException("Tournament File is null");
 | 
			
		||||
| 
						 | 
				
			
			@ -125,7 +125,7 @@ public class FileIO {
 | 
			
		|||
     * @throws IOException           File not readable
 | 
			
		||||
     * @throws FileNotFoundException File not found
 | 
			
		||||
     */
 | 
			
		||||
    public void saveTournament(Tournament tournament) throws IOException, FileNotFoundException {
 | 
			
		||||
    public synchronized void saveTournament(Tournament tournament) throws IOException, FileNotFoundException {
 | 
			
		||||
        if (tournament == null) {
 | 
			
		||||
            logger.warning("Given tournament file is empty");
 | 
			
		||||
            throw new IllegalArgumentException("Null tournament received");
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -3,9 +3,21 @@ package ch.zhaw.projekt2.turnierverwaltung;
 | 
			
		|||
import java.io.Serializable;
 | 
			
		||||
 | 
			
		||||
public class Game implements Serializable {
 | 
			
		||||
    private Participant participant1, Participant2;
 | 
			
		||||
    private Participant participant1, participant2;
 | 
			
		||||
    private int points1, points2;
 | 
			
		||||
    private Place place;
 | 
			
		||||
    private Game previousGame1, previousGame2;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public Game(Participant participant1, Participant participant2) {
 | 
			
		||||
        this.participant1 = participant1;
 | 
			
		||||
        this.participant2 = participant2;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Game(Game previousGame1, Game previousGame2){
 | 
			
		||||
        this.previousGame1 = previousGame1;
 | 
			
		||||
        this.previousGame2 = previousGame2;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Place getLocation() {
 | 
			
		||||
        return place;
 | 
			
		||||
| 
						 | 
				
			
			@ -39,11 +51,35 @@ public class Game implements Serializable {
 | 
			
		|||
        this.participant1 = participant1;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Participant getParticipant2() {
 | 
			
		||||
        return Participant2;
 | 
			
		||||
    public void setParticipant2(Participant participant2) {
 | 
			
		||||
        this.participant2 = participant2;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void setParticipant2(Participant participant2) {
 | 
			
		||||
        Participant2 = participant2;
 | 
			
		||||
    public Participant getParticipant2() {
 | 
			
		||||
        return participant2;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void setPlace(Place place) {
 | 
			
		||||
        this.place = place;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Place getPlace() {
 | 
			
		||||
        return place;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Participant getWinner(){
 | 
			
		||||
        if(points1 > points2){
 | 
			
		||||
            return participant1;
 | 
			
		||||
        } else if(points2 > points1){
 | 
			
		||||
            return participant2;
 | 
			
		||||
        } else {
 | 
			
		||||
            return null;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void refreshParticipants(){
 | 
			
		||||
        participant1 = previousGame1.getWinner();
 | 
			
		||||
        participant2 = previousGame2.getWinner();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,17 +5,14 @@ import javafx.collections.ObservableList;
 | 
			
		|||
 | 
			
		||||
import java.io.File;
 | 
			
		||||
import java.io.Serializable;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.Arrays;
 | 
			
		||||
import java.util.Iterator;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.*;
 | 
			
		||||
 | 
			
		||||
public class Tournament implements Serializable {
 | 
			
		||||
    private String name;
 | 
			
		||||
    private Type type;
 | 
			
		||||
    private List<Participant> participants;
 | 
			
		||||
    private List<Place> places;
 | 
			
		||||
 | 
			
		||||
    private List<List<Game>> gameList;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public Tournament(String name, Type type) throws InvalidNameException, InvalidTypeException {
 | 
			
		||||
| 
						 | 
				
			
			@ -29,6 +26,7 @@ public class Tournament implements Serializable {
 | 
			
		|||
        setType(type);
 | 
			
		||||
        participants = new ArrayList<>();
 | 
			
		||||
        places = new ArrayList<>();
 | 
			
		||||
        gameList = new ArrayList<>();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void saveParticipant(Participant newParticipant) throws ParticipantExistsException {
 | 
			
		||||
| 
						 | 
				
			
			@ -72,6 +70,52 @@ public class Tournament implements Serializable {
 | 
			
		|||
        return placesObservable;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    /*
 | 
			
		||||
    creates a complete new GameSchedule
 | 
			
		||||
     */
 | 
			
		||||
    public void createGameSchedule() throws NumberOfParticipantInvalidException {
 | 
			
		||||
        gameList = new ArrayList<>();
 | 
			
		||||
        if (type == Type.KO) {
 | 
			
		||||
            if (numberOfParticipantValid()) {
 | 
			
		||||
                calcGameSchedule();
 | 
			
		||||
                //TODO Logging
 | 
			
		||||
            } else {
 | 
			
		||||
                throw new NumberOfParticipantInvalidException("Can not Create Game Schedule for KO Modus");
 | 
			
		||||
                //TODO Logging
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        } else {
 | 
			
		||||
            //TODO for Type Group
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private boolean numberOfParticipantValid() {
 | 
			
		||||
        double res = Math.log(participants.size()) / Math.log(2);
 | 
			
		||||
        return (res * 10) % 10 == 0 && participants.size() >=4;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private void calcGameSchedule() {
 | 
			
		||||
        Collections.shuffle(participants);
 | 
			
		||||
 | 
			
		||||
        for (int i = 0; i < (Math.log(participants.size()) / Math.log(2)); i++) {
 | 
			
		||||
            List<Game> gameRound = new ArrayList<>();
 | 
			
		||||
            if (i == 0) {
 | 
			
		||||
                for (int j = 0; j < participants.size() - 1; j += 2) {
 | 
			
		||||
                    gameRound.add(new Game(participants.get(j), participants.get(j+1)));
 | 
			
		||||
                }
 | 
			
		||||
            } else {
 | 
			
		||||
                for (int j = 0; j < (gameList.get(i-1).size()/2); j++) {
 | 
			
		||||
                    gameRound.add(new Game(gameList.get(i-1).get(j*2),gameList.get(i-1).get(j*2+1)));
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
            gameList.add(gameRound);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public String getName() {
 | 
			
		||||
        return name;
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			@ -88,6 +132,10 @@ public class Tournament implements Serializable {
 | 
			
		|||
        this.type = type;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public List<List<Game>> getGameList() {
 | 
			
		||||
        return gameList;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public enum Type {
 | 
			
		||||
        KO("KO-System"), GROUPS("Gruppenspiele");
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -164,5 +212,14 @@ public class Tournament implements Serializable {
 | 
			
		|||
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public class NumberOfParticipantInvalidException extends Exception {
 | 
			
		||||
        public NumberOfParticipantInvalidException() {
 | 
			
		||||
            super();
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        public NumberOfParticipantInvalidException(String msg) {
 | 
			
		||||
            super(msg);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -3,11 +3,14 @@ package ch.zhaw.projekt2.turnierverwaltung;
 | 
			
		|||
import java.io.IOException;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.concurrent.ExecutorService;
 | 
			
		||||
import java.util.concurrent.Executors;
 | 
			
		||||
 | 
			
		||||
public class TournamentDecorator implements IsObservable{
 | 
			
		||||
    private Tournament tournament;
 | 
			
		||||
    private FileIO fileIO;
 | 
			
		||||
    private List<IsObserver> listener = new ArrayList<>();
 | 
			
		||||
    private ExecutorService executorService;
 | 
			
		||||
 | 
			
		||||
    public TournamentDecorator(FileIO fileIO){
 | 
			
		||||
        setFileIO(fileIO);
 | 
			
		||||
| 
						 | 
				
			
			@ -15,10 +18,12 @@ public class TournamentDecorator implements IsObservable{
 | 
			
		|||
            @Override
 | 
			
		||||
            public void update() {
 | 
			
		||||
                if(tournament != null){
 | 
			
		||||
 | 
			
		||||
                    saveTournament();
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
        executorService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void setFileIO(FileIO fileIO) {
 | 
			
		||||
| 
						 | 
				
			
			@ -43,14 +48,13 @@ public class TournamentDecorator implements IsObservable{
 | 
			
		|||
        listener.remove(observer);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void saveTournament(){
 | 
			
		||||
        try {
 | 
			
		||||
            fileIO.saveTournament(tournament);
 | 
			
		||||
        } catch (IOException e) {
 | 
			
		||||
            e.printStackTrace(); //TODO handle and logging
 | 
			
		||||
        }
 | 
			
		||||
        executorService.execute(new saveTask());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void createTournament(String name, Tournament.Type type){
 | 
			
		||||
        if(fileIO.tournamentExists(name)){
 | 
			
		||||
            System.out.println("Tournament with same name exists already.");
 | 
			
		||||
| 
						 | 
				
			
			@ -78,6 +82,11 @@ public class TournamentDecorator implements IsObservable{
 | 
			
		|||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void createNewGameSchedule() throws Tournament.NumberOfParticipantInvalidException {
 | 
			
		||||
        tournament.createGameSchedule();
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void savePlayer(String firstName, String name, String phoneNumber, String dateOfBirth){
 | 
			
		||||
        try {
 | 
			
		||||
            tournament.saveParticipant(new Player(firstName, name, phoneNumber, dateOfBirth));
 | 
			
		||||
| 
						 | 
				
			
			@ -120,9 +129,23 @@ public class TournamentDecorator implements IsObservable{
 | 
			
		|||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void informListener() {
 | 
			
		||||
        for(IsObserver observer : listener) {
 | 
			
		||||
            observer.update();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private class saveTask implements Runnable {
 | 
			
		||||
 | 
			
		||||
        @Override
 | 
			
		||||
        public void run() {
 | 
			
		||||
            try {
 | 
			
		||||
                fileIO.saveTournament(tournament);
 | 
			
		||||
            } catch (IOException e) {
 | 
			
		||||
                e.printStackTrace(); //TODO handle and logging
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -25,13 +25,13 @@ public class MainWindow extends Application {
 | 
			
		|||
 | 
			
		||||
        BorderPane pane = factory.loadMainWindow();
 | 
			
		||||
        factoryDecorator = new FactoryDecorator(fileIO, factory, pane);
 | 
			
		||||
        factory.loadTournamentList(pane, factoryDecorator);
 | 
			
		||||
        factoryDecorator.openTournamentList();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        Scene scene = new Scene(pane);
 | 
			
		||||
        primaryStage.setScene(scene);
 | 
			
		||||
        primaryStage.setMaximized(true);
 | 
			
		||||
        primaryStage.setResizable(false);
 | 
			
		||||
        primaryStage.setResizable(true);
 | 
			
		||||
        primaryStage.setFullScreen(false);
 | 
			
		||||
        primaryStage.show();
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,16 +1,80 @@
 | 
			
		|||
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
 | 
			
		||||
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.FXController;
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.*;
 | 
			
		||||
import javafx.beans.value.ObservableValue;
 | 
			
		||||
import javafx.event.Event;
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
import javafx.scene.control.ChoiceBox;
 | 
			
		||||
import javafx.scene.control.Label;
 | 
			
		||||
import javafx.scene.control.TextField;
 | 
			
		||||
import javafx.scene.layout.Pane;
 | 
			
		||||
import javafx.scene.layout.VBox;
 | 
			
		||||
 | 
			
		||||
public class GameController extends FXController{
 | 
			
		||||
 | 
			
		||||
    private GameDecorator gameDecorator;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private ChoiceBox<?> placesChoiceBox;
 | 
			
		||||
    private VBox mainVBox;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Label participantNameOne;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Label participantNameTwo;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private ChoiceBox<Place> placesChoiceBox;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField pointsTeamOne;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private TextField pointsTeamTwo;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void saveGameResult(Event event) {
 | 
			
		||||
        gameDecorator.saveGameResult(pointsTeamOne.getText(), pointsTeamTwo.getText());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    private void saveGamePlace(Place newPlace) {
 | 
			
		||||
        gameDecorator.saveGamePlace(newPlace);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public double getGameBoxHeigth(){
 | 
			
		||||
        return mainVBox.getPrefHeight();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public void loadContent() {
 | 
			
		||||
        participantNameOne.setText(gameDecorator.getParticipantOne());
 | 
			
		||||
        participantNameTwo.setText(gameDecorator.getParticipantTwo());
 | 
			
		||||
        pointsTeamOne.setText(String.valueOf(gameDecorator.getPoints1()));
 | 
			
		||||
        pointsTeamTwo.setText(String.valueOf(gameDecorator.getPoints2()));
 | 
			
		||||
        placesChoiceBox.setItems(getTournamentDecorator().getTournament().getPlaces());
 | 
			
		||||
        placesChoiceBox.setValue(gameDecorator.getPlace());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void refreshParticipants(){
 | 
			
		||||
        gameDecorator.refreshParticipants();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void addListener(GameDecorator gameDecorator){
 | 
			
		||||
        gameDecorator.addListener(new IsObserver() {
 | 
			
		||||
            @Override
 | 
			
		||||
            public void update() {
 | 
			
		||||
                refreshParticipants();
 | 
			
		||||
                loadContent();
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
    public void setup(TournamentDecorator tournamentDecorator, FileIO fileIO, FactoryDecorator factoryDecorator, Pane pane, GameDecorator gameDecorator) {
 | 
			
		||||
        setTournamentDecorator(tournamentDecorator);
 | 
			
		||||
        this.gameDecorator = gameDecorator;
 | 
			
		||||
        placesChoiceBox.getSelectionModel().selectedItemProperty().addListener((ObservableValue<? extends Place> observable, Place oldValue, Place newValue) -> saveGamePlace(newValue));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,82 @@
 | 
			
		|||
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
 | 
			
		||||
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.*;
 | 
			
		||||
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
public class GameDecorator implements IsObservable{
 | 
			
		||||
    private Game game;
 | 
			
		||||
    private List<IsObserver> listener = new ArrayList<>();
 | 
			
		||||
 | 
			
		||||
    public GameDecorator (Game game) {
 | 
			
		||||
        this.game = game;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public void addListener(IsObserver observer) {
 | 
			
		||||
        listener.add(observer);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public void removeListener(IsObserver observer) {
 | 
			
		||||
        listener.remove(observer);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void saveGameResult(String points1, String points2){
 | 
			
		||||
        if(points1.length() > 0){
 | 
			
		||||
            game.setPoints1(Integer.parseInt(points1));
 | 
			
		||||
        } else {
 | 
			
		||||
            game.setPoints1(0);
 | 
			
		||||
        }
 | 
			
		||||
        if(points2.length() > 0) {
 | 
			
		||||
            game.setPoints2(Integer.parseInt(points2));
 | 
			
		||||
        } else {
 | 
			
		||||
            game.setPoints2(0);
 | 
			
		||||
        }
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void saveGamePlace(Place place){
 | 
			
		||||
        game.setPlace(place);
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public String getPoints1() {
 | 
			
		||||
       return String.valueOf(game.getPoints1());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public String getPoints2() {
 | 
			
		||||
        return String.valueOf(game.getPoints2());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public String getParticipantOne() {
 | 
			
		||||
        if (game.getParticipant1() != null) {
 | 
			
		||||
            return game.getParticipant1().toString();
 | 
			
		||||
        }
 | 
			
		||||
        return "1";
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public String getParticipantTwo() {
 | 
			
		||||
        if (game.getParticipant2() != null) {
 | 
			
		||||
            return game.getParticipant2().toString();
 | 
			
		||||
        }
 | 
			
		||||
        return "2";
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void refreshParticipants(){
 | 
			
		||||
        game.refreshParticipants();
 | 
			
		||||
        informListener();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public Place getPlace() {
 | 
			
		||||
        return game.getPlace();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public void informListener() {
 | 
			
		||||
        for(IsObserver observer : listener) {
 | 
			
		||||
            observer.update();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			@ -1,24 +1,69 @@
 | 
			
		|||
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
 | 
			
		||||
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.FXController;
 | 
			
		||||
import ch.zhaw.projekt2.turnierverwaltung.Tournament;
 | 
			
		||||
import javafx.event.ActionEvent;
 | 
			
		||||
import javafx.fxml.FXML;
 | 
			
		||||
import javafx.scene.control.Button;
 | 
			
		||||
import javafx.scene.control.CheckBox;
 | 
			
		||||
import javafx.scene.layout.HBox;
 | 
			
		||||
 | 
			
		||||
public class GameScheduleController extends FXController {
 | 
			
		||||
    
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Button createScheduleBtn;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Button editLocBtn;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Button editParticipantBtn;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private Button closeTournamentBtn;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private HBox hBoxCenter;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    private CheckBox treeView;
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void createNewSchedule(ActionEvent event) {
 | 
			
		||||
        try {
 | 
			
		||||
            getTournamentDecorator().createNewGameSchedule();
 | 
			
		||||
        } catch (Tournament.NumberOfParticipantInvalidException e) {
 | 
			
		||||
            //TODO Method in FactoryDecorater to show msg
 | 
			
		||||
            e.printStackTrace();
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void openPlacesFormular(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        getFactoryDecorator().openPlacesFormular();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void openParticipantFormular(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        getFactoryDecorator().openParticipantFormular();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void closeTournament(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        getFactoryDecorator().openTournamentList();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void changeView(ActionEvent event) {
 | 
			
		||||
        loadContent();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public void loadContent() {
 | 
			
		||||
 | 
			
		||||
        getFactoryDecorator().loadGameList(hBoxCenter, getTournamentDecorator(), treeView.isSelected());
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -97,6 +97,7 @@ public class ParticipantFormularController extends FXController {
 | 
			
		|||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void close(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        getFactoryDecorator().openScheduleView();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -73,6 +73,7 @@ public class PlacesFormularController extends FXController {
 | 
			
		|||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void close(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        getFactoryDecorator().openScheduleView();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -4,8 +4,6 @@ import javafx.scene.control.Alert;
 | 
			
		|||
import javafx.scene.control.ButtonBar;
 | 
			
		||||
import javafx.scene.control.ButtonType;
 | 
			
		||||
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
 | 
			
		||||
public class AlertDelete extends Alert {
 | 
			
		||||
    ButtonType yesButton = new ButtonType("Ja", ButtonBar.ButtonData.YES);
 | 
			
		||||
    ButtonType noButton = new ButtonType("Nein", ButtonBar.ButtonData.NO);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -61,6 +61,7 @@ public class TournamentListController extends FXController {
 | 
			
		|||
 | 
			
		||||
    @FXML
 | 
			
		||||
    void openTournament(ActionEvent event) {
 | 
			
		||||
        removeListener();
 | 
			
		||||
        FileIO.TournamentFile tournamentFile = tournamentListView.getSelectionModel().getSelectedItems().get(0);
 | 
			
		||||
        getFactoryDecorator().openTournament(tournamentFile);
 | 
			
		||||
    }
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,29 +7,37 @@
 | 
			
		|||
<?import javafx.scene.layout.HBox?>
 | 
			
		||||
<?import javafx.scene.layout.VBox?>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<VBox alignment="CENTER" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="150.0" prefWidth="200.0" xmlns="http://javafx.com/javafx/17" xmlns:fx="http://javafx.com/fxml/1" fx:controller="GameContoller">
 | 
			
		||||
<VBox alignment="CENTER" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="90.0" prefWidth="450.0" style="-fx-border-color: black; -fx-border-insets: 2; -fx-border-width: 3;" xmlns="http://javafx.com/javafx/18" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController">
 | 
			
		||||
   <children>
 | 
			
		||||
      <VBox fx:id="mainVBox" alignment="CENTER" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="90.0">
 | 
			
		||||
         <children>
 | 
			
		||||
      <Label fx:id="teamNameOne" text="Team One" />
 | 
			
		||||
            <HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
 | 
			
		||||
               <children>
 | 
			
		||||
            <Label text="Points">
 | 
			
		||||
                  <Label fx:id="participantNameOne" style="-fx-font-weight: bold;" text="Participant One">
 | 
			
		||||
                     <HBox.margin>
 | 
			
		||||
                        <Insets right="20.0" />
 | 
			
		||||
                     </HBox.margin>
 | 
			
		||||
                  </Label>
 | 
			
		||||
            <TextField fx:id="pointsTeamOne" prefHeight="25.0" prefWidth="50.0" />
 | 
			
		||||
         </children>
 | 
			
		||||
      </HBox>
 | 
			
		||||
      <Label fx:id="teamNameTwo" text="Team Two" />
 | 
			
		||||
      <HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
 | 
			
		||||
         <children>
 | 
			
		||||
            <Label text="Points">
 | 
			
		||||
                  <TextField fx:id="pointsTeamOne" alignment="CENTER" onKeyTyped="#saveGameResult" prefHeight="25.0" prefWidth="50.0">
 | 
			
		||||
                     <HBox.margin>
 | 
			
		||||
                        <Insets right="20.0" />
 | 
			
		||||
                     </HBox.margin>
 | 
			
		||||
                  </TextField>
 | 
			
		||||
                  <Label text=":">
 | 
			
		||||
                     <HBox.margin>
 | 
			
		||||
                        <Insets right="20.0" />
 | 
			
		||||
                     </HBox.margin>
 | 
			
		||||
                  </Label>
 | 
			
		||||
                  <TextField fx:id="pointsTeamTwo" alignment="CENTER" onKeyTyped="#saveGameResult" prefHeight="25.0" prefWidth="50.0">
 | 
			
		||||
                     <HBox.margin>
 | 
			
		||||
                        <Insets right="20.0" />
 | 
			
		||||
                     </HBox.margin>
 | 
			
		||||
                  </TextField>
 | 
			
		||||
                  <Label fx:id="participantNameTwo" style="-fx-font-weight: bold;" text="Participant Two">
 | 
			
		||||
                     <HBox.margin>
 | 
			
		||||
                        <Insets right="20.0" />
 | 
			
		||||
                     </HBox.margin>
 | 
			
		||||
                  </Label>
 | 
			
		||||
            <TextField fx:id="pointsTeamTwo" prefHeight="25.0" prefWidth="50.0" />
 | 
			
		||||
               </children>
 | 
			
		||||
            </HBox>
 | 
			
		||||
            <HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
 | 
			
		||||
| 
						 | 
				
			
			@ -41,6 +49,11 @@
 | 
			
		|||
                  </Label>
 | 
			
		||||
                  <ChoiceBox fx:id="placesChoiceBox" prefWidth="150.0" />
 | 
			
		||||
               </children>
 | 
			
		||||
               <VBox.margin>
 | 
			
		||||
                  <Insets top="10.0" />
 | 
			
		||||
               </VBox.margin>
 | 
			
		||||
            </HBox>
 | 
			
		||||
         </children>
 | 
			
		||||
      </VBox>
 | 
			
		||||
   </children>
 | 
			
		||||
</VBox>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,26 +1,41 @@
 | 
			
		|||
<?xml version="1.0" encoding="UTF-8"?>
 | 
			
		||||
 | 
			
		||||
<?import javafx.geometry.Insets?>
 | 
			
		||||
<?import javafx.scene.control.Button?>
 | 
			
		||||
<?import javafx.scene.layout.BorderPane?>
 | 
			
		||||
<?import javafx.scene.layout.HBox?>
 | 
			
		||||
<?import javafx.geometry.*?>
 | 
			
		||||
<?import javafx.scene.control.*?>
 | 
			
		||||
<?import javafx.scene.layout.*?>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
<BorderPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/17" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameScheduleController">
 | 
			
		||||
<BorderPane maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/11.0.2" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameScheduleController">
 | 
			
		||||
   <top>
 | 
			
		||||
      <HBox alignment="CENTER_RIGHT" prefHeight="100.0" prefWidth="200.0" BorderPane.alignment="CENTER">
 | 
			
		||||
      <HBox alignment="TOP_RIGHT" prefHeight="100.0" prefWidth="200.0" BorderPane.alignment="CENTER">
 | 
			
		||||
         <children>
 | 
			
		||||
            <Button mnemonicParsing="false" onAction="#openParticipantFormular" text="Teilnehmer bearbeiten">
 | 
			
		||||
            <CheckBox fx:id="treeView" mnemonicParsing="false" onAction="#changeView" selected="true" text="Baumansicht" />
 | 
			
		||||
            <Button fx:id="createScheduleBtn" mnemonicParsing="false" onAction="#createNewSchedule" text="Create New Game Schedule">
 | 
			
		||||
               <HBox.margin>
 | 
			
		||||
                  <Insets right="20.0" />
 | 
			
		||||
               </HBox.margin>
 | 
			
		||||
            </Button>
 | 
			
		||||
            <Button mnemonicParsing="false" onAction="#openPlacesFormular" text="Orte bearbeiten">
 | 
			
		||||
            <Button fx:id="editParticipantBtn" mnemonicParsing="false" onAction="#openParticipantFormular" text="Teilnehmer bearbeiten">
 | 
			
		||||
               <HBox.margin>
 | 
			
		||||
                  <Insets right="40.0" />
 | 
			
		||||
                  <Insets right="20.0" />
 | 
			
		||||
               </HBox.margin>
 | 
			
		||||
            </Button>
 | 
			
		||||
            <Button fx:id="editLocBtn" mnemonicParsing="false" onAction="#openPlacesFormular" text="Orte bearbeiten">
 | 
			
		||||
               <HBox.margin>
 | 
			
		||||
                  <Insets right="20.0" />
 | 
			
		||||
               </HBox.margin>
 | 
			
		||||
            </Button>
 | 
			
		||||
            <Button fx:id="closeTournamentBtn" layoutX="470.0" layoutY="10.0" mnemonicParsing="false" onAction="#closeTournament" text="Close Tournament">
 | 
			
		||||
               <HBox.margin>
 | 
			
		||||
                  <Insets right="20.0" />
 | 
			
		||||
               </HBox.margin></Button>
 | 
			
		||||
         </children>
 | 
			
		||||
      </HBox>
 | 
			
		||||
   </top>
 | 
			
		||||
   <center>
 | 
			
		||||
      <ScrollPane maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="200.0" prefWidth="200.0" BorderPane.alignment="CENTER">
 | 
			
		||||
         <content>
 | 
			
		||||
            <HBox fx:id="hBoxCenter" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="324.0" prefWidth="600.0" />
 | 
			
		||||
         </content>
 | 
			
		||||
      </ScrollPane>
 | 
			
		||||
   </center>
 | 
			
		||||
</BorderPane>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue