This commit is contained in:
Antonio 2025-12-11 10:32:58 +01:00
parent a240756042
commit b71ee88449
14 changed files with 238 additions and 99 deletions

3
.idea/.gitignore generated vendored Normal file
View file

@ -0,0 +1,3 @@
# Default ignored files
/shelf/
/workspace.xml

13
.idea/compiler.xml generated Normal file
View file

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<annotationProcessing>
<profile name="Maven default annotation processors profile" enabled="true">
<sourceOutputDir name="target/generated-sources/annotations" />
<sourceTestOutputDir name="target/generated-test-sources/test-annotations" />
<outputRelativeToContentRoot value="true" />
<module name="jdbc-konsolen-projekt" />
</profile>
</annotationProcessing>
</component>
</project>

7
.idea/encodings.xml generated Normal file
View file

@ -0,0 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="Encoding">
<file url="file://$PROJECT_DIR$/src/main/java" charset="UTF-8" />
<file url="file://$PROJECT_DIR$/src/main/resources" charset="UTF-8" />
</component>
</project>

20
.idea/jarRepositories.xml generated Normal file
View file

@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="RemoteRepositoriesConfiguration">
<remote-repository>
<option name="id" value="central" />
<option name="name" value="Central Repository" />
<option name="url" value="https://repo.maven.apache.org/maven2" />
</remote-repository>
<remote-repository>
<option name="id" value="central" />
<option name="name" value="Maven Central repository" />
<option name="url" value="https://repo1.maven.org/maven2" />
</remote-repository>
<remote-repository>
<option name="id" value="jboss.community" />
<option name="name" value="JBoss Community repository" />
<option name="url" value="https://repository.jboss.org/nexus/content/repositories/public/" />
</remote-repository>
</component>
</project>

12
.idea/misc.xml generated Normal file
View file

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="MavenProjectsManager">
<option name="originalFiles">
<list>
<option value="$PROJECT_DIR$/pom.xml" />
</list>
</option>
</component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_24" default="true" project-jdk-name="openjdk-24" project-jdk-type="JavaSDK" />
</project>

6
.idea/vcs.xml generated Normal file
View file

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="VcsDirectoryMappings">
<mapping directory="" vcs="Git" />
</component>
</project>

View file

