Compare commits
No commits in common. "13bc9ae1dd9719f55e1eac91ea2c50ee1c97fcef" and "0fed0fb12be7986fecf08a55813cbb2fe307554f" have entirely different histories.
13bc9ae1dd
...
0fed0fb12b
1
.gitignore
vendored
1
.gitignore
vendored
@ -38,4 +38,3 @@ build/
|
||||
.DS_Store
|
||||
|
||||
/database.db
|
||||
/Rechnungen/**
|
5
pom.xml
5
pom.xml
@ -45,11 +45,6 @@
|
||||
<artifactId>sqlite-jdbc</artifactId>
|
||||
<version>3.40.0.0</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.controlsfx</groupId>
|
||||
<artifactId>controlsfx</artifactId>
|
||||
<version>11.1.2</version>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
|
12
readme.md
12
readme.md
@ -1,13 +1,3 @@
|
||||
# Essensbestellungsverwaltung
|
||||
|
||||
---
|
||||
|
||||
### Anleitung zum Benutzen
|
||||
Beim ersten Start des Programms wird die Datenbank erstellt und der erste Benutzer der angelegt wird, ist ein Mitarbeiter Account. Danach sind alle weiteren User für Eltern. Weitere Mitarbeiter können über das Mitarbeiter Menu erstellt werden.
|
||||
|
||||
##### Desweitern werden Folgende Beispiel Accounts erstellt:
|
||||
Ein Eltern Account mit Kindern:
|
||||
testparent@test.de/test
|
||||
|
||||
Ein Mitarbeiter Account:
|
||||
testworker@test.de/test
|
||||
test
|
||||
|
@ -13,7 +13,6 @@ import java.util.List;
|
||||
/**
|
||||
* A collection of functions loosely related to account management
|
||||
* Acts as an abstraction layer to the database
|
||||
*
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
public class AccountMgr {
|
||||
@ -22,7 +21,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* creates a user with createUser(...) and adds its id to the 'worker' table
|
||||
*
|
||||
* @param worker the worker to be created
|
||||
* @return userid or -1
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -36,7 +34,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* creates a user with createUser(...) and adds its id to the 'parent' table
|
||||
*
|
||||
* @param parent the parent to be created
|
||||
* @return userid or -1
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -50,7 +47,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* adds a user to the database
|
||||
*
|
||||
* @param user the user to be created
|
||||
* @return userid or -1
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -71,7 +67,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* adds an address to the database
|
||||
*
|
||||
* @param address the address to be created
|
||||
* @return id or -1
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -84,7 +79,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* adds a child and allergies to the database
|
||||
*
|
||||
* @param child the child to be created
|
||||
* @return id of child or -1
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -105,51 +99,7 @@ public class AccountMgr {
|
||||
}
|
||||
|
||||
/**
|
||||
* update Child
|
||||
*
|
||||
* @param child the child to be updated
|
||||
* @return id of child
|
||||
* @author Johannes Kantz
|
||||
*/
|
||||
protected static long updateChild(Child child) {
|
||||
String[] childH = { "id", "name", "firstname", "addressid" };
|
||||
String[] childD = { String.valueOf(child.getId()), child.getName(), child.getFirstname(),
|
||||
String.valueOf(child.getAddress().getId()) };
|
||||
long updates = Database.update("child", childH, childD);
|
||||
String[] child_allergyH = { "childid", "allergyid", "severityid" };
|
||||
Database.select("child_allergy", new String[] { "childid" }, new String[] { String.valueOf(child.getId()) })
|
||||
.stream().forEach(row -> {
|
||||
String allergyId = row.split(":")[0];
|
||||
Database.delete("child_allergy", Integer.parseInt(allergyId));
|
||||
});
|
||||
for (AllergySeverity allergy : child.getAllergies()) {
|
||||
String sId = String.valueOf(child.getId());
|
||||
String sAllergyId = String.valueOf(allergy.getAllergy().getId());
|
||||
String sSeverityId = String.valueOf(allergy.getSeverityId());
|
||||
String[] child_allergyD = { sId, sAllergyId, sSeverityId };
|
||||
Database.insert("child_allergy", child_allergyH, child_allergyD);
|
||||
}
|
||||
return updates;
|
||||
}
|
||||
|
||||
/**
|
||||
* delete Child
|
||||
*
|
||||
* @author Johannes Kantz
|
||||
*/
|
||||
protected static void deleteChildWithId(long id) {
|
||||
Database.delete("child", id);
|
||||
Database.select("child_allergy", new String[] { "childid" }, new String[] { String.valueOf(id) }).stream()
|
||||
.forEach(row -> {
|
||||
String allergyId = row.split(":")[0];
|
||||
Database.delete("child_allergy", Integer.parseInt(allergyId));
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* returns a User(Worker | Parent) for a given id or null if no unique id was
|
||||
* found
|
||||
*
|
||||
* returns a User(Worker | Parent) for a given id or null if no unique id was found
|
||||
* @param id id of the User
|
||||
* @return User(Worker | Parent) or null
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -178,7 +128,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* returns a Child for a given id or null if no unique id was found
|
||||
*
|
||||
* @param id id of child
|
||||
* @return Child or null
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -198,86 +147,13 @@ public class AccountMgr {
|
||||
List<String> severity = Database.getEntryById("severity", Long.parseLong(allergyParts[3]));
|
||||
String sSeverity = severity.get(0).split(":")[1];
|
||||
long lSeverity = Long.parseLong(severity.get(0).split(":")[0]);
|
||||
allergySeverities.add(
|
||||
new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyParts[2])), lSeverity, sSeverity));
|
||||
allergySeverities.add(new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyParts[2])),lSeverity,sSeverity));
|
||||
}
|
||||
return new Child(id,parts[1],parts[2],getAddressById(Long.parseLong(parts[3])),allergySeverities);
|
||||
}
|
||||
|
||||
/**
|
||||
* returns all Children
|
||||
*
|
||||
* @return {List<Child} List with Childen or empty List
|
||||
* @author Johannes Kantz
|
||||
*/
|
||||
protected static List<Child> getAllChildren() {
|
||||
List<String> entry = Database.getTable("child");
|
||||
if (entry.size() < 1) {
|
||||
return new ArrayList<>();
|
||||
}
|
||||
List<Child> children = new ArrayList<>();
|
||||
for (String s : entry) {
|
||||
String[] parts = s.split(":");
|
||||
String[] child_allergyH = { "childid" };
|
||||
String[] child_allergyD = { String.valueOf(parts[0]) };
|
||||
List<String> entriesAllergy = Database.select("child_allergy", child_allergyH, child_allergyD);
|
||||
List<AllergySeverity> allergySeverities = new ArrayList<>();
|
||||
for (String entryAllergy : entriesAllergy) {
|
||||
String[] allergyParts = entryAllergy.split(":");
|
||||
List<String> severity = Database.getEntryById("severity", Long.parseLong(allergyParts[3]));
|
||||
String sSeverity = severity.get(0).split(":")[1];
|
||||
long lSeverity = Long.parseLong(severity.get(0).split(":")[0]);
|
||||
allergySeverities.add(new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyParts[2])),
|
||||
lSeverity, sSeverity));
|
||||
}
|
||||
children.add(new Child(Long.parseLong(parts[0]), parts[1], parts[2],
|
||||
getAddressById(Long.parseLong(parts[3])), allergySeverities));
|
||||
}
|
||||
return children;
|
||||
}
|
||||
|
||||
/**
|
||||
* returns all Children from parent
|
||||
* @param id parentid
|
||||
* @return {List<Child} List with Childen or empty List
|
||||
* @author Johannes Kantz
|
||||
*/
|
||||
protected static List<Child> getAllChildrenFromParentWithId(long id) {
|
||||
List<String> entry = Database.select("parent_child", new String[] { "parentuserid" },
|
||||
new String[] { String.valueOf(id) });
|
||||
if (entry.size() < 1) {
|
||||
return new ArrayList<>();
|
||||
}
|
||||
List<String> childIds = new ArrayList<>();
|
||||
for (String s : entry) {
|
||||
String[] parts = s.split(":");
|
||||
childIds.add(parts[2]);
|
||||
}
|
||||
List<Child> children = new ArrayList<>();
|
||||
for (String s : childIds) {
|
||||
List<String> child = Database.getEntryById("child", Long.parseLong(s));
|
||||
String[] parts = child.get(0).split(":");
|
||||
String[] child_allergyH = { "childid" };
|
||||
String[] child_allergyD = { String.valueOf(parts[0]) };
|
||||
List<String> entriesAllergy = Database.select("child_allergy", child_allergyH, child_allergyD);
|
||||
List<AllergySeverity> allergySeverities = new ArrayList<>();
|
||||
for (String entryAllergy : entriesAllergy) {
|
||||
String[] allergyParts = entryAllergy.split(":");
|
||||
List<String> severity = Database.getEntryById("severity", Long.parseLong(allergyParts[3]));
|
||||
String sSeverity = severity.get(0).split(":")[1];
|
||||
long lSeverity = Long.parseLong(severity.get(0).split(":")[0]);
|
||||
allergySeverities.add(new AllergySeverity(FoodMgr.getAllergyById(Long.parseLong(allergyParts[2])),
|
||||
lSeverity, sSeverity));
|
||||
}
|
||||
children.add(new Child(Long.parseLong(parts[0]), parts[1], parts[2],
|
||||
getAddressById(Long.parseLong(parts[3])), allergySeverities));
|
||||
}
|
||||
return children;
|
||||
}
|
||||
|
||||
/**
|
||||
* returns an Address for a given id or null if no unique id was found
|
||||
*
|
||||
* @param id id of the address
|
||||
* @return Address or null
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -293,7 +169,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* creates entries in the database to match parent to child
|
||||
*
|
||||
* @param parentId id of parent
|
||||
* @param childId id of child
|
||||
* @return id of parent_child or -1
|
||||
@ -307,7 +182,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* a simple login to check if a given email matches a password
|
||||
*
|
||||
* @param email email
|
||||
* @param pw password
|
||||
* @return id or -1
|
||||
@ -333,7 +207,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* checks if id is in worker table
|
||||
*
|
||||
* @param id userid
|
||||
* @return true if id is in worker table
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -347,7 +220,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* checks if id is in parent table
|
||||
*
|
||||
* @param id userid
|
||||
* @return true if id is in parent table
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -361,7 +233,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* returns a hashed and salted password
|
||||
*
|
||||
* @param pw the password to hash
|
||||
* @return hashed and salted password
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -385,7 +256,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* generates a secure random salt, Base64 encoded
|
||||
*
|
||||
* @return String Base64 encoded
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
@ -399,7 +269,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* gives the invoice for one month and one child
|
||||
*
|
||||
* @param date YYYY-MM the month
|
||||
* @param childId id of child
|
||||
* @return the invoice as a List
|
||||
@ -437,7 +306,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* gets the price per meal from the database and converts it to double
|
||||
*
|
||||
* @return double price
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
@ -448,7 +316,6 @@ public class AccountMgr {
|
||||
|
||||
/**
|
||||
* converts the price per meal to integer and updates it in the database
|
||||
*
|
||||
* @param price double
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
|
@ -1,141 +0,0 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.collections.FXCollections;
|
||||
import javafx.collections.ObservableList;
|
||||
import javafx.event.ActionEvent;
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.scene.control.*;
|
||||
import org.controlsfx.control.CheckComboBox;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class ChildController {
|
||||
public TextField firstName;
|
||||
public ChoiceBox childChoiceBox;
|
||||
public TextField lastName;
|
||||
public Button kindHinzufügenButton;
|
||||
public CheckComboBox allergienComboBox;
|
||||
public Button kindLoeschenButton;
|
||||
|
||||
private Child currentChild = null;
|
||||
|
||||
private long selectedChildId;
|
||||
|
||||
@FXML
|
||||
public void initialize() {
|
||||
kindLoeschenButton.setDisable(true);
|
||||
updateChildChoiceBoxItems();
|
||||
|
||||
List<String> a = Database.getTable("allergy");
|
||||
ObservableList<String> allergies = FXCollections.observableArrayList();
|
||||
for (String allergie : a) {
|
||||
allergies.add(allergie.split(":")[0] + ": " + allergie.split(":")[1]);
|
||||
}
|
||||
allergienComboBox.getItems().addAll(allergies);
|
||||
}
|
||||
|
||||
public void onSelectChild(ActionEvent mouseEvent) {
|
||||
selectedChildId = Integer.parseInt(childChoiceBox.getValue().toString().split(":")[0]);
|
||||
System.out.println("Selected Child: " + selectedChildId);
|
||||
|
||||
clearInputs();
|
||||
|
||||
if(selectedChildId == 0) {
|
||||
kindHinzufügenButton.setText("Kind Hinzufügen");
|
||||
kindLoeschenButton.setDisable(true);
|
||||
return;
|
||||
}
|
||||
|
||||
// Get selected child and update fields
|
||||
currentChild = AccountMgr.getChildById(selectedChildId);
|
||||
firstName.setText(currentChild.getFirstname());
|
||||
lastName.setText(currentChild.getName());
|
||||
for (AllergySeverity a : currentChild.getAllergies()){
|
||||
allergienComboBox.getCheckModel().check((int) a.getAllergy().getId() - 1);
|
||||
}
|
||||
kindHinzufügenButton.setText("Kind updaten");
|
||||
kindLoeschenButton.setDisable(false);
|
||||
}
|
||||
|
||||
public void onKindHinzufügen(ActionEvent actionEvent) {
|
||||
if(childChoiceBox.getValue() == null){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Sie müssen ein Kind auswählen");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
|
||||
if(lastName.getText().isBlank() || firstName.getText().isBlank()){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Es wurden nicht alle Felder ausgefüllt");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
|
||||
Address adress = AccountMgr.currentUser.getAddress();
|
||||
List<AllergySeverity> allergies = new ArrayList<>();
|
||||
allergienComboBox.getCheckModel().getCheckedItems().stream().forEach(a -> {
|
||||
long id = Integer.parseInt(a.toString().split(":")[0]);
|
||||
String name = a.toString().split(":")[1].trim();
|
||||
// TODO: Allergy Severity
|
||||
allergies.add(new AllergySeverity(new Allergy(id, name, ""), 2, null));
|
||||
});
|
||||
|
||||
if(selectedChildId == 0){
|
||||
long id = AccountMgr.createChild(new Child(lastName.getText(), firstName.getText(), adress, allergies));
|
||||
System.out.println("Child created: " + id);
|
||||
|
||||
if(id <= 0){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Es ist ein fehler beim erstellen des Kinds aufgetreten");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
AccountMgr.matchParentChild(String.valueOf(AccountMgr.currentUser.getId()), String.valueOf(id));
|
||||
|
||||
childChoiceBox.getItems().add(id + ": " + firstName.getText() + " " + lastName.getText());
|
||||
childChoiceBox.setValue(childChoiceBox.getItems().get(childChoiceBox.getItems().size() - 1));
|
||||
clearInputs();
|
||||
onSelectChild(null);
|
||||
|
||||
Alert alert = new Alert(Alert.AlertType.CONFIRMATION);
|
||||
alert.setTitle("Kind erstellt");
|
||||
alert.setHeaderText("Es wurde ein Kind erstellt");
|
||||
alert.showAndWait();
|
||||
}else {
|
||||
long id = AccountMgr.updateChild(new Child(currentChild.getId(), lastName.getText(), firstName.getText(), adress, allergies));
|
||||
System.out.println("Updated Child: " + id);
|
||||
}
|
||||
}
|
||||
|
||||
private void clearInputs(){
|
||||
firstName.setText("");
|
||||
lastName.setText("");
|
||||
allergienComboBox.getCheckModel().clearChecks();
|
||||
}
|
||||
|
||||
public void updateChildChoiceBoxItems(){
|
||||
List<Child> childList = AccountMgr.getAllChildrenFromParentWithId(AccountMgr.currentUser.getId());
|
||||
|
||||
ObservableList<Object> childOptions = FXCollections.observableArrayList(childList.stream().map(c -> c.getId() + ": " + c.getFirstname() + " " + c.getName()).toList().toArray(new String[0]));
|
||||
childOptions.add(0, "0: neues Kind erstellen");
|
||||
childChoiceBox.setItems(childOptions);
|
||||
}
|
||||
|
||||
public void onKindLoeschen(ActionEvent actionEvent) {
|
||||
AccountMgr.deleteChildWithId(currentChild.getId());
|
||||
System.out.println("Deleted Child: " + currentChild.getId());
|
||||
|
||||
childChoiceBox.getItems().remove(childChoiceBox.getItems().stream().filter(v -> v.equals(currentChild.getId() + ": " + currentChild.getFirstname() + " " + currentChild.getName())).findFirst().get());
|
||||
childChoiceBox.setValue(childChoiceBox.getItems().get(1));
|
||||
|
||||
onSelectChild(null);
|
||||
|
||||
Alert alert = new Alert(Alert.AlertType.CONFIRMATION);
|
||||
alert.setTitle("Kind wurde gelöscht");
|
||||
alert.showAndWait();
|
||||
}
|
||||
}
|
@ -1,15 +1,11 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.collections.FXCollections;
|
||||
import javafx.collections.ObservableList;
|
||||
import javafx.event.ActionEvent;
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.scene.control.Alert;
|
||||
import javafx.scene.control.RadioButton;
|
||||
import javafx.scene.control.TextArea;
|
||||
import javafx.scene.control.TextField;
|
||||
import javafx.scene.text.Text;
|
||||
import org.controlsfx.control.CheckComboBox;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
@ -30,18 +26,9 @@ public class CreateFoodController {
|
||||
@FXML
|
||||
public RadioButton isFleischRadio;
|
||||
@FXML
|
||||
public Text responseText;
|
||||
public CheckComboBox allergienComboBox;
|
||||
|
||||
public TextArea allergienTextBox;
|
||||
@FXML
|
||||
public void initialize() {
|
||||
List<String> a = Database.getTable("allergy");
|
||||
ObservableList<String> allergies = FXCollections.observableArrayList();
|
||||
for (String allergie : a) {
|
||||
allergies.add(allergie.split(":")[0] + ": " + allergie.split(":")[1]);
|
||||
}
|
||||
allergienComboBox.getItems().addAll(allergies);
|
||||
}
|
||||
public Text responseText;
|
||||
|
||||
@FXML
|
||||
public void onAbbrechen(ActionEvent actionEvent) {
|
||||
@ -52,60 +39,19 @@ public class CreateFoodController {
|
||||
public void onHinzufuegen(ActionEvent actionEvent) {
|
||||
String gerichtName = name.getText();
|
||||
String beschreibung = description.getText();
|
||||
|
||||
if(gerichtName.isBlank()){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Es wurden nicht alle Felder ausgefüllt");
|
||||
alert.setContentText("Das Feld 'Name' ist nicht ausgefüllt");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
if(beschreibung.isBlank()){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Es wurden nicht alle Felder ausgefüllt");
|
||||
alert.setContentText("Das Feld 'Beschreibung' ist nicht ausgefüllt");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
|
||||
if(!isHauptgerichtRadio.isSelected() && !isDessertRadio.isSelected()){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Es wurden nicht alle Felder ausgefüllt");
|
||||
alert.setContentText("Das Feld 'Art' ist nicht ausgefüllt");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
// art auswähelen
|
||||
}
|
||||
boolean isNachtisch = !isHauptgerichtRadio.isSelected();
|
||||
if(!isVegetarischRadio.isSelected() && !isVeganRadio.isSelected() && !isFleischRadio.isSelected()){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Ungültige Eingabe");
|
||||
alert.setHeaderText("Es wurden nicht alle Felder ausgefüllt");
|
||||
alert.setContentText("Das Feld 'Typ' ist nicht ausgefüllt");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
if(!isVegetarischRadio.isSelected() && !isVeganRadio.isSelected() && isFleischRadio.isSelected()){
|
||||
// Typ auswählen
|
||||
}
|
||||
int ft = isVeganRadio.isSelected() ? 1 : isVeganRadio.isSelected() ? 2 : 3;
|
||||
FoodType foodType = new FoodType(ft, "Vegan");
|
||||
List<Allergy> allergies = new ArrayList<>();
|
||||
allergienComboBox.getCheckModel().getCheckedItems().stream().forEach(a -> {
|
||||
long id = Integer.parseInt(a.toString().split(":")[0]);
|
||||
String name = a.toString().split(":")[1].trim();
|
||||
allergies.add((new Allergy(id, name, "")));
|
||||
});
|
||||
System.out.println(allergies.get(0).getName());
|
||||
// TODO: allergien hinzufügen
|
||||
|
||||
long id = FoodMgr.createFood(new Food(gerichtName, beschreibung, isNachtisch, foodType, allergies));
|
||||
if(id <= 0){
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Es ist ein Problem beim Erstellen des Gerichts aufgetreten");
|
||||
alert.setHeaderText("Bitte überprüfen Sie ihre Eingabe");
|
||||
alert.setContentText("Es besteht die Möglichkeit, dass dieses Gericht bereits existiert");
|
||||
alert.showAndWait();
|
||||
return;
|
||||
}
|
||||
System.out.println("Food created with id: " + id);
|
||||
responseText.setText("New Food Created");
|
||||
clearInputs();
|
||||
@ -119,6 +65,6 @@ public class CreateFoodController {
|
||||
isVeganRadio.setSelected(false);
|
||||
isVegetarischRadio.setSelected(false);
|
||||
isFleischRadio.setSelected(false);
|
||||
allergienComboBox.getCheckModel().clearChecks();
|
||||
allergienTextBox.setText("");
|
||||
}
|
||||
}
|
||||
|
@ -31,28 +31,20 @@ public class CreateFoodplanController {
|
||||
ChoiceBox secondDessert;
|
||||
|
||||
private List<Food> foods;
|
||||
private List<Food> veganFoods;
|
||||
private List<Food> desserts;
|
||||
private List<Food> veganDesserts;
|
||||
private FoodPlan currentPlan;
|
||||
|
||||
|
||||
@FXML
|
||||
public void initialize() {
|
||||
veganFoods = FoodMgr.getVeganFood(false);
|
||||
foods = FoodMgr.getFood(false);
|
||||
veganDesserts = FoodMgr.getVeganFood(true);
|
||||
desserts = FoodMgr.getFood(true);
|
||||
|
||||
ObservableList<Object> foodOptions = FXCollections.observableArrayList(foods.stream().map(food -> food.getId() + ": " + food.getName()).toList().toArray(new String[0]));
|
||||
ObservableList<Object> veganFoodOptions = FXCollections.observableArrayList(veganFoods.stream().map(food -> food.getId() + ": " + food.getName()).toList().toArray(new String[0]));
|
||||
ObservableList<Object> veganDessertOptions = FXCollections.observableArrayList(veganDesserts.stream().map(dessert -> dessert.getId() + ": " + dessert.getName()).toList().toArray(new String[0]));
|
||||
ObservableList<Object> dessertOptions = FXCollections.observableArrayList(desserts.stream().map(dessert -> dessert.getId() + ": " + dessert.getName()).toList().toArray(new String[0]));
|
||||
firstMeal.setItems(veganFoodOptions);
|
||||
firstMeal.setItems(foodOptions);
|
||||
secondMeal.setItems(foodOptions);
|
||||
|
||||
|
||||
firstDessert.setItems(veganDessertOptions);
|
||||
ObservableList<Object> dessertOptions = FXCollections.observableArrayList(desserts.stream().map(dessert -> dessert.getId() + ": " + dessert.getName()).toList().toArray(new String[0]));
|
||||
firstDessert.setItems(dessertOptions);
|
||||
secondDessert.setItems(dessertOptions);
|
||||
|
||||
date.setValue(LocalDate.now());
|
||||
|
@ -1,76 +0,0 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.event.ActionEvent;
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.scene.control.Button;
|
||||
import javafx.scene.control.DatePicker;
|
||||
import javafx.scene.control.ListView;
|
||||
|
||||
import java.time.LocalDate;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Calendar;
|
||||
import java.util.List;
|
||||
|
||||
public class DailyOrderController {
|
||||
public ListView listView;
|
||||
public DatePicker datePicker;
|
||||
public Button sendButton;
|
||||
|
||||
|
||||
@FXML
|
||||
public void initialize() {
|
||||
datePicker.setValue(LocalDate.now());
|
||||
updatePlan(datePicker.getValue().toString());
|
||||
}
|
||||
|
||||
public void onChangeDate(ActionEvent actionEvent) {
|
||||
updatePlan(datePicker.getValue().toString());
|
||||
}
|
||||
|
||||
|
||||
private void updatePlan(String date){
|
||||
listView.getItems().clear();
|
||||
System.out.print("Orders from " + date + " : ");
|
||||
List<String> orders = new ArrayList<>();
|
||||
FoodPlan food_plan = FoodMgr.getFoodPlan(date);
|
||||
if(food_plan == null){
|
||||
sendButton.setVisible(false);
|
||||
return;
|
||||
}
|
||||
sendButton.setVisible(true);
|
||||
if(food_plan.isSent()){
|
||||
sendButton.setDisable(true);
|
||||
sendButton.setText("Bestellung wurde Gesendet");
|
||||
}else {
|
||||
sendButton.setDisable(false);
|
||||
sendButton.setText("Bestellung senden");
|
||||
}
|
||||
String sId = String.valueOf(food_plan.getId());
|
||||
String[] food_selectionH = {"food_planid","foodid"};
|
||||
Food[] foodArray = {
|
||||
food_plan.getFoodVegan(),
|
||||
food_plan.getFoodSecond(),
|
||||
food_plan.getDessertVegan(),
|
||||
food_plan.getDessertSecond()
|
||||
};
|
||||
for(int i = 0; i < 4; i++){
|
||||
String foodName = foodArray[i].getName();
|
||||
String[] food_selectionD = {sId, String.valueOf(foodArray[i].getId())};
|
||||
int count = Database.count("food_selection",food_selectionH,food_selectionD);
|
||||
orders.add(count+" X "+foodName);
|
||||
}
|
||||
|
||||
System.out.println(orders);
|
||||
|
||||
|
||||
for(String order : orders){
|
||||
listView.getItems().add(order);
|
||||
}
|
||||
}
|
||||
|
||||
public void onSendButton(ActionEvent actionEvent) {
|
||||
FoodMgr.getDayOrder(datePicker.getValue().toString());
|
||||
sendButton.setDisable(true);
|
||||
sendButton.setText("Bestellung wurde Gesendet");
|
||||
}
|
||||
}
|
@ -9,10 +9,8 @@ import java.util.List;
|
||||
|
||||
/**
|
||||
* Basic operations on the database
|
||||
* Use init() -> createDb() -> fillDb() to create the skeleton with some default
|
||||
* values
|
||||
* Use init() -> createDb() -> fillDb() to create the skeleton with some default values
|
||||
* Provides select, insert, update, delete, count operations and more
|
||||
*
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
public class Database {
|
||||
@ -20,7 +18,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* creates new database.db if it doesn't exist
|
||||
*
|
||||
* @return true if a new database has been created
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
@ -35,7 +32,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* connects to the database
|
||||
*
|
||||
* @return Connection to the database
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
@ -51,7 +47,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* creates the initial structure of the db
|
||||
*
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
protected static void createDb(){
|
||||
@ -183,12 +178,10 @@ public class Database {
|
||||
|
||||
/**
|
||||
* inserts fixed values into the database
|
||||
*
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
protected static void fillDb(){
|
||||
List<String> sqls = new ArrayList<>();
|
||||
// food_type
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_type (id,name)
|
||||
VALUES ('1','Vegan');""");
|
||||
@ -198,7 +191,6 @@ public class Database {
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_type (id,name)
|
||||
VALUES ('3','Fleischhaltig');""");
|
||||
// allergy
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO allergy (id,name,handle)
|
||||
VALUES('1','Eier','a');""");
|
||||
@ -265,7 +257,6 @@ public class Database {
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO allergy (id,name,handle)
|
||||
VALUES('22','Konservierungsstoff','8');""");
|
||||
// severity
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO severity (id,name)
|
||||
VALUES('1','Harmlos');""");
|
||||
@ -278,150 +269,6 @@ public class Database {
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO price (id,price)
|
||||
VALUES('1','500');""");
|
||||
// user
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO address (id,street,number,plz,city)
|
||||
VALUES('1','teststreet','69','1337','Mond');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO user (id,name,firstname,addressid,password,email)
|
||||
VALUES('1','testparent','testparent','1','YOD+TB0twF2SrueBj26t5OjEJK/Al4G6/hq+IMRyBz4=.f4zL2UJW4POrf/xgJdNaiw==','testparent@test.de');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO parent (userid)
|
||||
VALUES('1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO user (id,name,firstname,addressid,password,email)
|
||||
VALUES('2','testworker','testworker','1','YOD+TB0twF2SrueBj26t5OjEJK/Al4G6/hq+IMRyBz4=.f4zL2UJW4POrf/xgJdNaiw==','testworker@test.de');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO worker (userid)
|
||||
VALUES('2');""");
|
||||
// food
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('1','Steak','69','0','3');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('2','Schnitzel','69','0','3');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('3','Hamburger','69','0','3');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('4','Nudeln','69','0','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('5','Salat','69','0','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('6','Pudding','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('7','Eis','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('8','Wackelpudding','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('9','Kuchen','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('10','Apfel','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('11','Banane','69','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('12','Nudelauflauf','69','0','3');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('13','Reibekuchen','69','0','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('14','Gefüllte Paprika','69','0','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('15','Suishi','69','0','2');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food (id,name,description,isdessert,food_typeid)
|
||||
VALUES('16','Champignons','69','0','2');""");
|
||||
// child
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO child (id,name,firstname,addressid)
|
||||
VALUES('1','Lustig','Peter','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO child (id,name,firstname,addressid)
|
||||
VALUES('2','Wahnsinn','Rainer','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO parent_child ('id',parentuserid,childid)
|
||||
VALUES('1','1','1');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO parent_child ('id',parentuserid,childid)
|
||||
VALUES('2','1','2');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO child_allergy (childid,allergyid,severityid)
|
||||
VALUES('1','1','2');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO child_allergy (childid,allergyid,severityid)
|
||||
VALUES('1','3','2');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO child_allergy (childid,allergyid,severityid)
|
||||
VALUES('1','4','2');""");
|
||||
// foodplan
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('1','2023-02-06','4','1','8','7');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('2','2023-02-07','5','2','6','7');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('3','2023-02-08','4','3','8','6');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('4','2023-02-09','16','1','11','10');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('5','2023-02-09','14','13','7','9');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_plan ('id',date,food1,food2,dessert1,dessert2)
|
||||
VALUES('6','2023-02-10','13','15','8','6');""");
|
||||
// food_selection
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('1','1','1','4');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('2','1','1','8');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('3','2','1','4');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('4','2','1','8');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('5','1','2','5');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('6','1','2','7');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('7','2','2','5');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('8','2','2','7');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('9','1','3','4');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('10','1','3','8');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('11','2','3','4');""");
|
||||
sqls.add("""
|
||||
INSERT OR IGNORE INTO food_selection ('id',childid,food_planid,foodid)
|
||||
VALUES('12','2','3','6');""");
|
||||
|
||||
try(Connection conn = connect(); Statement stmt = conn.createStatement()){
|
||||
for (String sql : sqls) {
|
||||
stmt.execute(sql);
|
||||
@ -434,7 +281,6 @@ public class Database {
|
||||
/**
|
||||
* inserts data into table and returns its id
|
||||
* simple duplication check
|
||||
*
|
||||
* @param table name of the database table
|
||||
* @param header String[] order should match with values
|
||||
* @param values String[] order should match with header
|
||||
@ -477,7 +323,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* returns a single id that matches the given data
|
||||
*
|
||||
* @param table the table that contains the searched entry
|
||||
* @param header the header of the table, order should match with values
|
||||
* @param values the data you want the id of, order should match witch values
|
||||
@ -533,7 +378,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* deletes an entry from table with matching id
|
||||
*
|
||||
* @param table the table that contains the entry you want to delete
|
||||
* @param id the id of the entry you want to delete
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -554,10 +398,8 @@ public class Database {
|
||||
* selectMatch: returns all matching rows from table
|
||||
* insert: inserts or ignores into table
|
||||
* count: counts exact matches from table
|
||||
* update: updates table, header/values[0] is used as WHERE, using id is
|
||||
* recommended header/values[1+] are used
|
||||
* update: updates table, header/values[0] is used as WHERE, using id is recommended header/values[1+] are used
|
||||
* as SET
|
||||
*
|
||||
* @param type exists, selectMatch, insert, count, update
|
||||
* @param table table
|
||||
* @param header header
|
||||
@ -640,12 +482,12 @@ public class Database {
|
||||
sb.append(" SET ");
|
||||
sb.append(header[1]);
|
||||
sb.append(" = ");
|
||||
sb.append("'" + values[1] + "'");
|
||||
sb.append(values[1]);
|
||||
for(int i = 2; i < header.length; i++){
|
||||
sb.append(", ");
|
||||
sb.append(header[i]);
|
||||
sb.append(" = ");
|
||||
sb.append("'" + values[i] + "'");
|
||||
sb.append(values[i]);
|
||||
}
|
||||
sb.append(" WHERE ");
|
||||
sb.append(header[0]);
|
||||
@ -659,7 +501,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* returns a list of all entries
|
||||
*
|
||||
* @param table the table you want
|
||||
* @return a list of all entries as String with the fields separated by ":"
|
||||
* @author Malte Schulze Hobeling
|
||||
@ -689,9 +530,7 @@ public class Database {
|
||||
}
|
||||
|
||||
/**
|
||||
* issues a select query on the database for the given table and the given
|
||||
* values checked with LIKE
|
||||
*
|
||||
* issues a select query on the database for the given table and the given values checked with LIKE
|
||||
* @param table the table you want the data from
|
||||
* @param header header for the WHERE portion, order should match with values
|
||||
* @param values values for the WHERE portion, order should match with header
|
||||
@ -725,7 +564,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* returns the entry from table with the given id
|
||||
*
|
||||
* @param table the table you want the entry from
|
||||
* @param id the id of the entry you want
|
||||
* @return a list of String separated by ":"
|
||||
@ -759,7 +597,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* counts the number of matching entries
|
||||
*
|
||||
* @param table the table you want to count
|
||||
* @param header the properties you want to count on
|
||||
* @param values the values for the properties
|
||||
@ -779,7 +616,6 @@ public class Database {
|
||||
|
||||
/**
|
||||
* updates an entry in the database
|
||||
*
|
||||
* @param table the table you want to update
|
||||
* @param header [0] is used as WHERE, everything else in SET
|
||||
* @param values [0] is used as WHERE, everything else in SET
|
||||
|
@ -235,9 +235,6 @@ public class FoodMgr {
|
||||
public static List<String> getDayOrder(String date){
|
||||
List<String> orders = new ArrayList<>();
|
||||
FoodPlan food_plan = getFoodPlan(date);
|
||||
if(food_plan == null){
|
||||
return orders;
|
||||
}
|
||||
String sId = String.valueOf(food_plan.getId());
|
||||
String[] food_selectionH = {"food_planid","foodid"};
|
||||
Food[] foodArray = {
|
||||
|
@ -1,20 +1,12 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.collections.FXCollections;
|
||||
import javafx.collections.ObservableList;
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.scene.control.Alert;
|
||||
import javafx.scene.control.ChoiceBox;
|
||||
import javafx.scene.control.Spinner;
|
||||
import javafx.scene.input.MouseEvent;
|
||||
import javafx.scene.text.Text;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
import java.util.Calendar;
|
||||
import java.util.List;
|
||||
|
||||
public class InvoiceController {
|
||||
@FXML
|
||||
@ -22,9 +14,6 @@ public class InvoiceController {
|
||||
@FXML
|
||||
ChoiceBox monatChoiceBox;
|
||||
|
||||
@FXML
|
||||
ChoiceBox childChoiceBox;
|
||||
|
||||
@FXML
|
||||
Spinner jahrSpinner;
|
||||
|
||||
@ -32,35 +21,12 @@ public class InvoiceController {
|
||||
public void initialize() {
|
||||
monatChoiceBox.setValue(intToMonth(Calendar.getInstance().get(Calendar.MONTH) + 1));
|
||||
jahrSpinner.getValueFactory().setValue(Calendar.getInstance().get(Calendar.YEAR));
|
||||
|
||||
List<Child> childList = AccountMgr.getAllChildren();
|
||||
ObservableList<Object> childOptions = FXCollections.observableArrayList(childList.stream()
|
||||
.map(c -> c.getId() + ": " + c.getFirstname() + " " + c.getName()).toList().toArray(new String[0]));
|
||||
childChoiceBox.setItems(childOptions);
|
||||
}
|
||||
|
||||
@FXML
|
||||
void onRechnungErstellenClick(MouseEvent mouseEvent) {
|
||||
if (childChoiceBox.getValue() == null) {
|
||||
Alert alert = new Alert(Alert.AlertType.ERROR);
|
||||
alert.setTitle("Es wurde kein Kind ausgewählt");
|
||||
alert.setHeaderText("Bitte wählen sie ein Kind aus");
|
||||
alert.showAndWait();
|
||||
}
|
||||
|
||||
String childId = childChoiceBox.getValue().toString().split(":")[0];
|
||||
String date = String.format("%d-%02d", Integer.parseInt(jahrSpinner.getValue().toString()),
|
||||
monthToInt(monatChoiceBox.getValue().toString()));
|
||||
|
||||
System.out.println("Invoice (" + date + ") from child: " + childId);
|
||||
|
||||
List<String> invoice = AccountMgr.getInvoice(date, childId);
|
||||
|
||||
responseText.setText(invoice.get(invoice.size() - 1));
|
||||
|
||||
// TODO: show invoice
|
||||
Child child = AccountMgr.getChildById(Long.parseLong(childId));
|
||||
exportInvoice("Rechnung_" + date + "_" + childId + "_" + child.getName() +"_" + child.getFirstname(), invoice);
|
||||
responseText.setText(monatChoiceBox.getValue().toString() + jahrSpinner.getValue());
|
||||
// hier rechnung erstellen
|
||||
}
|
||||
|
||||
private int monthToInt(String month) {
|
||||
@ -98,21 +64,4 @@ public class InvoiceController {
|
||||
default -> "";
|
||||
};
|
||||
}
|
||||
|
||||
private void exportInvoice(String filename, List<String> invoice) {
|
||||
try {
|
||||
Files.createDirectories(Path.of(Path.of("").toAbsolutePath() + "/Rechnungen"));
|
||||
|
||||
// TODO: save invoice to pdf or word
|
||||
File file = new File(Path.of("").toAbsolutePath() + "/Rechnungen/" + filename + ".txt");
|
||||
if (file.createNewFile()) {
|
||||
System.out.println("File created: " + file.getName());
|
||||
} else {
|
||||
System.out.println("File already exists.");
|
||||
}
|
||||
Files.write(Path.of(file.getAbsolutePath()), invoice);
|
||||
} catch (IOException e) {
|
||||
throw new RuntimeException(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,37 +0,0 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.scene.control.ListView;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
public class OrderHistoryController {
|
||||
public ListView listView;
|
||||
|
||||
@FXML
|
||||
public void initialize() {
|
||||
List<Child> children = AccountMgr.getAllChildrenFromParentWithId(AccountMgr.currentUser.getId());
|
||||
|
||||
List<String> orders = new ArrayList<>();
|
||||
|
||||
for (Child child : children) {
|
||||
List<String> selections = Database.select("food_selection", new String[] { "childid" }, new String[] { String.valueOf(child.getId()) });
|
||||
for (String selection : selections) {
|
||||
String[] selectionParts = selection.split(":");
|
||||
String foodplanid = selectionParts[2];
|
||||
String foodid = selectionParts[3];
|
||||
String foodName = FoodMgr.getFoodById(Long.parseLong(foodid)).getName();
|
||||
String date = FoodMgr.getFoodPlanById(Long.parseLong(foodplanid)).getDate();
|
||||
orders.add(String.format("%s\t %s \t %s", date, child.getFirstname(), foodName));
|
||||
}
|
||||
}
|
||||
|
||||
Collections.sort(orders);
|
||||
Collections.reverse(orders);
|
||||
for(String order : orders){
|
||||
listView.getItems().add(order);
|
||||
}
|
||||
}
|
||||
}
|
@ -4,30 +4,21 @@ import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* one constructor is used to create new parents the other is used to create
|
||||
* existing parents from database
|
||||
*
|
||||
* one constructor is used to create new parents the other is used to create existing parents from database
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
public class Parent extends User{
|
||||
List<Child> children;
|
||||
|
||||
public Parent(long id, String name, String firstname, String password, String email, Address address,
|
||||
List<Child> children) {
|
||||
public Parent(long id, String name, String firstname, String password, String email, Address address, List<Child> children) {
|
||||
super(id, name, firstname, password, email, address);
|
||||
this.children = children;
|
||||
}
|
||||
|
||||
public Parent(String name, String firstname, String password, String email, Address address) {
|
||||
super(name, firstname, password, email, address);
|
||||
this.children = new ArrayList<>();
|
||||
}
|
||||
|
||||
public Parent(User user) {
|
||||
super(user.getId(), user.getName(), user.getFirstname(), user.getPassword(), user.getEmail(), user.getAddress());
|
||||
this.children = new ArrayList<>();
|
||||
}
|
||||
|
||||
public List<Child> getChildren() {
|
||||
return children;
|
||||
}
|
||||
|
@ -44,7 +44,7 @@ public class ParentMenuController {
|
||||
@FXML
|
||||
public void onBestellungClick(MouseEvent mouseEvent) {
|
||||
setButtonActive(bestellungButton);
|
||||
changePage("orderHistory-view.fxml");
|
||||
changePage("dailyOrder-view.fxml");
|
||||
}
|
||||
|
||||
@FXML
|
||||
@ -55,8 +55,7 @@ public class ParentMenuController {
|
||||
|
||||
@FXML
|
||||
public void onAusloggenClick(MouseEvent mouseEvent) throws IOException {
|
||||
AccountMgr.currentUser = null;
|
||||
StartViewApplication.changeScene("login-view.fxml");
|
||||
StartViewApplication.changeScene("workerMenu-view.fxml");
|
||||
}
|
||||
|
||||
private void changePage(String page) {
|
||||
|
@ -4,11 +4,14 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
import javafx.fxml.FXML;
|
||||
import javafx.fxml.FXMLLoader;
|
||||
import javafx.scene.Scene;
|
||||
import javafx.scene.control.Alert;
|
||||
import javafx.scene.control.PasswordField;
|
||||
import javafx.scene.control.TextField;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.HashMap;
|
||||
|
||||
public class SingUpController {
|
||||
@FXML
|
||||
@ -71,24 +74,9 @@ public class SingUpController {
|
||||
}else {
|
||||
Address newAdresse = new Address(strasse,hausnummer,plz,stadt);
|
||||
User newUser = new User(name,vorname,passwort,email,newAdresse);
|
||||
if(StartViewApplication.firstLaunch){
|
||||
long id = AccountMgr.createWorker(new Worker(newUser));
|
||||
if(id < 1) {
|
||||
Alert a = new Alert(Alert.AlertType.ERROR,"Es ist ein Fehler bei der Erstellung Ihres Accounts aufgetreten.");
|
||||
a.showAndWait();
|
||||
return;
|
||||
}
|
||||
alert = new Alert(Alert.AlertType.CONFIRMATION,"Mitarbeiter Account erfolgreich erstellt");
|
||||
alert.showAndWait();
|
||||
StartViewApplication.firstLaunch = false;
|
||||
}else {
|
||||
long id = AccountMgr.createParent(new Parent(newUser));
|
||||
if(id < 1) {
|
||||
Alert a = new Alert(Alert.AlertType.ERROR,"Es ist ein Fehler bei der Erstellung Ihres Accounts aufgetreten.");
|
||||
a.showAndWait();
|
||||
return;
|
||||
}
|
||||
alert = new Alert(Alert.AlertType.CONFIRMATION,"Eltern Account erfolgreich erstellt");
|
||||
long creatNewUser = AccountMgr.createUser(newUser);
|
||||
if (creatNewUser > 0){
|
||||
alert = new Alert(Alert.AlertType.CONFIRMATION,"Ihrer Daten wurde gespeichert.");
|
||||
alert.showAndWait();
|
||||
}
|
||||
tfName.setText("");
|
||||
@ -105,6 +93,8 @@ public class SingUpController {
|
||||
|
||||
@FXML
|
||||
private void onAnmeldenBtClick() throws IOException {
|
||||
StartViewApplication.changeScene("login-view.fxml");
|
||||
FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("login-view.fxml"));
|
||||
Scene scene = new Scene(fxmlLoader.load(), 950,480);
|
||||
StartViewApplication.primary.setScene(scene);
|
||||
}
|
||||
}
|
||||
|
@ -15,11 +15,10 @@ import java.io.IOException;
|
||||
|
||||
public class StartViewApplication extends Application {
|
||||
public static Stage primary;
|
||||
public static boolean firstLaunch;
|
||||
|
||||
@Override
|
||||
public void start(Stage stage) throws IOException {
|
||||
FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource((firstLaunch) ? "signUp-view.fxml" : "login-view.fxml"));
|
||||
FXMLLoader fxmlLoader = new FXMLLoader(StartViewApplication.class.getResource("login-view.fxml"));
|
||||
Scene scene = new Scene(fxmlLoader.load(), 1300, 750);
|
||||
primary = stage;
|
||||
stage.setTitle("Essen Bestellung im Kindergarten");
|
||||
@ -30,7 +29,7 @@ public class StartViewApplication extends Application {
|
||||
}
|
||||
|
||||
public static void main(String[] args) {
|
||||
firstLaunch = Database.init();
|
||||
Database.init();
|
||||
Database.createDb();
|
||||
Database.fillDb();
|
||||
//Database.printSampleQuery();
|
||||
|
@ -1,21 +1,14 @@
|
||||
package com.bib.essensbestellungsverwaltung;
|
||||
|
||||
/**
|
||||
* one constructor is used to create new worker the other is used to create
|
||||
* existing worker from database
|
||||
*
|
||||
* one constructor is used to create new worker the other is used to create existing worker from database
|
||||
* @author Malte Schulze Hobeling
|
||||
*/
|
||||
public class Worker extends User{
|
||||
public Worker(long id, String name, String firstname, String password, String email, Address address) {
|
||||
super(id, name, firstname, password, email, address);
|
||||
}
|
||||
|
||||
public Worker(String name, String firstname, String password, String email, Address address) {
|
||||
super(name, firstname, password, email, address);
|
||||
}
|
||||
|
||||
public Worker(User user) {
|
||||
super(user.getId(), user.getName(), user.getFirstname(), user.getPassword(), user.getEmail(), user.getAddress());
|
||||
}
|
||||
}
|
||||
|
@ -12,6 +12,7 @@ import java.io.IOException;
|
||||
public class WorkerMenuController {
|
||||
@FXML
|
||||
public BorderPane contentView;
|
||||
|
||||
@FXML
|
||||
Button tagesbestellungButton;
|
||||
@FXML
|
||||
@ -27,13 +28,13 @@ public class WorkerMenuController {
|
||||
|
||||
@FXML
|
||||
public void initialize() {
|
||||
changePage("dailyOrder-view.fxml");
|
||||
changePage("menue-view.fxml");
|
||||
setButtonActive(tagesbestellungButton);
|
||||
}
|
||||
|
||||
@FXML
|
||||
public void onTagesbestellungenClick(MouseEvent mouseEvent) {
|
||||
changePage("dailyOrder-view.fxml");
|
||||
changePage("menue-view.fxml");
|
||||
setButtonActive(tagesbestellungButton);
|
||||
}
|
||||
|
||||
@ -70,8 +71,7 @@ public class WorkerMenuController {
|
||||
|
||||
@FXML
|
||||
public void onAusloggenClick(MouseEvent mouseEvent) throws IOException {
|
||||
AccountMgr.currentUser = null;
|
||||
StartViewApplication.changeScene("login-view.fxml");
|
||||
StartViewApplication.changeScene("parentMenu-view.fxml");
|
||||
}
|
||||
|
||||
private void changePage(String page) {
|
||||
|
@ -3,7 +3,6 @@ module com.bib.essensbestellungsverwaltung {
|
||||
requires javafx.fxml;
|
||||
requires java.sql;
|
||||
requires org.xerial.sqlitejdbc;
|
||||
requires org.controlsfx.controls;
|
||||
|
||||
|
||||
opens com.bib.essensbestellungsverwaltung to javafx.fxml;
|
||||
|
@ -1,32 +1,48 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<?import javafx.geometry.*?>
|
||||
<?import javafx.scene.control.*?>
|
||||
<?import javafx.scene.layout.*?>
|
||||
<?import javafx.scene.text.*?>
|
||||
<?import org.controlsfx.control.*?>
|
||||
<?import javafx.geometry.Insets?>
|
||||
<?import javafx.scene.control.Button?>
|
||||
<?import javafx.scene.control.ComboBox?>
|
||||
<?import javafx.scene.control.DatePicker?>
|
||||
<?import javafx.scene.control.ListView?>
|
||||
<?import javafx.scene.control.TextField?>
|
||||
<?import javafx.scene.layout.AnchorPane?>
|
||||
<?import javafx.scene.layout.HBox?>
|
||||
<?import javafx.scene.layout.VBox?>
|
||||
<?import javafx.scene.text.Font?>
|
||||
<?import javafx.scene.text.Text?>
|
||||
|
||||
<AnchorPane prefHeight="700.0" prefWidth="950.0" stylesheets="@child.css" xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.ChildController">
|
||||
<AnchorPane prefHeight="700.0" prefWidth="950.0" stylesheets="@child.css" xmlns="http://javafx.com/javafx/19" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.ParentController">
|
||||
<children>
|
||||
<Text layoutX="51.0" layoutY="90.0" strokeType="OUTSIDE" strokeWidth="0.0" text="Kinder">
|
||||
<font>
|
||||
<Font size="58.0" />
|
||||
</font>
|
||||
</Text>
|
||||
<HBox id="contentContainer" alignment="CENTER" layoutX="8.0" layoutY="165.0" prefHeight="127.0" prefWidth="937.0">
|
||||
<HBox id="contentContainer" alignment="CENTER" layoutX="8.0" layoutY="165.0" prefHeight="331.0" prefWidth="937.0">
|
||||
<children>
|
||||
<VBox id="contentContainer" prefHeight="250.0" prefWidth="256.0">
|
||||
<children>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Vorname">
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Name">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<TextField fx:id="firstName" prefWidth="97.0">
|
||||
<TextField prefWidth="97.0">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</TextField>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Geburtsdatum">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<DatePicker prefHeight="26.0" prefWidth="226.0">
|
||||
<VBox.margin>
|
||||
<Insets top="13.0" />
|
||||
</VBox.margin>
|
||||
</DatePicker>
|
||||
</children>
|
||||
<HBox.margin>
|
||||
<Insets left="15.0" right="15.0" />
|
||||
@ -34,16 +50,44 @@
|
||||
</VBox>
|
||||
<VBox id="contentContainer" prefHeight="250.0" prefWidth="256.0">
|
||||
<children>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Nachname">
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Alter">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<TextField fx:id="lastName" prefWidth="97.0">
|
||||
<TextField prefWidth="97.0">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</TextField>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Gruppe">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<ComboBox prefHeight="26.0" prefWidth="230.0">
|
||||
<VBox.margin>
|
||||
<Insets top="13.0" />
|
||||
</VBox.margin>
|
||||
</ComboBox>
|
||||
</children>
|
||||
<HBox.margin>
|
||||
<Insets left="15.0" right="15.0" />
|
||||
</HBox.margin>
|
||||
</VBox>
|
||||
<VBox id="contentContainer" prefHeight="250.0" prefWidth="256.0">
|
||||
<children>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Allergien">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<ListView prefHeight="101.0" prefWidth="227.0" />
|
||||
<TextField id="tfAddAllergy" promptText="Allergie hinzufügen">
|
||||
<VBox.margin>
|
||||
<Insets top="15.0" />
|
||||
</VBox.margin>
|
||||
</TextField>
|
||||
</children>
|
||||
<HBox.margin>
|
||||
<Insets left="15.0" right="15.0" />
|
||||
@ -51,19 +95,6 @@
|
||||
</VBox>
|
||||
</children>
|
||||
</HBox>
|
||||
<Button id="btAddChild" fx:id="kindHinzufügenButton" layoutX="779.0" layoutY="646.0" mnemonicParsing="false" onAction="#onKindHinzufügen" prefHeight="26.0" prefWidth="125.0" text="Kind hinzufügen" />
|
||||
<ChoiceBox fx:id="childChoiceBox" layoutX="704.0" layoutY="62.0" onAction="#onSelectChild" prefWidth="150.0" />
|
||||
<Label layoutX="704.0" layoutY="44.0" text="Kind" />
|
||||
<VBox id="contentContainer" layoutX="493.0" layoutY="330.0" prefHeight="250.0" prefWidth="256.0" spacing="20.0">
|
||||
<children>
|
||||
<Text strokeType="OUTSIDE" strokeWidth="0.0" text="Allergien">
|
||||
<VBox.margin>
|
||||
<Insets bottom="15.0" top="15.0" />
|
||||
</VBox.margin>
|
||||
</Text>
|
||||
<CheckComboBox fx:id="allergienComboBox" prefHeight="25.0" prefWidth="200.0" />
|
||||
</children>
|
||||
</VBox>
|
||||
<Button id="btAddChild" fx:id="kindLoeschenButton" layoutX="621.0" layoutY="646.0" mnemonicParsing="false" onAction="#onKindLoeschen" prefHeight="26.0" prefWidth="125.0" text="Kind löschen" />
|
||||
<Button id="btAddChild" layoutX="419.0" layoutY="502.0" mnemonicParsing="false" prefHeight="26.0" prefWidth="125.0" text="Kind hinzufügen" />
|
||||
</children>
|
||||
</AnchorPane>
|
||||
|
@ -4,7 +4,6 @@
|
||||
<?import javafx.scene.control.*?>
|
||||
<?import javafx.scene.layout.*?>
|
||||
<?import javafx.scene.text.*?>
|
||||
<?import org.controlsfx.control.*?>
|
||||
|
||||
<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="600.0" prefWidth="731.0" stylesheets="@createFood.css" xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.CreateFoodController">
|
||||
<children>
|
||||
@ -91,8 +90,8 @@
|
||||
</HBox>
|
||||
<HBox prefHeight="76.0" prefWidth="459.0">
|
||||
<children>
|
||||
<Label prefHeight="25.0" prefWidth="171.0" text="Allergien" />
|
||||
<CheckComboBox fx:id="allergienComboBox" prefHeight="25.0" prefWidth="200.0" />
|
||||
<Label prefHeight="41.0" prefWidth="171.0" text="Allergien mit Komma getrennt" />
|
||||
<TextArea fx:id="allergienTextBox" prefHeight="76.0" prefWidth="246.0" />
|
||||
</children>
|
||||
</HBox>
|
||||
<Text fx:id="responseText" fill="RED" strokeType="OUTSIDE" strokeWidth="0.0" textAlignment="CENTER" wrappingWidth="459.13673400878906">
|
||||
|
@ -1,23 +1,14 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<?import java.lang.*?>
|
||||
<?import java.util.*?>
|
||||
<?import javafx.scene.*?>
|
||||
<?import javafx.scene.control.*?>
|
||||
<?import javafx.scene.layout.*?>
|
||||
<?import javafx.scene.text.*?>
|
||||
|
||||
<AnchorPane prefHeight="700.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.DailyOrderController">
|
||||
<children>
|
||||
<HBox alignment="CENTER" layoutX="58.0" layoutY="221.0" prefHeight="349.0" prefWidth="683.0">
|
||||
<children>
|
||||
<ListView fx:id="listView" prefHeight="349.0" prefWidth="300.0" />
|
||||
</children>
|
||||
</HBox>
|
||||
<Text layoutX="88.0" layoutY="68.0" strokeType="OUTSIDE" strokeWidth="0.0" text="Tagesbestellung">
|
||||
<font>
|
||||
<Font name="System Bold" size="25.0" />
|
||||
</font>
|
||||
</Text>
|
||||
<DatePicker fx:id="datePicker" layoutX="88.0" layoutY="142.0" onAction="#onChangeDate" />
|
||||
<Label layoutX="88.0" layoutY="121.0" text="Datum" />
|
||||
<Button fx:id="sendButton" layoutX="374.0" layoutY="617.0" mnemonicParsing="false" onAction="#onSendButton" text="Bestellung senden" />
|
||||
</children>
|
||||
<AnchorPane xmlns="http://javafx.com/javafx"
|
||||
xmlns:fx="http://javafx.com/fxml"
|
||||
fx:controller="com.bib.essensbestellungsverwaltung.AdminController"
|
||||
prefHeight="400.0" prefWidth="600.0">
|
||||
|
||||
</AnchorPane>
|
||||
|
@ -17,10 +17,14 @@
|
||||
</font></Text>
|
||||
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="122.0" spacing="20.0">
|
||||
<children>
|
||||
<VBox alignment="CENTER" layoutX="150.0" layoutY="10.0" prefHeight="200.0" prefWidth="100.0">
|
||||
<VBox alignment="CENTER" prefHeight="200.0" prefWidth="100.0">
|
||||
<children>
|
||||
<Label text="Kind" />
|
||||
<ChoiceBox fx:id="childChoiceBox"></ChoiceBox>
|
||||
<Label text="Jahr" />
|
||||
<Spinner fx:id="jahrSpinner">
|
||||
<valueFactory>
|
||||
<SpinnerValueFactory.IntegerSpinnerValueFactory initialValue="2023" max="2100" min="2020" />
|
||||
</valueFactory>
|
||||
</Spinner>
|
||||
</children>
|
||||
</VBox>
|
||||
<VBox alignment="CENTER" prefHeight="200.0" prefWidth="100.0">
|
||||
@ -46,16 +50,6 @@
|
||||
</ChoiceBox>
|
||||
</children>
|
||||
</VBox>
|
||||
<VBox alignment="CENTER" prefHeight="200.0" prefWidth="100.0">
|
||||
<children>
|
||||
<Label text="Jahr" />
|
||||
<Spinner fx:id="jahrSpinner">
|
||||
<valueFactory>
|
||||
<SpinnerValueFactory.IntegerSpinnerValueFactory initialValue="2023" max="2100" min="2020" />
|
||||
</valueFactory>
|
||||
</Spinner>
|
||||
</children>
|
||||
</VBox>
|
||||
</children>
|
||||
</HBox>
|
||||
<Button mnemonicParsing="false" onMouseClicked="#onRechnungErstellenClick" text="Rechnung erstellen" />
|
||||
|
@ -31,6 +31,3 @@
|
||||
-fx-background-color: rgba(97, 97, 232, 0.3);
|
||||
-fx-background-radius: 25;
|
||||
}
|
||||
.sidebar-nav_button.active {
|
||||
-fx-background-color: #4e92b4;
|
||||
}
|
@ -1,17 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<?import javafx.scene.control.*?>
|
||||
<?import javafx.scene.layout.*?>
|
||||
<?import javafx.scene.text.*?>
|
||||
|
||||
|
||||
<AnchorPane prefHeight="700.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.OrderHistoryController">
|
||||
<children>
|
||||
<Text layoutX="91.0" layoutY="84.0" strokeType="OUTSIDE" strokeWidth="0.0" text="Bestellungen">
|
||||
<font>
|
||||
<Font name="System Bold" size="25.0" />
|
||||
</font>
|
||||
</Text>
|
||||
<ListView fx:id="listView" layoutX="91.0" layoutY="135.0" prefHeight="428.0" prefWidth="499.0" />
|
||||
</children>
|
||||
</AnchorPane>
|
@ -1,16 +1,20 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<?import javafx.geometry.*?>
|
||||
<?import javafx.geometry.Insets?>
|
||||
<?import javafx.scene.control.*?>
|
||||
<?import javafx.scene.image.*?>
|
||||
<?import javafx.scene.layout.*?>
|
||||
<?import javafx.scene.text.*?>
|
||||
|
||||
<BorderPane fx:id="contentView" prefHeight="750.0" prefWidth="1200.0" stylesheets="@menue.css" xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.bib.essensbestellungsverwaltung.WorkerMenuController">
|
||||
<BorderPane fx:id="contentView" prefHeight="750.0" prefWidth="1200.0" stylesheets="@menue.css"
|
||||
xmlns="http://javafx.com/javafx/17.0.2-ea" xmlns:fx="http://javafx.com/fxml/1"
|
||||
fx:controller="com.bib.essensbestellungsverwaltung.WorkerMenuController">
|
||||
<left>
|
||||
<VBox alignment="TOP_CENTER" prefHeight="750.0" prefWidth="350.0" spacing="10.0" style="-fx-background-color: #69b6ff; -fx-padding: 20;" BorderPane.alignment="CENTER">
|
||||
<VBox alignment="TOP_CENTER" prefHeight="750.0" prefWidth="350.0" spacing="10.0"
|
||||
style="-fx-background-color: #69b6ff; -fx-padding: 20;" BorderPane.alignment="CENTER">
|
||||
<children>
|
||||
<Button fx:id="tagesbestellungButton" alignment="CENTER_LEFT" mnemonicParsing="false" onMouseClicked="#onTagesbestellungenClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Tagesbestellung">
|
||||
<Button fx:id="tagesbestellungButton" alignment="CENTER_LEFT" mnemonicParsing="false"
|
||||
onMouseClicked="#onTagesbestellungenClick" prefHeight="60.0" prefWidth="250.0"
|
||||
styleClass="sidebar-nav_button" text="Tagesbestellung">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -22,7 +26,9 @@
|
||||
</ImageView>
|
||||
</graphic>
|
||||
</Button>
|
||||
<Button fx:id="monatsabrechnungButton" alignment="CENTER_LEFT" mnemonicParsing="false" onMouseClicked="#onMonatsabrechnungClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Monatsabrechnung">
|
||||
<Button fx:id="monatsabrechnungButton" alignment="CENTER_LEFT" mnemonicParsing="false"
|
||||
onMouseClicked="#onMonatsabrechnungClick" prefHeight="60.0" prefWidth="250.0"
|
||||
styleClass="sidebar-nav_button" text="Monatsabrechnung">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -34,7 +40,9 @@
|
||||
</ImageView>
|
||||
</graphic>
|
||||
</Button>
|
||||
<Button fx:id="wochenplanButton" alignment="CENTER_LEFT" mnemonicParsing="false" onMouseClicked="#onWochenplanClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Wochenplan">
|
||||
<Button fx:id="wochenplanButton" alignment="CENTER_LEFT" mnemonicParsing="false"
|
||||
onMouseClicked="#onWochenplanClick" prefHeight="60.0" prefWidth="250.0"
|
||||
styleClass="sidebar-nav_button" text="Wochenplan">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -46,7 +54,9 @@
|
||||
</ImageView>
|
||||
</graphic>
|
||||
</Button>
|
||||
<Button fx:id="mahlzeitButton" alignment="CENTER_LEFT" mnemonicParsing="false" onMouseClicked="#onMahlzeitClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Mahlzeit">
|
||||
<Button fx:id="mahlzeitButton" alignment="CENTER_LEFT" mnemonicParsing="false"
|
||||
onMouseClicked="#onMahlzeitClick" prefHeight="60.0" prefWidth="250.0"
|
||||
styleClass="sidebar-nav_button" text="Mahlzeit">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -58,7 +68,9 @@
|
||||
</ImageView>
|
||||
</graphic>
|
||||
</Button>
|
||||
<Button fx:id="mitarbeiterButton" alignment="CENTER_LEFT" mnemonicParsing="false" onMouseClicked="#onMitarbeiterClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Mitarbeiter">
|
||||
<Button fx:id="mitarbeiterButton" alignment="CENTER_LEFT" mnemonicParsing="false"
|
||||
onMouseClicked="#onMitarbeiterClick" prefHeight="60.0" prefWidth="250.0"
|
||||
styleClass="sidebar-nav_button" text="Mitarbeiter">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -75,7 +87,9 @@
|
||||
<Insets/>
|
||||
</opaqueInsets>
|
||||
</Region>
|
||||
<Button fx:id="einstellungenButton" alignment="CENTER_LEFT" layoutX="10.0" layoutY="130.0" mnemonicParsing="false" onMouseClicked="#onEinstellungenClick" prefHeight="60.0" prefWidth="250.0" styleClass="sidebar-nav_button" text="Einstellungen">
|
||||
<Button fx:id="einstellungenButton" alignment="CENTER_LEFT" layoutX="10.0" layoutY="130.0"
|
||||
mnemonicParsing="false" onMouseClicked="#onEinstellungenClick" prefHeight="60.0"
|
||||
prefWidth="250.0" styleClass="sidebar-nav_button" text="Einstellungen">
|
||||
<font>
|
||||
<Font size="20.0"/>
|
||||
</font>
|
||||
@ -94,9 +108,11 @@
|
||||
</VBox>
|
||||
</left>
|
||||
<top>
|
||||
<HBox alignment="CENTER_RIGHT" prefHeight="50.0" prefWidth="1200.0" style="-fx-background-color: #69b6ff;" BorderPane.alignment="CENTER">
|
||||
<HBox alignment="CENTER_RIGHT" prefHeight="50.0" prefWidth="1200.0" style="-fx-background-color: #69b6ff;"
|
||||
BorderPane.alignment="CENTER">
|
||||
<children>
|
||||
<Button mnemonicParsing="false" onMouseClicked="#onAusloggenClick" styleClass="sidebar-nav_button" text="Ausloggen">
|
||||
<Button mnemonicParsing="false" onMouseClicked="#onAusloggenClick" styleClass="sidebar-nav_button"
|
||||
text="Ausloggen">
|
||||
<opaqueInsets>
|
||||
<Insets/>
|
||||
</opaqueInsets>
|
||||
|
Loading…
Reference in New Issue
Block a user