diff --git a/.gitignore b/.gitignore index f0ded7c..2532936 100644 --- a/.gitignore +++ b/.gitignore @@ -72,3 +72,5 @@ crashlytics-build.properties .gradle/ build/ + +/client/config.json \ No newline at end of file diff --git a/client/app/build.gradle.kts b/client/app/build.gradle.kts index 6a5a8cf..3a8a5d6 100644 --- a/client/app/build.gradle.kts +++ b/client/app/build.gradle.kts @@ -5,24 +5,33 @@ plugins { } javafx { - version = "11" + version = "11.0.2" modules( "javafx.controls", "javafx.fxml" ) } +tasks.withType { + options.encoding = "UTF-8" +} + application { - mainClassName = "client.MainApplication" + mainClassName = "main.MainApplication" +} + +repositories { + mavenCentral() } dependencies { + implementation("com.jfoenix:jfoenix:9.0.10") implementation(project(":data")) } val jar by tasks.getting(Jar::class) { manifest { - attributes["Main-Class"] = "client.Launcher" + attributes["Main-Class"] = "main.Launcher" } from({ configurations.runtimeClasspath.get().map { if (it.isDirectory) it else zipTree(it) } diff --git a/client/app/src/main/java/events/CreateEventController.java b/client/app/src/main/java/events/CreateEventController.java new file mode 100644 index 0000000..0388faf --- /dev/null +++ b/client/app/src/main/java/events/CreateEventController.java @@ -0,0 +1,100 @@ +package events; + +import com.jfoenix.controls.*; +import helper.HttpRequestException; +import javafx.event.ActionEvent; +import javafx.fxml.FXML; +import javafx.scene.Node; +import javafx.scene.control.*; +import javafx.scene.layout.GridPane; +import javafx.stage.Stage; +import javafx.util.StringConverter; +import javafx.util.converter.LocalTimeStringConverter; +import container.DataController; +import container.Event; + +import java.time.LocalTime; +import java.time.format.FormatStyle; +import java.util.Locale; + +public class CreateEventController { + + @FXML + private GridPane mainGrid; + @FXML + protected JFXDatePicker datePickerDate; + @FXML + protected JFXTextField textName; + @FXML + protected JFXComboBox comboBoxPriority; + @FXML + private JFXToggleButton toggleBtnIsFullDay; + @FXML + private JFXToggleButton toggleBtnIsPrivate; + @FXML + private Label labelError; + @FXML + private JFXTimePicker timeStart; + @FXML + private JFXTimePicker timeEnd; + + + public CreateEventController() { + } + + //Marco Kühn// + @FXML + public void initialize() { + StringConverter defaultConverter = new LocalTimeStringConverter(FormatStyle.SHORT, Locale.GERMANY); + timeStart.set24HourView(true); + timeStart.setConverter(defaultConverter); + + timeEnd.set24HourView(true); + timeEnd.setConverter(defaultConverter); + } + + //Marc Beyer// + @FXML + protected void createBtnClick(ActionEvent actionEvent) { + try { + if (datePickerDate.getValue() == null) { + throw new IllegalArgumentException("Bitte w\u00e4hle ein Datum aus"); + } + + System.out.println(datePickerDate.getValue()); + + Event event = new Event( + textName.getText(), + comboBoxPriority.getSelectionModel().getSelectedIndex(), + toggleBtnIsFullDay.isSelected(), + toggleBtnIsPrivate.isSelected(), + timeStart.getValue(), + timeEnd.getValue(), + datePickerDate.getValue().atStartOfDay(), + (int) DataController.USER_ID + ); + + System.out.println(event.getAsUrlParam()); + + sendHttpRequest(event); + + Stage stage = (Stage) ((Node) actionEvent.getSource()).getScene().getWindow(); + stage.close(); + } catch (Exception e) { + labelError.setText(e.getMessage()); + } + } + + //Marc Beyer// + protected void sendHttpRequest(Event event) throws HttpRequestException { + DataController dataController = new DataController(); + dataController.createEvent(event); + } + + //Marc Beyer// + @FXML + protected void abortBtnClick(ActionEvent event) { + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } +} diff --git a/client/app/src/main/java/events/EditEventController.java b/client/app/src/main/java/events/EditEventController.java new file mode 100644 index 0000000..e813221 --- /dev/null +++ b/client/app/src/main/java/events/EditEventController.java @@ -0,0 +1,30 @@ +package events; + +import helper.HttpRequestException; +import container.DataController; +import container.Event; + +public class EditEventController extends CreateEventController{ + + private Event currentEvent; + + public Event getCurrentEvent() { + return currentEvent; + } + + public void setCurrentEvent(Event currentEvent) { + this.currentEvent = currentEvent; + + textName.setText(currentEvent.getName()); + datePickerDate.setValue(currentEvent.getDate().toLocalDate()); + comboBoxPriority.getSelectionModel().select(currentEvent.getPriority()); + + //timeEnd.setValue(currentEvent.getEnd()); + } + + @Override + protected void sendHttpRequest(Event event) throws HttpRequestException { + DataController dataController = new DataController(); + dataController.editEvent(currentEvent, event); + } +} diff --git a/client/app/src/main/java/main/CreateEventController.java b/client/app/src/main/java/main/CreateEventController.java deleted file mode 100644 index 14d52d3..0000000 --- a/client/app/src/main/java/main/CreateEventController.java +++ /dev/null @@ -1,68 +0,0 @@ -package main; - -import javafx.event.ActionEvent; -import javafx.fxml.FXML; -import javafx.scene.Node; -import javafx.scene.control.CheckBox; -import javafx.scene.control.ComboBox; -import javafx.scene.control.DatePicker; -import javafx.scene.control.TextField; -import javafx.stage.Stage; -import res.DataController; -import res.Event; - -public class CreateEventController { - - @FXML - public DatePicker datePickerDate; - @FXML - public TextField textName; - @FXML - public TextField textStart; - @FXML - public TextField textEnd; - @FXML - public ComboBox ComboBoxTyp; - @FXML - public ComboBox ComboBoxPriotity; - @FXML - public CheckBox checkBoxIsFullDay; - @FXML - public CheckBox checkBoxIsPrivate; - - - public CreateEventController(){} - - @FXML - public void initialize(){} - - - @FXML - protected void createBtnClick(ActionEvent actionEvent){ - - Event event = new Event( - textName.getText(), - ComboBoxPriotity.getSelectionModel().getSelectedIndex(), - checkBoxIsFullDay.isSelected(), - checkBoxIsPrivate.isSelected(), - textStart.getText(), - textEnd.getText(), - datePickerDate.getValue().atStartOfDay(), - 1 - ); - - System.out.println(event.getAsUrlParam()); - - DataController dataController = new DataController(); - dataController.createEvent(event); - - Stage stage = (Stage) ((Node) actionEvent.getSource()).getScene().getWindow(); - stage.close(); - } - - @FXML - protected void abortBtnClick(ActionEvent event){ - Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); - stage.close(); - } -} diff --git a/client/app/src/main/java/main/Launcher.java b/client/app/src/main/java/main/Launcher.java index fd5d4c8..38c385d 100644 --- a/client/app/src/main/java/main/Launcher.java +++ b/client/app/src/main/java/main/Launcher.java @@ -1,7 +1,7 @@ package main; public class Launcher { - + public static void main(String[] args) { MainApplication.main(args); } diff --git a/client/app/src/main/java/main/MainApplication.java b/client/app/src/main/java/main/MainApplication.java index 6514b0d..4bafb4a 100644 --- a/client/app/src/main/java/main/MainApplication.java +++ b/client/app/src/main/java/main/MainApplication.java @@ -1,27 +1,116 @@ +//Marc Beyer// package main; +import config.Config; +import config.ConfigLoader; +import container.DataController; +import container.HttpRequest; import javafx.application.Application; import javafx.fxml.FXMLLoader; import javafx.scene.Scene; +import javafx.stage.Modality; import javafx.stage.Stage; import java.io.IOException; import java.util.Objects; +import java.util.function.Consumer; + public class MainApplication extends Application { @Override public void start(Stage stage) throws IOException { + Config config = ConfigLoader.load(); + if(config == null){ + config = new Config(false, -1, ""); + } + + DataController.SERVER_URL = config.toServerUrl(); + + System.out.println("Ignore 'Illegal reflective access operation'-Warning. See https://github.com/sshahine/JFoenix/issues/1170"); + + if( + !config.isSaveLogin() + || !new DataController().loginWithToken(config.getId(), config.getToken()) + ){ + // Load login-scene + loadLoginScene(); + } + + if (DataController.USER_ID >= 0) { + if(config.isSaveLogin()){ + config.setId(DataController.USER_ID); + config.setToken(HttpRequest.TOKEN); + ConfigLoader.save(config); + } + + // Load main-scene + loadMainScene(stage); + + System.out.println("Logged in..."); + } + } + + private void loadMainScene(Stage stage) throws IOException { FXMLLoader fxmlLoader = new FXMLLoader(MainApplication.class.getResource("main-view.fxml")); Scene scene = new Scene(fxmlLoader.load(), 1200, 700); - scene.getStylesheets().add(Objects.requireNonNull(MainApplication.class.getResource("main-view.css")).toExternalForm()); - stage.setTitle("Hello!"); + scene.getStylesheets().add(Objects.requireNonNull( + MainApplication.class.getResource("main-view.css")).toExternalForm() + ); + stage.setTitle("SharePlaner"); stage.setScene(scene); stage.show(); + } + private void loadLoginScene() { + loadScene( + "Anmelden", + "../users/login.fxml", + "../users/login.css", + 650, + 500 + ); } public static void main(String[] args) { launch(); } + + public static void loadScene( + String title, + String fxml, + String css, + int width, + int height + ) { + loadScene(title, fxml, css, width, height, null); + } + + public static void loadScene( + String title, + String fxml, + String css, + int width, + int height, + Consumer method + ) { + FXMLLoader fxmlLoader = new FXMLLoader( + MainApplication.class.getResource(fxml)); + try { + Scene scene = new Scene(fxmlLoader.load(), width, height); + scene.getStylesheets().add(Objects.requireNonNull( + MainApplication.class.getResource(css)).toExternalForm()); + Stage stage = new Stage(); + stage.setTitle(title); + stage.setScene(scene); + stage.initModality(Modality.APPLICATION_MODAL); + stage.setResizable(false); + + if(method != null)method.accept(fxmlLoader); + + stage.showAndWait(); + } catch (IOException e) { + e.printStackTrace(); + } + } } \ No newline at end of file diff --git a/client/app/src/main/java/main/MainController.java b/client/app/src/main/java/main/MainController.java index 36f3aed..8473f08 100644 --- a/client/app/src/main/java/main/MainController.java +++ b/client/app/src/main/java/main/MainController.java @@ -1,36 +1,44 @@ +/* Marco Kühn, Marc Beyer */ package main; +import config.Config; +import config.ConfigLoader; +import container.DataController; +import container.Event; +import container.HttpRequest; +import events.EditEventController; +import helper.HttpRequestException; import javafx.event.ActionEvent; -import javafx.event.EventHandler; import javafx.fxml.FXML; -import javafx.fxml.FXMLLoader; -import javafx.geometry.Pos; -import javafx.scene.Scene; +import javafx.scene.Node; +import javafx.scene.control.Alert; import javafx.scene.control.Button; import javafx.scene.control.Label; -import javafx.scene.control.ScrollPane; import javafx.scene.layout.GridPane; import javafx.scene.layout.HBox; import javafx.scene.layout.VBox; -import javafx.stage.Modality; import javafx.stage.Stage; -import res.DataController; -import res.Event; +import ui.DayPane; +import ui.EventPane; +import ui.SvgBtnCreator; -import java.io.IOException; import java.time.Duration; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.ArrayList; -import java.util.Objects; public class MainController { @FXML - private GridPane calendarGrid; - + private VBox leftNav; @FXML - private Label LabelMonth; + private GridPane mainGridPane; + @FXML + private HBox buttonBox; + @FXML + private GridPane calendarGrid; + @FXML + private javafx.scene.control.Label LabelMonth; private final String[] dayNames = {"Montag", "Dienstag", "Mittwoch", "Donnerstag", "Freitag", "Samstag", "Sonntag"}; private final Label[] dayLabel = new Label[7]; @@ -48,8 +56,9 @@ public class MainController { public void initialize() { createWeek(); setDates(); - updateEvents(); + createBtns(); + leftNav.setSpacing(40); } private void updateEvents() { @@ -58,124 +67,114 @@ public class MainController { } DataController dataController = new DataController(); - ArrayList eventList = dataController.getAllVisibleEvents(); + try { + ArrayList eventList = dataController.getAllVisibleEvents(weekStartDateTime, weekStartDateTime.plusDays(7)); - for (Event event : eventList) { - addEvent(event); + for (Event event : eventList) { + addEvent(event); + } + } catch (HttpRequestException e) { + e.printStackTrace(); } } @FXML - protected void onAddBtnClick() { - try { - FXMLLoader fxmlLoader = new FXMLLoader(MainApplication.class.getResource("create-event.fxml")); - Scene scene = new Scene(fxmlLoader.load(), 650, 500); - scene.getStylesheets().add(Objects.requireNonNull(MainApplication.class.getResource("create-event.css")).toExternalForm()); - Stage stage = new Stage(); - stage.setTitle("Termin erstellen"); - stage.setScene(scene); - stage.initModality(Modality.APPLICATION_MODAL); - stage.setResizable(false); - //stage.initStyle(StageStyle.UNDECORATED); - stage.showAndWait(); - } catch (IOException e) { - e.printStackTrace(); - } + protected void onBackClick() { + weekOffset--; + setDates(); updateEvents(); } + @FXML + protected void onTodayClick() { + weekOffset = 0; + setDates(); + updateEvents(); + } + + @FXML + protected void onNextClick() { + weekOffset++; + setDates(); + updateEvents(); + } + + @FXML + protected void onAddBtnClick() { + MainApplication.loadScene( + "Termin erstellen", + "create-event.fxml", + "create-event.css", + 650, + 650 + ); + updateEvents(); + } + + protected void onSettingBtnClick(){ + MainApplication.loadScene( + "Einstellungen", + "option-view.fxml", + "option-view.css", + 650, + 600 + ); + } + + protected void onLogoutBtnClick(ActionEvent event){ + ConfigLoader.save(new Config()); + DataController.USER_ID = -1; + HttpRequest.TOKEN = ""; + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } + private void createWeek() { for (int i = 0; i < 7; i++) { - Label label = new Label(); - label.setText(dayNames[i]); - label.setMaxHeight(Double.MAX_VALUE); - label.setMaxWidth(Double.MAX_VALUE); - label.getStyleClass().add("labelDays"); - dayLabel[i] = label; - calendarGrid.add(label, i, 0); - - ScrollPane scrollPane = new ScrollPane(); - - VBox vBox = new VBox(); - vBox.getStyleClass().add("vBoxDays"); - vBox.setSpacing(10); - dayVBoxes[i] = vBox; - scrollPane.setContent(vBox); - - scrollPane.setFitToWidth(true); - scrollPane.setFitToHeight(true); - scrollPane.setHbarPolicy(ScrollPane.ScrollBarPolicy.AS_NEEDED); - scrollPane.getStyleClass().add("scrollDays"); - - calendarGrid.add(scrollPane, i, 1); + DayPane dayPane = new DayPane(); + this.dayLabel[i] = dayPane.getDayLabel(); + calendarGrid.add(dayPane.getDayLabel(), i, 0); + dayVBoxes[i] = dayPane.getDayVBox(); + calendarGrid.add(dayPane, i, 1); } } private void addEvent(Event event) { - VBox vBox = new VBox(); - vBox.getStyleClass().add("event"); - vBox.setSpacing(5); - - HBox btnHBox = new HBox(); - btnHBox.setAlignment(Pos.BOTTOM_RIGHT); - Button deleteBtn = new Button(); - deleteBtn.setText(" X "); - deleteBtn.setOnAction(e -> { - DataController dataController = new DataController(); - dataController.deleteEvent(event.getId()); + EventPane eventPane = new EventPane(event); + eventPane.getEditBtn().setOnAction(event1 -> { + MainApplication.loadScene( + "Termin bearbeiten", + "edit-event.fxml", + "create-event.css", + 650, + 650, + fxmlLoader -> { + EditEventController editEventController = fxmlLoader.getController(); + editEventController.setCurrentEvent(event); + } + ); updateEvents(); }); - Button editBtn = new Button(); - editBtn.setText("edit"); - btnHBox.getChildren().add(editBtn); - btnHBox.getChildren().add(deleteBtn); - vBox.getChildren().add(btnHBox); - - Label nameLabel = new Label(event.getName()); - vBox.getChildren().add(nameLabel); - - if (event.getStart() != null || event.getEnd() != null) { - String timeStr = (event.getStart() != null ? formatTime(event.getStart()) : "") - + (event.getEnd() != null ? " - " + formatTime(event.getEnd()) : ""); - Label timeLabel = new Label(timeStr); - vBox.getChildren().add(timeLabel); - } - - Label typeLabel = new Label("Wer: " + event.getOwnerName()); - vBox.getChildren().add(typeLabel); - - /* - Ä, ä \u00c4, \u00e4 - Ö, ö \u00d6, \u00f6 - Ü, ü \u00dc, \u00fc - ß \u00df - */ - Label prioLabel = new Label("Priorit\u00e4t: " + event.getPriority()); - vBox.getChildren().add(prioLabel); - - if (event.isFullDay()) { - Label fullDayLabel = new Label("Dieser Termin bockiert den ganzen Tag!"); - vBox.getChildren().add(fullDayLabel); - } + eventPane.getDeleteBtn().setOnAction(e -> { + DataController dataController = new DataController(); + try { + dataController.deleteEvent(event.getOwnerId(), event.getId(), event.getDate()); + } catch (HttpRequestException ex) { + new Alert(Alert.AlertType.ERROR, ex.getMessage()).showAndWait(); + } + updateEvents(); + }); LocalDateTime eventDate = event.getDate(); - - int day = (int) Duration.between(weekStartDateTime.toLocalDate().atStartOfDay(), eventDate.toLocalDate().atStartOfDay()).toDays(); + int day = (int) Duration.between( + weekStartDateTime.toLocalDate().atStartOfDay(), eventDate.toLocalDate().atStartOfDay()).toDays(); if (day >= 0 && day < 7) { - dayVBoxes[day].getChildren().add(vBox); + dayVBoxes[day].getChildren().add(eventPane); } } - private String formatTime(String time) { - String[] timeArr = time.split(":"); - if (timeArr.length > 2) { - return timeArr[0] + ":" + timeArr[1]; - } - return time; - } - private void setDates() { DateTimeFormatter dateFormatter = DateTimeFormatter.ofPattern("LLLL yyyy"); DateTimeFormatter dayFormatter = DateTimeFormatter.ofPattern("E dd.MM"); @@ -193,4 +192,39 @@ public class MainController { LabelMonth.setText(dateFormatter.format(weekStartDateTime)); } + + private void createBtns(){ + Button addBtn = SvgBtnCreator.createAddBtn(); + addBtn.setOnAction(e -> onAddBtnClick()); + addBtn.getStyleClass().add("main-btn"); + leftNav.getChildren().add(addBtn); + + Button settingsBtn = SvgBtnCreator.createSettingBtn(); + settingsBtn.setOnAction(e -> onSettingBtnClick()); + settingsBtn.getStyleClass().add("main-btn"); + leftNav.getChildren().add(settingsBtn); + + Button logoutBtn = SvgBtnCreator.createLogoutBtn(); + logoutBtn.setOnAction(this::onLogoutBtnClick); + logoutBtn.getStyleClass().add("main-btn"); + leftNav.getChildren().add(logoutBtn); + + Button backBtn = SvgBtnCreator.createBackBtn(); + backBtn.setOnAction(e -> onBackClick()); + backBtn.getStyleClass().add("navBtn"); + GridPane.setColumnIndex(backBtn, 1); + buttonBox.getChildren().add(backBtn); + + Button todayBtn = SvgBtnCreator.createTodayBtn(); + todayBtn.setOnAction(e -> onTodayClick()); + todayBtn.getStyleClass().add("navBtn"); + GridPane.setColumnIndex(todayBtn, 2); + buttonBox.getChildren().add(todayBtn); + + Button nextBtn = SvgBtnCreator.createNextBtn(); + nextBtn.setOnAction(e -> onNextClick()); + nextBtn.getStyleClass().add("navBtn"); + GridPane.setColumnIndex(nextBtn, 3); + buttonBox.getChildren().add(nextBtn); + } } \ No newline at end of file diff --git a/client/app/src/main/java/main/OptionController.java b/client/app/src/main/java/main/OptionController.java new file mode 100644 index 0000000..e2915aa --- /dev/null +++ b/client/app/src/main/java/main/OptionController.java @@ -0,0 +1,139 @@ +/* Marco Kühn */ +package main; + +import com.jfoenix.controls.*; +import config.Config; +import config.ConfigLoader; +import container.HttpRequest; +import helper.HttpRequestException; +import javafx.collections.FXCollections; +import javafx.collections.ObservableList; +import javafx.event.ActionEvent; +import javafx.fxml.FXML; +import javafx.fxml.FXMLLoader; +import javafx.scene.Node; +import javafx.scene.control.Alert; +import javafx.scene.control.ButtonType; +import javafx.scene.control.Label; +import javafx.scene.layout.GridPane; +import javafx.stage.Stage; +import container.DataController; +import container.User; +import users.EditUserController; + +import java.util.ArrayList; +import java.util.List; +import java.util.Optional; + +public class OptionController { + + @FXML + private JFXButton updateUserBtn; + @FXML + private JFXButton deleteUserBtn; + @FXML + private JFXButton createUserBtn; + @FXML + private JFXToggleButton saveLoginTBtn; + @FXML + private Label labelError; + @FXML + private GridPane mainGrid; + + private JFXComboBox comboBox; + private DataController dataController; + private List users; + private Config config; + + @FXML + public void initialize(){ + dataController = new DataController(); + try{ + users = dataController.getAllUser(); + } catch (HttpRequestException e){ + users = new ArrayList<>(); + } + + ObservableList observableUserList = FXCollections.observableArrayList(); + for (User user: users) { + observableUserList.add(user.getLogin()); + } + comboBox = new JFXComboBox<>(observableUserList); + comboBox.getStyleClass().add("comboBox"); + mainGrid.add(comboBox, 2,2); + + config = ConfigLoader.load(); + if(config == null){ + config = new Config(false, -1, ""); + } + saveLoginTBtn.setSelected(config.isSaveLogin()); + } + + public void onBackBtnClick(ActionEvent actionEvent) { + Stage stage = (Stage) ((Node) actionEvent.getSource()).getScene().getWindow(); + stage.close(); + } + + public void onCreateBtnClick(ActionEvent actionEvent) { + MainApplication.loadScene( + "User erstellen", + "../users/create-user.fxml", + "../users/create-user.css", + 800, + 650 + ); + } + + public void onUpdateBtnClick(ActionEvent actionEvent) { + int editIndex = comboBox.getSelectionModel().getSelectedIndex(); + + if(editIndex < 0 || editIndex >= users.size()) return; + + MainApplication.loadScene( + "User bearbeiten", + "../users/edit-user.fxml", + "../users/create-user.css", + 800, + 650, + fxmlLoader -> { + EditUserController editUserController = fxmlLoader.getController(); + editUserController.setCurrentUser(users.get(editIndex)); + } + ); + } + + public void onDeleteBtnClick(ActionEvent actionEvent) { + Alert alert = new Alert(Alert.AlertType.CONFIRMATION, "Wirklich löschen?"); + Optional result = alert.showAndWait(); + if(result.isPresent() && result.get() == ButtonType.OK){ + int removeIndex = comboBox.getSelectionModel().getSelectedIndex(); + try { + dataController.deleteUser(users.get(removeIndex)); + } catch (HttpRequestException e) { + Alert alert1 = new Alert(Alert.AlertType.ERROR, e.getMessage()); + alert1.showAndWait(); + return; + } + comboBox.getItems().remove(removeIndex); + users.remove(removeIndex); + } + } + + private void setUserAtController(FXMLLoader fxmlLoader){ + int editIndex = comboBox.getSelectionModel().getSelectedIndex(); + EditUserController editUserController = fxmlLoader.getController(); + editUserController.setCurrentUser(users.get(editIndex)); + } + + public void toggledBtn(ActionEvent actionEvent) { + config.setSaveLogin(saveLoginTBtn.isSelected()); + if(config.isSaveLogin()){ + config.setId(DataController.USER_ID); + config.setToken(HttpRequest.TOKEN); + } else { + config.setId(-1); + config.setToken(""); + } + ConfigLoader.save(config); + } +} diff --git a/client/app/src/main/java/ui/DayPane.java b/client/app/src/main/java/ui/DayPane.java new file mode 100644 index 0000000..26dc3e3 --- /dev/null +++ b/client/app/src/main/java/ui/DayPane.java @@ -0,0 +1,38 @@ +package ui; + +import javafx.scene.control.Label; +import javafx.scene.control.ScrollPane; +import javafx.scene.layout.VBox; + +public class DayPane extends ScrollPane { + + private final Label dayLabel; + private final VBox dayVBox; + + public DayPane() { + dayLabel = new Label(); + dayLabel.setMaxHeight(Double.MAX_VALUE); + dayLabel.setMaxWidth(Double.MAX_VALUE); + dayLabel.getStyleClass().add("labelDays"); + + dayVBox = new VBox(); + + dayVBox.getStyleClass().add("vBoxDays"); + dayVBox.setSpacing(10); + + setContent(dayVBox); + setFitToWidth(true); + setFitToHeight(true); + setHbarPolicy(ScrollPane.ScrollBarPolicy.AS_NEEDED); + getStyleClass().add("scrollDays"); + getStyleClass().add("scrollDays"); + } + + public Label getDayLabel() { + return dayLabel; + } + + public VBox getDayVBox() { + return dayVBox; + } +} diff --git a/client/app/src/main/java/ui/EventPane.java b/client/app/src/main/java/ui/EventPane.java new file mode 100644 index 0000000..8e74cc2 --- /dev/null +++ b/client/app/src/main/java/ui/EventPane.java @@ -0,0 +1,83 @@ +package ui; + +import container.Event; +import javafx.geometry.Pos; +import javafx.scene.Group; +import javafx.scene.control.Button; +import javafx.scene.control.Label; +import javafx.scene.layout.HBox; +import javafx.scene.layout.VBox; + +public class EventPane extends VBox { + + private Button deleteBtn; + private Button editBtn; + + public EventPane(Event event) { + this.getStyleClass().add("event"); + this.setSpacing(5); + + HBox btnHBox = new HBox(); + btnHBox.setAlignment(Pos.BOTTOM_RIGHT); + + Group svgDel = new Group( + SvgBtnCreator.createPath("M0 0h24v24H0z", "transparent", "transparent"), + SvgBtnCreator.createPath("M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z", + "white", "gray") + ); + deleteBtn = SvgBtnCreator.createBtn(svgDel, 24, "", "Löschen des Termins"); + deleteBtn.getStyleClass().add("deleteEventBtn"); + + Group svgEdit = new Group( + SvgBtnCreator.createPath("M0 0h24v24H0z", "transparent", "transparent"), + SvgBtnCreator.createPath("M3 17.25V21h3.75L17.81 9.94l-3.75-3.75L3 17.25zM20.71 7.04c.39-.39.39-1.02 0-1.41l-2.34-2.34c-.39-.39-1.02-.39-1.41 0l-1.83 1.83 3.75 3.75 1.83-1.83z", + "white", "gray") + ); + editBtn = SvgBtnCreator.createBtn(svgEdit, 24, "", "Bearbeiten des Termins"); + editBtn.getStyleClass().add("editEventBtn"); + + btnHBox.getChildren().add(editBtn); + btnHBox.getChildren().add(deleteBtn); + this.getChildren().add(btnHBox); + + Label nameLabel = new Label(event.getName()); + nameLabel.setWrapText(true); + this.getChildren().add(nameLabel); + + if (event.getStart() != null || event.getEnd() != null) { + String timeStr = (event.getStart() != null ? formatTime(event.getStart()) : "") + + (event.getEnd() != null ? " - " + formatTime(event.getEnd()) : ""); + Label timeLabel = new Label(timeStr); + this.getChildren().add(timeLabel); + } + + Label typeLabel = new Label("Wer: " + event.getOwnerName()); + this.getChildren().add(typeLabel); + + Label prioLabel = new Label("Priorität: " + event.getPriority()); + this.getChildren().add(prioLabel); + + if (event.isFullDay()) { + Label fullDayLabel = new Label("Dieser Termin bockiert den ganzen Tag!"); + fullDayLabel.setWrapText(true); + this.getChildren().add(fullDayLabel); + } + } + + public Button getDeleteBtn() { + return deleteBtn; + } + + public Button getEditBtn() { + return editBtn; + } + + + private String formatTime(String time) { + String[] timeArr = time.split(":"); + if (timeArr.length > 2) { + return timeArr[0] + ":" + timeArr[1]; + } + return time; + } +} diff --git a/client/app/src/main/java/ui/SvgBtnCreator.java b/client/app/src/main/java/ui/SvgBtnCreator.java new file mode 100644 index 0000000..c481fcb --- /dev/null +++ b/client/app/src/main/java/ui/SvgBtnCreator.java @@ -0,0 +1,91 @@ +package ui; + +import javafx.geometry.Bounds; +import javafx.scene.Group; +import javafx.scene.control.*; +import javafx.scene.shape.SVGPath; + +public class SvgBtnCreator { + + + public static Button createBtn(Group group, int svgSize, String styleClass, String toolTip) { + Button btn = new Button(); + + Bounds boundsDel = group.getBoundsInParent(); + double scaleDel = Math.min(svgSize / boundsDel.getWidth(), svgSize / boundsDel.getHeight()); + group.setScaleX(scaleDel); + group.setScaleY(scaleDel); + btn.setGraphic(group); + btn.setMaxSize(svgSize, svgSize); + btn.setMinSize(svgSize, svgSize); + btn.setContentDisplay(ContentDisplay.GRAPHIC_ONLY); + btn.getStyleClass().add(styleClass); + Tooltip tooltip = new Tooltip(toolTip); + btn.setTooltip(tooltip); + + return btn; + } + + public static SVGPath createPath(String d, String fill, String hoverFill) { + SVGPath path = new SVGPath(); + path.getStyleClass().add("svg"); + path.setContent(d); + path.setStyle("-fill:" + fill + ";-hover-fill:"+hoverFill+';'); + return path; + } + + public static Button createAddBtn(){ + Group svgAdd = new Group( + createPath("M0 0h24v24H0z", "transparent", "transparent"), + createPath("M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z", + "white", "gray") + ); + return createBtn(svgAdd, 40, "main-btn", "Erstellt einen neuen Termin"); + } + + public static Button createSettingBtn(){ + Group svgSettings = new Group( + createPath("M0 0h24v24H0V0z", "transparent", "transparent"), + createPath("M19.14,12.94c0.04-0.3,0.06-0.61,0.06-0.94c0-0.32-0.02-0.64-0.07-0.94l2.03-1.58c0.18-0.14,0.23-0.41,0.12-0.61 l-1.92-3.32c-0.12-0.22-0.37-0.29-0.59-0.22l-2.39,0.96c-0.5-0.38-1.03-0.7-1.62-0.94L14.4,2.81c-0.04-0.24-0.24-0.41-0.48-0.41 h-3.84c-0.24,0-0.43,0.17-0.47,0.41L9.25,5.35C8.66,5.59,8.12,5.92,7.63,6.29L5.24,5.33c-0.22-0.08-0.47,0-0.59,0.22L2.74,8.87 C2.62,9.08,2.66,9.34,2.86,9.48l2.03,1.58C4.84,11.36,4.8,11.69,4.8,12s0.02,0.64,0.07,0.94l-2.03,1.58 c-0.18,0.14-0.23,0.41-0.12,0.61l1.92,3.32c0.12,0.22,0.37,0.29,0.59,0.22l2.39-0.96c0.5,0.38,1.03,0.7,1.62,0.94l0.36,2.54 c0.05,0.24,0.24,0.41,0.48,0.41h3.84c0.24,0,0.44-0.17,0.47-0.41l0.36-2.54c0.59-0.24,1.13-0.56,1.62-0.94l2.39,0.96 c0.22,0.08,0.47,0,0.59-0.22l1.92-3.32c0.12-0.22,0.07-0.47-0.12-0.61L19.14,12.94z M12,15.6c-1.98,0-3.6-1.62-3.6-3.6 s1.62-3.6,3.6-3.6s3.6,1.62,3.6,3.6S13.98,15.6,12,15.6z", + "white", "gray") + ); + return createBtn(svgSettings, 40, "main-btn", "Öffnet die Einstellungen"); + } + + public static Button createLogoutBtn(){ + Group svgLogout = new Group( + createPath("M0 0h24v24H0z", "transparent", "transparent"), + createPath("M17 7l-1.41 1.41L18.17 11H8v2h10.17l-2.58 2.58L17 17l5-5zM4 5h8V3H4c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h8v-2H4V5z", + "white", "gray") + ); + return createBtn(svgLogout, 40, "main-btn", "Abmelden"); + } + + public static Button createBackBtn(){ + Group svgBack = new Group( + createPath("M0 0h24v24H0z", "transparent", "transparent"), + createPath("M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z", + "white", "lightgray") + ); + return createBtn(svgBack, 40, "navBtn", "Zeigt die vorherige Woche"); + } + + public static Button createTodayBtn(){ + Group svgToday = new Group( + createPath("M0 0h24v24H0z", "transparent", "transparent"), + createPath("M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 18H4V8h16v13z", + "white", "lightgray") + ); + return createBtn(svgToday, 40, "navBtn", "Zeigt die aktuelle Woche"); + } + + public static Button createNextBtn(){ + Group svgNext = new Group( + createPath("M0 0h24v24H0z", "transparent", "transparent"), + createPath("M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z", + "white", "lightgray") + ); + return createBtn(svgNext, 40, "navBtn", "Zeigt die nächste Woche"); + } + +} diff --git a/client/app/src/main/java/users/CreateUserController.java b/client/app/src/main/java/users/CreateUserController.java new file mode 100644 index 0000000..6078e21 --- /dev/null +++ b/client/app/src/main/java/users/CreateUserController.java @@ -0,0 +1,99 @@ +//Alex Rechtin// +package users; + +import helper.HttpRequestException; +import javafx.event.ActionEvent; +import javafx.fxml.FXML; +import javafx.scene.Node; +import javafx.scene.control.Label; +import javafx.scene.control.PasswordField; +import javafx.scene.control.TextField; +import javafx.scene.control.ToggleButton; +import javafx.stage.Stage; +import container.DataController; +import container.User; + +import java.util.Objects; + +public class CreateUserController { + + @FXML + protected TextField textName; + @FXML + protected PasswordField textPassword; + @FXML + protected PasswordField textPasswordSecond; + @FXML + protected ToggleButton checkButtonIsAdmin; + @FXML + protected TextField textLogin; + @FXML + protected TextField textForename; + @FXML + protected Label labelError; + + @FXML + protected void createUser(ActionEvent event) { + if (validateNameAndLogin() || validatePassword()) return; + + User user = new User(); + user.setLogin(textLogin.getText().trim()); + user.setForename(textForename.getText().trim()); + user.setName(textName.getText().trim()); + user.setPassword(textPassword.getText().trim()); + user.setAdmin(checkButtonIsAdmin.isSelected()); + + try { + sendHttpRequest(user); + } catch (HttpRequestException e) { + labelError.setText(e.getMessage()); + return; + } + + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } + + protected boolean validatePassword() { + if (textPassword.getText().trim().isEmpty()) { + labelError.setText("Bitte Passwort eingeben!"); + return true; + } + if (textPassword.getText().trim().length() < 8) { + labelError.setText("Das Passwort muss mindestens 8 Zeichen lang sein!"); + return true; + } + if (!Objects.equals(textPassword.getText(), textPasswordSecond.getText())){ + labelError.setText("Passwörter stimmen nicht überein!"); + return true; + } + return false; + } + + protected boolean validateNameAndLogin() { + if (textLogin.getText().trim().isEmpty()){ + labelError.setText("Bitte Login Namen angeben"); + return true; + } + if (textForename.getText().trim().isEmpty()) { + labelError.setText("Bitte Vornamen eingeben!"); + return true; + } + if (textName.getText().trim().isEmpty()) { + labelError.setText("Bitte Nachnamen eingeben!"); + return true; + } + return false; + } + + protected void sendHttpRequest(User user) throws HttpRequestException { + DataController dataController = new DataController(); + dataController.createUser(user); + } + + @FXML + protected void abortBtnClick(ActionEvent event) { + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } +} diff --git a/client/app/src/main/java/users/EditUserController.java b/client/app/src/main/java/users/EditUserController.java new file mode 100644 index 0000000..3b00b42 --- /dev/null +++ b/client/app/src/main/java/users/EditUserController.java @@ -0,0 +1,69 @@ +/* Marc Beyer */ +package users; + +import container.DataController; +import container.User; +import helper.HttpRequestException; +import javafx.event.ActionEvent; +import javafx.scene.Node; +import javafx.scene.control.Alert; +import javafx.stage.Stage; + +public class EditUserController extends CreateUserController{ + private User currentUser; + + public User getCurrentUser() { + return currentUser; + } + + public void setCurrentUser(User currentUser) { + this.currentUser = currentUser; + + textForename.setText(currentUser.getForename()); + textName.setText(currentUser.getName()); + textLogin.setText(currentUser.getLogin()); + checkButtonIsAdmin.setSelected(currentUser.isAdmin()); + } + + @Override + protected void createUser(ActionEvent event){ + if (validateNameAndLogin()) return; + + User user = new User(); + + if(!textPassword.getText().trim().isEmpty() || !textPasswordSecond.getText().trim().isEmpty()){ + if (validatePassword()) return; + user.setPassword(textPassword.getText().trim()); + } + + user.setUserId(currentUser.getUserId()); + user.setLogin(textLogin.getText().trim()); + user.setForename(textForename.getText().trim()); + user.setName(textName.getText().trim()); + user.setAdmin(checkButtonIsAdmin.isSelected()); + + try { + sendHttpRequest(user); + } catch (HttpRequestException e) { + labelError.setText(e.getMessage()); + return; + } + + if(currentUser.getUserId() == DataController.USER_ID){ + Alert alert = new Alert( + Alert.AlertType.WARNING, + "Bitte starte das Programm neu um die Änderungen anzuwenden." + ); + alert.showAndWait(); + } + + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } + + @Override + protected void sendHttpRequest(User user) throws HttpRequestException { + DataController dataController = new DataController(); + dataController.editUser(user); + } +} diff --git a/client/app/src/main/java/users/LoginController.java b/client/app/src/main/java/users/LoginController.java new file mode 100644 index 0000000..eecd403 --- /dev/null +++ b/client/app/src/main/java/users/LoginController.java @@ -0,0 +1,51 @@ +//Alex Rechtin// +package users; + +import com.jfoenix.controls.*; +import javafx.event.ActionEvent; +import javafx.fxml.FXML; +import javafx.scene.Node; +import javafx.scene.control.Label; +import javafx.stage.Stage; +import container.DataController; + +public class LoginController { + @FXML + private JFXTextField userField; + @FXML + private JFXPasswordField passField; + @FXML + private Label userErrLabel; + @FXML + private Label passErrLabel; + + @FXML + protected void login(ActionEvent event) { + if (userField.getText().trim().isEmpty()) { + userErrLabel.setText("Bitte Usernamen eingeben!"); + passErrLabel.setText(""); + return; + } + if (passField.getText().trim().isEmpty()) { + userErrLabel.setText(""); + passErrLabel.setText("Bitte Passwort eingeben!"); + return; + } + + DataController dataController = new DataController(); + if (!dataController.login(userField.getText(), passField.getText())) { + userErrLabel.setText("Name und Passwort passen nicht zueinander!"); + passErrLabel.setText("Name und Passwort passen nicht zueinander!"); + return; + } + + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } + + @FXML + protected void abortBtnClick(ActionEvent event) { + Stage stage = (Stage) ((Node) event.getSource()).getScene().getWindow(); + stage.close(); + } +} diff --git a/client/app/src/main/resources/main/create-event.css b/client/app/src/main/resources/main/create-event.css index 59602e9..2918a45 100644 --- a/client/app/src/main/resources/main/create-event.css +++ b/client/app/src/main/resources/main/create-event.css @@ -1,3 +1,4 @@ +/*Marco Kühn*/ GridPane{ -fx-background-color: #3E415F; -fx-padding: 20px; @@ -28,8 +29,52 @@ Label{ .inputField{ -fx-padding: 10px; + -fx-background-color: white; } .mainButton{ -fx-font-weight: bold; -} \ No newline at end of file + -fx-background-color: white; +} + +JFXButton{ + -fx-background-color: white; +} + +#labelError{ + -fx-font-weight: bold; + -fx-max-width: 1000px; + -fx-text-fill: #ff5555; + -fx-padding: 16px; + -fx-min-height: 140px; + -fx-max-height: 400px; + -fx-wrap-text: true; + -fx-font-size: 16px; +} + +.inputDate{ + -fx-background-color: white; +} + +.comboBox{ + -fx-background-color: white; +} + +.timePicker{ + -fx-background-color: white; +} + +.jfx-time-picker .date-picker-popup{ + -fx-max-width: 230px; + -fx-min-width: 230px; +} + +.jfx-time-picker .date-picker-popup > * > .spinner > .label { + -fx-max-width: 55px; + -fx-min-width: 55px; +} + +.jfx-date-picker .date-picker-popup > * > .spinner > .label { + -fx-max-width: 300px; + -fx-min-width: 300px; + } \ No newline at end of file diff --git a/client/app/src/main/resources/main/create-event.fxml b/client/app/src/main/resources/main/create-event.fxml index 2ca5917..e46c1cf 100644 --- a/client/app/src/main/resources/main/create-event.fxml +++ b/client/app/src/main/resources/main/create-event.fxml @@ -1,11 +1,16 @@ + + - + + + @@ -13,48 +18,49 @@ - - - - - - - - - + + + + + + + + + - - + + - - - - - - - - - - + + + + + + + + + + - - - + + + - - - + + + + diff --git a/client/app/src/main/resources/main/edit-event.fxml b/client/app/src/main/resources/main/edit-event.fxml new file mode 100644 index 0000000..f416926 --- /dev/null +++ b/client/app/src/main/resources/main/edit-event.fxml @@ -0,0 +1,66 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/client/app/src/main/resources/main/main-view.css b/client/app/src/main/resources/main/main-view.css index f6a436d..3dcf8ac 100644 --- a/client/app/src/main/resources/main/main-view.css +++ b/client/app/src/main/resources/main/main-view.css @@ -1,72 +1,121 @@ +/*Alex Rechtin, Marco Kühn*/ * { - -fx-dark-background-color: #525E74; - -fx-darkest-background-color: #2B2D42; - - -fx-bright-background-color: #77859E; - -fx-brighter-background-color: #52567E; - -fx-brightest-background-color: #ffffff; - - -fx-bright-border-color: #B0B0B0; - -fx-brighter-text-color: #ffffff; + -fx-base-background-color: #2B2D42; + -fx-base1-background-color: #525E74; + -fx-main-border-color: #B0B0B0; + -fx-main-text-color: #ffffff; } -.mainGrid{ - -fx-background-color: -fx-darkest-background-color; + +GridPane{ + -fx-background-color: -fx-base-background-color; } -.mainVbox{ - -fx-background-color: -fx-dark-background-color; +.main-panel{ + -fx-background-color: #282C34; +} + +.vbox-main{ + -fx-background-color: #333333; + -fx-alignment: top-center; + } .gridCalendar Line{ - -fx-stroke: -fx-bright-border-color; + -fx-stroke: -fx-main-border-color; } .gridCalender{ - -fx-background-color: -fx-darkest-background-color; + -fx-background-color: -fx-base-background-color; -fx-min-height: 80px; -fx-max-height: 80px; } .labelMonth{ -fx-padding: 0 0 0 20; - -fx-background-color: -fx-bright-background-color; + -fx-background-color: #77859E; -fx-font-size: 35px; -fx-font-weight: bold; } .scrollDays{ - -fx-background-color: -fx-darkest-background-color; - -fx-border-color: -fx-bright-border-color; + -fx-background-color: -fx-base-background-color; + -fx-border-color: -fx-main-border-color; } .vBoxDays{ - -fx-background-color: -fx-darkest-background-color; + -fx-background-color: -fx-base-background-color; } .labelDays{ -fx-alignment: center; - -fx-background-color: -fx-dark-background-color; + -fx-background-color: -fx-base1-background-color; -fx-font-size: 25px; - -fx-border-color: -fx-bright-border-color; + -fx-border-color: -fx-main-border-color; } Label{ - -fx-text-fill: -fx-brighter-text-color; + -fx-text-fill: -fx-main-text-color; } .event{ - -fx-background-color: -fx-dark-background-color; + -fx-background-color: -fx-base1-background-color; } -.mainBtn{ - -fx-background-color: -fx-brightest-background-color; - -fx-text-fill: -fx-brighter-text-color; - -fx-background-radius: 5em; - -fx-min-width: 40px; - -fx-min-height: 40px; - -fx-max-width: 40px; - -fx-max-height: 40px; +.main-btn{ + -fx-background-color: transparent; + -fx-border-color: transparent; +} + +.main-btn .svg { + -fx-fill: -fill; +} + +.main-btn:hover .svg { + -fx-fill: -hover-fill; +} + +.buttonBox{ + -fx-background-color: #77859E; +} + +.navBtn{ + -fx-background-color: transparent; + -fx-border-color: transparent; +} + +.navBtn .svg { + -fx-fill: -fill; +} + +.navBtn:hover .svg { + -fx-fill: -hover-fill; +} + +.editEventBtn{ + -fx-background-color: transparent; + -fx-border-color: transparent; +} + +.editEventBtn .svg { + -fx-fill: -fill; +} + +.editEventBtn:hover .svg { + -fx-fill: -hover-fill; +} + +.deleteEventBtn{ + -fx-background-color: transparent; + -fx-border-color: transparent; +} + +.deleteEventBtn .svg { + -fx-fill: -fill; +} + +.deleteEventBtn:hover .svg { + -fx-fill: -hover-fill; } diff --git a/client/app/src/main/resources/main/main-view.fxml b/client/app/src/main/resources/main/main-view.fxml index f7b211a..5cd69e3 100644 --- a/client/app/src/main/resources/main/main-view.fxml +++ b/client/app/src/main/resources/main/main-view.fxml @@ -1,66 +1,66 @@ + + - - - + + - + - + - - - - + - - + + + + + - - + + - + + - - - - - - + percentWidth="14.2857142857"/> + + + + + + - - + + + diff --git a/client/app/src/main/resources/main/option-view.css b/client/app/src/main/resources/main/option-view.css new file mode 100644 index 0000000..63f8e9b --- /dev/null +++ b/client/app/src/main/resources/main/option-view.css @@ -0,0 +1,59 @@ +/* Marco Kühn */ +GridPane{ + -fx-background-color: #3E415F; + -fx-padding: 20px; + -fx-font-size: 20px; + -fx-font-family: Segoe UI; + + -fx-border-insets: 1; + -fx-border-color: #B0B0B0; + -fx-border-style: solid; + -fx-border-width: 2; + -fx-effect: dropshadow(three-pass-box, rgba(100, 100, 100, 1), 24, 0.5, 0, 0); +} + +Label{ + -fx-text-fill: white; + -fx-max-width: 200px; + -fx-min-width: 200px; +} + +.mainLabel{ + -fx-background-color: #8D99AE; + -fx-padding: 10px; + -fx-max-width: 200px; + -fx-min-width: 200px; + -fx-font-weight: bold; + -fx-alignment: center; +} + +.mainButton{ + -fx-font-weight: bold; + -fx-background-color: white; +} + +JFXButton{ + -fx-background-color: white; +} + +#labelError{ + -fx-font-weight: bold; + -fx-max-width: 1000px; + -fx-text-fill: #ff5555; + -fx-padding: 16px; + -fx-min-height: 140px; + -fx-max-height: 400px; + -fx-wrap-text: true; + -fx-font-size: 16px; +} + +.comboBox{ + -fx-background-color: white; + -fx-max-width: 200px; + -fx-min-width: 200px; +} + +.userBtn{ + -fx-max-width: 200px; + -fx-min-width: 200px; +} \ No newline at end of file diff --git a/client/app/src/main/resources/main/option-view.fxml b/client/app/src/main/resources/main/option-view.fxml new file mode 100644 index 0000000..56ef502 --- /dev/null +++ b/client/app/src/main/resources/main/option-view.fxml @@ -0,0 +1,52 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + User bearbeiten + User löschen + User anlegen + + + + + diff --git a/client/app/src/main/resources/users/create-user.css b/client/app/src/main/resources/users/create-user.css new file mode 100644 index 0000000..2d13534 --- /dev/null +++ b/client/app/src/main/resources/users/create-user.css @@ -0,0 +1,57 @@ +/*Alex Rechtin*/ +* { + -fx-base-background-color: #2B2D42; + -fx-base1-background-color: #525E74; + + -fx-main-border-color: #B0B0B0; + -fx-main-text-color: #ffffff; +} + + +GridPane{ + -fx-background-color: #3E415F; + -fx-padding: 20px; + -fx-font-size: 20px; + -fx-font-family: Segoe UI; + + -fx-border-insets: 1; + -fx-border-color: #B0B0B0; + -fx-border-style: solid; + -fx-border-width: 2; + -fx-effect: dropshadow(three-pass-box, rgba(100, 100, 100, 1), 24, 0.5, 0, 0); +} + +.mainLabel{ + -fx-padding: 10px; + -fx-max-width: 400px; + -fx-min-width: 400px; + -fx-font-weight: bold; + -fx-alignment: top-center; +} + + +Label{ + -fx-text-fill: white; + -fx-max-width: 150px; + -fx-min-width: 150px; +} + +.textField{ + -fx-max-width: 400px; + -fx-min-width: 400px; +} + +.errorMessage{ + -fx-max-width: 400px; + -fx-min-width: 400px; +} + +Button{ + -fx-max-width: 150px; + -fx-min-width: 150px; +} + +.btnLogin{ + -fx-font-weight: bold; +} + diff --git a/client/app/src/main/resources/users/create-user.fxml b/client/app/src/main/resources/users/create-user.fxml new file mode 100644 index 0000000..f48f872 --- /dev/null +++ b/client/app/src/main/resources/users/create-user.fxml @@ -0,0 +1,59 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/client/app/src/main/resources/users/edit-user.fxml b/client/app/src/main/resources/users/edit-user.fxml new file mode 100644 index 0000000..7ee0071 --- /dev/null +++ b/client/app/src/main/resources/users/edit-user.fxml @@ -0,0 +1,57 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/client/app/src/main/resources/users/login.css b/client/app/src/main/resources/users/login.css new file mode 100644 index 0000000..963c6b6 --- /dev/null +++ b/client/app/src/main/resources/users/login.css @@ -0,0 +1,54 @@ +/* Marco Kühn*/ +* { + -fx-base-background-color: #2B2D42; + -fx-base1-background-color: #525E74; + + -fx-main-border-color: #B0B0B0; + -fx-main-text-color: #ffffff; +} + +GridPane{ + -fx-background-color: #3E415F; + -fx-padding: 20px; + -fx-font-size: 20px; + -fx-font-family: Segoe UI; + + -fx-border-insets: 1; + -fx-border-color: #B0B0B0; + -fx-border-style: solid; + -fx-border-width: 2; + -fx-effect: dropshadow(three-pass-box, rgba(100, 100, 100, 1), 24, 0.5, 0, 0); +} + +Label{ + -fx-text-fill: white; + -fx-max-width: 150px; + -fx-min-width: 150px; +} + +.errorLbl{ + -fx-font-weight: bold; + -fx-max-width: 200px; + -fx-text-fill: #ff5555; + -fx-padding: 16px; + -fx-min-height: 140px; + -fx-max-height: 400px; + -fx-wrap-text: true; + -fx-font-size: 16px; +} + +.userField{ + -fx-background-color: white; +} + +.passField{ + -fx-background-color: white; +} + +.quitBtn{ + -fx-background-color: white; +} + +.loginBtn{ + -fx-background-color: white; +} \ No newline at end of file diff --git a/client/app/src/main/resources/users/login.fxml b/client/app/src/main/resources/users/login.fxml new file mode 100644 index 0000000..711054b --- /dev/null +++ b/client/app/src/main/resources/users/login.fxml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/client/data/build.gradle.kts b/client/data/build.gradle.kts index 5b07f24..790eeb5 100644 --- a/client/data/build.gradle.kts +++ b/client/data/build.gradle.kts @@ -2,9 +2,14 @@ plugins { java } +tasks.withType { + options.encoding = "UTF-8" +} + dependencies { val jacksonVersion = "2.13.0" implementation("com.fasterxml.jackson.core:jackson-databind:$jacksonVersion") implementation("com.fasterxml.jackson.core:jackson-core:$jacksonVersion") implementation("com.fasterxml.jackson.core:jackson-annotations:$jacksonVersion") + implementation("com.fasterxml.jackson.datatype:jackson-datatype-jsr310:$jacksonVersion") } diff --git a/client/data/src/main/java/config/Config.java b/client/data/src/main/java/config/Config.java new file mode 100644 index 0000000..cfbe489 --- /dev/null +++ b/client/data/src/main/java/config/Config.java @@ -0,0 +1,81 @@ +//Marc Beyer// +package config; + +public class Config { + private boolean saveLogin; + private long id; + private String token; + private String connectionMethod; + private String hostAddress; + private int port; + + public Config(){ + saveLogin = false; + id = -1; + token = ""; + connectionMethod = "http"; + hostAddress = "localhost"; + port = 8080; + } + + public Config(boolean saveLogin, long id, String token) { + this.saveLogin = saveLogin; + this.id = id; + this.token = token; + connectionMethod = "http"; + hostAddress = "localhost"; + port = 8080; + } + + public boolean isSaveLogin() { + return saveLogin; + } + + public void setSaveLogin(boolean saveLogin) { + this.saveLogin = saveLogin; + } + + public long getId() { + return id; + } + + public void setId(long id) { + this.id = id; + } + + public String getToken() { + return token; + } + + public void setToken(String token) { + this.token = token; + } + + public String getConnectionMethod() { + return connectionMethod; + } + + public void setConnectionMethod(String connectionMethod) { + this.connectionMethod = connectionMethod; + } + + public String getHostAddress() { + return hostAddress; + } + + public void setHostAddress(String hostAddress) { + this.hostAddress = hostAddress; + } + + public int getPort() { + return port; + } + + public void setPort(int port) { + this.port = port; + } + + public String toServerUrl(){ + return getConnectionMethod() + "://" + getHostAddress() + ":" + getPort(); + } +} diff --git a/client/data/src/main/java/config/ConfigLoader.java b/client/data/src/main/java/config/ConfigLoader.java new file mode 100644 index 0000000..68e1f86 --- /dev/null +++ b/client/data/src/main/java/config/ConfigLoader.java @@ -0,0 +1,43 @@ +//Marc Beyer// +package config; + +import com.fasterxml.jackson.databind.ObjectMapper; + +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Paths; + +public class ConfigLoader { + + public static Config load(){ + try { + String jsonString = Files.readString(Paths.get("config.json")); + + ObjectMapper objectMapper = new ObjectMapper(); + objectMapper.findAndRegisterModules(); + return objectMapper.readValue(jsonString, Config.class); + } catch (IOException e) { + System.out.println("config.json missing"); + Config config = new Config(false, -1, ""); + save(config); + return config; + } + } + + public static void save(Config config){ + ObjectMapper objectMapper = new ObjectMapper(); + objectMapper.findAndRegisterModules(); + + try { + Files.writeString( + Paths.get("config.json"), + objectMapper.writeValueAsString(config) + .replace(",", ",\n\t") + .replace("{", "{\n\t") + .replace("}", "\n}") + ); + } catch (IOException e) { + e.printStackTrace(); + } + } +} diff --git a/client/data/src/main/java/container/DataController.java b/client/data/src/main/java/container/DataController.java new file mode 100644 index 0000000..1c9d5d5 --- /dev/null +++ b/client/data/src/main/java/container/DataController.java @@ -0,0 +1,220 @@ +package container; + +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.core.type.TypeReference; +import com.fasterxml.jackson.databind.ObjectMapper; +import helper.HttpRequestException; +import helper.Tuple; + +import java.time.LocalDateTime; +import java.util.*; + +public class DataController { + + public static long USER_ID = -1; + public static String SERVER_URL = "http://localhost:8080"; + + private static final String ALL_EVENTS_ENDPOINT = "/event/all"; + private static final String ADD_EVENT_ENDPOINT = "/event/add"; + private static final String DELETE_EVENT_ENDPOINT = "/event/del"; + private static final String EDIT_EVENT_ENDPOINT = "/event/edit"; + + private static final String ALL_USER_ENDPOINT = "/user/all"; + private static final String ADD_USER_ENDPOINT = "/user/add"; + private static final String DELETE_USER_ENDPOINT = "/user/del"; + private static final String EDIT_USER_ENDPOINT = "/user/edit"; + + private static final String LOGIN_ENDPOINT = "/user/login"; + private static final String LOGIN_WITH_TOKEN_ENDPOINT = "/user/login-with-token"; + private static final String HEADER_TEST_ENDPOINT = "/vpr/header-test"; + + private final HttpRequest httpRequest; + + public DataController() { + httpRequest = new HttpRequest(); + } + + public boolean login(String username, String password) { + try { + Tuple response = httpRequest.sendPostRequest( + SERVER_URL + LOGIN_ENDPOINT, + "login=" + username + + "&password=" + password, + false + ); + String[] data = response.getValue().split("\\s+"); + + USER_ID = Long.parseLong(data[1]); + HttpRequest.TOKEN = data[0]; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + + return USER_ID >= 0; + } + + public boolean loginWithToken(long userId, String token) { + try { + HttpRequest.TOKEN = token; + Tuple response = httpRequest.sendPostRequest( + SERVER_URL + LOGIN_WITH_TOKEN_ENDPOINT, + "userId=" + userId, + true + ); + + System.out.println(response.getKey() + " " + response.getValue()); + + if (response.getKey() != 200) return false; + } catch (Exception e) { + e.printStackTrace(); + return false; + } + USER_ID = userId; + HttpRequest.TOKEN = token; + return USER_ID >= 0; + } + + /********* + * Event * + *********/ + public void createEvent(Event event) throws HttpRequestException { + sendBasicHttpRequest( + SERVER_URL + ADD_EVENT_ENDPOINT, + event.getAsUrlParam(), + true + ); + } + + public void deleteEvent(int userId, int eventId, LocalDateTime date) throws HttpRequestException { + sendBasicHttpRequest( + SERVER_URL + DELETE_EVENT_ENDPOINT, + "userId=" + userId + "&eventId=" + eventId + "&date=" + date.toLocalDate(), + true + ); + } + + public void editEvent(Event oldEvent, Event event) throws HttpRequestException { + sendBasicHttpRequest( + SERVER_URL + EDIT_EVENT_ENDPOINT, + "eventId=" + oldEvent.getId() + + "&userId=" + oldEvent.getOwnerId() + + "&date=" + oldEvent.getDate().toLocalDate() + + "&newDate=" + event.getDate().toLocalDate() + + "&newName=" + event.getName() + + "&newStart=" + event.getStart() + + "&newEnd=" + event.getEnd() + + "&newPriority=" + event.getPriority() + + "&newIsFullDay=" + event.isFullDay() + + "&newIsPrivate=" + event.isPrivate(), + true + ); + } + + public ArrayList getAllVisibleEvents(LocalDateTime startDate, LocalDateTime endDate) throws HttpRequestException { + try { + Tuple response = httpRequest.sendPostRequest( + SERVER_URL + ALL_EVENTS_ENDPOINT, + "userId=" + USER_ID + "&startDate=" + startDate.toLocalDate() + "&endDate=" + endDate.toLocalDate(), + true + ); + if (response.getKey() != 200) { + throw new HttpRequestException(response); + } + String jsonResponse = response.getValue(); + System.out.println(jsonResponse); + + ObjectMapper objectMapper = new ObjectMapper(); + objectMapper.findAndRegisterModules(); + return (ArrayList) objectMapper.readValue(jsonResponse, new TypeReference>() { + }); + + } catch (HttpRequestException e) { + throw e; + } catch (Exception e) { + throw new HttpRequestException("Es konnte keine Verbindung mit dem Server hergestellt werden.", 600); + } + } + + /******** + * User * + ********/ + + public List getAllUser() throws HttpRequestException { + String userJSON = sendBasicHttpRequest( + SERVER_URL + ALL_USER_ENDPOINT, + "", + true + ); + + ObjectMapper objectMapper = new ObjectMapper(); + objectMapper.findAndRegisterModules(); + try { + List list = objectMapper.readValue(userJSON, new TypeReference<>() { + }); + + for(User u : list){ + System.out.println(u); + } + return list; + } catch (JsonProcessingException e) { + e.printStackTrace(); + } + return new ArrayList<>(); + } + + public void createUser(User user) throws HttpRequestException { + sendBasicHttpRequest( + SERVER_URL + ADD_USER_ENDPOINT, + "name=" + user.getName() + + "&forename=" + user.getForename() + + "&login=" + user.getLogin() + + "&password=" + user.getPassword() + + "&isAdmin=" + user.isAdmin(), + true + ); + } + + public void deleteUser(User user) throws HttpRequestException { + sendBasicHttpRequest( + SERVER_URL + DELETE_USER_ENDPOINT, + "userId=" + user.getUserId(), + true + ); + } + + public void editUser(User user) throws HttpRequestException { + String urlParam = "userId=" + user.getUserId() + + "&name=" + user.getName() + + "&forename=" + user.getForename() + + "&login=" + user.getLogin() + + "&isAdmin=" + user.isAdmin() + + (user.getPassword() == null ? "" : "&password=" + user.getPassword()); + + System.out.println(urlParam); + sendBasicHttpRequest( + SERVER_URL + EDIT_USER_ENDPOINT, + urlParam, + true + ); + } + + private String sendBasicHttpRequest(String urlString, String urlParameters, boolean sendAuth) throws HttpRequestException { + try { + Tuple response = httpRequest.sendPostRequest( + urlString, + urlParameters, + sendAuth + ); + if (response.getKey() != 200) { + throw new HttpRequestException(response); + } + + return response.getValue(); + } catch (HttpRequestException e) { + throw e; + } catch (Exception e) { + throw new HttpRequestException("Es konnte keine Verbindung mit dem Server hergestellt werden.", 600); + } + } +} \ No newline at end of file diff --git a/client/data/src/main/java/res/Event.java b/client/data/src/main/java/container/Event.java similarity index 65% rename from client/data/src/main/java/res/Event.java rename to client/data/src/main/java/container/Event.java index 33ee93f..b9958bd 100644 --- a/client/data/src/main/java/res/Event.java +++ b/client/data/src/main/java/container/Event.java @@ -1,10 +1,11 @@ -package res; - -import com.sun.jdi.event.StepEvent; +package container; +import java.time.Duration; import java.time.LocalDateTime; +import java.time.LocalTime; import java.time.format.DateTimeFormatter; -import java.util.ArrayList; +import java.util.regex.Matcher; +import java.util.regex.Pattern; public class Event { @@ -21,53 +22,41 @@ public class Event { private int ownerId; private String ownerName; - /* - Constructor for SELECT: - e.id AS eid, - e.name AS ename, - e.start, - e.end, - e.priority, - e.is_full_day, - - ue.date, - - u.id AS uid, - u.forename, - u.name AS uname - */ - - public Event(ArrayList arr) { - id = (int) arr.get(0); - name = (String) arr.get(1); - start = (String) arr.get(2); - end = (String) arr.get(3); - priority = (int) arr.get(4); - isFullDay = (Boolean) arr.get(5); //((String)arr.get(5)).equals("true"); - - - DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"); - date = LocalDateTime.parse(arr.get(6) + " 00:00", formatter); - - ownerId = (int) arr.get(7); - ownerName = arr.get(8) + " " + arr.get(9); - } + public Event() {} public Event(String name, int priority, boolean isFullDay, boolean isPrivate, - String start, - String end, + LocalTime start, + LocalTime end, LocalDateTime date, int ownerId - ) { + ) throws IllegalArgumentException { + + System.out.println("Create Event"); + if (name.length() < 3) { + throw new IllegalArgumentException("Der Name muss eine Länge von 3 haben."); + } + Pattern pattern = Pattern.compile("[A-Za-zäöüÄÖÜß0-9 =!?+*/$.:,;_<>()-]*"); + Matcher matcher = pattern.matcher(name); + if (!matcher.matches()) { + throw new IllegalArgumentException("Der Name darf nur aus Zahlen, Buchstaben und folgenden Sonderzeichen bestehen: äöü ÄÖÜ ß =!?+*/$.:,;_ <>()-"); + } + if (priority < 0) { + throw new IllegalArgumentException("Bitte eine Priorität wählen."); + } + LocalDateTime today = LocalDateTime.now().toLocalDate().atStartOfDay(); + if (Duration.between(today, date).isNegative()) { + throw new IllegalArgumentException("Das Datum muss in der Zukunft liegen."); + } + this.name = name; this.priority = priority; this.isFullDay = isFullDay; this.isPrivate = isPrivate; - this.start = start; - this.end = end; + if (start != null) this.start = start.toString(); + if (end != null) this.end = end.toString(); this.date = date; this.ownerId = ownerId; } @@ -132,8 +121,9 @@ public class Event { return date; } - public void setDate(LocalDateTime date) { - this.date = date; + public void setDate(String date) { + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"); + this.date = LocalDateTime.parse(date + " 00:00", formatter); } public int getOwnerId() { @@ -167,7 +157,7 @@ public class Event { "&name=" + getName() + "&start=" + getStart() + "&end=" + getEnd() + - "&prority=" + getPriority() + + "&priority=" + getPriority() + "&isFullDay=" + isFullDay() + "&isPrivate=" + isPrivate(); } diff --git a/client/data/src/main/java/container/HttpRequest.java b/client/data/src/main/java/container/HttpRequest.java new file mode 100644 index 0000000..8ddf2d2 --- /dev/null +++ b/client/data/src/main/java/container/HttpRequest.java @@ -0,0 +1,77 @@ +package container; + +import helper.Tuple; + +import java.io.BufferedReader; +import java.io.DataOutputStream; +import java.io.IOException; +import java.io.InputStreamReader; +import java.net.HttpURLConnection; +import java.net.URL; +import java.nio.charset.StandardCharsets; + +public class HttpRequest { + public static String TOKEN = ""; + + public Tuple sendPostRequest(String urlString, String urlParameters, boolean sendAuth) throws Exception { + byte[] postData = urlParameters.getBytes(StandardCharsets.UTF_8); + int postDataLength = postData.length; + + URL url = new URL(urlString); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + + connection.setDoOutput(true); + connection.setInstanceFollowRedirects(false); + connection.setRequestMethod("POST"); + connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); + connection.setRequestProperty("charset", "utf-8"); + connection.setRequestProperty("Content-Length", Integer.toString(postDataLength)); + connection.setUseCaches(false); + + if(sendAuth){ + connection.setRequestProperty("Accept", "application/json"); + connection.setRequestProperty("Authorization", "Bearer " + TOKEN); + } + + try (DataOutputStream writer = new DataOutputStream(connection.getOutputStream())) { + writer.write(postData); + } + + return getHttpTuple(connection); + } + + public Tuple sendGetRequest(String urlString) throws Exception { + URL url = new URL(urlString); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.setRequestMethod("GET"); + + connection.setConnectTimeout(5000); + connection.setReadTimeout(5000); + + int status = connection.getResponseCode(); + + return getHttpTuple(connection); + } + + private Tuple getHttpTuple(HttpURLConnection connection) throws IOException { + int status = connection.getResponseCode(); + String inputLine; + StringBuilder content = new StringBuilder(); + BufferedReader in; + + if (status == 200) { + in = new BufferedReader(new InputStreamReader(connection.getInputStream(), StandardCharsets.UTF_8)); + } else { + in = new BufferedReader(new InputStreamReader(connection.getErrorStream(), StandardCharsets.UTF_8)); + } + + while ((inputLine = in.readLine()) != null) { + content.append(inputLine); + } + in.close(); + + connection.disconnect(); + + return new Tuple<>(status, content.toString()); + } +} diff --git a/client/data/src/main/java/container/User.java b/client/data/src/main/java/container/User.java new file mode 100644 index 0000000..37e5d27 --- /dev/null +++ b/client/data/src/main/java/container/User.java @@ -0,0 +1,75 @@ +package container; + +public class User { + + private int userId; + private String login; + private String forename; + private String name; + private String password; + private boolean isAdmin; + + public User(){} + + + + public int getUserId() { + return userId; + } + + public void setUserId(int userId) { + this.userId = userId; + } + + public String getLogin() { + return login; + } + + public void setLogin(String login) { + this.login = login; + } + + public String getForename() { + return forename; + } + + public void setForename(String forename) { + this.forename = forename; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public boolean isAdmin() { + return isAdmin; + } + + public void setAdmin(boolean admin) { + isAdmin = admin; + } + + public String getPassword() { + return password; + } + + public void setPassword(String password) { + this.password = password; + } + + @Override + public String toString() { + return "User{" + + "userId=" + userId + + ", login='" + login + '\'' + + ", forename='" + forename + '\'' + + ", name='" + name + '\'' + + ", password='" + password + '\'' + + ", isAdmin=" + isAdmin + + '}'; + } +} diff --git a/client/data/src/main/java/helper/HttpRequestException.java b/client/data/src/main/java/helper/HttpRequestException.java new file mode 100644 index 0000000..1734ddc --- /dev/null +++ b/client/data/src/main/java/helper/HttpRequestException.java @@ -0,0 +1,24 @@ +//Marc Beyer// +package helper; + +public class HttpRequestException extends Exception{ + private int status; + + public HttpRequestException(String message, int status) { + super(message); + this.status = status; + } + + public HttpRequestException(Tuple response) { + super(response.getValue()); + this.status = response.getKey(); + } + + public int getStatus() { + return status; + } + + public void setStatus(int status) { + this.status = status; + } +} diff --git a/client/data/src/main/java/helper/Tuple.java b/client/data/src/main/java/helper/Tuple.java new file mode 100644 index 0000000..5ae234e --- /dev/null +++ b/client/data/src/main/java/helper/Tuple.java @@ -0,0 +1,28 @@ +//Marc Beyer// +package helper; + +public class Tuple { + public final X key; + public final Y value; + + public Tuple(X key, Y value) { + this.key = key; + this.value = value; + } + + public X getKey() { + return key; + } + + public Y getValue() { + return value; + } + + @Override + public String toString() { + return "Tuple{" + + "key=" + key + + ", value=" + value + + '}'; + } +} diff --git a/client/data/src/main/java/res/DataController.java b/client/data/src/main/java/res/DataController.java deleted file mode 100644 index ddc826d..0000000 --- a/client/data/src/main/java/res/DataController.java +++ /dev/null @@ -1,96 +0,0 @@ -package res; - -import com.fasterxml.jackson.core.JsonProcessingException; -import com.fasterxml.jackson.databind.ObjectMapper; - -import java.io.BufferedReader; -import java.io.DataOutputStream; -import java.io.InputStreamReader; -import java.io.OutputStream; -import java.net.HttpURLConnection; -import java.net.URL; -import java.nio.charset.StandardCharsets; -import java.util.*; - -public class DataController { - - private static final String ALL_EVENTS_ENDPOINT = "http://localhost:8080/vpr/all-events"; - private static final String ALL_USERS_ENDPOINT = "http://localhost:8080/vpr/all-users"; - private static final String ADD_EVENT_ENDPOINT = "http://localhost:8080/vpr/add-event"; - private static final String DELETE_EVENT_ENDPOINT = "http://localhost:8080/vpr/del-event"; - - private final HttpRequest httpRequest; - - public DataController(){ - httpRequest = new HttpRequest(); - } - - public void createEvent(Event event){ - try { - System.out.println(httpRequest.sendPostRequest(ADD_EVENT_ENDPOINT, event.getAsUrlParam())); - } catch (Exception e) { - e.printStackTrace(); - } - } - - public void deleteEvent(int eventId){ - try { - System.out.println(httpRequest.sendPostRequest(DELETE_EVENT_ENDPOINT, "eventId=" + eventId)); - } catch (Exception e) { - e.printStackTrace(); - } - } - - public ArrayList getAllVisibleEvents() { - ArrayList eventList = new ArrayList<>(); - - try { - String jsonResponse = httpRequest.sendPostRequest(ALL_EVENTS_ENDPOINT, "userId=1"); - System.out.println(jsonResponse); - - ObjectMapper objectMapper = new ObjectMapper(); - //String json = "{ \"color\" : \"Black\", \"type\" : \"BMW\" }"; - - for (Object obj : objectMapper.readValue(jsonResponse, Object[].class)){ - ArrayList list = new ArrayList<>(); - if (obj.getClass().isArray()) { - list = (ArrayList) Arrays.asList((Object[])obj); - } else if (obj instanceof Collection) { - list = new ArrayList<>((Collection) obj); - } - eventList.add(new Event(list)); - - } - } catch (Exception e) { - e.printStackTrace(); - } - - return eventList; - } - - public Event[] getAllEvents() { - Event[] eventList = null; - - try { - String jsonResponse = httpRequest.sendGetRequest("http://localhost:8080/vpr/all-events-test"); - eventList = parseJsonToEventList(jsonResponse); - for (Event e : eventList) { - System.out.println(e); - } - } catch (Exception e) { - e.printStackTrace(); - } - - return eventList; - } - - private Event[] parseJsonToEventList(String jsonString) throws JsonProcessingException { - ArrayList eventList; - - // Parse JSON - ObjectMapper objectMapper = new ObjectMapper(); - //String json = "{ \"color\" : \"Black\", \"type\" : \"BMW\" }"; - - return objectMapper.readValue(jsonString, Event[].class); - } -} diff --git a/client/data/src/main/java/res/HttpRequest.java b/client/data/src/main/java/res/HttpRequest.java deleted file mode 100644 index 183efb8..0000000 --- a/client/data/src/main/java/res/HttpRequest.java +++ /dev/null @@ -1,76 +0,0 @@ -package res; - -import java.io.BufferedReader; -import java.io.DataOutputStream; -import java.io.InputStreamReader; -import java.net.HttpURLConnection; -import java.net.URL; -import java.nio.charset.StandardCharsets; -import java.util.Arrays; - -public class HttpRequest { - public String sendPostRequest(String urlString, String urlParameters) throws Exception{ - byte[] postData = urlParameters.getBytes(StandardCharsets.UTF_8); - int postDataLength = postData.length; - - URL url = new URL(urlString); - HttpURLConnection con = (HttpURLConnection) url.openConnection(); - - con.setDoOutput(true); - con.setInstanceFollowRedirects(false); - con.setRequestMethod("POST"); - con.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); - con.setRequestProperty("charset", "utf-8"); - con.setRequestProperty("Content-Length", Integer.toString(postDataLength)); - con.setUseCaches(false); - try (DataOutputStream wr = new DataOutputStream(con.getOutputStream())) { - wr.write(postData); - } - - int status = con.getResponseCode(); - if (status == 200) { - BufferedReader in = new BufferedReader( - new InputStreamReader(con.getInputStream())); - String inputLine; - StringBuilder content = new StringBuilder(); - while ((inputLine = in.readLine()) != null) { - content.append(inputLine); - } - in.close(); - - con.disconnect(); - return content.toString(); - } else { - con.disconnect(); - throw new Exception("Status: " + status); - } - } - - public String sendGetRequest(String urlString) throws Exception{ - URL url = new URL(urlString); - HttpURLConnection con = (HttpURLConnection) url.openConnection(); - con.setRequestMethod("GET"); - - con.setConnectTimeout(5000); - con.setReadTimeout(5000); - - int status = con.getResponseCode(); - if (status == 200) { - BufferedReader in = new BufferedReader( - new InputStreamReader(con.getInputStream())); - String inputLine; - StringBuilder content = new StringBuilder(); - while ((inputLine = in.readLine()) != null) { - content.append(inputLine); - } - in.close(); - - con.disconnect(); - return content.toString(); - - } else { - con.disconnect(); - throw new Exception("Status: " + status); - } - } -}