@ -8,12 +8,10 @@ import de.antco.projekt.model.WorkOrderItem;
import de.antco.projekt.service.WorkshopService;
import java.sql.SQLException;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Scanner;
import java.util.*;
public class ConsoleUi {
private final WorkshopService service;
private final Scanner scanner = new Scanner(System.in);
@ -23,168 +21,235 @@ public class ConsoleUi {
public void start() {
boolean running = true;
while (running) {
printMenu();
String input = scanner.nextLine();
showMenu();
String choice = scanner.nextLine().trim();
try {
switch (input) {
switch (choice) {
case "1" -> addPerson();
case "2" -> listPersons();
case "2" -> showPersons();
case "3" -> addVehicle();
case "4" -> listVehiclesOfPerson();
case "4" -> showVehiclesOfPerson();
case "5" -> createWorkOrder();
case "6" -> listWorkOrders();
case "6" -> showWorkOrders();
case "0" -> running = false;
default -> System.out.println("Unbekannte Auswahl");
default -> System.out.println("Ungültige Eingabe.");
}
} catch (SQLException e) {
System.out.println("Fehler: " + e.getMessage());
System.out.println("Ein Fehler ist aufgetreten: " + e.getMessage());
}
}
System.out.println("Bis dann");
System.out.println("Programm beendet.");
}
private void printMenu() {
System.out.println();
System.out.println("==== Werkstatt Menü ====");
private void showMenu() {
System.out.println("\n=== Werkstatt Menü ===");
System.out.println("1) Kunde anlegen");
System.out.println("2) Kunden anzeigen");
System.out.println("3) Fahrzeug anlegen");
System.out.println("4) Fahrzeuge einer Person");
System.out.println("4) Fahrzeuge einer Person anzeigen");
System.out.println("5) Werkstattvorgang anlegen");
System.out.println("6) Vorgänge anzeigen");
System.out.println("0) Ende");
System.out.println("0) Beenden");
System.out.print("Auswahl: ");
}
private void addPerson() throws SQLException {
System.out.print("Name: ");
String name = scanner.nextLine();
System.out.print("Telefon: ");
String phone = scanner.nextLine();
Person person = service.createPerson(name, phone);
System.out.println("Kunde gespeichert mit ID " + person.getId());
private int readInt(String text) {
while (true) {
System.out.print(text);
String input = scanner.nextLine();
try {
return Integer.parseInt(input.trim());
} catch (NumberFormatException e) {
System.out.println("Bitte eine gültige Zahl eingeben.");
}
}
}
private void listPersons() throws SQLException {
private String readNonEmpty(String text) {
while (true) {
System.out.print(text);
String value = scanner.nextLine().trim();
if (!value.isEmpty()) {
return value;
}
System.out.println("Eingabe darf nicht leer sein.");
}
}
private String readValidName(String text) {
while (true) {
String name = readNonEmpty(text);
if (name.matches("[a-zA-ZäöüÄÖÜß ]+")) {
return name;
}
System.out.println("Der Name darf nur Buchstaben enthalten.");
}
}
private String readPhoneNumber(String text) {
while (true) {
System.out.print(text);
String phone = scanner.nextLine().trim();
if (phone.matches("\\d+")) {
return phone;
}
System.out.println("Telefonnummer darf nur Zahlen enthalten.");
}
}
private void addPerson() throws SQLException {
String name = readValidName("Name: ");
String phone = readPhoneNumber("Telefonnummer: ");
Person person = service.createPerson(name, phone);
System.out.println("Kunde gespeichert (ID: " + person.getId() + ")");
}
private void showPersons() throws SQLException {
List<Person> persons = service.listPersons();
if (persons.isEmpty()) {
System.out.println("Keine Personen da");
System.out.println("Keine Kunden vorhanden.");
return;
}
persons.forEach(p -> System.out.println(p.toString()));
System.out.println("\n--- Kundenliste ---");
persons.forEach(System.out::println);
}
private void addVehicle() throws SQLException {
System.out.print("Personen ID: ");
int personId = parseInt(scanner.nextLine());
Person owner = service.findPerson(personId);
if (owner == null) {
System.out.println("Person nicht gefunden");
int personId = readInt("Personen-ID: ");
Person person = service.findPerson(personId);
if (person == null) {
System.out.println("Person wurde nicht gefunden.");
return;
}
System.out.print("Hersteller: ");
String brand = scanner.nextLine();
System.out.print("Modell: ");
String model = scanner.nextLine();
System.out.print("Kennzeichen: ");
String plate = scanner.nextLine();
String brand = readNonEmpty("Hersteller: ");
String model = readNonEmpty("Modell: ");
String plate = readNonEmpty("Kennzeichen: ");
Vehicle vehicle = service.createVehicle(personId, brand, model, plate);
System.out.println("Fahrzeug gespeichert mit ID " + vehicle.getId());
System.out.println("Fahrzeug angelegt (ID: " + vehicle.getId() + ")");
}
private void listVehiclesOfPerson() throws SQLException {
System.out.print("Personen ID: ");
int personId = parseInt(scanner.nextLine());
Person owner = service.findPerson(personId);
if (owner == null) {
System.out.println("Person nicht gefunden");
private void showVehiclesOfPerson() throws SQLException {
int personId = readInt("Personen-ID: ");
Person person = service.findPerson(personId);
if (person == null) {
System.out.println("Person nicht gefunden.");
return;
}
List<Vehicle> vehicles = service.listVehicles(personId);
System.out.println("Fahrzeuge von " + owner.getName() + ":");
System.out.println("Fahrzeuge von " + person.getName() + ":");
if (vehicles.isEmpty()) {
System.out.println("Keine Einträge");
return;
System.out.println("Keine Fahrzeuge vorhanden.");
} else {
vehicles.forEach(System.out::println);
}
vehicles.forEach(v -> System.out.println(v.toString()));
}
private void createWorkOrder() throws SQLException {
System.out.print("Fahrzeug ID: ");
int vehicleId = parseInt(scanner.nextLine());
int vehicleId = readInt("Fahrzeug-ID: ");
Vehicle vehicle = service.findVehicle(vehicleId);
if (vehicle == null) {
System.out.println("Fahrzeug nicht gefunden");
System.out.println("Fahrzeug nicht gefunden.");
return;
}
System.out.print("Notiz: ");
String note = scanner.nextLine();
String note = readNonEmpty("Notiz: ");
List<ServiceItem> catalog = service.listServiceItems();
Map<Integer, Integer> selected = new LinkedHashMap<>();
boolean adding = true;
while (adding) {
showCatalog(catalog);
System.out.print("Service ID (leer = fertig): ");
String input = scanner.nextLine();
if (input.isBlank()) {
adding = false;
} else {
int serviceId = parseInt(input);
ServiceItem item = catalog.stream().filter(s -> s.getId() == serviceId).findFirst().orElse(null);
if (item == null) {
System.out.println("Service gibt es nicht");
continue;
}
System.out.print("Menge: ");
int qty = parseInt(scanner.nextLine());
if (qty <= 0) {
System.out.println("Menge muss > 0 sein");
continue;
}
selected.put(serviceId, selected.getOrDefault(serviceId, 0) + qty);
Map<Integer, Integer> selectedItems = new LinkedHashMap<>();
while (true) {
System.out.println("\n--- Service-Katalog ---");
catalog.forEach(System.out::println);
System.out.print("Service-ID (leer = fertig): ");
String input = scanner.nextLine().trim();
if (input.isEmpty()) {
break;
}
int serviceId;
try {
serviceId = Integer.parseInt(input);
} catch (NumberFormatException e) {
System.out.println("Bitte eine gültige ID eingeben.");
continue;
}
ServiceItem item = catalog.stream()
.filter(s -> s.getId() == serviceId)
.findFirst()
.orElse(null);
if (item == null) {
System.out.println("Service nicht gefunden.");
continue;
}
int qty = readInt("Menge: ");
if (qty <= 0) {
System.out.println("Menge muss größer als 0 sein.");
continue;
}
selectedItems.merge(serviceId, qty, Integer::sum);
}
if (selected.isEmpty()) {
System.out.println("Keine Positionen gespeichert");
if (selectedItems.isEmpty()) {
System.out.println("Keine Positionen ausgewählt.");
return;
}
int orderId = service.createWorkOrder(vehicleId, note, selected);
System.out.println("Vorgang angelegt mit ID " + orderId);
int orderId = service.createWorkOrder(vehicleId, note, selectedItems);
System.out.println("Vorgang wurde angelegt (ID: " + orderId + ")");
}
private void showCatalog(List<ServiceItem> items) {
System.out.println("Katalog:");
items.forEach(item -> System.out.println(item.toString()));
}
private void listWorkOrders() throws SQLException {
private void showWorkOrders() throws SQLException {
List<WorkOrderDetails> orders = service.listWorkOrders();
if (orders.isEmpty()) {
System.out.println("Keine Vorgänge gespeichert");
System.out.println("Keine Vorgänge vorhanden.");
return;
}
for (WorkOrderDetails order : orders) {
System.out.println("--- Vorgang " + order.getOrderId() + " ---");
System.out.println("\n--- Vorgang " + order.getOrderId() + " ---");
System.out.println("Kunde: " + order.getPersonName());
System.out.println("Fahrzeug: " + order.getVehicleText());
System.out.println("Datum: " + order.getCreatedAt());
if (order.getNote() != null && !order.getNote().isBlank()) {
System.out.println("Notiz: " + order.getNote());
}
for (WorkOrderItem item : order.getItems()) {
System.out.println(" * " + item.getServiceItem().getTitle() + " x" + item.getQuantity() +
System.out.println(" - " + item.getServiceItem().getTitle() +
" x" + item.getQuantity() +
" = " + item.getTotalPrice() + "");
}
System.out.println("Summe: " + order.getTotal() + "");
}
}
private int parseInt(String input) {
try {
return Integer.parseInt(input.trim());
} catch (NumberFormatException e) {
return -1;
System.out.println("Gesamtsumme: " + order.getTotal() + "");
}
}
}
}

View file

@ -0,0 +1,4 @@
package de.antco.projekt.Exporters;
public interface IExporter {
}

View file

@ -0,0 +1,4 @@
package de.antco.projekt.Importers;
public interface IImporter {
}

View file

@ -0,0 +1,5 @@
package de.antco.projekt.loggers;
public interface ILogger {
void Log();
}

Binary file not shown.